creode/laravel-taxonomy

Base module for handling taxonomy within Laravel.

1.4.0 2024-10-24 14:38 UTC

README

Latest Version on Packagist GitHub Tests Action Status GitHub Code Style Action Status Total Downloads

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.