PHPackages                             opscale-co/notification-center - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Mail &amp; Notifications](/categories/mail)
4. /
5. opscale-co/notification-center

ActiveLibrary[Mail &amp; Notifications](/categories/mail)

opscale-co/notification-center
==============================

Notification Center

1.1.6(2mo ago)013↓100%MITPHPPHP ^8.2CI passing

Since Feb 12Pushed 2mo agoCompare

[ Source](https://github.com/opscale-co/notification-center)[ Packagist](https://packagist.org/packages/opscale-co/notification-center)[ Docs](https://github.com/opscale-co/notification-center)[ RSS](/packages/opscale-co-notification-center/feed)WikiDiscussions main Synced 1mo ago

READMEChangelog (10)Dependencies (14)Versions (11)Used By (0)

Support us
----------

[](#support-us)

At Opscale, we’re passionate about contributing to the open-source community by providing solutions that help businesses scale efficiently. If you’ve found our tools helpful, here are a few ways you can show your support:

⭐ **Star this repository** to help others discover our work and be part of our growing community. Every star makes a difference!

💬 **Share your experience** by leaving a review on [Trustpilot](https://www.trustpilot.com/review/opscale.co) or sharing your thoughts on social media. Your feedback helps us improve and grow!

📧 **Send us feedback** on what we can improve at . We value your input to make our tools even better for everyone.

🙏 **Get involved** by actively contributing to our open-source repositories. Your participation benefits the entire community and helps push the boundaries of what’s possible.

💼 **Hire us** if you need custom dashboards, admin panels, internal tools or MVPs tailored to your business. With our expertise, we can help you systematize operations or enhance your existing product. Contact us at  to discuss your project needs.

Thanks for helping Opscale continue to scale! 🚀

Description
-----------

[](#description)

Make sure your users get notified. Notification Center for Laravel Nova gives you multi-channel delivery strategies with automatic channel escalation, smart retries, and advanced open/action tracking — so no message goes unnoticed.

[![Demo](https://raw.githubusercontent.com/opscale-co/notification-center/refs/heads/main/screenshots/notification-center.gif)](https://raw.githubusercontent.com/opscale-co/notification-center/refs/heads/main/screenshots/notification-center.gif)

Installation
------------

[](#installation)

[![Latest Version on Packagist](https://camo.githubusercontent.com/2b390fe8499da4988e76679b945b1ceae3193f3356834c19342717aa3f7bb7da/68747470733a2f2f696d672e736869656c64732e696f2f7061636b61676973742f762f6f707363616c652d636f2f6e6f74696669636174696f6e2d63656e7465722e7376673f7374796c653d666c61742d737175617265)](https://packagist.org/packages/opscale-co/notification-center)

You can install the package in to a Laravel app that uses [Nova](https://nova.laravel.com) via composer:

```
composer require opscale-co/notification-center
```

Next up, you must register the tool with Nova. This is typically done in the `tools` method of the `NovaServiceProvider`.

```
// in app/Providers/NovaServiceProvider.php
// ...
public function tools()
{
    return [
        // ...
        new \Opscale\NotificationCenter\Tool(),
    ];
}
```

Usage
-----

[](#usage)

Publish the configuration and run the migrations:

```
php artisan notification-center:install
```

Configuration
-------------

[](#configuration)

The configuration file `config/notification-center.php` is organized around four features:

### Templates

[](#templates)

Notifications use templates from [Nova Dynamic Resources](https://github.com/opscale-co/nova-dynamic-resources) to define their fields. Refer to the composition example for setting up templates.

### Orchestration

[](#orchestration)

Define delivery strategies per notification type (marketing, transactional, system, alert, reminder). Each strategy configures an ordered list of channels to attempt (e.g., `['webpush', 'whatsapp', 'sms']`) with automatic channel escalation — if a channel times out, the next one in the list is attempted. Map channel identifiers to notification classes in the `messages` config to control how each channel renders its content.

### Deliverability

[](#deliverability)

Fine-tune when and how notifications reach your users. Configure time windows (allowed days and hours), retry intervals with escalating delays, max attempts per channel, and channel timeout thresholds. The scheduler re-dispatches strategies hourly for all published, non-expired notifications. Web push requires HTTPS since service workers only work in secure contexts. For WhatsApp, set your Twilio Content Template SID via the `TWILIO_WHATSAPP_CONTENT_SID` environment variable.

### Segmentation

[](#segmentation)

Target the right users with audiences. Create **static** audiences with manually curated profiles, **dynamic** audiences that resolve membership at query time based on criteria rules, or **segments** as named reusable cohorts based on shared profile attributes. Attach one or more audiences to a notification when publishing.

### In-App Notifications

[](#in-app-notifications)

Three built-in channels deliver notifications directly inside your application:

- **Nova**: Sends notifications through Laravel Nova's native notification bell. Users receive real-time alerts within the Nova admin panel.
- **Card**: Renders notifications as visual cards on the **Notifications Dashboard**, a dedicated Nova dashboard where users can browse and manage their card notifications.
- **Web Push**: Delivers browser push notifications via service workers. Requires HTTPS — service workers are only available in secure contexts. Make sure your application is served over HTTPS in all environments where web push is enabled.

### Tracking

[](#tracking)

Every delivery generates unique open and action slugs for built-in tracking. Tracking routes are registered automatically. Enable Google Analytics integration by setting your GA4 Measurement ID via the `GOOGLE_ANALYTICS_ID` environment variable.

Testing
-------

[](#testing)

```
npm run test
```

Changelog
---------

[](#changelog)

Please see [CHANGELOG](CHANGELOG.md) for more information on what has changed recently.

Contributing
------------

[](#contributing)

Please see [CONTRIBUTING](https://github.com/opscale-co/.github/blob/main/CONTRIBUTING.md) for details.

Security
--------

[](#security)

If you discover any security related issues, please email  instead of using the issue tracker.

Credits
-------

[](#credits)

- [Opscale](https://github.com/opscale-co)

License
-------

[](#license)

The MIT License (MIT). Please see [License File](LICENSE.md) for more information.

###  Health Score

40

—

FairBetter than 88% of packages

Maintenance84

Actively maintained with recent releases

Popularity6

Limited adoption so far

Community8

Small or concentrated contributor base

Maturity53

Maturing project, gaining track record

 Bus Factor1

Top contributor holds 68.8% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

###  Release Activity

Cadence

Every ~0 days

Total

10

Last Release

81d ago

### Community

Maintainers

![](https://avatars.githubusercontent.com/u/3722594?v=4)[opscale](/maintainers/opscale)[@opscale](https://github.com/opscale)

---

Top Contributors

[![opscale-development](https://avatars.githubusercontent.com/u/181295122?v=4)](https://github.com/opscale-development "opscale-development (22 commits)")[![semantic-release-bot](https://avatars.githubusercontent.com/u/32174276?v=4)](https://github.com/semantic-release-bot "semantic-release-bot (10 commits)")

---

Tags

laravelpackagetoolnovaopscale

###  Code Quality

TestsPHPUnit

### Embed Badge

![Health badge](/badges/opscale-co-notification-center/health.svg)

```
[![Health](https://phpackages.com/badges/opscale-co-notification-center/health.svg)](https://phpackages.com/packages/opscale-co-notification-center)
```

###  Alternatives

[dniccum/custom-email-sender

A tool for Laravel's Nova administrator panel that allows you to send custom email messages that within your application that leverages the applications existing settings and configurations.

6235.9k](/packages/dniccum-custom-email-sender)[inspheric/nova-email-field

A Laravel Nova email field.

33456.9k1](/packages/inspheric-nova-email-field)[coreproc/nova-notification-feed

A Laravel Nova package that adds a notification feed in your Nova app.

10149.1k](/packages/coreproc-nova-notification-feed)[kirschbaum-development/nova-mail

A Laravel Nova action for sending mail.

7484.2k](/packages/kirschbaum-development-nova-mail)

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
