creode / laravel-taxonomy
Base module for handling taxonomy within Laravel.
Requires
- php: ^8.1
- illuminate/contracts: ^10.0 | ^11.0
- spatie/laravel-package-tools: ^1.14.0
Requires (Dev)
- laravel/pint: ^1.0
- nunomaduro/collision: ^7.8 | ^8.1
- nunomaduro/larastan: ^2.0.1
- orchestra/testbench: ^8.8
- pestphp/pest: ^2.20
- pestphp/pest-plugin-arch: ^2.0
- pestphp/pest-plugin-laravel: ^2.0
- phpstan/extension-installer: ^1.1
- phpstan/phpstan-deprecation-rules: ^1.0
- phpstan/phpstan-phpunit: ^1.0
This package is auto-updated.
Last update: 2024-10-24 14:38:43 UTC
README
This module is designed to allow other modules to add taxonomy to their models. It provides a base class for terms and a trait for parentable models.
Installation
You can install the package via composer:
composer require creode/laravel-taxonomy
Usage
Covered in this section are details about some of the features of this module and how to use them.
Term class
A term class corresponds to a single term in a taxonomy. It is a model that can be used to store additional information about a term.
This module aims to allow you to easily create new Term models by extending the base Term class. This allows you to add additional functionality to your terms. You can see an example below on how this can be done.
use Creode\LaravelTaxonomy\Models\Term; class Folder extends Term { /** * Machine name of the specific term to use. * * @var string */ protected $machine_name = 'folders'; }
Dynamic Relationships
The goal of this module to allow other modules to add dynamic relationships to child classes. For example, you might want to link the above Folder
model to a Page
model. This can be done by extending the TermsServiceProvider
and adding the following properties.
class FolderPageServiceProvider extends TermsServiceProvider { protected $termClass = Folder::class; protected $relationClass = Page::class; protected $relationFieldId = 'folder_id'; // optional (only used if multiple is false). protected $relationshipName = 'folder'; protected $multiple = false; // optional (defaults to false). }
Adding a relationship in this way allows a decoupling of dependencies between modules. This means that the Page
module does not need to know about the Folder
module in order to add a relationship between the two.
Parentable Trait
The parentable trait allows you to add a parent relationship to a term. This is useful for creating a hierarchy of terms. For example, you might want to create a folder structure for your terms.
use Creode\LaravelTaxonomy\Concerns\Parentable; class Folder extends Term { use Parentable; }
Migration Helper
Since this module is designed to be used by other modules, it comes with an optional helper class that can be used to create common Term
fields. This helper class can be used in a migration file like so:
Schema::create('folders', function (Blueprint $table) { $table->id(); $table->baseTermFields(); });
This just adds the following fields to your table. You can also add these fields manually if you prefer:
$this->string('name')->nullable(); $this->string('slug')->nullable(); $this->unsignedBigInteger('parent_id')->nullable();
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.