jeidison/model-filtrable

Filter Eloquent Models and Relationships

0.4 2020-12-09 11:22 UTC

This package is auto-updated.

Last update: 2025-01-08 11:34:36 UTC


README

Installation

$ composer require jeidison/model-filtrable

Usage

Add Trait in model

...

use Jeidison\Filtrable\Filtrable;

class Professional extends Model
{
    use Filtrable;

    ...
    protected $fillable = [
        //All fields filtrable;
    ];
    ...

    public function places()
    {
        return $this->belongsToMany(Place::class, 'prof_place', 'id_prof', 'id_place');
    }
    
    public function specialties()
    {
        return $this->belongsToMany(Specialty::class, 'prof_spec', 'id_prof', 'id_spec');
    }
}

Service

...

use App\Models\Professional;

class ProfessionalService implements IProfessionalService
{
    public function filter()
    {
         return Professional::filter(request()->all())->get(); 
        // or
         return Professional::filter(['field_one' => 'value1'])->get();     
    }
}

Querying at the API-endpoint

Filtering:

Where

    /api/professionals?id_prof=1
    or
    /api/professionals?id_prof:==1
    or
    /api/professionals?id_prof:<>=1
    or
    /api/professionals?id_prof:!==1
    or
    /api/professionals?id_prof:>=1
    or
    /api/professionals?id_prof:<=1
    ...

WhereIn

    /api/professionals?id_prof:in=1,2

WhereNotIn

    /api/professionals?id_prof:notIn=1,2

WhereBetween

    /api/professionals?id_prof:between=1,2
    /api/professionals?updated_at:between=2020-03-10 14:00:27,2020-03-10 14:00:27

WhereNotBetween

    /api/professionals?id_prof:notBetween=1,2
    /api/professionals?updated_at:notBetween=2020-03-10 14:00:27,2020-03-10 14:00:27

WhereNull

    /api/professionals?id_prof:null=

WhereNotNull

    /api/professionals?id_prof:notNull=

Where Like

    /api/professionals?prof_name:like=Jeidison%

Where Date

    /api/professionals?created_at:whereDate=2020-03-10

orWhere

    /api/professionals?id_prof:>=100&prof_name:orWhere=Jeidison

With:

    /api/professionals?with=places,specialties

Has:

    /api/professionals?has=places

Relationship:

    /api/places->id_place=1
    /api/places->professionals->id_place=1
    /api/places->professionals->id_place:<>=1
    /api/places->professionals->id_place:<=1
    ...

Order By:

    /api/professionals?order=id_place
    or 
    /api/professionals?order=id_prof:desc
    or 
    /api/professionals?order=id_prof:asc
    or 
    /api/professionals?order=id_place,id_prof:desc
    or 
    /api/professionals?order=id_place:asc,id_prof:desc

Fields Response:

    /api/professionals?fields=id_place,prof_name,prof_phone,prof_email

Paginate:

    /api/professionals?paginate
    or
    /api/professionals?paginate&paginate:page=0
    or
    /api/professionals?paginate&paginate:perPage=10&paginate:page=0
    ...

Credits