Laravel-5.7: все категории не отображаются в заголовке из базы данных - PullRequest
0 голосов
/ 15 января 2019

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

Вот продукты Контроллер:

ProductsController.php

public function products($url = null)
{

  $categories = Category::with('products')->where(['parent_id'=>0])->get();
  $categoryDetails = Category::where(['url' => $url])->first();

  if($categoryDetails->parent_id==0)
  {
      //if url is main category url
      $subCategories = Category::where(['parent_id'=>$categoryDetails])->get();
      $cat_ids = "";
      foreach ($subCategories as $subCat) {
          $cat_ids .= $subCat->id.",";
      }
      $productsAll = Product::whereIn('category_id',array($cat_ids))->get();
  }
  else
  {
      //if url is sub category url
      $productsAll = Product::where(['category_id' => $categoryDetails->id])
                          ->get();
  }

  return view('products.listing')
            ->with(compact('categories','categoryDetails','productsAll'));
}

и на listing.blade.php я пишу это, чтобы связать его с категориями:

{{ $categoryDetails->name }}

Код контроллера:

Controller.php

<?php

  namespace App\Http\Controllers;

  use Illuminate\Foundation\Bus\DispatchesJobs;
  use Illuminate\Routing\Controller as BaseController;
  use Illuminate\Foundation\Validation\ValidatesRequests;
  use Illuminate\Foundation\Auth\Access\AuthorizesRequests;
  use App\Category;

  class Controller extends BaseController
  {
   use AuthorizesRequests, DispatchesJobs, ValidatesRequests;

    public static function mainCategories(){
    $mainCategories = Category::where(['parent_id' => 0])->get();
    $mainCategories = json_decode(json_encode($mainCategories));
    /*echo "<pre>"; print_r($mainCategories); die;*/
    return $mainCategories;
    }
   }

Код, который я пишу в заголовке:

header.blade.php

<?php use App\Http\Controllers\Controller;
  $mainCategories =  Controller::mainCategories();
?>

<!--some html-->

@foreach($mainCategories as $cat)
          <div class="dropdown-content">
               <a href="{{ asset('products/'.$cat->url) }}" style="margin-bottom: -10px;">{{ $cat->name }}</a>
          </div>
@endforeach

Ответы [ 2 ]

0 голосов
/ 15 января 2019

Вы можете использовать Просмотр данных для этого (https://laravel.com/docs/master/views#passing-data-to-views):

В вашем App/Providers/AppServiceProvider.php файле:

public function boot()
{
    View::share('mainCategories', Category::where(['parent_id' => 0])->get());
}

И просто используйте:

@foreach($mainCategories as $cat)
  // .... your code
@endforeach

В ваших файлах шаблонов.

0 голосов
/ 15 января 2019

Попробуйте изменить

<?php use App\Http\Controllers\Controller;
  $mainCategories =  Controller::mainCategories();
?>

до

<?php 
  use App\Controller;
  $mainCategories =  Controller::mainCategories();
?>

или более непосредственно:

<?php 
   $mainCategories =  App\Controller::mainCategories();
?>

в header.blade.php

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...