italofantone / sluggable
Is a PHP library designed to simplify and automate the creation of URL-friendly slugs based on Laravel.
Requires
- php: ^8.1
- illuminate/database: ^10.0|^11.0|^12.0
- illuminate/support: ^10.0|^11.0|^12.0
Requires (Dev)
- orchestra/testbench: ^9.2
- phpunit/phpunit: ^11.3
README
Is a PHP library designed to simplify and automate the creation of URL-friendly slugs based on Laravel.
⚠️ This code was used for educational purposes [...]
Installation
You can install the sluggable package via composer. Run the following command:
composer require italofantone/sluggable
Usage
- Add the trait to your model:
To use the Sluggable functionality, include the Sluggable trait in your Eloquent model. Here's an example:
<?php
namespace App\Models;
use Italofantone\Sluggable\Sluggable;
use Illuminate\Database\Eloquent\Model;
class Lesson extends Model
{
use Sluggable;
protected $fillable = ['title', 'body'];
}
Migration example: You need to create the slug field.
<?php
use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;
return new class extends Migration
{
/**
* Run the migrations.
*/
public function up(): void
{
Schema::create('lessons', function (Blueprint $table) {
$table->id();
$table->string('title');
$table->string('slug')->unique();
$table->text('body');
$table->timestamps();
});
}
/**
* Reverse the migrations.
*/
public function down(): void
{
Schema::dropIfExists('lessons');
}
};
- Customize the separator: Run the following command.
php artisan vendor:publish --tag=sluggable-config
You can customize the slug separator in the config/sluggable.php
file. For example:
<?php
return [
/**
* The field that will be used to generate the slug.
* e.g. 'my title' will be converted to 'my-title'.
*
* Default: '-'.
*/
'separator' => '-',
];
This will change the default separator used in generated slugs.
- Customizing the slug source field:
You can customize which attribute is used to generate the slug by setting the protected $slugSourceField
property in your model.
Example:
To use the name attribute instead of the default attribute (like title), do the following:
<?php
namespace App\Models;
use Italofantone\Sluggable\Sluggable;
use Illuminate\Database\Eloquent\Model;
class Lesson extends Model
{
use Sluggable;
protected $fillable = ['name', 'body'];
protected $slugSourceField = 'name';
}
With this configuration, the slug will be generated based on the name
attribute.
Contact
- Email: i@rimorsoft.com
- Twitter: @italofantone
- LinkedIn: italofantone
Donations
If you find this project useful and would like to support its development, you can make a donation via PayPal:
- PayPal: Donate via PayPal
Thank you for your support!