This Package enables you to Categorize your Eloquent Models. just use the trait in the model and you're good to go.
- PHP 7.2+
- Laravel 7+
composer require bvkdev/categorizable
php artisan vendor:publish --provider="BvkDev\Categorizable\CategorizableServiceProvider"
php artisan migrate
Laravel Categorizable package will be auto-discovered by Laravel. and if not: register the package in config/app.php providers array manually.
'providers' => [
...
BvkDev\Categorizable\CategorizableServiceProvider::class,
],
<?php
namespace App;
use Illuminate\Database\Eloquent\Model;
use BvkDev\Categorizable\Categorizable;
class Product extends Model
{
use Categorizable;
}
first of all we need to create some Category to work with. Laravel Categorizable package relies on another package called laravel-nestedset that is responsible for creating, updating, removing and retrieving single or nested categories. Here i demonstrate how to create categories and assign one as the other's child.. but you can always refer to package's repository for full documentation. https://github.com/lazychaser/laravel-nestedset
use App\Product;
use BvkDev\Categorizable\Category;
// first we create a bunch of categories
// create "BackEnd" category
Category::create([
'name' => 'BackEnd'
]);
// create "PHP" category
Category::create([
'name' => 'PHP'
]);
// create "FrontEnd" category
Category::create([
'name' => 'FrontEnd'
]);
// create "Test" Category (alternative way)
$test = new Category();
$test->name = 'Test';
$test->save();
// assign "PHP" as a child of "BackEnd" category
$parent = Category::findByName('BackEnd');
$child = Category::findByName('PHP');
$parent->appendNode($child);
// delete "Test" Category
$testObj = Category::findByName('Test');
$testObj->delete();
// assuming that we have these variables
$product = Product::first();
// 3 different ways of getting a category's instance
$backendCategory = Category::findById(1); // 'BackEnd'
$phpCategory = Category::findByName('PHP'); // 'PHP'
$frontendCategory = Category::find(3); // 'FrontEnd'
$product->attachCategory($phpCategory);
$product->detachCategory($phpCategory);
$product->syncCategories([
$phpCategory,
$backendCategory
]);
$product->syncCategories([]);
$product->syncCategories([
$frontendCategory
]);
// removes attached categories & adds the given categories
// single use case
$product->hasCategory($phpCategory);
// multiple use case
$product->hasCategory([
$phpCategory,
$backendCategory
]);
// return boolean
$product->categoriesList();
// return array [id => name]
$product->categoriesId();
// return array
$categoryProducts = Category::find(1)
->entries(Product::class)
->get();
// return collection
$productWithCategories = Product::with('categories')
->get();
// you have access to categories() relationship in case you need eager loading
$category = Product::first()->categories()->first();
$category->parent;
// return the category's parent if available
$category = Product::first()->categories()->first();
$category->children;
// return the category's children if any
$category = Product::first()->categories()->first();
$category->ancestors;
// return the category's ancestors if any
$category = Product::first()->categories()->first();
$category->descendants;
// return the category's descendants if any
- Behrooz Valikhani - behrooz.valikhani@gmail.com