Custom relationship for Eloquent that merges/combines multiple one-to-may (hasMany) relationships
korridor/laravel-has-many-merged is a Laravel package for custom relationship for eloquent that merges/combines multiple one-to-may (hasmany) relationships.
It currently has 91 GitHub stars and 136.120 downloads on Packagist (latest version 1.3.0).
Install it with composer require korridor/laravel-has-many-merged.
Discover more Laravel packages by korridor
or browse all Laravel packages to compare alternatives.
Last updated
Custom relationship for Eloquent that merges/combines multiple one-to-may (hasMany) relationships. This relation fully supports lazy and eager loading.
[!NOTE] Check out solidtime - The modern Open Source Time-Tracker at solidtime.io
You can install the package via composer with following command:
composer require korridor/laravel-has-many-merged
If you want to use this package with older Laravel/PHP version please install the 0.* version.
composer require korridor/laravel-has-many-merged "^0"
This package is tested for the following Laravel versions:
In the following example there are two models User and Message. Each message has a sender and a receiver. The User model has two hasMany relations - one for the sent messages and the other for the received ones.
With this plugin you can add a relation that contains sent and received messages of a user.
use Korridor\LaravelHasManyMerged\HasManyMerged;
use Korridor\LaravelHasManyMerged\HasManyMergedRelation;
class User extends Model
{
use HasManyMergedRelation;
// ...
/**
* @return HasManyMerged<Message>
*/
public function messages(): HasManyMerged
{
return $this->hasManyMerged(Message::class, ['sender_user_id', 'receiver_user_id']);
}
/**
* @return HasMany<Message>
*/
public function sentMessages(): HasMany
{
return $this->hasMany(Message::class, 'sender_user_id');
}
/**
* @return HasMany<Message>
*/
public function receivedMessages(): HasMany
{
return $this->hasMany(Message::class, 'receiver_user_id');
}
}
I am open for suggestions and contributions. Just create an issue or a pull request.
The docker folder contains a local docker environment for development.
The docker workspace has composer and xdebug installed.
docker-compose run workspace bash
The composer test command runs all tests with phpunit.
The composer test-coverage command runs all tests with phpunit and creates a coverage report into the coverage folder.
The composer fix command formats the code with php-cs-fixer.
The composer lint command checks the code with phpcs.
This package is licensed under the MIT License (MIT). Please see license file for more information.