epigra / nova-settings
A Laravel Nova tool for editing custom settings using native Nova fields.
Installs: 12 739
Dependents: 0
Suggesters: 0
Security: 0
Stars: 18
Watchers: 3
Forks: 5
Open Issues: 7
Requires
- akaunting/setting: ^1.1
- epigra/core: ^11.0
This package is auto-updated.
Last update: 2021-12-05 14:18:40 UTC
README
This Laravel Nova package allows you to create custom settings in code (using Nova's native fields) and creates a UI for the users where the settings can be edited by using akaunting/setting package.
Installation
Install the package in a Laravel Nova project via Composer:
composer require epigra/nova-settings
To publish the database migration(s) configuration of akaunting/setting
php artisan vendor:publish --tag=setting php artisan vendor:publish --tag=nova-settings php artisan migrate
Register the tool with Nova in the tools()
method of the NovaServiceProvider
:
// in app/Providers/NovaServiceProvider.php public function tools() { return [ // ... new \Epigra\NovaSettings\NovaSettingsTool ]; }
Usage
Registering fields
Define the fields in your NovaServiceProvider
's boot()
function by calling NovaSettings::addSettingsFields()
.
\Epigra\NovaSettings\NovaSettingsTool::addSettingsFields([ Text::make('Some setting', 'some_setting'), Number::make('A number', 'a_number') ]); // OR // Using a callable \Epigra\NovaSettings\NovaSettingsTool::addSettingsFields(function() { return [ Text::make('Some setting', 'some_setting'), Number::make('A number', 'a_number'), ]; });
Configuration
reload_page_on_save
This feature is turned off per default. You may turn it on by changing reload_page_on_save
value from
false
to true
under config/nova-settings.php
to reload the entire page on save. Useful when updating any Nova UI related settings.
Credits
Thanks for the inspiration.
akaunting/setting
You can visit https://github.com/akaunting/setting to get more information on how to use getters/setters and facade of settings package.
optimistdigital/nova-settings
This package is inspired by optimistdigital/nova-settings