--- title: Customizing notifications --- ## Overview 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 are multiple options. ## Styling notifications Notifications have dedicated CSS classes you can hook into to apply your own styling. Open the inspector in your browser to find out which classes you need to target. ## Using a 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('filament-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
``` ## Using a 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.