kalimeromk/filterable
最新稳定版本:v1.6
Composer 安装命令:
composer require kalimeromk/filterable
包简介
A Laravel package that simplifies dynamic filtering and searching across models and their relationships, eliminating repetitive query code.
关键字:
README 文档
README
Filterable is a Laravel package designed to simplify dynamic filtering and searching across models and their relationships, eliminating the need for repetitive query code. It provides an easy-to-use trait and macros for building powerful, dynamic query filters.
Installation
-
Require the package via Composer:
composer require kalimeromk/filterable
-
The package supports auto-discovery, so no manual registration of the service provider is needed. However, if you are using an older Laravel version, add the service provider to your
config/app.php:'providers' => [ Kalimeromk\Filterable\PackageServiceProvider::class, ];
Usage
1. Using whereLike Macro
The whereLike macro allows you to perform "LIKE" searches on multiple fields, including related model fields.
Example:
use App\Models\User; $users = User::query() ->whereLike(['name', 'email'], 'John') ->get();
This will return all users where the name or email fields contain the string "John".
Searching on Related Models:
$users = User::query() ->whereLike(['posts.title', 'posts.content'], 'Laravel') ->with('posts') ->get();
This will return all users who have posts with a title or content containing the string "Laravel".
2. Using the Filterable Trait
The Filterable trait allows you to dynamically filter a model based on specific criteria, including LIKE queries, boolean fields, and whereIn filters, as well as range filters like _min and _max.
Setup:
Add the Filterable trait to your model:
namespace App\Models; use Illuminate\Database\Eloquent\Model; use Kalimeromk\Filterable\Traits\Filterable; class User extends Model { use Filterable; protected $fillable = ['name', 'email', 'is_active']; // Define fields for specific filters protected $boolFields = ['is_active']; protected $likeFields = ['name', 'email']; }
Example Controller:
use App\Models\User; use Illuminate\Http\Request; class UserController extends Controller { public function index(Request $request) { $filters = $request->only(['name', 'email', 'is_active', 'age_min', 'age_max']); $users = User::filter($filters)->get(); return response()->json($users); } }
Example API Request:
- Request:
GET /users?name=Jane&is_active=true&age_min=25&age_max=35 - Result:
Returns all active users (
is_active = true) whose name contains "Jane" and whose age is between 25 and 35.
Testing the Package
This package uses Orchestra Testbench for testing.
Running Tests
To run the tests:
-
Install the dependencies:
composer install
-
Run PHPUnit:
vendor/bin/phpunit
License
This package is open-sourced software licensed under the MIT license.
统计信息
- 总下载量: 2.56k
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 5
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2022-07-30