Laravel 5.4在两个枢轴上属于同一个人的多个下拉列表

时间:2018-05-30 18:51:30

标签: php laravel-5.4 dropdown has-and-belongs-to-many

我正在尝试连接特定用户角色使用的公司。具有特定角色的用户可以为多家公司“工作”。公司可以“雇用”多个用户。我有5个表(用户,role_user,角色,公司和company_user)

模特关系:

App\User:

public function roles()
    {
        return $this
            ->belongsToMany('App\Role')
            ->withTimestamps();
    }


    public function companies()
    {
        return $this
            ->belongsToMany('App\Company')
            ->withTimestamps();
    }


App\Role:
    public function users()
    {
        return $this
            ->belongsToMany('App\User')
            ->withTimestamps();
    }


App\Companies:
    public function users()
    {
        return $this->belongsToMany('App\User');  // with user_role ??
    }

公司财务总监

public function edit(Request $request, $id) {

$company = Company::findOrFail($id);

$users = User::where('role_id',4)->pluck('username')->all(); // no role_id column
$users = User::pluck('username','id')->all();  // returns all users

return view('companies.edit', compact(['company','users']));
}

public function update(Request $request, $id) {
    /* TODO */
}

修改视图

{!! Form::select('users[]', $users, null, ['class' => 'form-control', 'multiple' => 'multiple']) !!}

我想将具有特定用户角色的用户与这些公司签约。有没有办法设置关系或可能是范围?

奖金问题:)是否有一种简单的方法可以在下拉列表中显示连接值?名字+姓氏而不是用户名?

1 个答案:

答案 0 :(得分:0)

也许不是最整洁的解决方案,但似乎有效:)

模型

public function scopeOfRole($query, $role) {
    return $query->
    join('role_user', 'role_user.user_id', '=', 'users.id')->
    join('roles', 'roles.id', '=', 'role_user.role_id')->
    select(
        DB::raw('GROUP_CONCAT(users.first_name," ",users.last_name) as username'),
            'users.id')->
    where('roles.name', $role)->
    groupBy('users.id');
}

的Controler

public function edit(Request $request, $id) {

$company = Company::findOrFail($id);
$users = User::OfRole('my role')->pluck('username','users.id')->all();

return view('companies.edit', compact(['company','users']));
}

编辑视图

{!! Form::select('users[]', $users, $company->users()->pluck('users.id'), ['class' => 'form-control', 'multiple' => 'multiple']) !!}
相关问题