Rev 16785 | 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\Mvc\Controller\AbstractActionController;use Laminas\Log\LoggerInterface;use Laminas\View\Model\JsonModel;use Laminas\View\Model\ViewModel;use LeadersLinked\Library\Functions;use LeadersLinked\Hydrator\ObjectPropertyHydrator;use LeadersLinked\Mapper\PlanningTaskMapper;use LeadersLinked\Model\PlanningTask;use LeadersLinked\Form\Planning\PlanningTaskForm;use LeadersLinked\Form\Planning\PlanningTaskHeaderForm;use LeadersLinked\Mapper\PlanningPeriodMapper;use LeadersLinked\Model\PlanningObjective;use LeadersLinked\Mapper\PlanningObjectiveMapper;use LeadersLinked\Mapper\PlanningGoalMapper;use LeadersLinked\Mapper\PlanningTaskUserMapper;use LeadersLinked\Mapper\UserMapper;use LeadersLinked\Model\PlanningTaskUser;class PlanningTaskController extends AbstractActionController {/**** @var \Laminas\Db\Adapter\AdapterInterface*/private $adapter;/**** @var \LeadersLinked\Cache\CacheInterface*/private $cache;/**** @var \Laminas\Log\LoggerInterface*/private $logger;/**** @var array*/private $config;/**** @var \Laminas\Mvc\I18n\Translator*/private $translator;/**** @param \Laminas\Db\Adapter\AdapterInterface $adapter* @param \LeadersLinked\Cache\CacheInterface $cache* @param \Laminas\Log\LoggerInterface LoggerInterface $logger* @param array $config* @param \Laminas\Mvc\I18n\Translator $translator*/public function __construct($adapter, $cache, $logger, $config, $translator){$this->adapter = $adapter;$this->cache = $cache;$this->logger = $logger;$this->config = $config;$this->translator = $translator;}public function indexAction() {$currentUserPlugin = $this->plugin('currentUserPlugin');$currentUser = $currentUserPlugin->getUser();$currentCompany = $currentUserPlugin->getCompany();$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) {$link_add = '';$period_id = Functions::sanitizeFilterString($this->params()->fromQuery('period_id'));$objective_id = Functions::sanitizeFilterString($this->params()->fromQuery('objective_id'));$goal_id = Functions::sanitizeFilterString($this->params()->fromQuery('goal_id'));if(empty($period_id)) {return new JsonModel(['success' => true,'data' => ['items' => [],'total' => 0,'link_add' => '',]]);}$planningPeriodMapper = PlanningPeriodMapper::getInstance($this->adapter);$planningPeriod = $planningPeriodMapper->fetchOneByUuid($period_id);if (!$planningPeriod) {$data = ['success' => false,'data' => 'ERROR_RECORD_NOT_FOUND'];return new JsonModel($data);}if ($planningPeriod->company_id != $currentCompany->id) {return new JsonModel(['success' => false,'data' => 'ERROR_UNAUTHORIZED']);}$objectives = [];$goals = [];$planningObjectiveMapper = PlanningObjectiveMapper::getInstance($this->adapter);if(empty($objective_id)) {$planningObjective = null;$records = $planningObjectiveMapper->fetchAllActiveByCompanyIdAndPeriodId($planningPeriod->company_id, $planningPeriod->id);foreach($records as $record){if(empty($planningObjective)) {$planningObjective = $record;}$objectives[ $record->uuid ] = $record->title;}} else {$planningObjective = $planningObjectiveMapper->fetchOneByUuid($objective_id);if (!$planningObjective) {$data = ['success' => false,'data' => 'ERROR_RECORD_NOT_FOUND'];return new JsonModel($data);}if ($planningObjective->period_id != $planningPeriod->id) {return new JsonModel(['success' => false,'data' => 'ERROR_UNAUTHORIZED']);}}if(empty($planningObjective)) {return new JsonModel(['success' => true,'data' => ['items' => [],'total' => 0,'link_add' => '','objectives' => $objectives,'goals' => $goals,]]);}$planningGoalMapper = PlanningGoalMapper::getInstance($this->adapter);if(empty($goal_id)) {$planningGoal = null;$records = $planningGoalMapper->fetchAllActiveByCompanyIdAndObjectiveId($planningPeriod->company_id, $planningObjective->id);foreach($records as $record){if(empty($planningGoal)) {$planningGoal = $record;}$goals[ $record->uuid ] = $record->title;}} else {$planningGoal = $planningGoalMapper->fetchOneByUuid($goal_id);if (!$planningGoal) {$data = ['success' => false,'data' => 'ERROR_RECORD_NOT_FOUND'];return new JsonModel($data);}if ($planningGoal->objective_id != $planningObjective->id) {return new JsonModel(['success' => false,'data' => 'ERROR_UNAUTHORIZED']);}}if(empty($planningGoal)) {return new JsonModel(['success' => true,'data' => ['items' => [],'total' => 0,'link_add' => '','objectives' => $objectives,'goals' => $goals,]]);}$link_add = $this->url()->fromRoute('planning/tasks/add', ['goal_id' => $planningGoal->uuid ]);$acl = $this->getEvent()->getViewModel()->getVariable('acl');$allowAdd = $acl->isAllowed($currentUser->usertype_id, 'planning/tasks/add');$allowEdit = $acl->isAllowed($currentUser->usertype_id, 'planning/tasks/edit');$allowDelete = $acl->isAllowed($currentUser->usertype_id, 'planning/tasks/delete');$search = $this->params()->fromQuery('search', []);$search = empty($search['value']) ? '' : Functions::sanitizeFilterString($search['value']);$records_x_page = intval($this->params()->fromQuery('length', 10), 10);$page = (intval($this->params()->fromQuery('start', 1), 10)/$records_x_page)+1;$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(Functions::sanitizeFilterString($order[0]['dir']));$fields = ['title', 'start', 'end', 'progress'];$order_field = isset($fields[$order_field]) ? $fields[$order_field] : 'title';if(!in_array($order_direction, ['ASC', 'DESC'])) {$order_direction = 'ASC';}$planningTaskMapper = PlanningTaskMapper::getInstance($this->adapter);$paginator = $planningTaskMapper->fetchAllDataTableByCompanyIdAndGoalId($planningGoal->company_id, $planningGoal->id, $search, $page, $records_x_page, $order_field, $order_direction);$items = [];$records = $paginator->getCurrentItems();foreach($records as $record){$dtStart = \DateTime::createFromFormat('Y-m-d', $record->start);$dtEnd = \DateTime::createFromFormat('Y-m-d', $record->end);$item = ['title' => $record->title,'description' => $record->description,'status' => $record->status,'start' => $dtStart->format('d/m/Y'),'end' => $dtEnd->format('d/m/Y'),'progress' => $record->progress ? $record->progress : 0,'actions' => ['link_edit' => $allowEdit ? $this->url()->fromRoute('planning/tasks/edit', ['id' => $record->uuid]) : '','link_delete' => $allowDelete ? $this->url()->fromRoute('planning/tasks/delete', ['id' => $record->uuid]) : '',//'link_goal' => $allowTask ? $this->url()->fromRoute('planning/tasks/tasks', ['goal_id' => $record->uuid]) : '',//'link_goal_report' => $allowTaskReport ? $this->url()->fromRoute('planning/tasks/report', ['id' => $record->uuid]) : '',]];array_push($items, $item);}return new JsonModel(['success' => true,'data' => ['items' => $items,'objectives' => $objectives,'goals' => $goals,'total' => $paginator->getTotalItemCount(),'link_add' => $allowAdd ? $link_add : '',]]);} else {$form = new PlanningTaskForm($this->adapter, $currentCompany->id);$formFilter = new PlanningTaskHeaderForm($this->adapter, $currentCompany->id);$this->layout()->setTemplate('layout/layout-backend');$viewModel = new ViewModel();$viewModel->setTemplate('leaders-linked/planning/tasks');$viewModel->setVariables(['form' => $form,'formFilter' => $formFilter,]);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->isPost()) {$goal_id = Functions::sanitizeFilterString($this->params()->fromRoute('goal_id'));$planningGoalMapper = PlanningGoalMapper::getInstance($this->adapter);$planningGoal = $planningGoalMapper->fetchOneByUuid($goal_id);if (!$planningGoal) {$data = ['success' => false,'data' => 'ERROR_RECORD_NOT_FOUND'];return new JsonModel($data);}if ($planningGoal->company_id != $currentCompany->id) {return new JsonModel(['success' => false,'data' => 'ERROR_UNAUTHORIZED']);}$form = new PlanningTaskForm($this->adapter, $currentCompany->id);$dataPost = $request->getPost()->toArray();if(!empty($dataPost['date_range'])) {$s = explode('-', $dataPost['date_range']);$start = trim($s[0]);$end = trim($s[1]);$dtStart = \DateTime::createFromFormat('d/m/Y', $start);$dtEnd = \DateTime::createFromFormat('d/m/Y', $end);if(!$dtStart && !$dtEnd) {$dataPost['date_range'] = '';}}$form->setData($dataPost);if($form->isValid()) {$dataPost = (array) $form->getData();$dataPost['status'] = empty($dataPost['status']) ? PlanningTask::STATUS_INACTIVE : $dataPost['status'];$hydrator = new ObjectPropertyHydrator();$planningTask = new PlanningTask();$planningTask->company_id = $planningGoal->company_id;$planningTask->period_id = $planningGoal->period_id;$planningTask->objective_id = $planningGoal->objective_id;$planningTask->goal_id = $planningGoal->id;$hydrator->hydrate($dataPost, $planningTask);$planningTaskMapper = PlanningTaskMapper::getInstance($this->adapter);$result = $planningTaskMapper->insert($planningTask);if($result) {$userMapper = UserMapper::getInstance($this->adapter);$planningTaskUserMapper = PlanningTaskUserMapper::getInstance($this->adapter);$user_ids = empty($dataPost['user_id']) ? [] : $dataPost['user_id'];foreach($user_ids as $user_id){$user = $userMapper->fetchOneByUuid($user_id);if($user) {$planningTaskUser = new PlanningTaskUser();$planningTaskUser->company_id = $planningTask->company_id;$planningTaskUser->period_id = $planningTask->period_id;$planningTaskUser->objective_id = $planningTask->objective_id;$planningTaskUser->goal_id = $planningTask->goal_id;$planningTaskUser->task_id = $planningTask->id;$planningTaskUser->user_id = $user->id;$planningTaskUserMapper->insert($planningTaskUser);}}$this->logger->info('Se agrego el tarea la planificación : ' . $planningTask->title, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);$data = ['success' => true,'data' => 'LABEL_RECORD_ADDED'];} else {$data = ['success' => false,'data' => $planningTaskMapper->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);}$planningTaskMapper = PlanningTaskMapper::getInstance($this->adapter);$planningTask = $planningTaskMapper->fetchOneByUuid($uuid);if (!$planningTask) {$data = ['success' => false,'data' => 'ERROR_RECORD_NOT_FOUND'];return new JsonModel($data);}if ($planningTask->company_id != $currentCompany->id) {return new JsonModel(['success' => false,'data' => 'ERROR_UNAUTHORIZED']);}if($request->isPost()) {$form = new PlanningTaskForm($this->adapter, $currentCompany->id);$dataPost = $request->getPost()->toArray();$dataPost['status'] = empty($dataPost['status']) ? PlanningTask::STATUS_INACTIVE : $dataPost['status'];if(empty($dataPost['date_range'])) {$dataPost['start'] = date('Y-m-d');$dataPost['end'] = date('Y-m-d');} else {$s = explode('-', $dataPost['date_range']);$start = trim($s[0]);$end = trim($s[1]);$dtStart = \DateTime::createFromFormat('d/m/Y', $start);$dtEnd = \DateTime::createFromFormat('d/m/Y', $end);if($dtStart && $dtEnd) {$dataPost['start'] = $dtStart->format('Y-m-d');$dataPost['end'] = $dtEnd->format('Y-m-d');} else {$dataPost['start'] = date('Y-m-d');$dataPost['end'] = date('Y-m-d');}}$form->setData($dataPost);if($form->isValid()) {$dataPost = (array) $form->getData();$hydrator = new ObjectPropertyHydrator();$hydrator->hydrate($dataPost, $planningTask);$result = $planningTaskMapper->update($planningTask);if($result) {$userMapper = UserMapper::getInstance($this->adapter);$planningTaskUserMapper = PlanningTaskUserMapper::getInstance($this->adapter);$planningTaskUserMapper->deleteAllByTaskId($planningTask->id);$user_ids = empty($dataPost['user_id']) ? [] : $dataPost['user_id'];foreach($user_ids as $user_id){$user = $userMapper->fetchOneByUuid($user_id);if($user) {$planningTaskUser = new PlanningTaskUser();$planningTaskUser->company_id = $planningTask->company_id;$planningTaskUser->period_id = $planningTask->period_id;$planningTaskUser->objective_id = $planningTask->objective_id;$planningTaskUser->goal_id = $planningTask->goal_id;$planningTaskUser->task_id = $planningTask->id;$planningTaskUser->user_id = $user->id;$planningTaskUserMapper->insert($planningTaskUser);}}$this->logger->info('Se actualizo el tarea la planificación : ' . $planningTask->title, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);$data = ['success' => true,'data' => 'LABEL_RECORD_UPDATED'];} else {$data = ['success' => false,'data' => $planningTaskMapper->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()) {$user_ids = [];$userMapper = UserMapper::getInstance($this->adapter);$planningTaskUserMapper = PlanningTaskUserMapper::getInstance($this->adapter);$records = $planningTaskUserMapper->fetchAllByTaskId($planningTask->id);foreach($records as $record){$user = $userMapper->fetchOne($record->user_id);if($user) {array_push($user_ids, $user->uuid);}}$data = ['success' => true,'data' => ['title' => $planningTask->title,'description' => $planningTask->description,'start' => $planningTask->start,'end' => $planningTask->end,'status' => $planningTask->status,'progress' => $planningTask->progress,'cost' => $planningTask->cost,'place' => $planningTask->place,'how' => $planningTask->how,'detour' => $planningTask->detour,'evaluation' => $planningTask->evaluation,'priority' => $planningTask->priority,'urgent' => $planningTask->urgent,'user_id' => $user_ids,'hours' => $planningTask->hours,]];return new JsonModel($data);} else {$data = ['success' => false,'data' => 'ERROR_METHOD_NOT_ALLOWED'];return new JsonModel($data);}return new JsonModel($data);}public function deleteAction(){$currentUserPlugin = $this->plugin('currentUserPlugin');$currentCompany = $currentUserPlugin->getCompany();$currentUser = $currentUserPlugin->getUser();$request = $this->getRequest();$uuid = $this->params()->fromRoute('id');if(!$uuid) {$data = ['success' => false,'data' => 'ERROR_INVALID_PARAMETER'];return new JsonModel($data);}$planningTaskMapper = PlanningTaskMapper::getInstance($this->adapter);$planningTask = $planningTaskMapper->fetchOneByUuid($uuid);if (!$planningTask) {$data = ['success' => false,'data' => 'ERROR_RECORD_NOT_FOUND'];return new JsonModel($data);}if ($planningTask->company_id != $currentCompany->id) {return new JsonModel(['success' => false,'data' => 'ERROR_UNAUTHORIZED']);}if ($request->isPost()) {$result = $planningTaskMapper->delete($planningTask);if ($result) {$this->logger->info('Se borro el tarea de la planificación :' . $planningTask->title, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);$data = ['success' => true,'data' => 'LABEL_RECORD_DELETED'];} else {$data = ['success' => false,'data' => $planningTaskMapper->getError()];return new JsonModel($data);}} else {$data = ['success' => false,'data' => 'ERROR_METHOD_NOT_ALLOWED'];return new JsonModel($data);}return new JsonModel($data);}}