rolfhaug/laravel-model-settings 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

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

rolfhaug/laravel-model-settings

最新稳定版本:v0.0.2

Composer 安装命令:

composer require rolfhaug/laravel-model-settings

包简介

A package that gives you a fluent api to add key/value settings to any Eloquent model

README 文档

README

This package allows you to easily extend any Laravel Model, with a Settings Model. Perfect for configuration settings and personal preferences.

You can then easily set and retrieve key/value pairs through an elegant API. If the setting does not exist, NULL will be returned.

$user = User::find(1);

$user->settings->set('my_setting', 'my_value');

echo $user->settings->my_setting; // my_value

Installation

composer require rolfhaug/laravel-model-settings

If you're using an older version than Laravel 5.6, add this to your providers in config/app.php.

RolfHaug\ModelSettings\ModelSettingsProvider::class,

Create a new Settings model

  1. Use the command to create a new settings model

art make:model-settings --model=user

  1. Add the Settings trait to your model

use RolfHaug\ModelSettings\Settings;

Tip: The command creates a migration that can be rolled back.

How to use the package

$user = User:find(1);

Set settings

// Single setting
$user->settings->set('newsletter', true);

// Array of settings
$settings = [
	['awesome_setting' => 'awesome_value'],
	['another_setting' => 'another_value']
];

$user->settings->set($settings);

Access settings

If the setting does not exist, NULL will be returned.

$user->settings->newsletter;

// Array of all available settings
$user->settings->all();

Destroy setting

$user->settings->delete('newsletter');

Scopes

$users = User::whereSetting('newsletter', true)->get();

$users = User::whereHasSetting('newsletter')->get();

$users = User::whereDoesntHaveSetting('newsletter')->get();

统计信息

  • 总下载量: 2.46k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 5
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 5
  • Watchers: 1
  • Forks: 2
  • 开发语言: PHP

其他信息

  • 授权协议: mit
  • 更新时间: 2018-08-09