mohamedsaad/dynamic-filters 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

mohamedsaad/dynamic-filters

最新稳定版本:v1.0.0

Composer 安装命令:

composer require mohamedsaad/dynamic-filters

包简介

Dynamic filtering package for Laravel models with support for relations and custom operators

README 文档

README

A powerful package to add dynamic filtering, searching, sorting, and column selection to your Laravel models and API endpoints.

Installation

Install the package via Composer:

composer require mohamedsaad/dynamic-filters

Publish the configuration file:

php artisan vendor:publish --tag=dynamic-filters-config

Configuration File

The configuration file will be published to config/dynamic-filters.php:

<?php

return [
    /*
    |--------------------------------------------------------------------------
    | Allowed Operators
    |--------------------------------------------------------------------------
    | Operators allowed for filtering.
    */
    'allowed_operators' => ['=', 'like', 'in', 'between', '>', '<', '>=', '<='],

    /*
    |--------------------------------------------------------------------------
    | Default Relation Column
    |--------------------------------------------------------------------------
    | When filtering by relation directly (e.g., ?filters[organization]=3),
    | this column will be used.
    */
    'default_relation_column' => 'id',

    /*
    |--------------------------------------------------------------------------
    | Allowed Sorting Columns
    |--------------------------------------------------------------------------
    | Restrict sorting to specific columns. Leave empty to allow all.
    */
    'allowed_sorting_columns' => [],
];

Model Setup

Add the HasDynamicFilters trait to your Eloquent model and optionally define searchable columns:

<?php

namespace App\Models;

use Illuminate\Database\Eloquent\Model;
use MohamedSaad\DynamicFilters\Traits\HasDynamicFilters;

class User extends Model
{
    use HasDynamicFilters;

    // Optional: Define searchable columns for the "search" feature
    protected array $searchable = ['name', 'email', 'profile.city'];
}

Controller Setup

Apply filters, search, sorting, and column selection dynamically in your controller:

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use App\Models\User;

class UserController extends Controller
{
    public function index(Request $request)
    {
        // Apply filters, search, sorting, and columns dynamically
        $users = User::applyFilters($request)->paginate(15);

        return response()->json($users);
    }
}

API Examples

Apply Filters to Specific Columns

GET /users?filters[status]=active&filters[age][operator]=>&filters[age][value]=25

Filtering Relations

GET /users?filters[organization]=2
GET /users?filters[organization.name]=CompanyX

Global Search

Search across all predefined searchable columns:

GET /users?search=ahmed

Column Selection

Select only the columns you need:

GET /users?columns[]=id&columns[]=name

Multi-level Sorting

Sort by multiple columns (prefix with - for descending):

GET /users?sort=-created_at,name,profile.city

Combined Example

Combine everything in one request:

GET /users?search=ahmed&filters[status]=active&filters[organization.id]=3&columns[]=id&columns[]=name&sort=-created_at,email

Using with API Resources

Integrate with Laravel API Resources:

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use App\Models\User;
use App\Http\Resources\UserResource;

class UserController extends Controller
{
    public function index(Request $request)
    {
        $users = User::applyFilters($request)->paginate();
        return UserResource::collection($users);
    }
}

License

This package is open-sourced software licensed under the MIT license.

统计信息

  • 总下载量: 1
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 3
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 3
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: proprietary
  • 更新时间: 2025-08-07