remzikocak / laravel-options
Database Options/Settings Package for Laravel 9/10/11.
Installs: 3 068
Dependents: 0
Suggesters: 0
Security: 0
Stars: 7
Watchers: 3
Forks: 1
Open Issues: 0
Requires
- php: ^8.1
- ext-json: *
- illuminate/database: ^9.0|^10.0|^11.0
- illuminate/support: ^9.0|^10.0|^11.0
Requires (Dev)
- orchestra/testbench: ^7.0|^8.0
- phpunit/phpunit: ^9.0
README
Laravel Options Package
This Package will help you to dynamically add Option fields to your Backend Panel.
Installation
You can install the package via composer:
composer require remzikocak/laravel-options
The Package will automatically register the Service Provider and Facade. Afterwards, you need to publish and migrate:
php artisan vendor:publish --provider="RKocak\Options\OptionsServiceProvider"
php artisan migrate
This will create the migration files and options.php file in your config folder.
Usage
First of all, you need to create a Optiongroup and an Option.
use RKocak\Options\Models\Optiongroup; use RKocak\Options\Models\Option; Optiongroup::create([ 'label' => 'My Optiongroup', 'description' => 'Optiongroup description', // can be null 'display_order' => 1, ]); Option::create([ 'name' => 'myOption' // should be unique 'label' => 'My Option', 'description' => 'My awesome Option', 'value' => 'Option value', 'type' => 'text', ]);
Option groups and options have a many-to-many relationship. Groups can have many options, and options can belong to many groups. Understanding this relationship is essential for displaying them in your backend panel.
For assignment, use the following:
$group = Optiongroup::find(1); $option = Option::find(1); // Assign option to a group $group->options()->attach($option); // or.. $option->groups()->attach($group);
Getting options
To retrieve the computed value, use the getValue()
method from the Option Model.
$option->getValue(); // This will be the "raw" value that is stored in the database $option->value
A better and more performant option is to utilize the Options
Facade.
This will cache the options when you only require a key => value store.
You can use it as following:
Options::get('optionName'); // You can pass a second parameter as default value Options::get('optionName', null); // or use the helper function options('optionName', null);
Check if option with the given name exists
Options::has('optionName');
While the cache usually refreshes automatically, if you need to do it manually, use the following method.
Options::getLoader()->rebuildCache();
Adding custom Types
To add your custom type, you need to create a class that extends RKocak\Options\Type
Example:
<?php namespace App; use RKocak\Options\Models\Option; use RKocak\Options\Type; class MyType extends Type { /** * @return string */ public static function getName(): string { return 'my_type'; } /** * @param Option $option * @return string */ public function render(Option $option): string { return '<div> <input type="text" name="options['. htmlspecialchars($option->name) .']" id="options['. htmlspecialchars($option->name) .']" value="'. htmlspecialchars($option->getValue()) .'" class=""/> </div>'; } /** * Store the new value * * @param $newValue * @param $oldValue * @return mixed */ public function store($newValue, $oldValue) { return $newValue; } /** * Cast value * * @param $value * @return mixed|string */ public function cast($value) { return (string) $value; } }
then add the class in configuration file to the types array. After that you can use it like all other types.
Rendering HTML for Edit Form
Rendering options is straightforward with a few pre-added "Types."
$option = Option::first(); $html = $option->renderEditHTML(); // ..or $html = $option->toHtml(); // Alternatively, you can use the model instance directly in your Blade views: {{ $option }}
License
The MIT License (MIT). Please see License File for more information.