mirror of
https://github.com/Einundzwanzig-Podcast/einundzwanzig-portal.git
synced 2025-12-11 06:46:47 +00:00
83 lines
2.9 KiB
PHP
83 lines
2.9 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Livewire\Tables;
|
|
|
|
use App\Models\BitcoinEvent;
|
|
use Illuminate\Database\Eloquent\Builder;
|
|
use Rappasoft\LaravelLivewireTables\DataTableComponent;
|
|
use Rappasoft\LaravelLivewireTables\Views\Column;
|
|
use Rappasoft\LaravelLivewireTables\Views\Filters\TextFilter;
|
|
|
|
class BitcoinEventTable extends DataTableComponent
|
|
{
|
|
public string $country;
|
|
|
|
protected $model = BitcoinEvent::class;
|
|
|
|
public function configure(): void
|
|
{
|
|
$this->setPrimaryKey('id')
|
|
->setDefaultSort('from', 'asc')
|
|
->setAdditionalSelects(['bitcoin_events.id'])
|
|
->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);
|
|
}
|
|
|
|
public function filters(): array
|
|
{
|
|
return [
|
|
TextFilter::make('Event by ID', 'byid')
|
|
->hiddenFromMenus()
|
|
->filter(function (Builder $builder, string $value) {
|
|
$builder->whereIn('bitcoin_events.id', str($value)->explode(','));
|
|
}),
|
|
];
|
|
}
|
|
|
|
public function columns(): array
|
|
{
|
|
return [
|
|
Column::make(__('Title'), 'title')
|
|
->format(
|
|
fn($value, $row, Column $column) => view('columns.bitcoin_events.title')->withRow($row)
|
|
)
|
|
->sortable(),
|
|
Column::make(__('From'), 'from')
|
|
->format(
|
|
fn($value, $row, Column $column) => $value->asDateTime()
|
|
),
|
|
Column::make(__('To'), 'to')
|
|
->format(
|
|
fn($value, $row, Column $column) => $value->asDateTime()
|
|
),
|
|
Column::make(__('Venue'), 'venue.name'),
|
|
Column::make(__('Link'), 'link')
|
|
->format(
|
|
fn($value, $row, Column $column) => view('columns.bitcoin_events.link')->withRow($row)
|
|
)
|
|
->sortable(),
|
|
];
|
|
}
|
|
|
|
public function builder(): Builder
|
|
{
|
|
return BitcoinEvent::query()
|
|
->where(fn($query) => $query
|
|
->whereHas('venue.city.country',
|
|
fn($query) => $query->where('code', $this->country))
|
|
->orWhere('show_worldwide', true));
|
|
}
|
|
}
|