承接 secretwebmaster/laravel-optionable 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

secretwebmaster/laravel-optionable

最新稳定版本:v2.1.1

Composer 安装命令:

composer require secretwebmaster/laravel-optionable

包简介

Allow any Eloquent model to have own options such as user options, page options, etc.

README 文档

README

Laravel Optionable adds flexible, structured option storage to any Eloquent model. Options are stored in a dedicated table with support for:

  • scope (e.g. theme, template, seo)
  • group (e.g. section or nested context)
  • repeatable items with sort
  • nested JSON option values
  • fallbacks
  • translation support (via HasTranslations)

This package powers advanced option systems such as WNCMS theme options, page template options, and model metadata.

v2.1 is the Laravel 13 support line and targets:

  • PHP 8.4+
  • Laravel / Illuminate 13.x
  • Orchestra Testbench 11.x for package testing

Installation

composer require secretwebmaster/laravel-optionable
php artisan migrate

The package depends on secretwebmaster/wncms-translatable because option values use its translation trait internally.

Usage

Add HasOptions to any Eloquent model:

use Illuminate\Database\Eloquent\Model;
use Secretwebmaster\LaravelOptionable\Traits\HasOptions;

class Page extends Model
{
    use HasOptions;
}

You may now store unlimited structured options on this model.

Getting Options

Get all rows (optional scope/group)

$rows = $page->getOptions();
$rows = $page->getOptions('theme');
$rows = $page->getOptions('theme', 'header');

Returns a sorted Collection of Option rows.

Get a single option value

$value = $page->getOption('title', 'theme');

Or with group:

$value = $page->getOption('button_text', 'theme', 'hero');

Fallback support:

$value = $page->getOption('color', 'theme', 'footer', 'default-color');

Allow null values:

$page->getOption('logo', 'theme', null, null, false);

Setting Options

Set a single option

$page->setOption('title', 'Hello World', 'theme');

With group and sort:

$page->setOption('image', '/a.jpg', 'theme', 'gallery', 0);
$page->setOption('image', '/b.jpg', 'theme', 'gallery', 1);

Set multiple options for a scope/group

$page->setOptions('theme', 'hero', [
    ['key' => 'title', 'value' => 'Welcome'],
    ['key' => 'subtitle', 'value' => 'Enjoy'],
    ['key' => 'button_text', 'value' => 'Click'],
]);

This clears existing options under that scope/group first.

Deleting Options

Delete a single option

$page->deleteOption('title', 'theme');

With group and sort:

$page->deleteOption('image', 'theme', 'gallery', 1);

Clear all options under a scope/group

$page->clearOptions('theme', 'hero');

Table Schema (v2)

The migration creates:

Column Type Description
id bigint primary key
scope string nullable Option namespace (e.g. theme/template/seo)
group string nullable Optional subgroup
key string Option key
sort integer nullable Repeatable index
value text/json Value (translated or raw)
is_translatable boolean Whether value uses HasTranslations
optionable_type string Morph type
optionable_id bigint Morph id
timestamps

Indexes:

  • scope + group + key + sort + optionable_type + optionable_id
  • polymorphic indexes

Legacy Support (v1)

Snake_case method names continue to work for all methods that still exist in v2, thanks to the __call() snake_case fallback.

Supported snake_case aliases:

  • get_option()
  • set_option()
  • get_options()
  • set_options()
  • delete_option()
  • clear_options()

The following v1 methods have been removed and no longer exist:

  • deleteOptions()
  • deleteAllOptions() Therefore their snake_case forms (delete_options(), delete_all_options()) are not available.

统计信息

  • 总下载量: 155
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 4
  • 依赖项目数: 1
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2024-04-27

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固