larasup/reference 问题修复 & 功能扩展

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

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

larasup/reference

最新稳定版本:v1.0.0

Composer 安装命令:

composer require larasup/reference

包简介

Hierarchical reference books (dictionaries) for Laravel

README 文档

README

Hierarchical reference books (dictionaries) for Laravel. Store key-value dictionaries with tree structure support.

Installation

composer require larasup/reference

The package uses Laravel auto-discovery, so the service provider will be registered automatically.

Publish the config (optional):

php artisan vendor:publish --tag=reference-config

Run migrations:

php artisan migrate

Configuration

// config/reference.php
return [
    'table_prefix' => 'reference_', // customize table names prefix
];

This will create reference_books and reference_items tables. Change the prefix to use different table names.

Usage

Via Facade

use Larasup\Reference\Facades\Reference;

// Create a book
$book = Reference::createBook('countries');

// Get or create (idempotent)
$book = Reference::getOrCreateBook('countries');

// Get by entity key
$book = Reference::getBook('countries');

// Add items
Reference::createItem($book, 'ru', ['name' => 'Russia', 'code' => 'RU']);
Reference::createItem($book, 'us', ['name' => 'United States', 'code' => 'US']);

// Hierarchical items
$europe = Reference::createItem($book, 'europe', ['name' => 'Europe'], sort: 1);
Reference::createItem($book, 'fr', ['name' => 'France'], parentId: $europe->id, sort: 1);
Reference::createItem($book, 'de', ['name' => 'Germany'], parentId: $europe->id, sort: 2);

// Get tree structure
$tree = Reference::getTree('countries');
// Returns root items with nested `children` relation loaded

Via Service (DI)

use Larasup\Reference\Services\ReferenceService;

class MyController
{
    public function __construct(
        private readonly ReferenceService $reference,
    ) {}

    public function index()
    {
        $tree = $this->reference->getTree('countries');
    }
}

API

ReferenceService

MethodDescription
createBook(string $entity): BookCreate a new book. Throws if already exists.
getBook(string $entity): ?BookGet book by entity key. Returns null if not found.
getOrCreateBook(string $entity): BookGet existing or create new book.
createItem(Book\|int $book, string $uid, array $properties = [], ?int $parentId = null, ?int $sort = null): ItemCreate an item in a book. Validates book existence, uid uniqueness, and parent ownership.
getTree(Book\|int\|string $book): CollectionGet all items as a tree. Accepts Book model, id, or entity string.

Models

Book — a named dictionary (entity is the unique key).

Item — an entry in a book with:

  • uid — unique identifier within the book
  • properties — JSON key-value data
  • parent_id — optional parent for tree structures
  • sort — optional ordering
  • status — integer status flag (default: 1)

Validation

The service validates:

  • Book entity uniqueness on creation
  • Book existence when creating items by id
  • Item uid uniqueness within the same book
  • Parent item existence and ownership (must belong to the same book)

All validation errors throw Larasup\Reference\Exceptions\ReferenceException.

License

MIT

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-04-09

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固