ModelResource

Быстрые фильтры (теги)

Основы

Иногда возникает необходимость создать фильтры (выборку результатов) и отобразить их на листинге. Для таких ситуаций были созданы теги.

 namespaces
namespace App\MoonShine\Resources;
 
use Illuminate\Database\Eloquent\Builder;
use MoonShine\Laravel\QueryTags\QueryTag;
use MoonShine\Laravel\Resources\ModelResource;
 
class PostResource extends ModelResource
{
// ...
 
protected function queryTags(): array
{
return [
QueryTag::make(
'Post with author', // Заголовок тега
fn(Builder $query) => $query->whereNotNull('author_id') // Query builder
)
];
}
}

query_tags query_tags_dark

Иконка

Вы можете добавить иконку к тегу с помощью метода icon().

 namespaces
use Illuminate\Database\Eloquent\Builder;
use MoonShine\Laravel\QueryTags\QueryTag;
 
QueryTag::make(
'Post without an author',
fn(Builder $query) => $query->whereNull('author_id')
)
->icon('users')

Для более подробной информации, пожалуйста, обратитесь к разделу Иконки.

Активный элемент

Вы можете сделать QueryTag активным по умолчанию. Для этого нужно использовать метод default().

default(Closure|bool|null $condition = null)
 namespaces
use Illuminate\Database\Eloquent\Builder;
use MoonShine\Laravel\QueryTags\QueryTag;
 
QueryTag::make(
'All posts',
fn(Builder $query) => $query
)
->default()

Условие отображения

Вы можете захотеть отображать теги только при определенных условиях. Для этого можно использовать метод canSee(), которому нужно передать функцию обратного вызова, возвращающую TRUE или FALSE.

 namespaces
use Illuminate\Database\Eloquent\Builder;
use MoonShine\Laravel\QueryTags\QueryTag;
 
QueryTag::make(
'Post with author', // Заголовок тега
fn(Builder $query) => $query->whereNotNull('author_id')
)
->canSee(fn() => auth()->user()->moonshine_user_role_id === 1)

Псевдоним

По умолчанию значение для URL генерируется автоматически из параметра label. При этом все символы не латинского алфавита заменяются соответствующей транслитерацией 'Заголовок' => 'zagolovok'.

Метод alias() позволяет задать собственное значение для URL.

 namespaces
use Illuminate\Database\Eloquent\Builder;
use MoonShine\Laravel\QueryTags\QueryTag;
 
QueryTag::make(
'Archived Posts',
fn(Builder $query) => $query->where('is_archived', true)
)
->alias('archive')

По умолчанию все кнопки-теги выводятся в строку, но вы можете вывести их через выпадающий список. Для этого в ресурсе измените свойство $queryTagsInDropdown.

class PostResource extends ModelResource
{
protected bool $queryTagsInDropdown = true;
 
// ...
}

События

Вызов собственных событий после успешного обновления данных:

QueryTag::make('QueryTag', fn($q) => $q)->events([
AlpineJs::event(
JsEvent::FRAGMENT_UPDATED, 'custom-fragment'
)
])

Модификатор кнопки

QueryTag::make('QueryTag', fn($q) => $q)
->modifyButton(fn(ActionButton $btn) => $btn)