定制 marcelodelgado/filament-announcements 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

marcelodelgado/filament-announcements

最新稳定版本:v1.0.0

Composer 安装命令:

composer require marcelodelgado/filament-announcements

包简介

Filament v5 plugin for institutional announcements on the admin dashboard

README 文档

README

Filament Announcements Banner

Latest Version Total Downloads PHP Version License

Filament Announcements

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

统计信息

  • 总下载量: 0
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 5
  • 点击次数: 11
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 5
  • Watchers: 0
  • Forks: 1
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-05-14

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固