在我的模型中,我具有以下两个功能:
public function Children()
{
return $this->hasMany(Menu::class, 'parent_menu_id', 'id');
}
public function ActiveChildren()
{
$securityLevel = Auth()->User()->security_level_id;
$activeChildren = Menu::Children()
->where('active_', TRUE)
->where('security_level_id', $securityLevel);
return $activeChildren;
}
Children()
返回所有菜单项的列表,这些菜单项的parent_menu_id与该记录的ID相匹配。在Nova中用于设置目的。
使用ActiveChildren()
,我试图为实际菜单创建一个过滤的项目列表,其中active_
= TRUE,而security_level_id
=当前用户的安全级别ID。
但是,ActiveChildren()
返回所有菜单项,而不是过滤后的集合。 ActiveChildren使用以下静态函数填充数组:
public static function Tree()
{
return static::with(implode('.', array_fill(0, 4, 'ActiveChildren')))
->where('menu_type', '=', 'PRT')
->get();
}
只要刀片文件中包含菜单,就会通过AppServiceProvider加载该文件:
public function boot()
{
view()->composer('desktop.menu.parent', function ($view) {
$items = Menu::Tree();
$view->withItems($items);
});
}
所有这些都很好,只是菜单项未过滤,有什么主意吗?
答案 0 :(得分:1)
您似乎需要更新ActiveChildren()
关系:
public function ActiveChildren()
{
$securityLevel = Auth()->User()->security_level_id;
/* $activeChildren = Menu::Children()
* ->where('active_', TRUE)
* ->where('security_level_id', $securityLevel);
*
* return $activeChildren;
*/
return $this->Children() // switch Menu::Children() to $this->Children()
->where('active_', TRUE)
->where('security_level_id', $securityLevel);
}
答案 1 :(得分:1)
尝试一下:
\App\model_name::where('active_',TRUE)->where('security_level_id', $securityLevel);
答案 2 :(得分:0)
经过更多调查,我发现问题出在刀片服务器代码中。
我仍然引用$item['children']
而不是$item['activechildren']
<li>{{ $item['menu_text'] }}</li>
@if (count($item['activechildren']) > 0)
<ul>
@foreach($item['activechildren'] as $item)
@include('desktop.menu.children', $item)
@endforeach
</ul>
@endif
为什么$item['children']
仍然有效?为什么这没有引发错误?