Rev 564 | 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\JobDescriptionMapper;use LeadersLinked\Mapper\CompetencyTypeMapper;use LeadersLinked\Model\JobDescription;use LeadersLinked\Form\JobDescriptionForm;use LeadersLinked\Mapper\CompetencyMapper;use LeadersLinked\Mapper\JobDescriptionCompetencyMapper;use LeadersLinked\Mapper\JobDescriptionSubordinateMapper;use LeadersLinked\Model\JobDescriptionCompetency;use LeadersLinked\Model\JobDescriptionSubordinate;class JobDescriptionController 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);$page = intval($this->params()->fromQuery('start', 1), 10);$records_x_page = intval($this->params()->fromQuery('length', 10), 10);$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 = ['name'];$order_field = isset($fields[$order_field]) ? $fields[$order_field] : 'name';if(!in_array($order_direction, ['ASC', 'DESC'])) {$order_direction = 'ASC';}$jobDescriptionMapper = JobDescriptionMapper::getInstance($this->adapter);$paginator = $jobDescriptionMapper->fetchAllDataTableByCompanyId($currentCompany->id, $search, $page, $records_x_page, $order_field, $order_direction);$items = [];$records = $paginator->getCurrentItems();foreach($records as $record){$item = ['name' => $record->name,'status' => $record->status,'actions' => ['link_edit' => $this->url()->fromRoute('settings/jobs-description/edit', ['id' => $record->uuid ]),'link_delete' => $this->url()->fromRoute('settings/jobs-description/delete', ['id' => $record->uuid ])]];array_push($items, $item);}return new JsonModel(['success' => true,'data' => ['items' => $items,'total' => $paginator->getTotalItemCount(),]]);} else {$form = new JobDescriptionForm($this->adapter, $currentCompany->id);$this->layout()->setTemplate('layout/layout-backend');$viewModel = new ViewModel();$viewModel->setTemplate('leaders-linked/jobs-description/index.phtml');$viewModel->setVariable('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()) {$data = ['competency_types' => [],'competencies' => [],'jobs_description' => [],];$competencyTypeMapper = CompetencyTypeMapper::getInstance($this->adapter);$records = $competencyTypeMapper->fetchAllByCompanyId($currentCompany->id);$competencyTypesUUID = [];foreach($records as $record){array_push($data['competency_types'], ['competency_type_id' => $record->uuid,'name' => $record->name,]);$competencyTypesUUID[$record->id] = $record->uuid;}$competencyMapper = CompetencyMapper::getInstance($this->adapter);$records = $competencyMapper->fetchAllActiveByCompanyId($currentCompany->id);foreach($records as $record){if(isset($competencyTypesUUID[$record->competency_type_id])) {array_push($data['competencies'], ['competency_type_id' => $competencyTypesUUID[$record->competency_type_id],'competency_id' => $record->uuid,'name' => $record->name,]);}}$jobDescriptionMapper = JobDescriptionMapper::getInstance($this->adapter);$records = $jobDescriptionMapper->fetchAllActiveByCompanyId($currentCompany->id);foreach($records as $record){array_push($data['jobs_description'], ['job_description_id' => $record->uuid,'name' => $record->name]);}$data = ['success' => true,'data' => $data,];return new JsonModel($data);} else if($request->isPost()) {$form = new JobDescriptionForm($this->adapter, $currentCompany->id);$dataPost = $request->getPost()->toArray();$form->setData($dataPost);if($form->isValid()) {$dataPost = (array) $form->getData();$dataPost['status'] = $dataPost['status'] ? $dataPost['status'] : JobDescription::STATUS_INACTIVE;$jobDescriptionMapper = JobDescriptionMapper::getInstance($this->adapter);if(!empty($dataPost['job_description_id_boss'])) {$jobDescriptionBoss = $jobDescriptionMapper->fetchOneByUuid($dataPost['job_description_id_boss']);if($jobDescriptionBoss) {if($jobDescriptionBoss->company_id == $currentCompany->id) {$dataPost['job_description_id_boss'] = $jobDescriptionBoss->id;} else {$dataPost['job_description_id_boss'] = null;}} else {$dataPost['job_description_id_boss'] = null;}}$hydrator = new ObjectPropertyHydrator();$jobDescription = new JobDescription();$hydrator->hydrate($dataPost, $jobDescription);if($currentCompany) {$jobDescription->company_id = $currentCompany->id;}$jobDescriptionMapper = JobDescriptionMapper::getInstance($this->adapter);$result = $jobDescriptionMapper->insert($jobDescription);if($result) {$jobDescriptionSubordinateMapper = JobDescriptionSubordinateMapper::getInstance($this->adapter);$jobDescriptionSubordinateMapper->deleteAllByJobDescriptionIdTopLevel($jobDescription->id);$jobDescriptionCompetencyMapper = JobDescriptionCompetencyMapper::getInstance($this->adapter);$jobDescriptionCompetencyMapper->deleteAllBJobDescriptionId($jobDescription->id);$competencyMapper = CompetencyMapper::getInstance($this->adapter);$competencies = $competencyMapper->fetchAllActiveByCompanyId($currentCompany->id);foreach($competencies as $competency){$level = filter_var($this->params()->fromPost('competency_level' . $competency->uuid, ''), FILTER_SANITIZE_NUMBER_INT);if(in_array($level, [1, 2, 3, 4])) {$jobDescriptionCompetency = new JobDescriptionCompetency();$jobDescriptionCompetency->competency_id = $competency->id;$jobDescriptionCompetency->job_description_id = $jobDescription->id;$jobDescriptionCompetency->level = $level;$jobDescriptionCompetencyMapper->insert($jobDescriptionCompetency);}}$jobsDescriptionListingSubordinate = $jobDescriptionMapper->fetchAllActiveByCompanyIdWhereIdNotEqual($currentCompany->id, $jobDescription->id);foreach($jobsDescriptionListingSubordinate as $jobDescriptionListingSubordinate){$job_description_subordinate = filter_var($this->params()->fromPost('job_description_id_subordinate' . $jobDescriptionListingSubordinate->uuid, ''), FILTER_SANITIZE_STRING);if($job_description_subordinate) {$jobDescriptionSubordinate = new JobDescriptionSubordinate();$jobDescriptionSubordinate->job_description_id_top_level = $jobDescription->id;$jobDescriptionSubordinate->job_description_id_low_level = $jobDescriptionListingSubordinate->id;$jobDescriptionSubordinateMapper->insert($jobDescriptionSubordinate);}}$this->logger->info('Se agrego el cargo ' . $jobDescription->name, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);$data = ['success' => true,'data' => 'LABEL_RECORD_ADDED'];} else {$data = ['success' => false,'data' => $jobDescriptionMapper->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);}$jobDescriptionMapper = JobDescriptionMapper::getInstance($this->adapter);$jobDescription = $jobDescriptionMapper->fetchOneByUuid($uuid);if(!$jobDescription) {$data = ['success' => false,'data' => 'ERROR_RECORD_NOT_FOUND'];return new JsonModel($data);}if($jobDescription->company_id != $currentCompany->id) {$data = ['success' => false,'data' => 'ERROR_UNAUTHORIZED'];return new JsonModel($data);}if($request->isPost()) {$form = new JobDescriptionForm($this->adapter, $currentCompany->id, $jobDescription->id);$dataPost = $request->getPost()->toArray();$form->setData($dataPost);if($form->isValid()) {$dataPost = (array) $form->getData();$dataPost['status'] = $dataPost['status'] ? $dataPost['status'] : JobDescription::STATUS_INACTIVE;if(!empty($dataPost['job_description_id_boss'])) {$jobDescriptionBoss = $jobDescriptionMapper->fetchOneByUuid($dataPost['job_description_id_boss']);if($jobDescriptionBoss) {if($jobDescriptionBoss->id != $jobDescription->id && $jobDescriptionBoss->company_id == $currentCompany->id) {$dataPost['job_description_id_boss'] = $jobDescriptionBoss->id;} else {$dataPost['job_description_id_boss'] = null;}} else {$dataPost['job_description_id_boss'] = null;}}$hydrator = new ObjectPropertyHydrator();$hydrator->hydrate($dataPost, $jobDescription);$result = $jobDescriptionMapper->update($jobDescription);if($result) {$jobDescriptionSubordinateMapper = JobDescriptionSubordinateMapper::getInstance($this->adapter);$jobDescriptionSubordinateMapper->deleteAllByJobDescriptionIdTopLevel($jobDescription->id);$jobDescriptionCompetencyMapper = JobDescriptionCompetencyMapper::getInstance($this->adapter);$jobDescriptionCompetencyMapper->deleteAllBJobDescriptionId($jobDescription->id);$competencyMapper = CompetencyMapper::getInstance($this->adapter);$competencies = $competencyMapper->fetchAllActiveByCompanyId($currentCompany->id);foreach($competencies as $competency){$level = filter_var($this->params()->fromPost('competency_level' . $competency->uuid, ''), FILTER_SANITIZE_NUMBER_INT);if(in_array($level, [ 1, 2, 3, 4])) {$jobDescriptionCompetency = new JobDescriptionCompetency();$jobDescriptionCompetency->competency_id = $competency->id;$jobDescriptionCompetency->job_description_id = $jobDescription->id;$jobDescriptionCompetency->level = $level;$jobDescriptionCompetencyMapper->insert($jobDescriptionCompetency);}}$jobsDescriptionListingSubordinate = $jobDescriptionMapper->fetchAllActiveByCompanyIdWhereIdNotEqual($currentCompany->id, $jobDescription->id);foreach($jobsDescriptionListingSubordinate as $jobDescriptionListingSubordinate){$job_description_subordinate = filter_var($this->params()->fromPost('job_description_id_subordinate' . $jobDescriptionListingSubordinate->uuid, ''), FILTER_SANITIZE_STRING);if($job_description_subordinate) {$jobDescriptionSubordinate = new JobDescriptionSubordinate();$jobDescriptionSubordinate->job_description_id_top_level = $jobDescription->id;$jobDescriptionSubordinate->job_description_id_low_level = $jobDescriptionListingSubordinate->id;$jobDescriptionSubordinateMapper->insert($jobDescriptionSubordinate);}}$this->logger->info('Se actualizo el cargo ' . $jobDescription->name, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);$data = ['success' => true,'data' => 'LABEL_RECORD_UPDATED'];} else {$data = ['success' => false,'data' => $jobDescriptionMapper->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 if ($request->isGet()) {$hydrator = new ObjectPropertyHydrator();$data = $hydrator->extract($jobDescription);if(!empty($data['job_description_id_boss'])) {$jobDescriptionBoss = $jobDescriptionMapper->fetchOne($data['job_description_id_boss']);if($jobDescriptionBoss) {$data['job_description_id_boss'] = $jobDescriptionBoss->uuid;} else {$data['job_description_id_boss'] = '';}} else {$data['job_description_id_boss'] = '';}$data['competency_types'] = [];$competencyTypeMapper = CompetencyTypeMapper::getInstance($this->adapter);$records = $competencyTypeMapper->fetchAllByCompanyId($currentCompany->id);$competencyTypesUUID = [];foreach($records as $record){array_push($data['competency_types'], ['competency_type_id' => $record->uuid,'name' => $record->name,]);$competencyTypesUUID[$record->id] = $record->uuid;}$data['competencies'] = [];$jobDescriptionCompetencyMapper = JobDescriptionCompetencyMapper::getInstance($this->adapter);$competencyMapper = CompetencyMapper::getInstance($this->adapter);$records = $competencyMapper->fetchAllActiveByCompanyId($currentCompany->id);foreach($records as $record){if(isset($competencyTypesUUID[ $record->competency_type_id ])) {$level = 0;$jobDescriptionCompetency = $jobDescriptionCompetencyMapper->fetchOneByJobDescriptionIdAndCompetencyId($jobDescription->id, $record->id);if($jobDescriptionCompetency) {$level = $jobDescriptionCompetency->level;}array_push($data['competencies'], ['competency_type_id' => $competencyTypesUUID[$record->competency_type_id],'competency_id' => $record->uuid,'name' => $record->name,'level' => $level]);}}$data['jobs_description'] = [];$jobsDescriptionUUID = [];$jobDescriptionMapper = JobDescriptionMapper::getInstance($this->adapter);$records = $jobDescriptionMapper->fetchAllActiveByCompanyId($currentCompany->id);foreach($records as $record){if($record->id == $jobDescription->id) {continue;}$jobsDescriptionUUID[ $record->id ] = $record->uuid;array_push($data['jobs_description'], ['job_description_id' => $record->uuid,'name' => $record->name]);}$data['subordinates'] = [];$jobDescriptionSubordinateMapper = JobDescriptionSubordinateMapper::getInstance($this->adapter);$records = $jobDescriptionSubordinateMapper->fetchAllByJobDescriptionIdTopLevel($jobDescription->id);foreach($records as $record){if(isset($jobsDescriptionUUID[$record->job_description_id_low_level])) {array_push($data['subordinates'], $jobsDescriptionUUID[$record->job_description_id_low_level]);}}$response = ['success' => true,'data' => $data];return new JsonModel($response);} 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);}$jobDescriptionMapper = JobDescriptionMapper::getInstance($this->adapter);$jobDescription = $jobDescriptionMapper->fetchOneByUuid($uuid);if(!$jobDescription) {$data = ['success' => false,'data' => 'ERROR_RECORD_NOT_FOUND'];return new JsonModel($data);}if($jobDescription->company_id != $currentCompany->id) {$data = ['success' => false,'data' => 'ERROR_UNAUTHORIZED'];return new JsonModel($data);}if($request->isPost()) {$result = $jobDescriptionMapper->delete($jobDescription);if($result) {$this->logger->info('Se borro el cargo de trabajo ' . $jobDescription->name, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);$data = ['success' => true,'data' => 'LABEL_RECORD_DELETED'];} else {$data = ['success' => false,'data' => $jobDescriptionMapper->getError()];return new JsonModel($data);}} else {$data = ['success' => false,'data' => 'ERROR_METHOD_NOT_ALLOWED'];return new JsonModel($data);}return new JsonModel($data);}}