Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/code-axion/nestifyx
A Laravel Package for Effortless Drag-and-drop categories/subcategories reordering and sets of recursive methods to play with nested structures
https://github.com/code-axion/nestifyx
alpinejs drag-and-drop javascript jquery jstree laravel laravel-framework laravel-package package php plugin recursion reordering tailwindcss ui
Last synced: about 1 month ago
JSON representation
A Laravel Package for Effortless Drag-and-drop categories/subcategories reordering and sets of recursive methods to play with nested structures
- Host: GitHub
- URL: https://github.com/code-axion/nestifyx
- Owner: CODE-AXION
- License: mit
- Created: 2024-02-14T15:50:39.000Z (12 months ago)
- Default Branch: main
- Last Pushed: 2024-02-25T17:41:04.000Z (11 months ago)
- Last Synced: 2024-04-26T00:25:25.655Z (9 months ago)
- Topics: alpinejs, drag-and-drop, javascript, jquery, jstree, laravel, laravel-framework, laravel-package, package, php, plugin, recursion, reordering, tailwindcss, ui
- Language: PHP
- Homepage: https://youtu.be/XwGvh_4aXvA
- Size: 51.8 KB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE.md
Awesome Lists containing this project
README
# NestifyX Laravel Package
## OverviewThe NestifyX Laravel package provides features for managing categories and manipulate nested elements within your application using recursive methods.
> Organize Your Categories with Ease.
## Features
1. **Category Tree Management:** This Module includes Category Management with the Ability of changing its position using drag and drop feature, you just have to include a button component and that's it .
2. **Recursion Methods:** This Module includes various methods to play with recursions, like generating tree, fetch Children/Parent ids, generate breadcrumbs, show tree view in dropdown etc...3. **Performance:** Will do all your work in a single query.
#### Required Dependencies To Run Js Tree pop up
>AlpineJs, Jquery, Jstree## Installation
To utilize the NestifyX package in your application, follow these steps:1. **Installation**: Install the NestifyX package via Composer:
```bash
composer require codeaxion/nestifyx
```2. Add Your Required Dependencies via CDN (without these dependencies jstree wont work)
```js
//only optional if you have already have alpine js and tailwindcss package installed
//jquery in header
//jstree scripts and css (add styles in header and scripts in body)
```
3. Run necessary Migration
> Will add position column in your categories table for ordering
```php
php artisan migrate;
```4. Integration: Include the Nestify Facade
```php
use CodeAxion\NestifyX\Facades\NestifyX;
```
Thats's it Your setup is over## Optional
5. (Optional) Publish config file if you have different table name
```
php artisan vendor:publish --provider="CodeAxion\NestifyX\NestifyXServiceProvider" --tag="config"```
6. (Optional) Publish migration if you want
```
php artisan vendor:publish --provider="CodeAxion\NestifyX\NestifyXServiceProvider" --tag="migrations"```
## Usage
### Add Category Module Slider
> After adding this blade component click on the button named category tree to open category module slider
```html
```#### Convert Normal Eloquent Collection/Array To Nested Tree
```php
use CodeAxion\NestifyX\Facades\NestifyX;$categories = Category::orderByRaw('-position DESC')->get();
$categories = NestifyX::nestTree($categories);
```#### Sort Children without converting it to tree
```php
use CodeAxion\NestifyX\Facades\NestifyX;$categories = Category::orderByRaw('-position DESC')->get(); //Sort by children with it's position (RECOMMENDED after sorting is done by jstree)
//OR
$categories = Category::get() //Sort by only children;//will return original database collection
$categories = NestifyX::setIndent('|--')->sortChildren($categories); //fetch all categories and subcategories
//OR
$categories = NestifyX::setIndent('|--')->sortChildren($categories,5) //Pass different category id if you want their children of (refer to 2nd example)// In view
@foreach($categories as $category)
{{$category->indent}} {{$category->name}}
@endforeach//Will result
/**
Electronics
|-- Mobiles
|-- |-- All Mobiles
|-- Headphones
|-- |-- All Headphones
|-- Gaming
|-- |-- Gaming Laptops
|-- |-- Business Laptops
|-- Laptops
|-- |-- All Laptops
|-- |-- Apple Laptops
|-- |-- Microsoft Laptops
*/
```#### Flatten Children (- useful for dropdowns)
```php
use CodeAxion\NestifyX\Facades\NestifyX;$categories = \App\Models\Category::orderByRaw('-position DESC')->get();
//fetch all categories and subcategories (CASE 1)
$categories = NestifyX::setIndent('|--')->listsFlattened($categories);//OR
//pass different category id if you want their children of (CASE 2)
$categories = NestifyX::setIndent('|--')->listsFlattened($categories,5);
//OR
////if your column name is different (default will be name)
$categories = NestifyX::setIndent('|--')->setColumn('title')->listsFlattened($categories);dd($categories);
//Result (CASE 1):
/**
#items: array:7 [▼
4 => "Electronics"
5 => "|--Laptops"
9 => "|--|--All Laptops"
7 => "|--Mobiles"
10 => "|--|--All Mobiles"
8 => "|--Headphones"
11 => "|--|--All Headphones"
]
*///Result (CASE 2):
/**
#items: array:7 [▼
5 => "Laptops"
9 => "|-- All Laptops"
]
*/```
```html
@foreach ($categories as $id => $name)
{{$name}}
@endforeach
```#### Generate breadcrumbs for all categories
```php
$categories = \App\Models\Category::orderByRaw('-position DESC')->get();
$categories = NestifyX::setIndent(' \ ')->generateBreadCrumbs($categories);//will return flattened Result:
array:7 [▼ // routes\web.php:27
4 => "Electronics"
5 => "Electronics \ Laptops"
9 => "Electronics \ Laptops \ All Laptops"
7 => "Electronics \ Mobiles"
10 => "Electronics \ Mobiles \ All Mobiles"
8 => "Electronics \ Headphones"
11 => "Electronics \ Headphones \ All Headphones"
]
```#### Generate current breadcrumbs
```php$categories = Category::get();
$categories = NestifyX::generateCurrentBreadCrumbs($categories,5); //2nd param: child id
array:2 [▼
4 => array:2 [▼
"name" => "Electronics"
"category" => array:8 [▼
"id" => 4
"name" => "Electronics"
"parent_id" => null
"created_at" => "2024-02-18T13:37:52.000000Z"
"updated_at" => "2024-02-22T16:40:00.000000Z"
]
]
5 => array:2 [▼
"name" => "Laptops"
"category" => array:8 [▼
"id" => 5
"name" => "Laptops"
"parent_id" => 4
"created_at" => "2024-02-18T13:43:26.000000Z"
"updated_at" => "2024-02-22T16:40:00.000000Z"
]
]
]
``````html
//in view
```#### Get all parent ids of a child category
```php$categories = Category::get();
$categories = NestifyX::collectParentIds($categories,11);```
#### Get all child ids of a parent category
```php$categories = Category::get();
$categories = NestifyX::collectChildIds($categories,4);
```
### Upcoming Feature
> - Add Nestable2 plugin feature in Categories
> - Remove Alpine js dependency
> - Add support for bootstrap
New features suggestions are always welcome### Changelog
Please see [CHANGELOG](CHANGELOG.md) for more information what has changed recently.
## Contributing
Please see [CONTRIBUTING](CONTRIBUTING.md) for details.
## Credits
- [Code Axion](https://github.com/code-axion)
## License
The MIT License (MIT). Please see [License File](LICENSE.md) for more information.