. */ namespace SP\Modules\Web\Controllers\CustomField; use Exception; use JsonException; use SP\Core\Events\Event; use SP\Domain\Core\Acl\AclActionsInterface; use SP\Domain\Http\Dtos\JsonMessage; use SP\Modules\Web\Controllers\Traits\JsonTrait; /** * Class CustomFieldController * * @package SP\Modules\Web\Controllers */ final class ViewController extends CustomFieldViewBase { use JsonTrait; /** * View action * * @param int $id * * @return bool * @throws JsonException */ public function viewAction(int $id): bool { try { if (!$this->acl->checkUserAccess(AclActionsInterface::CUSTOMFIELD_VIEW)) { return $this->returnJsonResponse( JsonMessage::JSON_ERROR, __u('You don\'t have permission to do this operation') ); } $this->view->assign('header', __('View Field')); $this->view->assign('isView', true); $this->setViewData($id); $this->eventDispatcher->notify('show.customField', new Event($this)); } catch (Exception $e) { processException($e); $this->eventDispatcher->notify('exception', new Event($e)); return $this->returnJsonResponse(JsonMessage::JSON_ERROR, $e->getMessage()); } return $this->returnJsonResponseData(['html' => $this->render()]); } }