Files
einundzwanzig-portal/app/Http/Livewire/Tables/LecturerTable.php
Benjamin Takats 636efb95f5 table ids
2023-01-19 11:50:48 +01:00

113 lines
3.7 KiB
PHP

<?php
namespace App\Http\Livewire\Tables;
use App\Models\Lecturer;
use Illuminate\Database\Eloquent\Builder;
use Rappasoft\LaravelLivewireTables\DataTableComponent;
use Rappasoft\LaravelLivewireTables\Views\Column;
use Rappasoft\LaravelLivewireTables\Views\Columns\BooleanColumn;
use Rappasoft\LaravelLivewireTables\Views\Columns\ImageColumn;
class LecturerTable extends DataTableComponent
{
public string $country;
protected $model = Lecturer::class;
public function configure(): void
{
$this->setPrimaryKey('id')
->setAdditionalSelects(['id'])
->setDefaultSort('courses_events_count', 'desc')
->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 columns(): array
{
return [
ImageColumn::make('Bild')
->location(
fn($row) => $row->getFirstMediaUrl('avatar', 'thumb')
)
->attributes(fn($row) => [
'class' => 'rounded h-16 w-16',
'alt' => $row->name.' Avatar',
])
->collapseOnMobile(),
Column::make("Name", "name")
->sortable(),
BooleanColumn::make("Aktiv", 'active')
->sortable()
->collapseOnMobile(),
Column::make('Kurse')
->label(
fn($row, Column $column) => $row->courses_count
)
->collapseOnMobile(),
Column::make('Inhalte')
->label(
fn($row, Column $column) => $row->library_items_count
)
->collapseOnMobile(),
Column::make('')
->label(
fn($row, Column $column) => view('columns.lectures.action')
->withRow($row)
->withCountry($this->country)
),
];
}
public function builder(): Builder
{
return Lecturer::query()
->withCount([
'courses',
'coursesEvents',
'libraryItems',
]);
}
public function lecturerSearch($id, $event = true)
{
$lecturer = Lecturer::query()
->find($id);
if ($event) {
return to_route('school.table.event', [
'#table',
'country' => $this->country,
'table' => [
'filters' => [
'dozent' => $lecturer->id,
],
]
]);
} else {
return to_route('library.table.libraryItems', [
'#table',
'country' => $this->country,
'table' => [
'filters' => [
'lecturer_id' => $lecturer->id,
],
]
]);
}
}
}