ifranksmith / laravel-sluggable
Laravel slug maker trait
Installs: 315
Dependents: 0
Suggesters: 0
Security: 0
Stars: 2
Watchers: 1
Forks: 0
pkg:composer/ifranksmith/laravel-sluggable
This package is auto-updated.
Last update: 2025-10-21 19:59:20 UTC
README
Allows Laravel Eloquent models to implement a 'sluggable' feature.
Index
Installation
- Install the package via Composer
$ composer require ifranksmith/laravel-sluggable
- In Laravel >=5.5 this package will automatically get registered. For older versions, update your config/app.phpby adding an entry for the service provider.
'providers' => [ // ... IFrankSmith\Sluggable\SluggableServiceProvider ];
Usage
Your models should import the Traits/Sluggable.php trait and use it.
(see an example below):
use IFrankSmith\Sluggable\Traits\Sluggable; class Posts extends Model { use Sluggable; }
By default, this package will generate slug from the 'name' property of the mmodel and save it to the 'slug' property of the model.
However, if your model does not use those properties, you need to create a method on your model that returns the respective column and source. For example, if you want to make slug from 'title' to 'title_slug' property, you need to use it as shown below
use IFrankSmith\Sluggable\Traits\Sluggable; class Posts extends Model { use Sluggable; public function sluggable() { return [ "column" => "title_slug", "source" => "title", ]; } }
That's it ... your model is now "sluggable"!