From 10f662ce07cdc0924cb6688fcb2d502e7aa21acc Mon Sep 17 00:00:00 2001 From: Frederic Guillot Date: Fri, 13 May 2016 21:44:31 -0400 Subject: Add tasks in bulk from the board --- app/Controller/TaskBulk.php | 88 +++++++++++++++++++++++++++++++++++++++++ app/Controller/Taskcreation.php | 2 +- 2 files changed, 89 insertions(+), 1 deletion(-) create mode 100644 app/Controller/TaskBulk.php (limited to 'app/Controller') diff --git a/app/Controller/TaskBulk.php b/app/Controller/TaskBulk.php new file mode 100644 index 00000000..4e9d4443 --- /dev/null +++ b/app/Controller/TaskBulk.php @@ -0,0 +1,88 @@ +getProject(); + + if (empty($values)) { + $values = array( + 'swimlane_id' => $this->request->getIntegerParam('swimlane_id'), + 'column_id' => $this->request->getIntegerParam('column_id'), + 'project_id' => $project['id'], + ); + } + + $this->response->html($this->template->render('task_bulk/show', array( + 'project' => $project, + 'values' => $values, + 'errors' => $errors, + 'users_list' => $this->projectUserRole->getAssignableUsersList($project['id'], true, false, true), + 'colors_list' => $this->color->getList(), + 'categories_list' => $this->category->getList($project['id']), + ))); + } + + /** + * Save all tasks in the database + */ + public function save() + { + $project = $this->getProject(); + $values = $this->request->getValues(); + list($valid, $errors) = $this->taskValidator->validateBulkCreation($values); + + if ($valid) { + $this->createTasks($project, $values); + $this->response->redirect($this->helper->url->to( + 'Board', + 'show', + array('project_id' => $project['id']), + 'swimlane-'. $values['swimlane_id'] + ), true); + } else { + $this->show($values, $errors); + } + } + + /** + * Create all tasks + * + * @param array $project + * @param array $values + */ + protected function createTasks(array $project, array $values) + { + $tasks = preg_split('/\r\n|[\r\n]/', $values['tasks']); + + foreach ($tasks as $title) { + $title = trim($title); + + if (! empty($title)) { + $this->taskCreation->create(array( + 'title' => $title, + 'column_id' => $values['column_id'], + 'swimlane_id' => $values['swimlane_id'], + 'category_id' => empty($values['category_id']) ? 0 : $values['category_id'], + 'owner_id' => empty($values['owner_id']) ? 0 : $values['owner_id'], + 'color_id' => $values['color_id'], + 'project_id' => $project['id'], + )); + } + } + } +} diff --git a/app/Controller/Taskcreation.php b/app/Controller/Taskcreation.php index 1d8a0e29..1c9e0d82 100644 --- a/app/Controller/Taskcreation.php +++ b/app/Controller/Taskcreation.php @@ -79,6 +79,6 @@ class Taskcreation extends Base )); } - $this->response->redirect($this->helper->url->to('board', 'show', array('project_id' => $project['id']))); + $this->response->redirect($this->helper->url->to('board', 'show', array('project_id' => $project['id'])), true); } } -- cgit v1.2.3