Add filters to server list (#762)

* add server owner filter

* add egg filter

* replace SelectFilter with TernaryFilter
This commit is contained in:
Boy132 2024-12-05 08:31:34 +01:00 committed by GitHub
parent d2a7d7708c
commit 44b879215f
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

View File

@ -9,7 +9,10 @@ use App\Tables\Columns\ServerEntryColumn;
use Carbon\CarbonInterface; use Carbon\CarbonInterface;
use Filament\Resources\Pages\ListRecords; use Filament\Resources\Pages\ListRecords;
use Filament\Tables\Columns\Layout\Stack; use Filament\Tables\Columns\Layout\Stack;
use Filament\Tables\Filters\SelectFilter;
use Filament\Tables\Filters\TernaryFilter;
use Filament\Tables\Table; use Filament\Tables\Table;
use Illuminate\Database\Eloquent\Builder;
use Illuminate\Support\Arr; use Illuminate\Support\Arr;
use Illuminate\Support\Number; use Illuminate\Support\Number;
@ -19,9 +22,11 @@ class ListServers extends ListRecords
public function table(Table $table): Table public function table(Table $table): Table
{ {
$baseQuery = auth()->user()->can('viewList server') ? Server::query() : auth()->user()->accessibleServers();
return $table return $table
->paginated(false) ->paginated(false)
->query(fn () => auth()->user()->can('viewList server') ? Server::query() : auth()->user()->accessibleServers()) ->query(fn () => $baseQuery)
->poll('15s') ->poll('15s')
->columns([ ->columns([
Stack::make([ Stack::make([
@ -36,7 +41,24 @@ class ListServers extends ListRecords
->recordUrl(fn (Server $server) => Console::getUrl(panel: 'server', tenant: $server)) ->recordUrl(fn (Server $server) => Console::getUrl(panel: 'server', tenant: $server))
->emptyStateIcon('tabler-brand-docker') ->emptyStateIcon('tabler-brand-docker')
->emptyStateDescription('') ->emptyStateDescription('')
->emptyStateHeading('You don\'t have access to any servers!'); ->emptyStateHeading('You don\'t have access to any servers!')
->filters([
TernaryFilter::make('only_my_servers')
->label('Owned by')
->placeholder('All servers')
->trueLabel('My Servers')
->falseLabel('Others\' Servers')
->default()
->queries(
true: fn (Builder $query) => $query->where('owner_id', auth()->user()->id),
false: fn (Builder $query) => $query->whereNot('owner_id', auth()->user()->id),
blank: fn (Builder $query) => $query,
),
SelectFilter::make('egg')
->relationship('egg', 'name', fn (Builder $query) => $query->whereIn('id', $baseQuery->pluck('egg_id')))
->searchable()
->preload(),
]);
} }
// @phpstan-ignore-next-line // @phpstan-ignore-next-line