Rev 15371 | Rev 16768 | Ir a la última revisión | Autoría | Comparar con el anterior | Ultima modificación | Ver Log |
<?phpdeclare(strict_types=1);namespace LeadersLinked\Controller;use Laminas\Db\Adapter\AdapterInterface;use Laminas\Cache\Storage\Adapter\AbstractAdapter;use Laminas\Mvc\Controller\AbstractActionController;use LeadersLinked\Hydrator\ObjectPropertyHydrator;use Laminas\Log\LoggerInterface;use Laminas\View\Model\ViewModel;use Laminas\View\Model\JsonModel;use LeadersLinked\Library\Functions;use LeadersLinked\Mapper\CompetencyMapper;use LeadersLinked\Model\Competency;use LeadersLinked\Form\Competency\CompetencyForm;use LeadersLinked\Mapper\CompetencyTypeMapper;use LeadersLinked\Model\CompetencyType;use LeadersLinked\Mapper\CompetencyBehaviorMapper;use LeadersLinked\Model\CompetencyBehavior;use LeadersLinked\Mapper\BehaviorMapper;class CompetencyController extends AbstractActionController {/**** @var AdapterInterface*/private $adapter;/**** @var AbstractAdapter*/private $cache;/**** @var LoggerInterface*/private $logger;/**** @var array*/private $config;/**** @param AdapterInterface $adapter* @param AbstractAdapter $cache* @param LoggerInterface $logger* @param array $config*/public function __construct($adapter, $cache, $logger, $config) {$this->adapter = $adapter;$this->cache = $cache;$this->logger = $logger;$this->config = $config;}public function indexAction() {$currentUserPlugin = $this->plugin('currentUserPlugin');$currentUser = $currentUserPlugin->getUser();$currentCompany = $currentUserPlugin->getCompany();$request = $this->getRequest();$headers = $request->getHeaders();$request = $this->getRequest();if ($request->isGet()) {$headers = $request->getHeaders();$isJson = false;if ($headers->has('Accept')) {$accept = $headers->get('Accept');$prioritized = $accept->getPrioritized();foreach ($prioritized as $key => $value) {$raw = trim($value->getRaw());if (!$isJson) {$isJson = strpos($raw, 'json');}}}if ($isJson) {$search = $this->params()->fromQuery('search', []);$search = empty($search['value']) ? '' : filter_var($search['value'], FILTER_SANITIZE_STRING);$start = intval($this->params()->fromQuery('start', 0), 10);$records_x_page = intval($this->params()->fromQuery('length', 10), 10);$page = intval($start / $records_x_page);$page++;$order = $this->params()->fromQuery('order', []);$order_field = empty($order[0]['column']) ? 99 : intval($order[0]['column'], 10);$order_direction = empty($order[0]['dir']) ? 'ASC' : strtoupper(filter_var($order[0]['dir'], FILTER_SANITIZE_STRING));$fields = ['type', 'name'];$order_field = isset($fields[$order_field]) ? $fields[$order_field] : 'name';if (!in_array($order_direction, ['ASC', 'DESC'])) {$order_direction = 'ASC';}$competencyMapper = CompetencyMapper::getInstance($this->adapter);if ($currentCompany) {$paginator = $competencyMapper->fetchAllDataTableByCompanyId($currentCompany->id, $search, $page, $records_x_page, $order_field, $order_direction);} else {$paginator = $competencyMapper->fetchAllDataTableDefault($search, $page, $records_x_page, $order_field, $order_direction);}$items = [];$records = $paginator->getCurrentItems();foreach ($records as $record) {$item = ['type' => $record['type'],'name' => $record['name'],'status' => $record['status'],'actions' => ['link_edit' => $this->url()->fromRoute('jobs-description/competencies/edit', ['id' => $record['uuid']]),'link_delete' => $this->url()->fromRoute('jobs-description/competencies/delete', ['id' => $record['uuid']])]];array_push($items, $item);}return new JsonModel(['success' => true,'data' => ['items' => $items,'total' => $paginator->getTotalItemCount(),]]);} else {if ($currentCompany) {$form = new CompetencyForm($this->adapter, $currentCompany->id);} else {$form = new CompetencyForm($this->adapter);}$this->layout()->setTemplate('layout/layout-backend');$viewModel = new ViewModel();$viewModel->setTemplate('leaders-linked/competencies/index.phtml');$viewModel->setVariables(['form' => $form,]);return $viewModel;}} else {return new JsonModel(['success' => false,'data' => 'ERROR_METHOD_NOT_ALLOWED']);}}public function addAction() {$currentUserPlugin = $this->plugin('currentUserPlugin');$currentUser = $currentUserPlugin->getUser();$currentCompany = $currentUserPlugin->getCompany();$request = $this->getRequest();if ($request->isGet()) {$behaviors = [];$behaviorMapper = BehaviorMapper::getInstance($this->adapter);if($currentCompany) {$records = $behaviorMapper->fetchAllActiveByCompanyId($currentCompany->id);} else {$records = $behaviorMapper->fetchAllActiveByDefault();}foreach($records as $record){array_push($behaviors, ['id' => $record->uuid,'description' => $record->description,'checked' => 0]);}return new JsonModel(['success' => true,'data' => ['behaviors' => $behaviors]]);} else if ($request->isPost()) {if ($currentCompany) {$form = new CompetencyForm($this->adapter, $currentCompany->id);} else {$form = new CompetencyForm($this->adapter);}$dataPost = $request->getPost()->toArray();$form->setData($dataPost);if ($form->isValid()) {$dataPost = (array) $form->getData();$dataPost['status'] = $dataPost['status'] ? $dataPost['status'] : Competency::STATUS_INACTIVE;$competencyTypeMapper = CompetencyTypeMapper::getInstance($this->adapter);$competencyType = $competencyTypeMapper->fetchOneByUuid($dataPost['competency_type_id']);$dataPost['competency_type_id'] = $competencyType->id;$hydrator = new ObjectPropertyHydrator();$competency = new Competency();$hydrator->hydrate($dataPost, $competency);if ($currentCompany) {$competency->company_id = $currentCompany->id;}$competencyMapper = CompetencyMapper::getInstance($this->adapter);$result = $competencyMapper->insert($competency);if ($result) {$competencyBehaviorMapper = CompetencyBehaviorMapper::getInstance($this->adapter);$behaviorMapper = BehaviorMapper::getInstance($this->adapter);$competencyBehaviorMapper->deleteAllBCompetencyId($competency->id);$behavior_ids = $dataPost['behavior_id'];foreach ($behavior_ids as $behavior_id) {$behavior = $behaviorMapper->fetchOneByUuid($behavior_id);if ($behavior) {$behaviorCompetency = new CompetencyBehavior();$behaviorCompetency->competency_id = $competency->id;$behaviorCompetency->behavior_id = $behavior->id;$competencyBehaviorMapper->insert($behaviorCompetency);}}$this->logger->info('Se agrego la competencia ' . $competency->name, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);$data = ['success' => true,'data' => 'LABEL_RECORD_ADDED'];} else {$data = ['success' => false,'data' => $competencyMapper->getError()];}return new JsonModel($data);} else {$messages = [];$form_messages = (array) $form->getMessages();foreach ($form_messages as $fieldname => $field_messages) {$messages[$fieldname] = array_values($field_messages);}return new JsonModel(['success' => false,'data' => $messages]);}} else {$data = ['success' => false,'data' => 'ERROR_METHOD_NOT_ALLOWED'];return new JsonModel($data);}return new JsonModel($data);}public function editAction() {$currentUserPlugin = $this->plugin('currentUserPlugin');$currentUser = $currentUserPlugin->getUser();$currentCompany = $currentUserPlugin->getCompany();$request = $this->getRequest();$uuid = $this->params()->fromRoute('id');if (!$uuid) {$data = ['success' => false,'data' => 'ERROR_INVALID_PARAMETER'];return new JsonModel($data);}$competencyMapper = CompetencyMapper::getInstance($this->adapter);$competency = $competencyMapper->fetchOneByUuid($uuid);if (!$competency) {$data = ['success' => false,'data' => 'ERROR_RECORD_NOT_FOUND'];return new JsonModel($data);}if ($currentCompany) {if ($competency->company_id != $currentCompany->id) {$data = ['success' => false,'data' => 'ERROR_UNAUTHORIZED'];return new JsonModel($data);}} else {if ($competency->company_id) {$data = ['success' => false,'data' => 'ERROR_UNAUTHORIZED'];return new JsonModel($data);}}if ($request->isGet()) {$competencyTypeMapper = CompetencyTypeMapper::getInstance($this->adapter);$competencyType = $competencyTypeMapper->fetchOne($competency->competency_type_id);$competencyBehaviorMapper = CompetencyBehaviorMapper::getInstance($this->adapter);$behaviorMapper = BehaviorMapper::getInstance($this->adapter);if($currentCompany) {$records = $behaviorMapper->fetchAllActiveByCompanyId($currentCompany->id);} else {$records = $behaviorMapper->fetchAllActiveByDefault();}$behaviors = [];foreach($records as $record){$competencyBehavior = $competencyBehaviorMapper->fetchOneByBehaviorIdAndCompetencyId($record->id, $competency->id);array_push($behaviors, ['id' => $record->uuid,'description' => $record->description,'checked' => $competencyBehavior ? 1 : 0]);}$response = ['success' => true,'data' =>['competency_type_id' => $competencyType->uuid,'name' => $competency->name,'description' => $competency->description,'status' => $competency->status,'behaviors' => $behaviors,]];return new JsonModel($response);}else if ($request->isPost()) {if ($currentCompany) {$form = new CompetencyForm($this->adapter, $currentCompany->id);} else {$form = new CompetencyForm($this->adapter);}$dataPost = $request->getPost()->toArray();$form->setData($dataPost);if ($form->isValid()) {$dataPost = (array) $form->getData();$dataPost['status'] = empty($dataPost['status']) ? Competency::STATUS_INACTIVE : $dataPost['status'];$competencyTypeMapper = CompetencyTypeMapper::getInstance($this->adapter);$competencyType = $competencyTypeMapper->fetchOneByUuid($dataPost['competency_type_id']);$dataPost['competency_type_id'] = $competencyType->id;$hydrator = new ObjectPropertyHydrator();$hydrator->hydrate($dataPost, $competency);$result = $competencyMapper->update($competency);if ($result) {$competencyBehaviorMapper = CompetencyBehaviorMapper::getInstance($this->adapter);$behaviorMapper = BehaviorMapper::getInstance($this->adapter);$competencyBehaviorMapper->deleteAllBCompetencyId($competency->id);$behavior_ids = $dataPost['behavior_id'];foreach ($behavior_ids as $behavior_id) {$behavior = $behaviorMapper->fetchOneByUuid($behavior_id);if ($behavior) {$behaviorCompetency = new CompetencyBehavior();$behaviorCompetency->competency_id = $competency->id;$behaviorCompetency->behavior_id = $behavior->id;$competencyBehaviorMapper->insert($behaviorCompetency);}}$this->logger->info('Se actualizo la competencia ' . $competencyType->name, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);$data = ['success' => true,'data' => 'LABEL_RECORD_UPDATED'];} else {$data = ['success' => false,'data' => $competencyMapper->getError()];}return new JsonModel($data);} else {$messages = [];$form_messages = (array) $form->getMessages();foreach ($form_messages as $fieldname => $field_messages) {$messages[$fieldname] = array_values($field_messages);}return new JsonModel(['success' => false,'data' => $messages]);}} else {$data = ['success' => false,'data' => 'ERROR_METHOD_NOT_ALLOWED'];return new JsonModel($data);}return new JsonModel($data);}public function deleteAction() {$currentUserPlugin = $this->plugin('currentUserPlugin');$currentUser = $currentUserPlugin->getUser();$currentCompany = $currentUserPlugin->getCompany();$request = $this->getRequest();$uuid = $this->params()->fromRoute('id');if (!$uuid) {$data = ['success' => false,'data' => 'ERROR_INVALID_PARAMETER'];return new JsonModel($data);}$competencyMapper = CompetencyMapper::getInstance($this->adapter);$competency = $competencyMapper->fetchOneByUuid($uuid);if (!$competency) {$data = ['success' => false,'data' => 'ERROR_RECORD_NOT_FOUND'];return new JsonModel($data);}if ($currentCompany) {if ($competency->company_id != $currentCompany->id) {$data = ['success' => false,'data' => 'ERROR_UNAUTHORIZED'];return new JsonModel($data);}} else {if ($competency->company_id) {$data = ['success' => false,'data' => 'ERROR_UNAUTHORIZED'];return new JsonModel($data);}}if ($request->isPost()) {$result = $competencyMapper->delete($competency);if ($result) {$this->logger->info('Se borro la competencia ' . $competency->name, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);$data = ['success' => true,'data' => 'LABEL_RECORD_DELETED'];} else {$data = ['success' => false,'data' => $competencyMapper->getError()];return new JsonModel($data);}} else {$data = ['success' => false,'data' => 'ERROR_METHOD_NOT_ALLOWED'];return new JsonModel($data);}return new JsonModel($data);}public function importAction() {$currentUserPlugin = $this->plugin('currentUserPlugin');$currentUser = $currentUserPlugin->getUser();$currentCompany = $currentUserPlugin->getCompany();if (!$currentCompany) {$data = ['success' => false,'data' => 'ERROR_UNAUTHORIZED'];return new JsonModel($data);}$request = $this->getRequest();if ($request->isPost()) {$competencyTypeMapper = CompetencyTypeMapper::getInstance($this->adapter);$competencyMapper = CompetencyMapper::getInstance($this->adapter);$competenciesDefault = $competencyMapper->fetchAllByDefault();$new_records = 0;foreach ($competenciesDefault as $competencyDefault) {if ($competencyDefault->status == Competency::STATUS_INACTIVE) {continue;}$competency = $competencyMapper->fetchOneByCompanyIdAndCompetencyIdDefault($currentCompany->id, $competencyDefault->id);if (!$competency) {$competencyType = $competencyTypeMapper->fetchOneByCompanyId($currentCompany->id, $competencyDefault->competency_type_id);if (!$competencyType) {$competencyTypeDefault = $competencyTypeMapper->fetchOne($competencyDefault->competency_type_id);if (!$competencyTypeDefault) {continue;}$competencyType = new CompetencyType();$competencyType->company_id = $currentCompany->id;$competencyType->competency_type_id_default = $competencyTypeDefault->id;$competencyType->description = $competencyTypeDefault->description;$competencyType->name = $competencyTypeDefault->name;$competencyType->status = CompetencyType::STATUS_ACTIVE;if (!$competencyTypeMapper->insert($competencyType)) {$data = ['success' => false,'data' => 'ERROR_CANT_ADD_COMPETENCY_TYPE'];return new JsonModel($data);}}$competency = new Competency();$competency->competency_id_default = $competencyDefault->id;$competency->company_id = $currentCompany->id;$competency->competency_type_id = $competencyType->id;$competency->description = $competencyDefault->description;$competency->name = $competencyDefault->name;$competency->status = Competency::STATUS_ACTIVE;$behaviorMapper = BehaviorMapper::getInstance($this->adapter);$competencyBehaviorMapper = CompetencyBehaviorMapper::getInstance($this->adapter);$competencyBehaviors = $competencyBehaviorMapper->fetchAllByCompetencyId($competency->id);foreach ($competencyBehaviors as $record) {$behavior = $behaviorMapper->fetchOne($record->behavior_id);$behavior = $behaviorMapper->fetchOneByCompanyIdAndBehaviorIdDefault($currentCompany->id, $record->behavior_id);if ($behavior) {$behaviorCompetency = new CompetencyBehavior();$behaviorCompetency->competency_id = $competency->id;$behaviorCompetency->behavior_id = $behavior->id;$competencyBehaviorMapper->insert($behaviorCompetency);}}if ($competencyMapper->insert($competency)) {$new_records++;} else {$data = ['success' => false,'data' => $competencyMapper->getError()];return new JsonModel($data);}}}if ($new_records) {if (1 == $new_records) {$data = ['success' => true,'data' => 'LABEL_1_COMPETENCY_IMPORTED'];return new JsonModel($data);} else {$data = ['success' => true,'data' => $new_records . ' LABEL_MULTI_COMPETENCIES_IMPORTED'];return new JsonModel($data);}} else {$data = ['success' => true,'data' => 'LABEL_NO_COMPETENCY_IMPORTED'];return new JsonModel($data);}} else {$data = ['success' => false,'data' => 'ERROR_METHOD_NOT_ALLOWED'];return new JsonModel($data);}return new JsonModel($data);}}