承接 abhiaay/query-craft 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

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

abhiaay/query-craft

最新稳定版本:1.2.1

Composer 安装命令:

composer require abhiaay/query-craft

包简介

Laravel filter and sort by eloquent query

README 文档

README

Simple filter & sort for your laravel model only with minimal setup

Prerequisites

  • PHP 8.1
  • Laravel 10

Install

Composer

composer require abhiaay/query-craft

How To Use

Inside your Model App\Models\Post

<?php

namespace App\Models;

use Abhiaay\QueryCraft\QueryCraft;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\Factories\HasFactory;


class Post extends Model
{
    use HasFactory, QueryCraft;

    /**
     * @inheritdoc
     *
     * @return [alias => db_column]
     */
    public function filterableColumns(): array
    {
        return [
            'title' => 'title',
            // for relation or embed for mongodb
            'category' => 'category.id'
        ];
    }

    /**
     * @inheritdoc
     */
    public function sortableColumns(): array
    {
        return [
            'created_at' => 'created_at',
            // for relation or embed for mongodb
            'category' => 'category.name'
        ];
    }
}

Inside Your Controller or Query App\Http\Controllers\PostController

<?php

namespace App\Http\Controllers;

use App\Models\Post;
use Illuminate\Http\Request;
use Abhiaay\QueryCraft\Craft;

class PostController extends Controller
{
    public function index(Request $request)
    {
        $craft = Craft::parse($request);
        return Post::craft($craft)->paginate($request->input('per_page'));
    }
}

Using Filter

in your url will looks like this

https://domain.com/api/posts?filter[title][is]=how+do+i+use+syntax+highlighting+in+php+within+a+markdown+github+gist&filter[category][!is]=code

if value is array when you using in

https://domain.com/api/posts?filter[category][in][]=code&filter[category][in][]=programming

Using Sort

https://domain.com/api/posts?sort=created_at,-category

use symbol - indicate if column is descending without symbol indicate ascending

List of Operations Supported

  • is equal to =
  • !is equal to <>
  • like equal to like
  • !like equal to not like
  • gt equal to >
  • gte equal to >=
  • lt equal to <
  • lte equal to <=
  • mod equal to mod
  • regex equal to regexp
  • exists equal to exists
  • type equal to type
  • in equal to whereIn
  • !in equal to whereNotIn
  • between equal to whereBetween

统计信息

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

GitHub 信息

  • Stars: 2
  • Watchers: 1
  • Forks: 1
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2024-01-25