user(); $data = $request->getDto(); $querySettingsDto = new QuerySettingsDto( limit: 20, page: $data->getPage(), queryWith: [] ); $result = $this->roleService->index($data->getRoleBuilderDto(), $querySettingsDto, $user); if ($result->isError()) { $this->errors($result); } return view('private/roles/index', $result->getData()); } public function create(Request $request): View { $user = $request->user(); $result = $this->roleService->create($user); if ($result->isError()) { $this->errors($result); } return view('private/roles/create', $result->getData()); } public function edit(int $id, Request $request): View { $user = $request->user(); $result = $this->roleService->edit($id, $user); if ($result->isError()) { $this->errors($result); } return view('private/roles/edit', $result->getData()); } public function store(StoreUpdateRequest $request): RedirectResponse { $data = $request->getDto(); $user = $request->user(); $result = $this->roleService->store($data, $user); if ($result->isError()) { return redirect()->back()->withInput()->withErrors($result->getErrorsOrMessage()); } return redirect()->route('roles.edit', $result->getModel())->withSuccess($result->getMessage()); } public function update(int $id, StoreUpdateRequest $request): RedirectResponse { $data = $request->getDto(); $user = $request->user(); $result = $this->roleService->update($id, $data, $user); if ($result->isError()) { return redirect()->back()->withInput()->withErrors($result->getErrorsOrMessage()); } return redirect()->route('roles.edit', $result->getModel())->withSuccess($result->getMessage()); } public function destroy(int $id, Request $request): RedirectResponse { $user = $request->user(); $result = $this->roleService->destroy($id, $user); if ($result->isError()) { return redirect()->back()->withInput()->withErrors($result->getErrorsOrMessage()); } return redirect()->route('roles.index')->withSuccess($result->getMessage()); } }