$this->roles->getAllWithUsersCount()]); } public function create(): View { return view('role.add-edit', ['edit' => false]); } public function store(CreateRoleRequest $request): RedirectResponse { $this->roles->create($request->all()); return redirect()->route('roles.index') ->withSuccess(__('Role created successfully.')); } public function edit(Role $role): View { return view('role.add-edit', [ 'role' => $role, 'edit' => true, ]); } public function update(Role $role, UpdateRoleRequest $request): RedirectResponse { $this->roles->update($role->id, $request->all()); return redirect()->route('roles.index') ->withSuccess(__('Role updated successfully.')); } public function destroy(Role $role, UserRepository $userRepository): RedirectResponse { if (! $role->removable) { throw new NotFoundHttpException; } $userRole = $this->roles->findByName(Role::DEFAULT_USER_ROLE); $userRepository->switchRolesForUsers($role->id, $userRole->id); $this->roles->delete($role->id); Cache::flush(); return redirect()->route('roles.index') ->withSuccess(__('Role deleted successfully.')); } }