Plugins Manager & Generator
Manage your modules as a plugin system with plugin generator
Author:
Fady Mondy
Documentation
- Screenshots
- Installation
- Usage
- Install Plugins using command line
- List of all TomatoPHP Plugins
- List your package on the plugins list
- Use Selected Module in your panel
- Get Only Current Panel Plugins
- Stop Auto Discover Module Resources
- Stop Using Plugins UI
- Publish Assets
- Other Filament Packages

Manage your modules as a plugin system with plugin generator
#Screenshots

#Installation
composer require tomatophp/filament-plugins
after install your package please run this command
php artisan filament-plugins:install
By default the module classes are not loaded automatically. You can autoload your modules by adding merge-plugin to the extra section:
"extra": {
"laravel": {
"dont-discover": []
},
"merge-plugin": {
"include": [
"Modules/*/composer.json"
]
}
},
now you need to run this command to autoload your modules
composer dump-autoload
finally reigster the plugin on /app/Providers/Filament/AdminPanelProvider.php
->plugin(\TomatoPHP\FilamentPlugins\FilamentPluginsPlugin::make())
#Usage
you can create a new plugin using just a command
php artisan filament-plugins:generate
or you can use the GUI to create a new plugin, after create a plugin you need to make sure that it's loaded on composer by run this command
composer dump-autoload
after create the plugin you can create a new table inside it and than run the migration generator to convert it to a migration file then you can use the GUI to generate resources, pages, widget or model, or you can easy use this commands
php artisan filament-plugins:model
php artisan filament-plugins:resource
php artisan filament-plugins:page
php artisan filament-plugins:widget
it will generate the files for you and you can use it directly, please note that you need to generate the model first than use other commands
#Install Plugins using command line
you can install a plugins using the command line by using this command
php artisan filament:plugins
you can select all to install all TomatoPHP ecosystem plugins or you can select the plugin you want to install
#List of all TomatoPHP Plugins
you can list all TomatoPHP plugins by using this command
php artisan filament-plugins:list
#List your package on the plugins list
you can list your package on the plugins list by adding this a json file in your package root folder with name module.json with content like this:
{
"name": "FilamentAccounts",
"alias": "filament-accounts",
"description": {
"ar": "full accounts manager with API\/Notifications\/Contacts to manage your contacts and accounts",
"en": "full accounts manager with API\/Notifications\/Contacts to manage your contacts and accounts",
"gr": "full accounts manager with API\/Notifications\/Contacts to manage your contacts and accounts",
"sp": "full accounts manager with API\/Notifications\/Contacts to manage your contacts and accounts"
},
"keywords": [],
"priority": 0,
"providers": [
"TomatoPHP\\FilamentAccounts\\FilamentAccountsServiceProvider"
],
"files": [],
"title": {
"ar": "Filament Accounts",
"en": "Filament Accounts",
"gr": "Filament Accounts",
"sp": "Filament Accounts"
},
"color": "#007dff",
"icon": "heroicon-c-user-circle",
"placeholder": "placeholder.webp",
"type": "lib",
"version": "v1.0",
"github" : "https://github.com/tomatophp/filament-accounts",
"docs" : "https://github.com/tomatophp/filament-accounts"
}
make sure you allow packages scan on the filament-plugins.php config file
'scan' => true
now you can publish your package as module with the very easy way use this command
php artisan filament-plugins:publish
and input your package name from the list and it will move it to your module folder and register the provider to you, so you can custom anything you like on the package.
#Use Selected Module in your panel
you can use the selected module in your panel by using this code in your PanelProvider
->plugin(\TomatoPHP\FilamentPlugins\FilamentPluginsPlugin::make()->modules([
'CRM'
]))
so you will see only the selected modules in your panel
#Get Only Current Panel Plugins
on any plugin you can create a Page/Resource/Widget for selected panel, so if you need to showup only the current panel Page/Resources/Widgets you can use this code in your PanelProvider
->plugin(\TomatoPHP\FilamentPlugins\FilamentPluginsPlugin::make()->discoverCurrentPanelOnly())
#Stop Auto Discover Module Resources
you can stop auto-load module resources by using this code in your PanelProvider
->plugin(\TomatoPHP\FilamentPlugins\FilamentPluginsPlugin::make()->autoDiscoverModules(false))
#Stop Using Plugins UI
you can stop using the plugins UI by using this code in your PanelProvider
->plugin(\TomatoPHP\FilamentPlugins\FilamentPluginsPlugin::make()->useUI(false))
#Publish Assets
you can publish config file by use this command
php artisan vendor:publish --tag="filament-plugins-config"
you can publish views file by use this command
php artisan vendor:publish --tag="filament-plugins-views"
you can publish languages file by use this command
php artisan vendor:publish --tag="filament-plugins-lang"
you can publish migrations file by use this command
php artisan vendor:publish --tag="filament-plugins-migrations"
#Other Filament Packages
Checkout our Awesome TomatoPHP
The author
Manage your modules as a plugin system with plugin generator
From the same author
Tenancy Multi-database
Tenancy multi-database integration for FilamentPHP
Author:
Fady Mondy
Menu Generator
Menu view generator using view component
Author:
Fady Mondy
Translations Manager
Manage your translation with DB and cache, you can scan an collect translation strings like `trans()` and `__()`, and translate them using UI
Author:
Fady Mondy
Meta Manager
Convert any model on your app to pluggable model using Meta and get ready to use relation manager on FilamentPHP panel
Author:
Fady Mondy
Featured Plugins
A selection of plugins curated by the Filament team
Custom Dashboards
Let your users build and share their own dashboards with a drag-and-drop interface. Define your data sources in PHP and let them do the rest.
Filament
Advanced Tables (formerly Filter Sets)
Supercharge your tables with powerful features like user-customizable views, quick filters, multi-column sorting, advanced table searching, convenient view management, and more. Compatible with Resource Panel Tables, Relation Managers, Table Widgets, and Table Builder!
Kenneth Sese
Data Lens
Advanced Data Visualization for Laravel Filament - a premium reporting solution enabling custom column creation, sophisticated filtering, and enterprise-grade data insights within admin panels.
Padmission