davidwesdijk / laravel-polymorphic-eav
Integrate the entity-attribute-value model with polymorphic Eloquent-relations in your Laravel application.
Installs: 1 782
Dependents: 0
Suggesters: 0
Security: 0
Stars: 5
Watchers: 1
Forks: 3
Open Issues: 2
Requires
- php: ^7.1|^8.0
- illuminate/support: ^6.0|^7.0|^8.0|^9.0
Requires (Dev)
- orchestra/testbench: ^4.0
- phpunit/phpunit: ^8.0|^9.0
README
Integrate the entity-attribute-value model with polymorphic Eloquent-relations in your Laravel application.
Installation
You can install the package via composer:
composer require davidwesdijk/laravel-polymorphic-eav
Usage
Preparing your models
In order to implement the Entity-Attribute-Value-model to your Eloquent models, the only required action is to add the
HasEntityAttributeValues
Trait. That's all action required to use the full features this package brings.
use DavidWesdijk\LaravelPolymorphicEav\Traits\HasEntityAttributeValues; class Product extends Model { use HasEntityAttributeValues; // Implementation of your Eloquent model }
Assigning attributes
Attributes are, when the Trait is added, accessable and assignable by the props
accessor on your Eloquent Model.
Just set its value!
class ProductController extends Controller { public function update(AnyValidatedRequest $request, Product $product) { $product->props->details->color = $request->color; // E.g. 'red' // That's it! } }
Accessing attributes
The assigned attributes are simply accessible by defining the group and the attribute in the props
accessor like
the following example. The concept is that all required properties must be accessible, without throwing exceptions, to
keep you code clean, readable and maintainable.
// This attribute has been set before $product->props->details->color; // 'red' // This attribute has never been set before $product->props->details->sku; // null // Even if the group has never been defined $product->props->foo->bar; // null
Other functionality
If you'd like e.g. remove a property you can either set it's value to null, or you can simply unset the value. The database entry will be removed.
unset($product->props->details->color); $product->props->details->color; // null
Serializing
You might run into a situation where you have to have all assigned properties available in an array or json. This
package respects the Arrayable
and Jsonable
interfaces.
$product->props->details->toArray(); ['color' => 'red'] $product->props->details->toJson(); '{color: "red"}'
Testing
composer test
Changelog
Please see CHANGELOG for more information what has changed recently.
Contributing
Please see CONTRIBUTING for details.
Security
If you discover any security related issues, please email david@favor.media instead of using the issue tracker.
Credits
License
The MIT License (MIT). Please see License File for more information.