
A
Publisher
Amose
NotificationEngine
 Tools
 tool notification notifications easy to use flexible simple
A simple, flexible addon for godot that implements in-app notifications (cross-platform).
NotificationEngine
A lightweight and flexible notification system for Godot 4.x.
Shows customizable popup notifications (title, body, icon, actions) with smooth animations, stacking, themes, and signals you can listen to from anywhere. Includes a demo scene to learn how to build payloads interactively.
✨ Features
- Global notification engine (autoload singleton) to access all its featues.
- Bottom-left / bottom-right alignment presets for notifications.
- Feature packed notifications: title, body, icon, actions, themes, duration.
- Action buttons (with id,label, and an optionalicon).
- Signals for popup, popout, and action clicks.
- Theming support:- Built-in "default"theme.
- Pass your own Themeresource directly.
 
- Built-in 
- Safe defaults and strong payload validation.
- Works out-of-the-box, no scene editing required and easy to pick up.
- Demo scene included to test payloads and easily learn usage.
📦 Installation
- Copy the addons/NotificationEngine/folder into your Godot project.
- Enable the plugin:- In the editor: Project → Project Settings → Plugins → enable NotificationEngine.
- This will autoload the singleton NotificationEngine.
 
⚙️ Setup
- The engine automatically creates a CanvasLayerroot calledNotificationsRoot.
- Notifications are instantiated inside this layer and survive scene changes.
- You can trigger notifications from anywhere by calling NotificationEngine.notify()with a payload dictionary.
- You can get/set NotificationEngine's settings like spacing and alignment through the built-in methods:set_spacing(new_spacing : float),set_alignment(mode : SIDE)andget_alignment()
- You can access the following signals to have a greater control: notif_popup(notification : Control),notif_popout(notification : Control), andnotification_action(notification: Control, notif_id : int, action_id : String)
📝 Example
var example_icon := preload("res://icon.svg")
NotificationEngine.notify({
	"title": "Hello!",                       # NOT REQUIRED BUT RECOMMENDED
	"body": "This is a test notification.",  # OPTIONAL
	"icon": example_icon,                    # OPTIONAL
	"actions": [                             # OPTIONAL
		{
			"id": "action_1",                # REQUIRED for actions
			"label": "Action 1",             # REQUIRED for actions
			"icon": example_icon             # OPTIONAL for actions
		},
		{
			"id": "action_2",
			"label": "Action 2"
		}
	],
	"theme": "default",                      # OPTIONAL (string for built-in, or a Theme resource)
	"duration": 5.5,                         # OPTIONAL (seconds, default 3.0)
	"animation_duration": 0.4                # OPTIONAL (seconds, default 0.3)
})
🎮 Demo Scene
The repository includes a demo scene that lets you try out notifications interactively:
- Fill in title, body, actions, theme, etc.
- Press Submit to spawn a live notification.
- Great for documentation and for learning how to structure payloads.
🔔 Signals
The engine emits the following signals:
- notif_popup(notification : Control)
- notif_popout(notification : Control)
- notification_action(notification : Control, notif_id : int, action_id : String)You can connect to them from anywhere to handle notification lifecycle and actions.
📜 License
MIT License. Free to use, modify and share.