labrodev/laravel-numberable 问题修复 & 功能扩展

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

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

labrodev/laravel-numberable

最新稳定版本:v1.0.2

Composer 安装命令:

composer require labrodev/laravel-numberable

包简介

Laravel package providing a reusable trait that automatically assigns a document number to Eloquent models upon creation.

README 文档

README

Numberable is a Laravel package that provides a reusable trait for automatically assigning a number to Eloquent models upon their creation.

By default it generates a unique document number based on the model's ID and the current year. This method can be customized in individual models that use the trait, allowing for flexible document numbering logic.

  • Base Year: Uses the current year as the prefix for the document number.
  • Prediction Number: Sets a default "prediction number" (e.g., 10000), determining the minimum length of the number portion.
  • Padding: Pads the model ID with leading zeros to match the length of the prediction number, ensuring consistent document number lengths.

For example, if the current year is 2024 and the model ID is 45 and prediction number is 10000, the generated document number would be: 202400045.

But you are free to provide your own logic of generation for specific models.

You just need to overwrite method protected function generateNumberByTraitModelHasNumber(int $modelId): string in your model.

Installation

To install the package, run the following command in your Laravel project:

composer require labrodev/numberable

Requirements

  • PHP 8.1 or higher

Configuration

After installing the package, no additional configuration is needed to start using the UUID trait in your models.

Usage

To use the ModelHasNumber trait, simply include it in your Eloquent model:

<?php

namespace App\Models;

use Illuminate\Database\Eloquent\Model;
use Labrodev\Numberable\ModelHasNumber;

class ExampleModel extends Model
{
    use ModelHasNumber;
}

Ensure that your model has 'number' column in model database table.

If it is not, you may add it through Laravel migration:

$table->string('number');

Override number column name

If the column in your database table designated for document number storage has a name different from the default, you can customize the trait to accommodate this.

Simply override the trait method in your model by adding the following method with your specific column name:

/**
* @return string
*/
protected function modelHasNumberTraitColumn(): string
{
    return 'your-number-column-name';
}

Overwrite logic of number generation

You may overwrite logic of number generation by customize logic in overwritten method in your model:

/**
* @return string
*/
protected function generateNumberByTraitModelHasNumber(int $modelId): string
{
    // your own logic to generate a number 
}

If you want to keep basic logic by generating number based on current year + prediction number + model ID, but there is a necessity to adjust prediction number value, you may add method to your model:

protected function predictionNumberForTraitModelHasNumber(): int 
{
   return 10000; // your prediction number
}

Testing

To run the tests included with the package, execute the following command:

composer test

For static analysis to check the package code, execute the followin command:

composer analyse

Security

If you discover any security-related issues, please email admin@labrodev.com instead of using the issue tracker.

Credits

Labro Dev

License

The MIT License (MIT). Please see License File for more information.

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2024-11-10

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固