Laravel API получает категории только с сообщениями - PullRequest
0 голосов
/ 02 июня 2019

У меня есть ресурс API, и я вызываю его в своем контроллере API, чтобы он возвращал мои данные, мне нужно добавить один дополнительный фильтр в этот API, но я не уверен, как?

Что мне нужно

  1. Получить категории, которые имеют только сообщения.
  2. Исключить категории без публикации результатов.

Что у меня есть

  1. Список всех категорий с и без сообщений.

код

Resource

<?php

namespace App\Http\Resources;

use Illuminate\Http\Resources\Json\JsonResource;
use App\Http\Resources\PostResource;

class CategoryResource extends JsonResource
{
    /**
     * Transform the resource into an array.
     *
     * @param  \Illuminate\Http\Request  $request
     * @return array
     */
    public function toArray($request)
    {
        return [
            'id' => $this->id,
            'title' => $this->title,
            'image' => url('images', $this->photo),
            'url' => $this->slug,
            'posts' => PostResource::collection($this->whenLoaded('posts')),
            'created_at' => (string) $this->created_at,
            'updated_at' => (string) $this->updated_at,
        ];
    }
}

Controller

<?php

namespace App\Http\Controllers\API;

use Illuminate\Http\Request;
use App\Http\Controllers\Controller;
use App\Http\Resources\CategoryResource;
use App\Category;

class CategoryController extends Controller
{
    public function index(){
        $categories = CategoryResource::collection(Category::where('status', '1')->with('posts')->orderby('id', 'desc')->get());
        return response()->json($categories);
    }
}

Есть идеи, как добавить этот фильтр в мой контроллер?

1 Ответ

2 голосов
/ 02 июня 2019

Вы можете отфильтровать категории, в которых есть хотя бы одно сообщение, используя функцию has следующим образом:

Category::where('status', '1')->with('posts')->has('posts')->orderby('id', 'desc')->get();
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...