php - Laravel Print 根据用户的权限选择选项
问题描述
希望你一切顺利。
我正在使用 spatie 的权限包来管理我的用户的角色和权限。
我有4个角色
- 行政
- 超级经销商
- 经销商
- 零售商
在我的用户创建中,我使用Spatie\Permission\Models\Role
角色模型获取了所有角色......并且 foreach 循环生成选择值,但转折就在这里。管理员可以创建所有类型的用户,但超级经销商只能创建经销商和零售商,经销商只能创建零售商。我如何生成相应的用户角色选项?
目前我写了这段代码,它根本不工作
<select wire:model="role" name="role" class="block mt-1 w-full border-gray-300 focus:border-indigo-300 focus:ring focus:ring-indigo-200 focus:ring-opacity-50 rounded-md shadow-sm block mt-1 w-full">
<option value="" selected>Please select an option</option>
@forelse ($roles as $role)
@role('admin')
@if ($role == 'admin' || $role == 'super distributor' )
<option value="{{ $role->name }}">{{ Str::ucfirst($role->name) }}</option>
@endif
@endrole
@empty
<option >There is no roles available</option>
@endforelse
</select>
提前致谢
编辑:感谢@Abdul Rehman的解决方案。
我编辑了一点,这是最终的解决方案
public function mount()
{
$this->roles = $this->getRoles();
}
public function getRoles()
{
return [
'admin' => Role::all(),
'super distributor' => Role::whereIn('name', ['distributor','retailer','user'])->get(),
'distributor' => Role::whereIn('name', ['retailer'])->get(),
'retailer' => [],
'user' => [],
][auth()->user()->roles->pluck('name')[0]];
}
解决方案
从控制器处理这个事情不要让所有角色都获得基于哪个用户登录的角色。
喜欢
if(auth()->user()->hasRole('Admin')){
Role::all() //write query to fetch all roles
}
if(auth()->user()->hasRole('Super Distributor')){
Role::whereIn('id', [distributor_id,retailer_id])->get(); //write query to get only distributor and retailer role
}
像上面的查询一样获取其他人。
推荐阅读
- wordpress - 如何将另一个 wordpress 网站的帖子显示到我的 wordpress 网站?
- java - 当片段中的上下文为空时该怎么办
- php - 如何在没有 cron 的情况下自动化数据库表备份
- python - 调度程序使 python 脚本运行但不生成 csv 文件
- c# - 代码优先自动生成的值未创建相应的数据库逻辑
- ios - Unity 在 iPhone 上的 GetCloudProjectId() 崩溃
- json - 我正在尝试在 go 中打印 JSON
- javascript - 删除一行会导致浏览器冻结
- sql - SQL Server 从记录列表中更新多条记录
- r - 使用申请两个矩阵