parfumix / nova-settings-tool
A Laravel Nova tool to manage application settings.
Requires
- php: >=7.1.0
- laravel/nova: *
- spatie/valuestore: ^1.2
Requires (Dev)
- orchestra/testbench: ^4.0
- phpunit/phpunit: ^8.3
README
Store and edit simple app-wide settings right in Nova. Settings are stored as JSON using spatie/valuestore
, making them really easy to pull in and use everywhere else in your app.
Installation
Install the package via Composer in any Laravel app using Nova:
composer require parfumix/nova-settings-tool
Publish the default configuration file to config/nova-settings-tool.php
:
php artisan vendor:publish --tag="nova-settings-tool"
Register the tool with Nova in the tools
method of your NovaServiceProvider
:
// in app/Providers/NovaServiceProvider.php use Parfumix\NovaSettingsTool\SettingsTool; // ... public function tools() { return [ new SettingsTool, ]; }
Usage
Settings are declared in a nova-settings-tool.php
config file. This file specifies where settings are stored, what the tool’s title is in Nova’s sidebar, the layout of the settings page, and metadata about the settings themselves.
A default config file with some helpful examples is included as a starting point:
Each item in the settings
array is rendered as an input with a label and help text, similar to one of Nova’s fields. Settings can also be grouped into panels, to separate them visually.
The settings’ actual values are stored as JSON at the location specified in the config file—storage/app/settings.json
by default.
There are currently six available setting types:
text
: Single-line text inputtextarea
: Multi-line text inputtoggle
: Boolean switchcode
: CodeMirror text editornumber
: Number inputselect
: Single-select dropdown
All strings in this package, and any you pass to it, can easily be translated using Laravel’s built-in localization features.
Roadmap
The following features are planned or in development:
color
setting typedate
setting typefile
setting type- setting validation