inewtonua / laravel-settings
Laravel localized settings storage
v0.1
2020-08-13 01:43 UTC
Requires
- php: ^7.3
Requires (Dev)
- orchestra/testbench: ^6.0@dev
This package is auto-updated.
Last update: 2025-04-17 08:54:10 UTC
README
- Simple key-value storage
- Support multi-level array (dot delimited keys) structure.
- Localization supported.
Installation
-
Install package
composer require ineatonua/laravel-settings
-
Edit config/app.php (Skip this step if you are using laravel 5.5+)
service provider:
Ineatonua\Setting\SettingServiceProvider::class,
class aliases:
'Setting' => Ineatonua\Setting\SettingFacade::class,
-
Create settings table
php artisan vendor:publish --tag=laravel-settings-migrations php artisan migrate
-
Publish configs
php artisan vendor:publish --tag=laravel-settings-config
Usage
Setting::get('name', 'Computer'); // get setting value with key 'name' // return 'Computer' if the key does not exists Setting::all(); // get all settings Setting::lang('zh-TW')->get('name', 'Computer'); // get setting value with key and language Setting::set('name', 'Computer'); // set setting value by key Setting::lang('zh-TW')->set('name', 'Computer'); // set setting value by key and language Setting::has('name'); // check the key exists, return boolean Setting::lang('zh-TW')->has('name'); // check the key exists by language, return boolean Setting::forget('name'); // delete the setting by key Setting::lang('zh-TW')->forget('name'); // delete the setting by key and language
Dealing with array
Setting::get('item'); // return null; Setting::set('item', ['USB' => '8G', 'RAM' => '4G']); Setting::get('item'); // return array( // 'USB' => '8G', // 'RAM' => '4G', // ); Setting::get('item.USB'); // return '8G';
Dealing with locale
By default language parameter are being resets every set or get calls. You could disable that and set your own long term language parameter forever using any route service provider or other method.
Setting::lang(App::getLocale())->langResetting(false);