From 7d458cd5004d026dec0c41bbb1daacb259a52cfb Mon Sep 17 00:00:00 2001 From: Frederic Guillot Date: Mon, 12 Oct 2015 17:49:30 -0400 Subject: Add CSV import for tasks --- app/Controller/TaskImport.php | 73 +++++++++++++++++++++++++++++++++++++++++++ app/Controller/UserImport.php | 2 +- 2 files changed, 74 insertions(+), 1 deletion(-) create mode 100644 app/Controller/TaskImport.php (limited to 'app/Controller') diff --git a/app/Controller/TaskImport.php b/app/Controller/TaskImport.php new file mode 100644 index 00000000..0343b1dc --- /dev/null +++ b/app/Controller/TaskImport.php @@ -0,0 +1,73 @@ +getProject(); + + $this->response->html($this->projectLayout('task_import/step1', array( + 'project' => $project, + 'values' => $values, + 'errors' => $errors, + 'max_size' => ini_get('upload_max_filesize'), + 'delimiters' => Csv::getDelimiters(), + 'enclosures' => Csv::getEnclosures(), + 'title' => t('Import tasks from CSV file'), + ))); + } + + /** + * Process CSV file + * + */ + public function step2() + { + $project = $this->getProject(); + $values = $this->request->getValues(); + $filename = $this->request->getFilePath('file'); + + if (! file_exists($filename)) { + $this->step1($values, array('file' => array(t('Unable to read your file')))); + } + + $this->taskImport->projectId = $project['id']; + + $csv = new Csv($values['delimiter'], $values['enclosure']); + $csv->setColumnMapping($this->taskImport->getColumnMapping()); + $csv->read($filename, array($this->taskImport, 'import')); + + if ($this->taskImport->counter > 0) { + $this->session->flash(t('%d task(s) have been imported successfully.', $this->taskImport->counter)); + } + else { + $this->session->flashError(t('Nothing have been imported!')); + } + + $this->response->redirect($this->helper->url->to('taskImport', 'step1', array('project_id' => $project['id']))); + } + + /** + * Generate template + * + */ + public function template() + { + $this->response->forceDownload('tasks.csv'); + $this->response->csv(array($this->taskImport->getColumnMapping())); + } +} diff --git a/app/Controller/UserImport.php b/app/Controller/UserImport.php index e31ddbbb..9c27aa06 100644 --- a/app/Controller/UserImport.php +++ b/app/Controller/UserImport.php @@ -49,7 +49,7 @@ class UserImport extends Base $this->session->flash(t('%d user(s) have been imported successfully.', $this->userImport->counter)); } else { - $this->session->flash(t('Nothing have been imported!')); + $this->session->flashError(t('Nothing have been imported!')); } $this->response->redirect($this->helper->url->to('userImport', 'step1')); -- cgit v1.2.3