mirror of
https://github.com/pacnpal/thrillwiki_laravel.git
synced 2025-12-20 03:51:10 -05:00
189 lines
10 KiB
PHP
189 lines
10 KiB
PHP
<div class="container mx-auto px-4 py-8">
|
|
<div class="flex flex-col lg:flex-row gap-8">
|
|
<!-- Filters Sidebar -->
|
|
<div class="lg:w-1/4">
|
|
<div class="bg-white dark:bg-gray-800 p-6 rounded-lg shadow">
|
|
<h2 class="text-xl font-bold mb-4 dark:text-white">Filter Parks</h2>
|
|
<div class="space-y-4">
|
|
<!-- Search -->
|
|
<div class="flex flex-col">
|
|
<label for="search" class="text-sm font-medium text-gray-700 dark:text-gray-300">
|
|
Search
|
|
</label>
|
|
<div class="mt-1">
|
|
<input type="text"
|
|
wire:model.live="search"
|
|
id="search"
|
|
class="w-full rounded-md border-gray-300 shadow-sm focus:border-blue-500 focus:ring-blue-500 dark:bg-gray-700 dark:border-gray-600 dark:text-white"
|
|
placeholder="Search parks...">
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Location -->
|
|
<div class="flex flex-col">
|
|
<label for="location" class="text-sm font-medium text-gray-700 dark:text-gray-300">
|
|
Location
|
|
</label>
|
|
<div class="mt-1">
|
|
<input type="text"
|
|
wire:model.live="location"
|
|
id="location"
|
|
class="w-full rounded-md border-gray-300 shadow-sm focus:border-blue-500 focus:ring-blue-500 dark:bg-gray-700 dark:border-gray-600 dark:text-white"
|
|
placeholder="Filter by location...">
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Rating Range -->
|
|
<div class="flex flex-col">
|
|
<label class="text-sm font-medium text-gray-700 dark:text-gray-300">Rating Range</label>
|
|
<div class="flex gap-2 mt-1">
|
|
<input type="number"
|
|
wire:model.live="minRating"
|
|
min="0"
|
|
max="5"
|
|
step="0.1"
|
|
class="w-1/2 rounded-md border-gray-300 shadow-sm focus:border-blue-500 focus:ring-blue-500 dark:bg-gray-700 dark:border-gray-600 dark:text-white"
|
|
placeholder="Min">
|
|
<input type="number"
|
|
wire:model.live="maxRating"
|
|
min="0"
|
|
max="5"
|
|
step="0.1"
|
|
class="w-1/2 rounded-md border-gray-300 shadow-sm focus:border-blue-500 focus:ring-blue-500 dark:bg-gray-700 dark:border-gray-600 dark:text-white"
|
|
placeholder="Max">
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Minimum Rides -->
|
|
<div class="flex flex-col">
|
|
<label for="minRides" class="text-sm font-medium text-gray-700 dark:text-gray-300">
|
|
Minimum Rides
|
|
</label>
|
|
<div class="mt-1">
|
|
<input type="number"
|
|
wire:model.live="minRides"
|
|
id="minRides"
|
|
min="0"
|
|
class="w-full rounded-md border-gray-300 shadow-sm focus:border-blue-500 focus:ring-blue-500 dark:bg-gray-700 dark:border-gray-600 dark:text-white"
|
|
placeholder="Minimum number of rides">
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Minimum Coasters -->
|
|
<div class="flex flex-col">
|
|
<label for="minCoasters" class="text-sm font-medium text-gray-700 dark:text-gray-300">
|
|
Minimum Coasters
|
|
</label>
|
|
<div class="mt-1">
|
|
<input type="number"
|
|
wire:model.live="minCoasters"
|
|
id="minCoasters"
|
|
min="0"
|
|
class="w-full rounded-md border-gray-300 shadow-sm focus:border-blue-500 focus:ring-blue-500 dark:bg-gray-700 dark:border-gray-600 dark:text-white"
|
|
placeholder="Minimum number of coasters">
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Filter Actions -->
|
|
<div class="flex justify-between pt-2">
|
|
@if($filtersApplied)
|
|
<button wire:click="clearFilters"
|
|
type="button"
|
|
class="inline-flex justify-center py-2 px-4 border border-gray-300 shadow-sm text-sm font-medium rounded-md text-gray-700 bg-white hover:bg-gray-50 focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-blue-500 dark:bg-gray-700 dark:border-gray-600 dark:text-white dark:hover:bg-gray-600">
|
|
Clear Filters
|
|
</button>
|
|
@endif
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Results Section -->
|
|
<div class="lg:w-3/4">
|
|
<div class="bg-white dark:bg-gray-800 rounded-lg shadow">
|
|
<div class="p-6 border-b border-gray-200 dark:border-gray-700">
|
|
<div class="flex justify-between items-center">
|
|
<h2 class="text-xl font-bold dark:text-white">
|
|
Search Results
|
|
<span class="text-sm font-normal text-gray-500 dark:text-gray-400">({{ $results->total() }} found)</span>
|
|
</h2>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="divide-y divide-gray-200 dark:divide-gray-700">
|
|
@forelse($results as $park)
|
|
<div class="p-6 flex flex-col md:flex-row gap-4">
|
|
<!-- Park Image -->
|
|
<div class="md:w-48 h-32 bg-gray-200 dark:bg-gray-700 rounded-lg overflow-hidden">
|
|
@if($park->photos->isNotEmpty())
|
|
<img src="{{ $park->photos->first()->image_url }}"
|
|
alt="{{ $park->name }}"
|
|
class="w-full h-full object-cover">
|
|
@else
|
|
<div class="w-full h-full flex items-center justify-center text-gray-400 dark:text-gray-500">
|
|
No Image
|
|
</div>
|
|
@endif
|
|
</div>
|
|
|
|
<!-- Park Details -->
|
|
<div class="flex-1">
|
|
<h3 class="text-lg font-semibold">
|
|
<a href="{{ route('parks.show', $park) }}" class="hover:text-blue-600 dark:text-white dark:hover:text-blue-400">
|
|
{{ $park->name }}
|
|
</a>
|
|
</h3>
|
|
|
|
<div class="mt-2 text-sm text-gray-600 dark:text-gray-400">
|
|
@if($park->formatted_location)
|
|
<p>{{ $park->formatted_location }}</p>
|
|
@endif
|
|
</div>
|
|
|
|
<div class="mt-2 flex flex-wrap gap-2">
|
|
@if($park->average_rating)
|
|
<span class="inline-flex items-center px-2.5 py-0.5 rounded-full text-xs font-medium bg-green-100 text-green-800 dark:bg-green-800 dark:text-green-100">
|
|
{{ number_format($park->average_rating, 1) }} ★
|
|
</span>
|
|
@endif
|
|
|
|
<span class="inline-flex items-center px-2.5 py-0.5 rounded-full text-xs font-medium bg-blue-100 text-blue-800 dark:bg-blue-800 dark:text-blue-100">
|
|
{{ $park->status->label() }}
|
|
</span>
|
|
|
|
@if($park->ride_count)
|
|
<span class="inline-flex items-center px-2.5 py-0.5 rounded-full text-xs font-medium bg-purple-100 text-purple-800 dark:bg-purple-800 dark:text-purple-100">
|
|
{{ $park->ride_count }} Rides
|
|
</span>
|
|
@endif
|
|
|
|
@if($park->coaster_count)
|
|
<span class="inline-flex items-center px-2.5 py-0.5 rounded-full text-xs font-medium bg-yellow-100 text-yellow-800 dark:bg-yellow-800 dark:text-yellow-100">
|
|
{{ $park->coaster_count }} Coasters
|
|
</span>
|
|
@endif
|
|
</div>
|
|
|
|
@if($park->description)
|
|
<p class="mt-2 text-sm text-gray-600 dark:text-gray-400 line-clamp-2">
|
|
{{ $park->description }}
|
|
</p>
|
|
@endif
|
|
</div>
|
|
</div>
|
|
@empty
|
|
<div class="p-6 text-center text-gray-500 dark:text-gray-400">
|
|
No parks found matching your criteria.
|
|
</div>
|
|
@endforelse
|
|
</div>
|
|
|
|
@if($results->hasPages())
|
|
<div class="px-6 py-4 border-t border-gray-200 dark:border-gray-700">
|
|
{{ $results->links() }}
|
|
</div>
|
|
@endif
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div> |