amdadulhaq/unique-slug-laravel
最新稳定版本:v2.0.1
Composer 安装命令:
composer require amdadulhaq/unique-slug-laravel
包简介
Unique slug generator for Laravel
README 文档
README
A powerful and flexible unique slug generator package for Laravel with advanced features.
Installation
You can install the package via composer:
composer require amdadulhaq/unique-slug-laravel
Publish the configuration file:
php artisan vendor:publish --tag=unique-slug-config
Usage
Basic Usage
namespace App\Models; use AmdadulHaq\UniqueSlug\HasSlug; use Illuminate\Database\Eloquent\Model; class Article extends Model { use HasSlug; protected $fillable = ['name', 'slug']; }
Article::create(['name' => 'Hello World']); // Generates slug: hello-world Article::create(['name' => 'Hello World']); // Generates slug: hello-world-1
Configuration Options
Custom Source and Slug Fields
class Article extends Model { use HasSlug; public function getSlugSourceAttribute(): string { return 'title'; // Generate slug from title field } public function getSlugNameAttribute(): string { return 'slug'; // Store slug in slug field } public function getSlugSeparator(): string { return '_'; // Use underscore separator } }
Using Configuration File
// config/slug.php return [ 'update_on_update' => env('SLUG_UPDATE_ON_UPDATE', false), 'case' => env('SLUG_CASE', 'lower'), 'max_length' => env('SLUG_MAX_LENGTH', 255), 'reserved_slugs' => ['admin', 'dashboard', 'api'], 'suffix_separator' => env('SLUG_SUFFIX_SEPARATOR', '-'), 'skip_on_empty' => env('SLUG_SKIP_ON_EMPTY', false), 'include_soft_deleted' => env('SLUG_INCLUDE_SOFT_DELETED', false), ];
Advanced Features
Custom Slug Generation
class Article extends Model { use HasSlug; protected function generateCustomSlug(string $source): string { return 'article-'.strtolower($source); } }
Conditional Slug Generation
class Article extends Model { use HasSlug; public function shouldSkipSlug(): bool { return $this->published === false; } }
Case Transformation
Available cases: lower, upper, title, camel, snake
config(['slug.case' => 'upper']); Article::create(['name' => 'Hello World']); // Generates slug: HELLO-WORLD
Maximum Length
config(['slug.max_length' => 50]); Article::create(['name' => 'Very Long Title That Should Be Truncated']); // Truncates slug to 50 characters
Reserved Slugs
config(['slug.reserved_slugs' => ['admin', 'dashboard']]); Article::create(['name' => 'admin']); // Generates slug: admin-1
Query Scopes
Article::whereSlug('hello-world')->first(); Article::orWhereSlug('another-slug')->get(); Article::whereSlugLike('hello')->get();
Soft Delete Support
class Article extends Model { use HasSlug; use \Illuminate\Database\Eloquent\SoftDeletes; } // Include soft deleted records in uniqueness check config(['slug.include_soft_deleted' => true]);
Environment Variables
SLUG_UPDATE_ON_UPDATE=false SLUG_CASE=lower SLUG_MAX_LENGTH=255 SLUG_RESERVED_SLUGS=admin,dashboard,api SLUG_SUFFIX_SEPARATOR=- SLUG_SKIP_ON_EMPTY=false SLUG_INCLUDE_SOFT_DELETED=false
Testing
composer test
Changelog
Please see CHANGELOG for more information on what has changed recently.
Contributing
Please see CONTRIBUTING for details.
Security Vulnerabilities
Please review our security policy on how to report security vulnerabilities.
Credits
License
The MIT License (MIT). Please see License File for more information.
统计信息
- 总下载量: 512
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 1
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2024-10-19