Announcements plugin screenshot
Dark mode ready
Multilingual support
Supports v5.x

Announcements

A plugin for broadcasting institutional announcements directly on your admin dashboard, with severity levels, automatic expiration, and per-user dismiss.

Tags: Panels Widget
Supported versions:
5.x
Marcelo Delgado avatar Author: Marcelo Delgado

Documentation

Filament Announcements Banner

Latest Version Total Downloads PHP Version License


A Filament v5 plugin to display institutional announcements and alerts on your panel dashboard — with full CRUD, per-user dismiss, and automatic expiration.


#Screenshots

#Dashboard Widget

Widget

#Announcements List

List

#Create / Edit Form

Form


#Features

  • 📢 Dashboard widget — displays active announcements ordered by severity
  • Full CRUD via AnnouncementResource with type badges, bulk actions and inline toggles
  • Automatic expiration — uses starts_at / expires_at date windows, no jobs required
  • 👤 Per-user dismiss — dismissible announcements are remembered per user via a pivot table
  • 🔒 Flexible permissions — works out-of-the-box, with optional Gate or Spatie integration
  • 🌍 Translatable — all strings go through __() with publishable language files
  • 🎨 4 severity levelsinfo, warning, danger, success with Filament semantic colors

#Requirements

Dependency Version
PHP 8.2+
Laravel 11+
Filament 5.x
spatie/laravel-package-tools ^1.16

#Installation

Install via Composer:

composer require marcelodelgado/filament-announcements

Publish and run the migrations:

php artisan vendor:publish --tag="announcements-migrations"
php artisan migrate

Optionally publish config and views to customize them:

php artisan vendor:publish --tag="announcements-config"
php artisan vendor:publish --tag="announcements-views"
php artisan vendor:publish --tag="announcements-translations"

#Setup

#1. Register the plugin in your PanelProvider

use Marcelodelgado\Announcements\AnnouncementsPlugin;

public function panel(Panel $panel): Panel
{
    return $panel
        ->plugin(
            AnnouncementsPlugin::make()
                ->pollingInterval('120s') // optional, default: '60s'
        );
}

#2. Add the trait to your User model

use Marcelodelgado\Announcements\Traits\HasAnnouncements;

class User extends Authenticatable
{
    use HasAnnouncements;
}

That's it — the widget will appear on your dashboard and the Announcements menu item will show up in the sidebar.


#Configuration

After publishing, edit config/announcements.php:

Key Type Default Description
permission_check null, string or Closure null Access control for the Resource. null = no extra check. string = Laravel Gate name. Closure = receives the authenticated user, must return bool.
polling_interval string '60s' Fallback wire:poll interval for the widget when the panel plugin interval cannot be resolved.

#Permissions example

// config/announcements.php

// Using a Laravel Gate:
'permission_check' => 'manage-announcements',

// Using a closure:
'permission_check' => fn ($user) => $user->hasRole('admin'),

// Using Spatie Permission:
'permission_check' => fn ($user) => $user->can('manage-announcements'),

#How it works

Widget — only shows announcements where is_active = true and the current time falls within the starts_at / expires_at window. Results are ordered with danger first, then by created_at descending.

Dismiss — when a user closes a dismissible announcement, the action is recorded in the announcement_user pivot table (dismissed_at). That announcement will never show again for that user. Non-dismissible announcements hide the close button entirely.

Expiration — handled purely by the query. No scheduled commands required.


#Translations

The plugin ships with English strings. To add your own language, publish the translation files:

php artisan vendor:publish --tag="announcements-translations"

This will create lang/vendor/announcements/{locale}/announcements.php where you can override any string.


#Roadmap

  • Audience targeting by role / group
  • Custom icon picker per announcement
  • Optional CTA link/button on the widget
  • Multi-panel support
  • announcements:prune artisan command

#Changelog

Please see CHANGELOG.md for details on recent changes.


#Contributing

Pull requests are welcome! Please keep the scope aligned with the package goals.

  • Run vendor/bin/pint before submitting PHP changes
  • Add tests for new behaviour when applicable
  • Open an issue first for significant changes

#License

MIT — see LICENSE for details.


Made with ❤️ by Marcelo Delgado

The author

Marcelo Delgado avatar Author: Marcelo Delgado

Experienced Laravel developer with years of working on medium and large-scale web projects. Specialist in FilamentPHP and reusable package development. Enthusiast of best practices, automated testing, and open source contributions.

Plugins
1
Stars
6