table changes

This commit is contained in:
Benjamin Takats
2023-01-19 15:44:09 +01:00
parent 31c7b47548
commit faeb31d4b2
17 changed files with 46 additions and 37 deletions

View File

@@ -43,6 +43,11 @@ class BitcoinEventTable extends Component
]),
'events' => BitcoinEvent::query()
->where('bitcoin_events.from', '>=', now())
->where(fn($query) => $query
->whereHas('venue.city.country',
fn($query) => $query->where('countries.code', $this->country->code))
->orWhere('show_worldwide', true)
)
->get()
->map(fn($event) => [
'id' => $event->id,
@@ -64,9 +69,9 @@ class BitcoinEventTable extends Component
{
return to_route('bitcoinEvent.table.bitcoinEvent', [
'#table',
'country' => $this->country->code,
'year' => $this->year,
'table' => [
'country' => $this->country->code,
'year' => $this->year,
'bitcoin_events' => [
'filters' => [
'byid' => $id,
],
@@ -78,9 +83,9 @@ class BitcoinEventTable extends Component
{
return to_route('bitcoinEvent.table.bitcoinEvent', [
'#table',
'country' => $this->country->code,
'year' => $this->year,
'table' => [
'country' => $this->country->code,
'year' => $this->year,
'bitcoin_events' => [
'filters' => [
'byid' => $ids,
]

View File

@@ -11,9 +11,9 @@ class BookCaseTable extends Component
{
public ?Country $country = null;
public string $c = 'de';
public array $table = [];
public array $bookcases = [];
protected $queryString = ['table'];
protected $queryString = ['bookcases'];
public function render()
{

View File

@@ -8,10 +8,10 @@ use Livewire\Component;
class SearchByTagComponent extends Component
{
public string $country = 'de';
public ?array $table = [];
public ?array $bookcases = [];
protected $queryString = [
'table',
'library_items',
];
public function render()

View File

@@ -69,9 +69,9 @@ class MeetupEventTable extends Component
{
return to_route('meetup.table.meetupEvent', [
'#table',
'country' => $this->country->code,
'year' => $this->year,
'table' => [
'country' => $this->country->code,
'year' => $this->year,
'meetup_events' => [
'filters' => [
'byid' => $id,
],
@@ -85,7 +85,8 @@ class MeetupEventTable extends Component
return to_route('meetup.table.meetupEvent', [
'#table',
'year' => $this->year,
'country' => $this->country->code, 'table' => [
'country' => $this->country->code,
'meetup_events' => [
'filters' => [
'byid' => $ids,
]

View File

@@ -6,13 +6,13 @@ use App\Models\Country;
use Livewire\Component;
use RalphJSmit\Laravel\SEO\Support\SEOData;
class CouseTable extends Component
class CourseTable extends Component
{
public Country $country;
public function render()
{
return view('livewire.school.couse-table')->layout('layouts.app', [
return view('livewire.school.course-table')->layout('layouts.app', [
'SEOData' => new SEOData(
title: __('Courses'),
description: __('Choose your city, search for courses in the surrounding area and select a topic that suits you.'),

View File

@@ -70,7 +70,7 @@ class EventTable extends Component
'#table',
'country' => $this->country->code,
'year' => $this->year,
'table' => [
'course_events' => [
'filters' => [
'byid' => $id,
],
@@ -84,7 +84,7 @@ class EventTable extends Component
'#table',
'country' => $this->country->code,
'year' => $this->year,
'table' => [
'course_events' => [
'filters' => [
'byid' => $ids,
]

View File

@@ -8,10 +8,10 @@ use Livewire\Component;
class SearchByTagComponent extends Component
{
public string $country = 'de';
public ?array $table = [];
public ?array $courses = [];
protected $queryString = [
'table',
'courses',
];
public function render()

View File

@@ -92,7 +92,7 @@ class CityTable extends DataTableComponent
return to_route('school.table.event', [
'#table',
'country' => $this->country,
'table' => [
'course_events' => [
'filters' => [
'stadt' => $query->pluck('name')
->push($city->name)
@@ -117,7 +117,7 @@ class CityTable extends DataTableComponent
return to_route('bookCases.table.bookcases', [
'#table',
'country' => $this->country,
'table' => [
'bookcases' => [
'filters' => [
'byids' => $ids->implode(',')
],

View File

@@ -61,6 +61,7 @@ class CourseTable extends DataTableComponent
->sortable()
->collapseOnMobile(),
Column::make("Name", "name")
->searchable(fn(Builder $query, string $term) => $query->where('name', 'ilike', '%'.$term.'%'))
->sortable(),
Column::make("Tags")
->label(
@@ -104,8 +105,8 @@ class CourseTable extends DataTableComponent
{
return to_route('school.table.event', [
'#table',
'country' => $this->country,
'table' => [
'country' => $this->country,
'course_events' => [
'filters' => [
'course_id' => $id,
],

View File

@@ -17,7 +17,7 @@ class EventTable extends DataTableComponent
public string $country;
public bool $viewingModal = false;
public $currentModal;
public string $tableName = 'events';
public string $tableName = 'course_events';
public function configure(): void
{

View File

@@ -47,6 +47,7 @@ class LecturerTable extends DataTableComponent
])
->collapseOnMobile(),
Column::make("Name", "name")
->searchable(fn($query, $term) => $query->where('name', 'ilike', '%'.$term.'%'))
->sortable(),
BooleanColumn::make("Aktiv", 'active')
->sortable()
@@ -88,8 +89,8 @@ class LecturerTable extends DataTableComponent
if ($event) {
return to_route('school.table.event', [
'#table',
'country' => $this->country,
'table' => [
'country' => $this->country,
'course_events' => [
'filters' => [
'dozent' => $lecturer->id,
],
@@ -98,8 +99,8 @@ class LecturerTable extends DataTableComponent
} else {
return to_route('library.table.libraryItems', [
'#table',
'country' => $this->country,
'table' => [
'country' => $this->country,
'library_items' => [
'filters' => [
'lecturer_id' => $lecturer->id,
],

View File

@@ -93,7 +93,7 @@ class MeetupTable extends DataTableComponent
return to_route('meetup.table.meetupEvent', [
'country' => $this->country ?? $meetup->city->country->code,
'table' => [
'meetup_events' => [
'filters' => ['bymeetupid' => $id],
]
]);

View File

@@ -47,6 +47,7 @@ class VenueTable extends DataTableComponent
])
->collapseOnMobile(),
Column::make("Name", "name")
->searchable(fn($query, $term) => $query->where('name', 'ilike', '%'.$term.'%'))
->sortable(),
Column::make("Street", "street")
->sortable()
@@ -81,8 +82,8 @@ class VenueTable extends DataTableComponent
return to_route('school.table.event', [
'#table',
'country' => $this->country,
'table' => [
'country' => $this->country,
'course_events' => [
'filters' => [
'venue' => $venue->name,
],

View File

@@ -8,12 +8,12 @@
style="font-size: 128%; background-position: 0px center; list-style: outside;"
>
@php
$isActive = collect($table)->pluck('tag')->collapse()->contains($tag->name);
$isActive = collect($library_items)->pluck('tag')->collapse()->contains($tag->name);
$activeClass = $isActive ? 'text-amber-500 bg-amber-500' : 'bg-blue-50 text-white hover:text-amber-500';
@endphp
<a
class="{{ $activeClass }} flex relative flex-col flex-shrink-0 justify-between py-1 px-3 w-full h-20 border-0 border-solid duration-300 ease-in-out cursor-pointer bg-opacity-[0.07]"
href="{{ route(request()->route()->getName(), ['country' => $country, 'table' => ['filters' => ['tag' => [$tag->id]]]]) }}"
href="{{ route(request()->route()->getName(), ['country' => $country, 'library_items' => ['filters' => ['tag' => [$tag->id]]]]) }}"
>
<div
class="flex flex-1 items-center p-0 m-0 text-center align-baseline border-0 border-solid"

View File

@@ -8,12 +8,12 @@
style="font-size: 128%; background-position: 0px center; list-style: outside;"
>
@php
$isActive = collect($table)->pluck('tag')->collapse()->contains($tag->name);
$isActive = collect($courses)->pluck('tag')->collapse()->contains($tag->name);
$activeClass = $isActive ? 'text-amber-500 bg-amber-500' : 'bg-blue-50 text-white hover:text-amber-500';
@endphp
<a
class="{{ $activeClass }} flex relative flex-col flex-shrink-0 justify-between py-1 px-3 w-full h-20 border-0 border-solid duration-300 ease-in-out cursor-pointer bg-opacity-[0.07]"
href="{{ $isActive ? '#table' : route('school.table.course', ['country' => $country, 'table' => ['filters' => ['tag' => [$tag->name]]], '#table']) }}"
href="{{ $isActive ? '#table' : route('school.table.course', ['country' => $country, 'courses' => ['filters' => ['tag' => [$tag->name]]], '#table']) }}"
>
<div
class="flex flex-1 items-center p-0 m-0 text-center align-baseline border-0 border-solid"

View File

@@ -64,7 +64,7 @@ Route::middleware([
Route::get('/venue', \App\Http\Livewire\School\VenueTable::class)
->name('table.venue');
Route::get('/course', \App\Http\Livewire\School\CouseTable::class)
Route::get('/course', \App\Http\Livewire\School\CourseTable::class)
->name('table.course');
Route::get('/event', \App\Http\Livewire\School\EventTable::class)