linron/hyperf-filter

Powerful REPL for the Hyperf framework.

3.0.0 2023-11-24 07:53 UTC

This package is auto-updated.

Last update: 2024-04-24 09:11:58 UTC


README

说明

基于Hyperf3.0的模型过滤器

安装

composer require linron/hyperf-filter

使用

新建Filter

<?php
declare(strict_types=1);

namespace App\Filter;
use Hyperf\Filter\QueryFilter;
use Hyperf\Database\Model\Builder;

class TenderListFilter extends QueryFilter
{
    public function projectId(int $projectId): Builder
    {
        return $this->builder->where('project_id', $projectId);
    }

    public function partyName(string $partyName): Builder
    {
        return $this->builder->whereHas('project.partyUnit', function (Builder $query) use ($partyName) {
            $query->where('name', 'like', "%$partyName%");
        });
    }

    public function humanCost(array $humanCost): Builder
    {
        [$start, $end] = $humanCost;
        if($start) $this->builder->where('human_cost', '>=', $start);
        if($end) $this->builder->where('human_cost', '<=', $end);
        return $this->builder;
    }

    public function masterCost(array $masterCost): Builder
    {
        [$start, $end] = $masterCost;
        if($start) $this->builder->where('master_cost', '>=', $start);
        if($end) $this->builder->where('master_cost', '<=', $end);
        return $this->builder;
    }

    public function slaveCost(array $slaveCost): Builder
    {
        [$start, $end] = $slaveCost;
        if($start) $this->builder->where('slave_cost', '>=', $start);
        if($end) $this->builder->where('slave_cost', '<=', $end);
        return $this->builder;
    }

    public function deviceCost(array $deviceCost): Builder
    {
        [$start, $end] = $deviceCost;
        if($start) $this->builder->where('device_cost', '>=', $start);
        if($end) $this->builder->where('device_cost', '<=', $end);
        return $this->builder;
    }

    public function totalCost(array $totalCost): Builder
    {
        [$start, $end] = $totalCost;
        if($start) $this->builder->where('total_cost', '>=', $start);
        if($end) $this->builder->where('total_cost', '<=', $end);
        return $this->builder;
    }

    public function status(int $status): Builder
    {
        return $this->builder->where('status', $status);
    }
}

在模型基类中

<?php

declare(strict_types=1);

namespace App\Model;

use App\Utils\DiUtils;
use Hyperf\Database\Model\Builder;
use Hyperf\Utils\ApplicationContext;
use Hyperf\DbConnection\Model\Model as BaseModel;

/**
 * @method static Builder filter(...$args)
 */
abstract class Model extends BaseModel
{
    public function scopeFilter(Builder $query, array $params, string $filter): Builder
    {
        return ApplicationContext::getContainer()->get($filter)->filter($query, $params);
    }
}

使用Filter

$query = TenderModel::filter($request->post(), TenderListFilter::class);