PHP code example of makidizajnerica / laravel-filterator
1. Go to this page and download the library: Download makidizajnerica/laravel-filterator library. Choose the download type require.
2. Extract the ZIP file and open the index.php.
3. Add this code to the index.php.
<?php
require_once('vendor/autoload.php');
/* Start to develop here. Best regards https://php-download.com/ */
makidizajnerica / laravel-filterator example snippets
namespace App\Models;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\Builder;
use MakiDizajnerica\Filterator\Filter;
use MakiDizajnerica\Filterator\Contracts\Filterable as FilterableContract;
class User extends Model implements FilterableContract
{
// ...
/**
* Get filters for the filterator manager.
*
* @return array<string, \MakiDizajnerica\Filterator\Filters\Filter>
*/
public function filters(): array
{
return [
'name' => Filter::string(fn (Builder $query, string $name) => $query->where('name', 'LIKE', "%{$name}%")),
];
}
}
namespace App\Models;
use Illuminate\Support\Carbon;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\Builder;
use MakiDizajnerica\Filterator\Filter;
use MakiDizajnerica\Filterator\Contracts\Filterable as FilterableContract;
class User extends Model implements FilterableContract
{
// ...
/**
* Get filters for the filterator manager.
*
* @return array<string, \MakiDizajnerica\Filterator\Filters\Filter>
*/
public function filters(): array
{
return [
'is_admin' => Filter::boolean(fn (Builder $query, bool $isAdmin) => $query->where('is_admin', $isAdmin)),
'created_at' => Filter::date(fn (Builder $query, Carbon $createdAt) => $query->whereDate('created_at', $createdAt))
->format('Y-m-d') // optionally define format
->timezone('Europe/Belgrade'), // optionally define timezone
'credit' => Filter::float(fn (Builder $query, float $credit) => $query->where('credit', $credit))
->decimals(2), // optionally define number of decimals
'age' => Filter::integer(fn (Builder $query, int $age) => $query->where('age', $age)),
'name' => Filter::string(fn (Builder $query, string $name) => $query->where('name', 'LIKE', "%{$name}%")),
];
}
}
namespace App\Models;
use Illuminate\Support\Carbon;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\Builder;
use MakiDizajnerica\Filterator\Filter;
use MakiDizajnerica\Filterator\Contracts\Filterable as FilterableContract;
class User extends Model implements FilterableContract
{
// ...
/**
* Get filters for the filterator manager.
*
* @return array<string, \MakiDizajnerica\Filterator\Filters\Filter>
*/
public function filters(): array
{
return [
// ...
'created_at' => Filter::date(fn (Builder $query, Carbon $createdAt) => $query->whereDate('created_at', $createdAt))
->default(fn (Builder $query) => $query->whereDate('created_at', '1985-05-05')),
// ...
];
}
}
use App\Models\User;
use MakiDizajnerica\Filterator\Facades\Filterator;
$users = filterator(User::class)->get();
// or
$users = Filterator::filter(User::class)->get();
Loading please wait ...
Before you can download the PHP files, the dependencies should be resolved. This can take some minutes. Please be patient.