64 lines
1.3 KiB
PHP
64 lines
1.3 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace App\Models;
|
|
|
|
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
|
use Illuminate\Database\Eloquent\Model;
|
|
use Illuminate\Database\Eloquent\Relations\BelongsToMany;
|
|
use Illuminate\Support\Str;
|
|
|
|
class Tag extends Model
|
|
{
|
|
use HasFactory;
|
|
|
|
/**
|
|
* We shall set a blacklist of non-modifiable model attributes.
|
|
*
|
|
* @var array
|
|
*/
|
|
protected $guarded = ['id'];
|
|
|
|
/**
|
|
* Define the relationship with notes.
|
|
*
|
|
* @return BelongsToMany
|
|
*/
|
|
public function notes()
|
|
{
|
|
return $this->belongsToMany(Note::class);
|
|
}
|
|
|
|
/**
|
|
* The bookmarks that belong to the tag.
|
|
*
|
|
* @return BelongsToMany
|
|
*/
|
|
public function bookmarks()
|
|
{
|
|
return $this->belongsToMany('App\Models\Bookmark');
|
|
}
|
|
|
|
/**
|
|
* When creating a Tag model instance, invoke the nomralize method on the tag.
|
|
*
|
|
* @param string $value
|
|
*/
|
|
public function setTagAttribute(string $value)
|
|
{
|
|
$this->attributes['tag'] = $this->normalize($value);
|
|
}
|
|
|
|
/**
|
|
* This method actually normalizes a tag. That means lowercase-ing and
|
|
* removing fancy diatric characters.
|
|
*
|
|
* @param string $tag
|
|
* @return string
|
|
*/
|
|
public static function normalize(string $tag): string
|
|
{
|
|
return Str::slug($tag);
|
|
}
|
|
}
|