Files
einundzwanzig-portal/app/Http/Livewire/Tables/VenueTable.php
2023-02-27 13:09:46 +01:00

103 lines
3.4 KiB
PHP

<?php
namespace App\Http\Livewire\Tables;
use App\Models\Venue;
use Illuminate\Database\Eloquent\Builder;
use Rappasoft\LaravelLivewireTables\DataTableComponent;
use Rappasoft\LaravelLivewireTables\Views\Column;
use Rappasoft\LaravelLivewireTables\Views\Columns\ImageColumn;
class VenueTable extends DataTableComponent
{
public string $country;
public bool $manage = false;
public string $tableName = 'venues';
public function configure(): void
{
$this->setPrimaryKey('id')
->setAdditionalSelects(['venues.id', 'venues.created_by'])
->setThAttributes(function (Column $column) {
return [
'class' => 'px-6 py-3 text-left text-xs font-medium text-gray-500 uppercase tracking-wider dark:bg-gray-800 dark:text-gray-400',
'default' => false,
];
})
->setTdAttributes(function (Column $column, $row, $columnIndex, $rowIndex) {
return [
'class' => 'px-6 py-4 text-sm font-medium dark:text-white',
'default' => false,
];
})
->setColumnSelectStatus(false)
->setPerPage(10)
->setConfigurableAreas([
'toolbar-left-end' => [
'columns.venues.areas.toolbar-left-end', [
'country' => $this->country,
],
],
]);
}
public function columns(): array
{
return [
ImageColumn::make('Bild')
->location(
fn ($row) => $row->getFirstMediaUrl('images', 'thumb')
)
->attributes(fn ($row) => [
'class' => 'rounded h-16 w-16',
'alt' => $row->name.' Avatar',
])
->collapseOnMobile(),
Column::make('Name', 'name')
->searchable(fn ($query, $term) => $query->where('name', 'ilike', '%'.$term.'%'))
->sortable(),
Column::make('Street', 'street')
->sortable()
->collapseOnMobile(),
Column::make('Termine')
->label(
fn ($row, Column $column) => $row->course_events_count
)
->collapseOnMobile(),
Column::make('')
->label(
fn ($row, Column $column) => view('columns.venues.action')->withRow($row)->withManage($this->manage)
),
];
}
public function builder(): Builder
{
return Venue::query()
->withCount([
'courseEvents',
])
->whereHas('city.country', fn ($query) => $query->where('code', $this->country))
->orderByDesc('course_events_count')
->orderBy('venues.id');
}
public function venueSearch($id)
{
$venue = Venue::query()
->find($id);
return to_route('school.table.event', [
'#table',
'country' => $this->country,
'course_events' => [
'filters' => [
'venue' => $venue->name,
],
],
]);
}
}