ryangjchandler / filament-tools
Add a general-purpose tools page to your Filament project.
Fund package maintenance!
ryangjchandler
Installs: 3 116
Dependents: 0
Suggesters: 0
Security: 0
Stars: 36
Watchers: 1
Forks: 6
Open Issues: 6
Requires
- php: ^8.0
- filament/filament: ^2.0
- illuminate/contracts: ^9.0
- spatie/laravel-package-tools: ^1.9.2
Requires (Dev)
- nunomaduro/collision: ^6.0
- nunomaduro/larastan: ^2.0
- orchestra/testbench: ^7.0
- pestphp/pest: ^1.21
- pestphp/pest-plugin-laravel: ^1.1
- phpstan/extension-installer: ^1.1
- phpstan/phpstan-deprecation-rules: ^1.0
- phpstan/phpstan-phpunit: ^1.0
- phpunit/phpunit: ^9.5
- spatie/laravel-ray: ^1.26
This package is auto-updated.
Last update: 2023-09-03 08:32:59 UTC
README
Installation
You can install the package via Composer:
composer require ryangjchandler/filament-tools
Optionally, you can publish the views using
php artisan vendor:publish --tag="filament-tools-views"
Usage
This package will automatically register a new RyanChandler\FilamentTools\Tools
page in your Filament panel.
Registering a new tool
You can register a new tool by calling the Tools::register()
function, providing a Closure
as the only argument.
use RyanChandler\FilamentTools\Tools; use RyanChandler\FilamentTools\Tool; public function boot() { Tools::register(function (Tool $tool): Tool { return $tool->label('Clear Cache'); }); }
All tools require a label. If a label isn't provided, an instance of RyanChandler\FilamentTools\Exception\ToolsException
will be thrown.
The provided
Closure
will be executed via the container so you can type-hint any dependencies you need.
Tool forms
Each tool can contain it's own unique form. This form makes is simple to ask for input from the user and execute logic based on that input. You can provide your form's schema to the Tool::schema()
method.
Tools::register(function (Tool $tool): Tool { return $tool ->label('Clear Cache') ->schema([ TextInput::make('tag') ->nullable(), ]); });
To run some logic when the form is submitted you can use the Tool::onSubmit()
method, providing a Closure
as the only argument. This Closure
will receive an instance of RyanChandler\FilamentTools\ToolInput
. This class extends Illuminate\Support\Collection
so you are free to call any existing Collection methods.
Tools::register(function (Tool $tool): Tool { return $tool ->label('Clear Cache') ->schema([ TextInput::make('tag') ->nullable(), ]) ->onSubmit(function (ToolInput $input) { $tag = $input->get('tag'); // Do something cool here... }); });
Clearing form data on submit
By default, the state for your tool's form will be preserved between submissions.
If you would like to clear the data, you can call the ToolInput::clear()
method from inside of your submit callback.
$tool->onSubmit(function (ToolInput $input) { // Do something with input here... $input->clear(); $input->notify('Success!'); });
Rendering a custom view
You can provide a custom view to render inside of the tool by calling the Tool::view()
method.
Tools::register(function (Tool $tool): Tool { return $tool ->label('Clear Cache') ->view('tools.clear-cache'); });
Customising the column span
Each row on the tools page operates on a 12-column grid. The default width for a tool is 3 columns.
If you would like to customise the width of your tool, you can use the Tool::columnSpan()
method.
Tools::register(function (Tool $tool): Tool { return $tool ->label('Clear Cache') ->columnSpan(6); });
Authorization
By default, all users will be able to access the Tools page. If you would like to customise this behaviour and restrict access to certain users, you can use the Tools::can()
method.
public function boot() { Tools::can(function (User $user): bool { return $user->role === Role::Admin; }); }
If this callback returns false
, the navigation items will not be registered and anybody trying to access the route directly will receive a 403
response.
Testing
composer test
Changelog
Please see CHANGELOG for more information on what has changed recently.
Contributing
Please see CONTRIBUTING for details.
Security Vulnerabilities
Please review our security policy on how to report security vulnerabilities.
Credits
License
The MIT License (MIT). Please see License File for more information.