Add new automatic action: Move task to another column when the category is changed
This commit is contained in:
@@ -222,12 +222,17 @@ abstract class Base extends \Core\Base
|
||||
}
|
||||
|
||||
$data = $event->getAll();
|
||||
$result = false;
|
||||
|
||||
if ($this->isExecutable($data)) {
|
||||
$this->called = true;
|
||||
return $this->doAction($data);
|
||||
$result = $this->doAction($data);
|
||||
}
|
||||
|
||||
return false;
|
||||
if (DEBUG) {
|
||||
$this->container['logger']->debug(get_called_class().' => '.($result ? 'true' : 'false'));
|
||||
}
|
||||
|
||||
return $result;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -22,6 +22,7 @@ class TaskMoveColumnAssigned extends Base
|
||||
{
|
||||
return array(
|
||||
Task::EVENT_ASSIGNEE_CHANGE,
|
||||
Task::EVENT_UPDATE,
|
||||
);
|
||||
}
|
||||
|
||||
@@ -85,6 +86,6 @@ class TaskMoveColumnAssigned extends Base
|
||||
*/
|
||||
public function hasRequiredCondition(array $data)
|
||||
{
|
||||
return $data['column_id'] == $this->getParam('src_column_id') && $data['owner_id'];
|
||||
return $data['column_id'] == $this->getParam('src_column_id') && $data['owner_id'] > 0;
|
||||
}
|
||||
}
|
||||
|
||||
89
app/Action/TaskMoveColumnCategoryChange.php
Normal file
89
app/Action/TaskMoveColumnCategoryChange.php
Normal file
@@ -0,0 +1,89 @@
|
||||
<?php
|
||||
|
||||
namespace Action;
|
||||
|
||||
use Model\Task;
|
||||
|
||||
/**
|
||||
* Move a task to another column when the category is changed
|
||||
*
|
||||
* @package action
|
||||
* @author Francois Ferrand
|
||||
*/
|
||||
class TaskMoveColumnCategoryChange extends Base
|
||||
{
|
||||
/**
|
||||
* Get the list of compatible events
|
||||
*
|
||||
* @access public
|
||||
* @return array
|
||||
*/
|
||||
public function getCompatibleEvents()
|
||||
{
|
||||
return array(
|
||||
Task::EVENT_UPDATE,
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the required parameter for the action (defined by the user)
|
||||
*
|
||||
* @access public
|
||||
* @return array
|
||||
*/
|
||||
public function getActionRequiredParameters()
|
||||
{
|
||||
return array(
|
||||
'dest_column_id' => t('Destination column'),
|
||||
'category_id' => t('Category'),
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the required parameter for the event
|
||||
*
|
||||
* @access public
|
||||
* @return string[]
|
||||
*/
|
||||
public function getEventRequiredParameters()
|
||||
{
|
||||
return array(
|
||||
'task_id',
|
||||
'column_id',
|
||||
'project_id',
|
||||
'category_id',
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Execute the action (move the task to another column)
|
||||
*
|
||||
* @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)
|
||||
{
|
||||
$original_task = $this->taskFinder->getById($data['task_id']);
|
||||
|
||||
return $this->taskPosition->movePosition(
|
||||
$data['project_id'],
|
||||
$data['task_id'],
|
||||
$this->getParam('dest_column_id'),
|
||||
$original_task['position'],
|
||||
$original_task['swimlane_id']
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* 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 $data['column_id'] != $this->getParam('dest_column_id') && $data['category_id'] == $this->getParam('category_id');
|
||||
}
|
||||
}
|
||||
@@ -21,7 +21,8 @@ class TaskMoveColumnUnAssigned extends Base
|
||||
public function getCompatibleEvents()
|
||||
{
|
||||
return array(
|
||||
Task::EVENT_ASSIGNEE_CHANGE
|
||||
Task::EVENT_ASSIGNEE_CHANGE,
|
||||
Task::EVENT_UPDATE,
|
||||
);
|
||||
}
|
||||
|
||||
@@ -85,6 +86,6 @@ class TaskMoveColumnUnAssigned extends Base
|
||||
*/
|
||||
public function hasRequiredCondition(array $data)
|
||||
{
|
||||
return $data['column_id'] == $this->getParam('src_column_id') && ! $data['owner_id'];
|
||||
return $data['column_id'] == $this->getParam('src_column_id') && $data['owner_id'] == 0;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -57,6 +57,7 @@ class Action extends Base
|
||||
'TaskAssignUser' => t('Change the assignee based on an external username'),
|
||||
'TaskAssignCategoryLabel' => t('Change the category based on an external label'),
|
||||
'TaskUpdateStartDate' => t('Automatically update the start date'),
|
||||
'TaskMoveColumnCategoryChange' => t('Move the task to another column when the category is changed'),
|
||||
);
|
||||
|
||||
asort($values);
|
||||
|
||||
@@ -42,13 +42,19 @@ class TaskModification extends Base
|
||||
*/
|
||||
public function fireEvents(array $task, array $new_values)
|
||||
{
|
||||
$events = array();
|
||||
$event_data = array_merge($task, $new_values, array('task_id' => $task['id']));
|
||||
|
||||
if (isset($new_values['owner_id']) && $task['owner_id'] != $new_values['owner_id']) {
|
||||
$events = array(Task::EVENT_ASSIGNEE_CHANGE);
|
||||
// Values changed
|
||||
$event_data['changes'] = array_diff_assoc($new_values, $task);
|
||||
unset($event_data['changes']['date_modification']);
|
||||
|
||||
if ($this->isFieldModified('owner_id', $event_data['changes'])) {
|
||||
$events[] = Task::EVENT_ASSIGNEE_CHANGE;
|
||||
}
|
||||
else {
|
||||
$events = array(Task::EVENT_CREATE_UPDATE, Task::EVENT_UPDATE);
|
||||
$events[] = Task::EVENT_CREATE_UPDATE;
|
||||
$events[] = Task::EVENT_UPDATE;
|
||||
}
|
||||
|
||||
foreach ($events as $event) {
|
||||
@@ -56,6 +62,19 @@ class TaskModification extends Base
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Return true if the field is the only modified value
|
||||
*
|
||||
* @access public
|
||||
* @param string $field
|
||||
* @param array $changes
|
||||
* @return boolean
|
||||
*/
|
||||
public function isFieldModified($field, array $changes)
|
||||
{
|
||||
return isset($changes[$field]) && count($changes) === 1;
|
||||
}
|
||||
|
||||
/**
|
||||
* Prepare data before task modification
|
||||
*
|
||||
|
||||
Reference in New Issue
Block a user