Я пытаюсь отобразить меню ресторана, сгруппированные по категориям, например ...
Итак, в моей базе данных 3 таблицы, Рестораны,Категории и меню
Категория Модель
class Category extends Model
{
protected $fillable = [
'name'
];
/**
* @return \Illuminate\Database\Eloquent\Relations\HasMany
*/
public function menus_type()
{
return $this->hasMany('App\Menu','category_id');
}
}
Меню Модель
class Menu extends Model
{
protected $fillable = [
'name',
'price',
'description',
'photoPath',
'restaurant_id',
'category_id',
];
/**
* Menu belongs to Restaurant
*/
public function restaurant()
{
return $this->belongsTo('App\Restaurant');
}
/**
* Menu belongs to category type
*/
public function category_type()
{
return $this->belongsTo('App\Category', 'category_id');
}
}
Контроллер ресторана
public function show($slug, RestaurantRepository $repository){
if(! $restaurant = $repository->get(['slug' => $slug], with(['cuisines','user', 'photos', 'thumbs', 'region', 'ratings.user']))) return abort('404');
$menus=Menu::with(['category_type'])->where('restaurant_id',$restaurant->id)->get()->groupBy('category_id');
return view('frontend.restaurant.show', compact('restaurant', 'p','menus'));
}
когда я Дамп это выглядит просто отлично.
Результаты былисгруппированные
Теперь моя проблема связана с View , когда я пытаюсь получить результаты этого, я получаю ошибку.
@if($menus)
<ul>
@foreach($menus as $m)
<li>
{{$m->name}}
</li>
@endforeach
</ul>
@endif
ErrorException (E_ERROR).
Свойство [имя] не существует в этом экземпляре коллекции.