Label und Filter für Todo-Tabelle
This commit is contained in:
parent
b59bea841a
commit
b6c9f22b75
@ -2,12 +2,16 @@
|
|||||||
|
|
||||||
namespace App\Filament\Resources\Todos\Tables;
|
namespace App\Filament\Resources\Todos\Tables;
|
||||||
|
|
||||||
|
use App\Models\Group;
|
||||||
|
use App\Models\User;
|
||||||
use Filament\Actions\BulkActionGroup;
|
use Filament\Actions\BulkActionGroup;
|
||||||
use Filament\Actions\DeleteBulkAction;
|
use Filament\Actions\DeleteBulkAction;
|
||||||
use Filament\Actions\EditAction;
|
use Filament\Actions\EditAction;
|
||||||
use Filament\Tables\Columns\IconColumn;
|
use Filament\Tables\Columns\IconColumn;
|
||||||
use Filament\Tables\Columns\TextColumn;
|
use Filament\Tables\Columns\TextColumn;
|
||||||
|
use Filament\Tables\Filters\Filter;
|
||||||
use Filament\Tables\Table;
|
use Filament\Tables\Table;
|
||||||
|
use Illuminate\Database\Eloquent\Builder;
|
||||||
|
|
||||||
class TodosTable
|
class TodosTable
|
||||||
{
|
{
|
||||||
@ -16,34 +20,57 @@ class TodosTable
|
|||||||
return $table
|
return $table
|
||||||
->columns([
|
->columns([
|
||||||
TextColumn::make('created_at')
|
TextColumn::make('created_at')
|
||||||
|
->label('Erstellungsdatum')
|
||||||
->dateTime()
|
->dateTime()
|
||||||
->sortable()
|
->sortable()
|
||||||
->toggleable(isToggledHiddenByDefault: true),
|
->toggleable(isToggledHiddenByDefault: true),
|
||||||
TextColumn::make('updated_at')
|
TextColumn::make('updated_at')
|
||||||
|
->label('Bearbeitet')
|
||||||
->dateTime()
|
->dateTime()
|
||||||
->sortable()
|
->sortable()
|
||||||
->toggleable(isToggledHiddenByDefault: true),
|
->toggleable(isToggledHiddenByDefault: true),
|
||||||
TextColumn::make('name')
|
TextColumn::make('name')
|
||||||
|
->label('Name')
|
||||||
->searchable(),
|
->searchable(),
|
||||||
TextColumn::make('user.name')
|
TextColumn::make('user.name')
|
||||||
|
->label('Benutzer')
|
||||||
->searchable(),
|
->searchable(),
|
||||||
TextColumn::make('todoable.name')
|
TextColumn::make('todoable.name')
|
||||||
->label('Zugewiesen')
|
->label('Zugewiesen')
|
||||||
->searchable(),
|
->searchable(),
|
||||||
TextColumn::make('due_date')
|
TextColumn::make('due_date')
|
||||||
|
->label('Todo-Datum')
|
||||||
->date()
|
->date()
|
||||||
->sortable(),
|
->sortable(),
|
||||||
TextColumn::make('done_date')
|
TextColumn::make('done_date')
|
||||||
|
->label('Erledigt am')
|
||||||
->date()
|
->date()
|
||||||
->sortable(),
|
->sortable(),
|
||||||
TextColumn::make('follow_up')
|
TextColumn::make('follow_up')
|
||||||
|
->label('Wiedervorlage')
|
||||||
->date()
|
->date()
|
||||||
->sortable(),
|
->sortable(),
|
||||||
IconColumn::make('review')
|
IconColumn::make('review')
|
||||||
|
->label('Review')
|
||||||
->boolean(),
|
->boolean(),
|
||||||
])
|
])
|
||||||
->filters([
|
->filters([
|
||||||
//
|
Filter::make('mine')->label('von mir oder für mich')
|
||||||
|
->default()
|
||||||
|
->query(function (Builder $query) {
|
||||||
|
$query->where('user_id', filament()->auth()->user()->id)
|
||||||
|
->orWhere('todoable_type', User::class)->where('todoable_id', filament()->auth()->user()->id)
|
||||||
|
->orwhere('todoable_type', Group::class)->whereIn('todoable_id', User::find(filament()->auth()->user()->id)->groups()->get()->pluck('id'));
|
||||||
|
return $query;
|
||||||
|
}),
|
||||||
|
Filter::make('alleoffenen')
|
||||||
|
->default()
|
||||||
|
->label('nicht erledigt')
|
||||||
|
->query(function (Builder $query) {
|
||||||
|
$query->where('done_date', null);
|
||||||
|
return $query;
|
||||||
|
}),
|
||||||
|
|
||||||
])
|
])
|
||||||
->recordActions([
|
->recordActions([
|
||||||
EditAction::make(),
|
EditAction::make(),
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user