---
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.