summaryrefslogtreecommitdiff
path: root/app/Controller
diff options
context:
space:
mode:
Diffstat (limited to 'app/Controller')
-rw-r--r--app/Controller/Config.php2
-rw-r--r--app/Controller/Subtask.php2
-rw-r--r--app/Controller/Timer.php35
3 files changed, 37 insertions, 2 deletions
diff --git a/app/Controller/Config.php b/app/Controller/Config.php
index fbd374ab..19bc2767 100644
--- a/app/Controller/Config.php
+++ b/app/Controller/Config.php
@@ -42,7 +42,7 @@ class Config extends Base
switch ($redirect) {
case 'project':
- $values += array('subtask_restriction' => 0, 'subtask_time_tracking' => 0);
+ $values += array('subtask_restriction' => 0);
break;
case 'integrations':
$values += array('integration_slack_webhook' => 0, 'integration_hipchat' => 0, 'integration_gravatar' => 0, 'integration_jabber' => 0);
diff --git a/app/Controller/Subtask.php b/app/Controller/Subtask.php
index 5baa6004..6ee94333 100644
--- a/app/Controller/Subtask.php
+++ b/app/Controller/Subtask.php
@@ -256,7 +256,7 @@ class Subtask extends Base
case 'dashboard':
$this->response->redirect($this->helper->url->to('app', 'index'));
default:
- $this->response->redirect($this->helper->url->to('task', 'show', array('task_id' => $task['id'], 'project_id' => $task['project_id'])));
+ $this->response->redirect($this->helper->url->to('task', 'show', array('task_id' => $task['id'], 'project_id' => $task['project_id'])).'#subtasks');
}
}
diff --git a/app/Controller/Timer.php b/app/Controller/Timer.php
new file mode 100644
index 00000000..2a4531ba
--- /dev/null
+++ b/app/Controller/Timer.php
@@ -0,0 +1,35 @@
+<?php
+
+namespace Controller;
+
+/**
+ * Time Tracking controller
+ *
+ * @package controller
+ * @author Frederic Guillot
+ */
+class Timer extends Base
+{
+ /**
+ * Start/stop timer for subtasks
+ *
+ * @access public
+ */
+ public function subtask()
+ {
+ $project_id = $this->request->getIntegerParam('project_id');
+ $task_id = $this->request->getIntegerParam('task_id');
+ $subtask_id = $this->request->getIntegerParam('subtask_id');
+ $timer = $this->request->getStringParam('timer');
+
+ if ($timer === 'start') {
+ $this->subtaskTimeTracking->logStartTime($subtask_id, $this->userSession->getId());
+ }
+ else if ($timer === 'stop') {
+ $this->subtaskTimeTracking->logEndTime($subtask_id, $this->userSession->getId());
+ $this->subtaskTimeTracking->updateTaskTimeTracking($task_id);
+ }
+
+ $this->response->redirect($this->helper->url->to('task', 'show', array('project_id' => $project_id, 'task_id' => $task_id)).'#subtasks');
+ }
+}