Package Data | |
---|---|
Maintainer Username: | shamilchoudhury |
Maintainer Contact: | shamilchoudhury94@gmail.com (Shamil Choudhury) |
Package Create Date: | 2017-05-24 |
Package Last Update: | 2017-05-24 |
Language: | PHP |
License: | Unknown |
Last Refreshed: | 2025-05-11 03:04:13 |
Package Statistics | |
---|---|
Total Downloads: | 22 |
Monthly Downloads: | 0 |
Daily Downloads: | 0 |
Total Stars: | 2 |
Total Watchers: | 1 |
Total Forks: | 1 |
Total Open Issues: | 0 |
A tagging package for Laravel Eloquent models.
This package requires Laravel 5.3 or higher and PHP 7.0 or higher.
Install the shamilchoudhury/eloquent-tags
package via composer:
$ composer require shamilchoudhury/eloquent-tags
Add the service provider to providers
array in config/app.php
:
'providers' => [
...
\Shamil\Tags\Providers\TagsServiceProvider::class,
],
Use artisan to run the migration to create the required tags tables.
php artisan migrate
To make a model taggable, use the Taggable trait:
use Shamil\Tags\Taggable;
class Lesson extends Model
{
use Taggable;
}
Done. Now your model is "taggable"!
Tag your models with the tag()
method:
// Pass in an array
$lesson->tag(['snow', 'linen']);
// or you can pass in a model
$lesson->tag(\Shamil\Tags\Models\Tag::where('name', 'snow')->first());
// or a collection
$lesson->tag(\Shamil\Tags\Models\Tag::whereIn('name', ['snow', 'linen'])->get());
The tag()
method is additive, so you can easily add new tags to the existing ones:
$lesson->tag(['linen']); // lesson has one tag 'linen'
$lesson->tag(['snow', 'linen']); // lesson now has two tags: 'linen' and 'snow'
$lesson->tag(['navy']); // lesson has three tags
Tag names are normalized to avoid duplicate tags:
$lesson->tag(['snow', 'SNOW', 'sNoW']); // lesson will be tagged with 'snow' only once
You can easily grab tags associated with a model using their relationship:
$lesson = Lesson::find(1);
foreach($lesson->tags as $tag) {
echo $tag->name . ' ' ;
// or do other stuff
}
Since this is a direct relationship, you can easily order tags by their count:
$lesson = Lesson::find(1);
foreach($lesson->tags()->orderBy('count', 'desc')->get() as $tag) {
echo $tag->name . ' ' ; // this will echo tags in decreasing order of their count
}
Convert all tags associated with a model to an array:
$lesson = Lesson::find(1);
echo implode(' • ', $lesson->tags->pluck('name')->toArray()); // Seperate tags by bullet points
You can grab a model with specific tags using query scopes:
// withAnyTag()
$lesson = Lesson::withAnyTag(['linen', 'snow', 'navy']);
dd($lesson->get()); // take any lesson that is tagged with any of the provided tags
//withAllTags()
$lesson = Lesson::withAllTags(['yellowgreen', 'navy']);
dd($lesson->get()); // only take lessons that are tagged with all of the provided tags
//withoutTags()
$lesson = Lesson::withoutTags(['snow', 'linen']);
dd($lesson->get()); // only take lessons that are not tagged with all of the provided tags
You can delete all current tags and add new tags with retag()
:
$lesson = Lesson::find(1);
$lesson->retag(['darkorange']);
// all existing tags are removed and model is tagged with the tags provided
// in other words, model is first detagged and then tagged with the new tags
You can remove tags with untag()
:
$lesson->tag(['lightcoral', 'yellowgreen', 'navy']);
$lesson->untag(['lightcoral']);
// $lesson is now tagged with "yellowgreen" and "navy"
Simply use untag()
to remove all tags:
$lesson = Lesson::find(1);
$lesson->untag(); // all tags are removed
dd($lesson->tags); // $lesson now has an empty collection of tags
You can grab tags based on their count using the orderable scopes:
$tags = \Shamil\Tags\Models\Tag::usedGte(2); // tags with count greater than or equal to 2
dd($tags->get()); // all tags that have been used twice or more
// Similarly you can use other scopes
$tags = \Shamil\Tags\Models\Tag::usedGt(2); // tags with count greater than 2
$tags = \Shamil\Tags\Models\Tag::usedLte(2); // tags with count less than or equal to 2
$tags = \Shamil\Tags\Models\Tag::usedLt(2); // tags with count less than 2
Eloquent-tags is open-sourced software licensed under the MIT license.