summaryrefslogtreecommitdiff
path: root/app/Model/TaskModification.php
diff options
context:
space:
mode:
authorFrederic Guillot <fred@kanboard.net>2015-06-13 22:03:12 -0400
committerFrederic Guillot <fred@kanboard.net>2015-06-13 22:03:12 -0400
commitd577c73e46de23742bc069d0a444f0bedeca5abc (patch)
tree0cb485ab0f2b2140f4029538050f30658798a066 /app/Model/TaskModification.php
parent0dc247dca1336b5bdd2f6fec292d47b8ef65ca19 (diff)
Add new automatic action: Move task to another column when the category is changed
Diffstat (limited to 'app/Model/TaskModification.php')
-rw-r--r--app/Model/TaskModification.php25
1 files changed, 22 insertions, 3 deletions
diff --git a/app/Model/TaskModification.php b/app/Model/TaskModification.php
index 677fcd60..4691ce81 100644
--- a/app/Model/TaskModification.php
+++ b/app/Model/TaskModification.php
@@ -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) {
@@ -57,6 +63,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
*
* @access public