mirror of
https://github.com/Einundzwanzig-Podcast/einundzwanzig-portal.git
synced 2025-12-11 06:46:47 +00:00
132 lines
5.3 KiB
PHP
132 lines
5.3 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Livewire\Tables;
|
|
|
|
use App\Models\Library;
|
|
use App\Models\LibraryItem;
|
|
use App\Models\Tag;
|
|
use Illuminate\Database\Eloquent\Builder;
|
|
use Rappasoft\LaravelLivewireTables\DataTableComponent;
|
|
use Rappasoft\LaravelLivewireTables\Views\Column;
|
|
use Rappasoft\LaravelLivewireTables\Views\Columns\ImageColumn;
|
|
use Rappasoft\LaravelLivewireTables\Views\Filters\MultiSelectFilter;
|
|
use Rappasoft\LaravelLivewireTables\Views\Filters\SelectFilter;
|
|
|
|
class LibraryItemTable extends DataTableComponent
|
|
{
|
|
public string $currentTab;
|
|
protected $model = LibraryItem::class;
|
|
|
|
public function configure(): void
|
|
{
|
|
$this
|
|
->setPrimaryKey('id')
|
|
->setDefaultSort('order_column', 'asc')
|
|
->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(50);
|
|
}
|
|
|
|
public function filters(): array
|
|
{
|
|
return [
|
|
MultiSelectFilter::make('Tag')
|
|
->options(
|
|
Tag::query()
|
|
->where('type', 'library_item')
|
|
->get()
|
|
->pluck('name', 'id')
|
|
->toArray()
|
|
)
|
|
->filter(function (Builder $builder, array $values) {
|
|
$builder->whereHas('tags', function (Builder $query) use ($values) {
|
|
$query->whereIn('tags.id', $values);
|
|
});
|
|
}),
|
|
SelectFilter::make('Bibliothek')
|
|
->options(
|
|
Library::query()
|
|
->where('is_public', true)
|
|
->get()
|
|
->prepend(new Library(['name' => 'Alle']))
|
|
->pluck('name', 'name')
|
|
->toArray(),
|
|
)
|
|
->filter(function (Builder $builder, string $value) {
|
|
if ($value === 'Alle') {
|
|
return;
|
|
}
|
|
if (str($value)->contains(',')) {
|
|
$builder
|
|
->whereHas('libraries',
|
|
function ($query) use ($value) {
|
|
$query->whereIn('libraries.name', str($value)->explode(','));
|
|
});
|
|
} else {
|
|
$builder->whereHas('libraries',
|
|
fn($query) => $query->where('libraries.name', 'ilike', "%$value%"));
|
|
}
|
|
}),
|
|
];
|
|
}
|
|
|
|
public function columns(): array
|
|
{
|
|
return [
|
|
ImageColumn::make('Bild')
|
|
->location(
|
|
fn($row) => $row->getFirstMediaUrl('main', 'thumb')
|
|
)
|
|
->attributes(fn($row) => [
|
|
'class' => 'rounded h-16',
|
|
'alt' => $row->name.' Avatar',
|
|
])
|
|
->collapseOnMobile(),
|
|
Column::make('Ersteller', "lecturer.name")
|
|
->label(
|
|
fn($row, Column $column) => view('columns.courses.lecturer')->withRow($row)
|
|
)
|
|
->sortable()
|
|
->collapseOnMobile(),
|
|
Column::make("Name", "name")
|
|
->sortable(),
|
|
Column::make("Art", "type")
|
|
->sortable(),
|
|
Column::make("Tags")
|
|
->label(
|
|
fn($row, Column $column) => view('columns.library_items.tags')->withRow($row)
|
|
),
|
|
Column::make('')
|
|
->label(
|
|
fn($row, Column $column) => view('columns.library_items.action')->withRow($row)
|
|
),
|
|
];
|
|
}
|
|
|
|
public function builder(): Builder
|
|
{
|
|
$shouldBePublic = request()
|
|
->route()
|
|
->getName() !== 'library.lecturer';
|
|
|
|
return LibraryItem::query()
|
|
->whereHas('libraries', fn($query) => $query->where('libraries.is_public', $shouldBePublic))
|
|
->when($this->currentTab !== 'Alle', fn($query) => $query->whereHas('libraries',
|
|
fn($query) => $query->where('libraries.name', $this->currentTab)))
|
|
->withCount([
|
|
'lecturer',
|
|
]);
|
|
}
|
|
}
|