For defaultSort() which accepts a string, is there an easy way to sort by multiple columns?

->defaultSort("title") // group.group, sort_order
7 Replies
Patrick Boivin
Patrick Boivinβ€’2y ago
I'm not sure there's an easy solution for this... you can probably override the applyDefaultSortingToTableQuery() method on your Page or custom component. Easy enough I guess πŸ˜„
FullyLoadedTech
FullyLoadedTechOPβ€’2y ago
Do you have an example how to use that? I couldn't find that method defined anywhere. I'll keep looking.
Patrick Boivin
Patrick Boivinβ€’2y ago
Something like this on your page class:
protected function applyDefaultSortingToTableQuery(Builder $query, string $sortColumn, string $sortDirection): Builder
{
return $query
->orderBy('category', 'ASC')
->orderBy('title', 'ASC');
}
protected function applyDefaultSortingToTableQuery(Builder $query, string $sortColumn, string $sortDirection): Builder
{
return $query
->orderBy('category', 'ASC')
->orderBy('title', 'ASC');
}
I don't know if it's going to work everywhere, but something to experiment πŸ˜„
Martin Branches
Martin Branchesβ€’13mo ago
This is not working for me (filament 3) Method 'App\Filament\Resources\MyCountryResource\Pages\ListMyCountries::applyDefaultSortingToTableQuery()' is not compatible with method 'Filament\Resources\Pages\ListRecords::applyDefaultSortingToTableQuery()'.intelephense(P1038) any other ideas?
Adam Holmes
Adam Holmesβ€’2w ago
Is there any update on this? Are we able to defaultSort by multiple columns yet?
ModestasV
ModestasVβ€’2w ago
->defaultSort(function (Builder $query): Builder { return $query ->orderBy('floor') ->orderBy('room_number'); })
Adam Holmes
Adam Holmesβ€’2w ago
Amazing, thank you πŸ™‚

Did you find this page helpful?