filters updated

This commit is contained in:
Benjamin Takats
2022-12-05 20:24:16 +01:00
parent e921132504
commit fd2dee5590
12 changed files with 90 additions and 11 deletions

View File

@@ -4,10 +4,12 @@ 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
@@ -19,15 +21,43 @@ class LibraryItemTable extends DataTableComponent
{
$this
->setPrimaryKey('id')
->setDefaultSort('order_column', 'asc');
->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')
@@ -73,9 +103,10 @@ class LibraryItemTable extends DataTableComponent
->sortable(),
Column::make("Art", "type")
->sortable(),
Column::make("Sprache", "language_code")
->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)
@@ -86,6 +117,7 @@ class LibraryItemTable extends DataTableComponent
public function builder(): Builder
{
return LibraryItem::query()
->whereHas('libraries', fn($query) => $query->where('libraries.is_public', true))
->when($this->currentTab !== 'Alle', fn($query) => $query->whereHas('libraries',
fn($query) => $query->where('libraries.name', $this->currentTab)))
->withCount([