--- title: Customizing notifications --- Notifications come fully styled out of the box. However, if you want to apply your own styling or use a custom view to render notifications, there's multiple options. ## Styling notifications Notifications have dedicated CSS classes you can hook into to apply your own styling: - `filament-notifications` - `filament-notifications-notification` - `filament-notifications-icon` - `filament-notifications-title` - `filament-notifications-close-button` - `filament-notifications-date` - `filament-notifications-body` - `filament-notifications-actions` ## Custom notification view If your desired customization can't be achieved using the CSS classes above, you can create a custom view to render the notification. To configure the notification view, call the static `configureUsing()` method inside a service provider's `boot()` method and specify the view to use: ```php use Filament\Notifications\Notification; Notification::configureUsing(function (Notification $notification): void { $notification->view('notifications.notification'); }); ``` Next, create the view, in this example `resources/views/notifications/notification.blade.php`. The view should use the package's base notification component for the notification functionality and pass the available `$notification` variable through the `notification` attribute. This is the bare minimum required to create your own notification view: ```blade {{-- Notification content --}} ``` Getters for all notification properties will be available in the view. So, a custom notification view might look like this: ```blade

{{ $getTitle() }}

{{ $getDate() }}

{{ $getBody() }}

Close
``` ## Custom notification object Maybe your notifications require additional functionality that's not defined in the package's `Notification` class. Then you can create your own `Notification` class, which extends the package's `Notification` class. For example, your notification design might need a size property. Your custom `Notification` class in `app/Notifications/Notification.php` might contain: ```php $this->getSize(), ]; } public static function fromArray(array $data): static { return parent::fromArray()->size($data['size']); } public function size(string $size): static { $this->size = $size; return $this; } public function getSize(): string { return $this->size; } } ``` Next, you should bind your custom `Notification` class into the container inside a service provider's `boot()` method: ```php use App\Notifications\Notification; use Filament\Notifications\Notification as BaseNotification; $this->app->bind(BaseNotification::class, Notification::class); ``` You can now use your custom `Notification` class in the same way as you would with the default `Notification` object.