Как создать фильтр Nova для фильтрации ресурса по его отношению? - PullRequest
0 голосов
/ 17 октября 2018

У меня есть вопросный ресурс, который имеет много категорий (отношение многие ко многим).Я хотел бы создать фильтр ресурса вопросов для разных категорий.

<?php

namespace App\Nova\Filters;

use Illuminate\Http\Request;
use Laravel\Nova\Filters\Filter;

class CategoryType extends Filter
{
    /**
     * Apply the filter to the given query.
     *
     * @param  \Illuminate\Http\Request  $request
     * @param  \Illuminate\Database\Eloquent\Builder  $query
     * @param  mixed  $value
     * @return \Illuminate\Database\Eloquent\Builder
     */
    public function apply(Request $request, $query, $value)
    {
        return $query->categories()->where('id', $value);
    }

    /**
     * Get the filter's available options.
     *
     * @param  \Illuminate\Http\Request  $request
     * @return array
     */
    public function options(Request $request)
    {
            $categories = \App\Category::all();
            return $categories->pluck('id', 'name')->all();
    }
}

Ответы [ 2 ]

0 голосов
/ 14 декабря 2018

Как и при запросе любого отношения, вы хотите использовать замыкание.

public function apply(Request $request, $query, $value)
{
    return $query->whereHas('categories', function($query) use ($value) {
        $query->where('id', $value);
    });
}
0 голосов
/ 18 октября 2018

$query имеет тип \Illuminate\Database\Eloquent\Builder, не может использовать метод модели Eloquent categories().

Попробуйте использовать объединение, как показано ниже.category_question является промежуточной таблицей.Я не проверял, надеюсь, это поможет вам.

return $query
        ->join('category_question as cq', 'questions.id', 'cq.question_id')
        ->where('cq.category_id', $value)
        ->get();
...