Package Data | |
---|---|
Maintainer Username: | korridor |
Maintainer Contact: | 26689068+korridor@users.noreply.github.com (korridor) |
Package Create Date: | 2021-02-15 |
Package Last Update: | 2025-03-03 |
Home Page: | |
Language: | PHP |
License: | MIT |
Last Refreshed: | 2025-03-05 15:00:03 |
Package Statistics | |
---|---|
Total Downloads: | 68,158 |
Monthly Downloads: | 3,955 |
Daily Downloads: | 207 |
Total Stars: | 82 |
Total Watchers: | 4 |
Total Forks: | 4 |
Total Open Issues: | 5 |
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.