amjitk/laravel-global-notification 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

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

amjitk/laravel-global-notification

最新稳定版本:2.0.0

Composer 安装命令:

composer require amjitk/laravel-global-notification

包简介

A comprehensive notification system for Laravel with CMS and automated triggers.

README 文档

README

Global Notification Logo

Laravel Global Notification

A comprehensive notification system for Laravel applications. This package allows you to manage notification types and templates via a CMS and automatically trigger them based on system events.

Features

  • CMS Interface: Manage types, define variables, and test templates directly from the admin panel.
  • Multi-Channel Support: Configure different templates for different channels for the same event.
  • User Preference Center: Users can toggle specific notification channels on/off.
  • Auto-Triggering: Automatically fire notifications on Eloquent model events (created, updated, etc.).
  • In-App Toast Widget: Real-time polling widget to show notifications instantly.
  • User Notification Center: Built-in UI for users to view and manage their in-app notifications.
  • Dynamic Content: Use placeholders like {{name}} in your templates.

Installation

  1. Install the package via Composer:

    composer require amjitk/laravel-global-notification

    Note: If testing locally without Packagist, configure your composer.json repositories to point to the local path.

  2. Run Migrations:

    php artisan migrate
  3. (Optional) Publish Configuration and Assets:

    php artisan vendor:publish --tag=global-notification-config
    php artisan vendor:publish --tag=global-notification-views

Configuration

The configuration file config/global-notification.php allows you to customize:

  • Channels: Enabled channels (default: mail, database).
  • Route Prefix: URL prefix for the package routes (default: global-notification).
  • Middleware: Middleware for admin routes. Configurable via .env:
    GLOBAL_NOTIFICATION_AUTH_ENABLED=true # Set to false to disable authentication

Usage

1. Admin - Manage Notifications

Visit /global-notification/notification-types to create new Notification Types (e.g., order_placed).

  • Variables: Define available variables (e.g. order_id, amount) when creating a Type.
  • Templates: Create templates for each channel. Use the defined variables (e.g. {{ amount }}).
  • Testing: Use the "Send Test" button on any template to send a dummy notification to yourself immediately.

2. Triggering Notifications

Manual Trigger

Use the NotificationService to send a notification programmatically:

use AmjitK\GlobalNotification\Services\NotificationService;

$service = new NotificationService();
$service->send('order_placed', $user, ['order_id' => 123, 'amount' => '$50']);

Automatic Trigger (Model Events)

Add the AutoNotifyTrait to your Eloquent model:

use AmjitK\GlobalNotification\Traits\AutoNotifyTrait;

class Order extends Model
{
    use AutoNotifyTrait;

    // Map system events to Notification Type keys
    public $notificationRules = [
        'created' => 'order_placed',   // Fires 'order_placed' when Order is created
        'updated' => 'order_updated',  // Fires 'order_updated' when Order is updated
    ];
}

3. Notification Logs

View all system notifications at: /global-notification/logs

This page displays a global log of all notifications triggered in the system.

4. Scheduled Notifications

You can schedule notifications using the package's send method combined with Laravel's Scheduler. This creates a powerful workflow where you can define templates in the CMS types and trigger them via Cron jobs.

Why use the package's send method instead of Notification::send or Mail::send? Using $service->send() allows you to:

  1. Use CMS Templates: Manage the content of your scheduled emails/alerts dynamically without deploying code.
  2. Separate Logging: By tagging them with withSource('scheduled'), they appear in the dedicated Scheduled Logs dashboard, separating them from transactional or user alerts.

Example: Sending a Daily Digest

// app/Console/Kernel.php or app/Console/Commands/SendDailyDigest.php

use AmjitK\GlobalNotification\Services\NotificationService;

protected function schedule(Schedule $schedule)
{
    $schedule->call(function () {
        $service = app(NotificationService::class);
        $users = \App\Models\User::all();
        
        foreach ($users as $user) {
            // 'daily_digest' is a Notification Type defined in your CMS
            $service->withSource('scheduled')
                    ->send('daily_digest', $user, [
                        'date' => now()->toFormattedDateString(),
                        'stats' => $user->getDailyStats()
                    ]);
        }
    })->dailyAt('09:00');
}

5. In-App Widget (Toast)

To display a real-time toast notification in your application whenever a new notification arrives:

  1. Make sure you have published the views (or reference the package view).

  2. Add the following line to your main layout file (e.g., resources/views/layouts/app.blade.php), preferably just before the closing </body> tag:

    @include('global-notification::components.toast')
  3. Ensure your application layout includes Alpine.js or vanilla JS support (the component uses vanilla JS but allows for easy customization).

6. User Preferences

Users can manage their notification preferences (opt-in/out of specific channels) by visiting: /global-notification/preferences

  • The interface allows users to toggle channels (e.g., turn off Email for "Order Updates" but keep it for "Promotions").
  • The system automatically checks these preferences before sending any notification.

Testing

To run the package tests:

composer install
vendor/bin/phpunit

统计信息

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

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: Blade

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-12-18

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固