From 911be6ed00c1ece5d9ef2c16e80899bb7bffad67 Mon Sep 17 00:00:00 2001 From: i00171 Date: Sun, 26 Jun 2016 18:33:23 +0200 Subject: New actionprovider that closes tasks if they are in a specific column and havn't been changed for X days. --- app/Action/TaskCloseNoActivityColumn.php | 98 ++++++++++++++++++++++++++++++++ app/ServiceProvider/ActionProvider.php | 2 + 2 files changed, 100 insertions(+) create mode 100644 app/Action/TaskCloseNoActivityColumn.php (limited to 'app') diff --git a/app/Action/TaskCloseNoActivityColumn.php b/app/Action/TaskCloseNoActivityColumn.php new file mode 100644 index 00000000..42043e1f --- /dev/null +++ b/app/Action/TaskCloseNoActivityColumn.php @@ -0,0 +1,98 @@ + t('Duration in days'), + 'column_id' => t('Column') + ); + } + + /** + * Get the required parameter for the event + * + * @access public + * @return string[] + */ + public function getEventRequiredParameters() + { + return array('tasks'); + } + + /** + * Execute the action (close the task) + * + * @access public + * @param array $data Event data dictionary + * @return bool True if the action was executed or false when not executed + */ + public function doAction(array $data) + { + $results = array(); + $max = $this->getParam('duration') * 86400; + + foreach ($data['tasks'] as $task) { + $duration = time() - $task['date_modification']; + //echo $task['column_id']; + //echo $this->getParam('column_id'); + + if ($duration > $max && $task['column_id'] == $this->getParam('column_id')) { + $results[] = $this->taskStatusModel->close($task['id']); + } + } + + return in_array(true, $results, true); + } + + /** + * Check if the event data meet the action condition + * + * @access public + * @param array $data Event data dictionary + * @return bool + */ + public function hasRequiredCondition(array $data) + { + return count($data['tasks']) > 0; + } +} diff --git a/app/ServiceProvider/ActionProvider.php b/app/ServiceProvider/ActionProvider.php index 34202052..9383be12 100644 --- a/app/ServiceProvider/ActionProvider.php +++ b/app/ServiceProvider/ActionProvider.php @@ -32,6 +32,7 @@ use Kanboard\Action\TaskMoveColumnUnAssigned; use Kanboard\Action\TaskOpen; use Kanboard\Action\TaskUpdateStartDate; use Kanboard\Action\TaskCloseNoActivity; +use Kanboard\Action\TaskCloseNoActivityColumn; /** * Action Provider @@ -68,6 +69,7 @@ class ActionProvider implements ServiceProviderInterface $container['actionManager']->register(new TaskClose($container)); $container['actionManager']->register(new TaskCloseColumn($container)); $container['actionManager']->register(new TaskCloseNoActivity($container)); + $container['actionManager']->register(new TaskCloseNoActivityColumn($container)); $container['actionManager']->register(new TaskCreation($container)); $container['actionManager']->register(new TaskDuplicateAnotherProject($container)); $container['actionManager']->register(new TaskEmail($container)); -- cgit v1.2.3 From 95b553f5bfd15749573c273354f995e62b6564a0 Mon Sep 17 00:00:00 2001 From: i00171 Date: Sun, 26 Jun 2016 22:00:40 +0200 Subject: Removed old debug code. --- app/Action/TaskCloseNoActivityColumn.php | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) (limited to 'app') diff --git a/app/Action/TaskCloseNoActivityColumn.php b/app/Action/TaskCloseNoActivityColumn.php index 42043e1f..7af0b7fc 100644 --- a/app/Action/TaskCloseNoActivityColumn.php +++ b/app/Action/TaskCloseNoActivityColumn.php @@ -44,7 +44,7 @@ class TaskCloseNoActivityColumn extends Base { return array( 'duration' => t('Duration in days'), - 'column_id' => t('Column') + 'column_id' => t('Column') ); } @@ -73,8 +73,6 @@ class TaskCloseNoActivityColumn extends Base foreach ($data['tasks'] as $task) { $duration = time() - $task['date_modification']; - //echo $task['column_id']; - //echo $this->getParam('column_id'); if ($duration > $max && $task['column_id'] == $this->getParam('column_id')) { $results[] = $this->taskStatusModel->close($task['id']); -- cgit v1.2.3