首页 > 解决方案 > Laravel Print 根据用户的权限选择选项

问题描述

希望你一切顺利。

我正在使用 spatie 的权限包来管理我的用户的角色和权限。

我有4个角色

  1. 行政
  2. 超级经销商
  3. 经销商
  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]];
    }

标签: phplaravellaravel-permission

解决方案


从控制器处理这个事情不要让所有角色都获得基于哪个用户登录的角色。

喜欢

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
}

像上面的查询一样获取其他人。


推荐阅读