F
Filament4mo ago
blink

Persistent bulk action

Hi, How to display bulk actions even if no row is selected? I know I can add them in header actions, but they dont look nice on right side above search. thanks
No description
5 Replies
toeknee
toeknee4mo ago
You can't, it sounds like you want header actions which are not selection relative
blink
blinkOP4mo ago
You can place bulk actions as header actions without issue, they will be disabled until u select a record. What I need is to show buttons in the bulk action row, header actions are rendered above the search bar and look ugly >sounds like you want header actions I whant existing bulk actions to be rendered even if row is not slected, it will be disabled until I select a record
toeknee
toeknee4mo ago
That is not possible out of the box. You will need to add custom css: .fi-ta .fi-ta-actions {display:inherit !important;} But then the problem you will have is, you will want each action to alert that nothing is selected. So really you need to create a PR to add support for always showing bulk action actions if Dan would accept it.
neil.keena
neil.keena3w ago
@Vitali Kartsivadze I solved this using a render hook. I display a disabled "bulk actions" button and then hide it whenever records are selected. Here is how I'm doing it. You could adapt this to your own use case: AppServiceProvider:
FilamentView::registerRenderHook(
TablesRenderHook::TOOLBAR_START,
fn (): string => view('filament.disabled-bulk-actions'),
Scopes: [
ListEnrollments::class
],
);
FilamentView::registerRenderHook(
TablesRenderHook::TOOLBAR_START,
fn (): string => view('filament.disabled-bulk-actions'),
Scopes: [
ListEnrollments::class
],
);
disabled-bulk-actions.blade.php:
<div x-tooltip.raw="Select some records first" x-show="!selectedRecords.length">

<x-filament::button
color="gray"
:disabled="true"
>Bulk actions</x-filament::button>

</div>
<div x-tooltip.raw="Select some records first" x-show="!selectedRecords.length">

<x-filament::button
color="gray"
:disabled="true"
>Bulk actions</x-filament::button>

</div>
blink
blinkOP3w ago
Thanks for sharing. I solved it by publishing filament table views and implementing persistency checks in the blade file. When I need persistent bulk actions, I add a property to the list record class of resource. @if ((! $isReordering) && count($bulkActions)) <x-filament-tables::actions x-data="{ persistent: {{ $persistentBulkActions }} }" :actions="$bulkActions" x-cloak="x-cloak" x-show="selectedRecords.length || persistent" /> @endif

Did you find this page helpful?