korridor/laravel-has-many-merged
最新稳定版本:1.2.0
Composer 安装命令:
composer require korridor/laravel-has-many-merged
包简介
Custom relationship for Eloquent that merges/combines multiple one-to-may (hasMany) relationships
README 文档
README
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
Installation
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"
Requirements
This package is tested for the following Laravel versions:
- 12.* (PHP 8.2, 8.3, 8.4)
- 11.* (PHP 8.2, 8.3, 8.4)
- 10.* (PHP 8.1, 8.2, 8.3)
Usage examples
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'); } }
Contributing
I am open for suggestions and contributions. Just create an issue or a pull request.
Local docker environment
The docker folder contains a local docker environment for development.
The docker workspace has composer and xdebug installed.
docker-compose run workspace bash
Testing
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.
Codeformatting/Linting
The composer fix command formats the code with php-cs-fixer.
The composer lint command checks the code with phpcs.
License
This package is licensed under the MIT License (MIT). Please see license file for more information.
统计信息
- 总下载量: 107.82k
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 89
- 点击次数: 2
- 依赖项目数: 2
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2021-02-15