Update all event-related view templates and controllers to properly handle and display event images throughout the application. 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
110 lines
5.4 KiB
Plaintext
Executable File
110 lines
5.4 KiB
Plaintext
Executable File
<div class="max-w-6xl mx-auto px-4 sm:px-6 lg:px-8 py-8">
|
|
<!-- Breadcrumb -->
|
|
<%= render 'components/breadcrumb', crumbs: [
|
|
{ name: 'Accueil', path: root_path },
|
|
{ name: 'Événements', path: events_path }
|
|
] %>
|
|
|
|
<!-- Page Header -->
|
|
<header class="flex flex-col sm:flex-row justify-between items-start sm:items-center mb-8 gap-4">
|
|
<div>
|
|
<h1 class="text-3xl lg:text-4xl font-bold text-gray-900">Événements à venir</h1>
|
|
<p class="text-gray-600 mt-2">Découvrez les meilleurs afterworks et événements de Paris</p>
|
|
</div>
|
|
<div class="bg-purple-100 text-purple-800 px-4 py-2 rounded-full text-sm font-medium">
|
|
<%= @events.total_count %> événements trouvés
|
|
</div>
|
|
</header>
|
|
|
|
<!-- Events Grid -->
|
|
<% if @events.any? %>
|
|
<div class="grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-8">
|
|
<% @events.each do |event| %>
|
|
<article class="group bg-white rounded-2xl shadow-lg hover:shadow-2xl transition-all duration-300 overflow-hidden transform hover:-translate-y-1">
|
|
<%= link_to event_path(event.slug, event), class: "block" do %>
|
|
<% if event.has_image? %>
|
|
<div class="relative overflow-hidden aspect-[4/3]">
|
|
<%= image_tag event.event_image_variant(:medium), alt: event.name, class: "w-full h-full object-cover group-hover:scale-105 transition-transform duration-300" %>
|
|
<!-- Event featured badge -->
|
|
<% if event.featured? %>
|
|
<div class="absolute top-4 left-4">
|
|
<span class="bg-yellow-400 text-gray-900 px-3 py-1 rounded-full text-sm font-medium shadow-lg">
|
|
★ En vedette
|
|
</span>
|
|
</div>
|
|
<% end %>
|
|
<!-- Date badge -->
|
|
<div class="absolute bottom-4 right-4">
|
|
<span class="bg-white/90 backdrop-blur-sm text-gray-900 px-3 py-1 rounded-full text-sm font-bold shadow-lg">
|
|
<%= event.start_time.strftime("%d/%m") %>
|
|
</span>
|
|
</div>
|
|
</div>
|
|
<% else %>
|
|
<div class="relative overflow-hidden aspect-[4/3] bg-gradient-to-br from-purple-600 to-blue-600 flex items-center justify-center">
|
|
<i data-lucide="calendar" class="w-16 h-16 text-white"></i>
|
|
<!-- Date badge -->
|
|
<div class="absolute bottom-4 right-4">
|
|
<span class="bg-white/90 backdrop-blur-sm text-gray-900 px-3 py-1 rounded-full text-sm font-bold shadow-lg">
|
|
<%= event.start_time.strftime("%d/%m") %>
|
|
</span>
|
|
</div>
|
|
</div>
|
|
<% end %>
|
|
|
|
<div class="p-6">
|
|
<div class="mb-4">
|
|
<h2 class="text-xl font-bold text-gray-900 mb-2 group-hover:text-purple-600 transition-colors line-clamp-2"><%= event.name %></h2>
|
|
<p class="text-sm text-gray-500 flex items-center">
|
|
<i data-lucide="map-pin" class="w-4 h-4 mr-2"></i>
|
|
<%= event.venue_name.truncate(25) %>
|
|
</p>
|
|
<p class="text-sm text-gray-500 flex items-center mt-1">
|
|
<i data-lucide="clock" class="w-4 h-4 mr-2"></i>
|
|
<%= l(event.start_time, format: '%A %d %B • %H:%M') %>
|
|
</p>
|
|
</div>
|
|
|
|
<p class="text-gray-600 text-sm mb-4 line-clamp-2">
|
|
<%= event.description.truncate(100) %>
|
|
</p>
|
|
|
|
<div class="flex justify-between items-center pt-4 border-t border-gray-100">
|
|
<div>
|
|
<% if event.ticket_types.any? %>
|
|
<p class="text-sm font-semibold text-gray-900">
|
|
À partir de <%= format_price(event.ticket_types.minimum(:price_cents)) %>€
|
|
</p>
|
|
<% else %>
|
|
<p class="text-sm text-gray-500">Pas de billets disponibles</p>
|
|
<% end %>
|
|
</div>
|
|
|
|
<div class="inline-flex items-center text-purple-600 font-medium text-sm group-hover:text-purple-700">
|
|
Voir détails
|
|
<i data-lucide="arrow-right" class="w-4 h-4 ml-1 group-hover:translate-x-1 transition-transform"></i>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<% end %>
|
|
</article>
|
|
<% end %>
|
|
</div>
|
|
|
|
<!-- Pagination -->
|
|
<div class="flex justify-center mt-12">
|
|
<%= paginate @events, theme: "tailwind" %>
|
|
</div>
|
|
<% else %>
|
|
<!-- Empty State -->
|
|
<div class="text-center py-16">
|
|
<div class="w-24 h-24 bg-gradient-to-br from-purple-100 to-blue-100 rounded-full flex items-center justify-center mx-auto mb-6">
|
|
<i data-lucide="calendar-x" class="w-12 h-12 text-purple-600"></i>
|
|
</div>
|
|
<h3 class="text-2xl font-bold text-gray-900 mb-4">Aucun événement disponible</h3>
|
|
<p class="text-gray-600 mb-8 max-w-md mx-auto">Il n'y a aucun événement à venir pour le moment. Revenez bientôt pour découvrir de nouvelles sorties!</p>
|
|
<%= link_to "<i data-lucide=\"home\" class=\"w-4 h-4 mr-2\"></i> Retour à l'accueil".html_safe, root_path, class: "inline-flex items-center bg-purple-600 text-white px-6 py-3 rounded-full font-semibold hover:bg-purple-700 transition-all duration-200 shadow-lg hover:shadow-xl transform hover:-translate-y-0.5" %>
|
|
</div>
|
|
<% end %>
|
|
</div>
|