bizhub/inertia-query-filter
最新稳定版本:1.2.0
Composer 安装命令:
composer require bizhub/inertia-query-filter
包简介
Laravel + Inertiajs query filters
README 文档
README
Install
composer require bizhub/inertia-query-filter
Example
1. Create filter in App\QueryFilters
<?php namespace App\QueryFilters; use Bizhub\QueryFilter\QueryFilter; class UserFilter extends QueryFilter { public function trashed() { $this->builder->withTrashed(); } public function status($value) { $this->builder->where('status', $value); } }
2. Add Filterable trait to the model
<?php namespace App\Models; use Illuminate\Http\Request; use Bizhub\QueryFilter\Filterable; use Illuminate\Foundation\Auth\User as Authenticatable; class User extends Authenticatable { use Filterable; }
3. Use filter scope
<?php namespace App\Http\Controllers; use App\Models\User; use Illuminate\Http\Request; use Inertia\Inertia; class UserController extends Controller { /** * Get list of users * * @param Request $request * @return \Inertia\Response */ public function index(Request $request) { return Inertia::render('Users/Index', [ 'users' => User::filter()->paginate() ]); } }
4. Use $inertia.replace in page/component
import throttle from 'lodash/throttle' import pickBy from 'lodash/pickBy' import mapValues from 'lodash/mapValues' export default { props: ['users', 'filters'], data() { return { filter: { trashed: this.filters.trashed, status: this.filters.status } } }, watch: { filter: { handler: throttle(function() { this.$inertia.replace( route('users', pickBy(this.filter)), { only: ['users'], } ) }, 500), deep: true } }, methods: { clearFilter() { this.filter = mapValues(this.filter, () => null) } } }
统计信息
- 总下载量: 5.17k
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 6
- 点击次数: 1
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2020-12-11