I have User
Role
models defined in a many-to-many relationship. When creating user I have a multiple select box to pick roles for specific user:
<div class="col-lg-6 col-md-6 col-sm-6 col-xs-6">
<div class="form-group">
<label for="roles">Roles</label>
{!! Form::select('roles[]',$roles, null,['class' => 'form-control selectpicker','multiple' => 'true']) !!}
</div>
</div>
This is a form which is shared in both create and edit methods, but for edit it is like this:
{!! Form::model($patient, ['route' => ['patients.update', $patient->id], 'method' => 'PUT']) !!}
@include('patients.partials.form')
{!! Form::close()!!}
When I try to edit user with roles, no roles get selected...this is the controller
public function edit(User $user)
{
$clinics = Clinic::pluck('name', 'id');
$roles = Role::pluck('display_name', 'id');
$states = State::pluck('name', 'id');
$cities = City::pluck('name', 'id');
return view('users.edit', compact('user', 'clinics', 'states', 'cities', 'roles'));
}
EDIT:
I handle update like this:
public function update(Request $request, User $user)
{
if ($request->has('password'))
$user->update($request->except('password_confirmation'));
else
$user->update($request->except('password', 'password_confirmation'));
$user->roles()->sync($request->roles);
return redirect('users')->with('status', 'User Updated!');
}
Part of the request dump:
"roles": [
"1",
"4"
],
"first_name": "xy",
"last_name": "yx",