diff options
author | emkael <emkael@tlen.pl> | 2020-05-05 14:25:42 +0200 |
---|---|---|
committer | emkael <emkael@tlen.pl> | 2020-05-05 14:25:42 +0200 |
commit | 62827e6cf470449c117624058fb36ad94804bcc0 (patch) | |
tree | 10cd1e4d36c34b694acfadaa69fc7f6ae2b1eabd /plugins/TimeMachine/Controller/SubtaskController.php | |
parent | 7b66ddf2e4fbdb837e78d8b7dbaa9fc38391bc32 (diff) |
Diffstat (limited to 'plugins/TimeMachine/Controller/SubtaskController.php')
-rw-r--r-- | plugins/TimeMachine/Controller/SubtaskController.php | 100 |
1 files changed, 100 insertions, 0 deletions
diff --git a/plugins/TimeMachine/Controller/SubtaskController.php b/plugins/TimeMachine/Controller/SubtaskController.php new file mode 100644 index 00000000..423a0d88 --- /dev/null +++ b/plugins/TimeMachine/Controller/SubtaskController.php @@ -0,0 +1,100 @@ +<?php + +namespace Kanboard\Plugin\TimeMachine\Controller; + +use Kanboard\Controller\BaseController; +use Kanboard\Core\Controller\AccessForbiddenException; +use Kanboard\Core\Controller\PageNotFoundException; + +/** + * Subtask controller + * + * @package Kanboard\Plugin\TimeMachine\Controller + * @author yvalentin + */ +class SubtaskController extends BaseController +{ + + /** + * Edit form with subTaskTimeTracking + * + * @access public + * @param array $values + * @param array $errors + * @throws AccessForbiddenException + * @throws PageNotFoundException + */ + public function edit(array $values = [], array $valuesSttts = [], array $errors = [], array $errorsSttts = []) + { + $task = $this->getTask(); + $subtask = $this->getSubtask($task); + $sttts = $this->subtaskTimeTrackingModel->getBySubTaskId($subtask['id']); + + $this->response->html($this->template->render('subtask/edit', array( + 'values' => empty($values) ? $subtask : $values, + 'errors' => $errors, + 'errorsSttts' => $errorsSttts, + 'users_list' => $this->projectUserRoleModel->getAssignableUsersList($task['project_id']), + 'status_list' => $this->subtaskModel->getStatusList(), + 'sttts' => empty($valuesSttts) ? $sttts : $valuesSttts, + 'subtask' => $subtask, + 'task' => $task, + ))); + } + + /** + * Update and validate a subtask with subTaskTimeTracking + * + * @access public + */ + public function update() + { + $task = $this->getTask(); + $subtask = $this->getSubtask($task); + + $values = $this->request->getValues(); + $values['id'] = $subtask['id']; + $values['task_id'] = $task['id']; + + // get subTaskTimeTracking values + $valuesSttts = $this->getSubTaskTimeTracking($values); + + list($valid, $errors) = $this->subtaskValidator->validateModification($values); + list($validSttts, $errorsSttts) = $this->helper->subTaskTimeTrackingValidator->validates($valuesSttts); + + if ($valid && !in_array(false, $validSttts)) { + if ($this->subtaskModel->update($values) + && $this->subtaskTimeTrackingModel->updates($valuesSttts, $subtask['id'], $task['id'])) { + $this->flash->success(t('Sub-task updated successfully.')); + } else { + $this->flash->failure(t('Unable to update your sub-task.')); + } + + return $this->response->redirect($this->helper->url->to('TaskViewController', 'show', array('project_id' => $task['project_id'], 'task_id' => $task['id'])), true); + } + + return $this->edit($values, $valuesSttts, $errors, $errorsSttts); + } + + /** + * Get Sub Task Time Tracking from form values + * + * @param array $values + * + * @return array + */ + private function getSubTaskTimeTracking(array &$values) + { + $sttts = []; + foreach ($values as $key => $value) { + if(strpos($key,'-') !== false) { + list($column, $id) = explode('-', $key); + $sttts[$id][$column] = $value; + $sttts[$id]['id'] = $id; + unset($values[$key]); + } + } + + return $sttts; + } +} |