Actions on Custom Widgets on resource page

Hello, is it possible to make the actions visible on a custom widget? I successfully create a page like on the screenshot. But I want to make a view like the 2nd screenshot. Is it possible? When I return title as empty string my actions are disappearing also.
7 Replies
onursahindur
onursahindurOP2y ago
Or is there a way I can return a custom widget source to getTitle of the page?
Patrick Boivin
I don't think there's an easy way to do exactly what you want but if your actions are mostly links to other sections (eg. create, print, etc.), you could include them as simple buttons in your widget template :
<x-filament-support::button color="primary" tag="a" :href=" ... ">
Label
</x-filament-support::button>
<x-filament-support::button color="primary" tag="a" :href=" ... ">
Label
</x-filament-support::button>
And remove the default actions from your ListRecords page :
protected function getActions(): array
{
return [];
}
protected function getActions(): array
{
return [];
}
onursahindur
onursahindurOP2y ago
Thanks for your answer. I considered to do it like that, however I have already made a slideOver modal to complete the actions already :/ Do you know any quick support to open modals from widget button?
LeandroFerreira
I'm not sure if it is the best way, but you could duplicate the files: vendor/filament/filament/resources/views/resources/pages/list-records.blade.php vendor/filament/filament/resources/views/components/page.blade.php modify and use in the page. Ex:
protected static string $view = 'components.list-records';
protected static string $view = 'components.list-records';
<x-page :class="\Illuminate\Support\Arr::toCssClasses([
'filament-resources-list-records-page',
'filament-resources-' . str_replace('/', '-', $this->getResource()::getSlug()),
])">
{{ $this->table }}
</x-page>
<x-page :class="\Illuminate\Support\Arr::toCssClasses([
'filament-resources-list-records-page',
'filament-resources-' . str_replace('/', '-', $this->getResource()::getSlug()),
])">
{{ $this->table }}
</x-page>
But take a look: https://filamentphp.com/blog/publishing-views-in-laravel
Filament
Publishing views in Laravel can be dangerous - how to stay safe by ...
Filament is a collection of tools for rapidly building beautiful TALL stack apps, designed for humans.
LeandroFerreira
Filament
Opening a modal in a blade with button outside it's trigger slot by...
Filament is a collection of tools for rapidly building beautiful TALL stack apps, designed for humans.
onursahindur
onursahindurOP2y ago
Thank you, I will try opening a modal in a blade. The first suggestion looks dangerous maybe, but I will give it a try too. These Helped a lot, cheers
LeandroFerreira
add a filament card
//resources/views/components/page.blade.php
...

<x-filament::card>
@if ($header = $this->getHeader())
{{ $header }}
@elseif ($heading = $this->getHeading())
<x-filament::header :actions="$this->getCachedActions()">
<x-slot name="heading">
{{ $heading }}
</x-slot>

@if ($subheading = $this->getSubheading())
<x-slot name="subheading">
{{ $subheading }}
</x-slot>
@endif
</x-filament::header>
@endif
</x-filament::card>

...
//resources/views/components/page.blade.php
...

<x-filament::card>
@if ($header = $this->getHeader())
{{ $header }}
@elseif ($heading = $this->getHeading())
<x-filament::header :actions="$this->getCachedActions()">
<x-slot name="heading">
{{ $heading }}
</x-slot>

@if ($subheading = $this->getSubheading())
<x-slot name="subheading">
{{ $subheading }}
</x-slot>
@endif
</x-filament::header>
@endif
</x-filament::card>

...

Did you find this page helpful?