mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-11 07:11:04 +01:00
Discard no-op transactions from transaction groups.
Move assignees to CC as a side effect of reassignment. Summary: Test Plan: Reviewers: CC:
This commit is contained in:
parent
9eccb3e23d
commit
56880cc92e
3 changed files with 39 additions and 7 deletions
|
@ -49,6 +49,7 @@ class ManiphestTransactionSaveController extends ManiphestController {
|
||||||
case ManiphestTransactionType::TYPE_CCS:
|
case ManiphestTransactionType::TYPE_CCS:
|
||||||
$ccs = $request->getArr('ccs');
|
$ccs = $request->getArr('ccs');
|
||||||
$ccs = array_merge($ccs, $task->getCCPHIDs());
|
$ccs = array_merge($ccs, $task->getCCPHIDs());
|
||||||
|
$ccs = array_filter($ccs);
|
||||||
$ccs = array_unique($ccs);
|
$ccs = array_unique($ccs);
|
||||||
$transaction->setNewValue($ccs);
|
$transaction->setNewValue($ccs);
|
||||||
break;
|
break;
|
||||||
|
@ -59,8 +60,31 @@ class ManiphestTransactionSaveController extends ManiphestController {
|
||||||
throw new Exception('unknown action');
|
throw new Exception('unknown action');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$transactions = array($transaction);
|
||||||
|
|
||||||
|
switch ($action) {
|
||||||
|
case ManiphestTransactionType::TYPE_OWNER:
|
||||||
|
if ($task->getOwnerPHID() == $transaction->getNewValue()) {
|
||||||
|
// If this is actually no-op, don't generate the side effect.
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
// When a task is reassigned, move the previous owner to CC.
|
||||||
|
$old = $task->getCCPHIDs();
|
||||||
|
$new = array_merge(
|
||||||
|
$old,
|
||||||
|
array($task->getOwnerPHID()));
|
||||||
|
$new = array_unique(array_filter($new));
|
||||||
|
if ($old != $new) {
|
||||||
|
$cc = clone $transaction;
|
||||||
|
$cc->setTransactionType(ManiphestTransactionType::TYPE_CCS);
|
||||||
|
$cc->setNewValue($new);
|
||||||
|
$transactions[] = $cc;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
$editor = new ManiphestTransactionEditor();
|
$editor = new ManiphestTransactionEditor();
|
||||||
$editor->applyTransactions($task, array($transaction));
|
$editor->applyTransactions($task, $transactions);
|
||||||
|
|
||||||
return id(new AphrontRedirectResponse())
|
return id(new AphrontRedirectResponse())
|
||||||
->setURI('/T'.$task->getID());
|
->setURI('/T'.$task->getID());
|
||||||
|
|
|
@ -25,7 +25,7 @@ class ManiphestTransactionEditor {
|
||||||
$email_to = array();
|
$email_to = array();
|
||||||
$email_to[] = $task->getOwnerPHID();
|
$email_to[] = $task->getOwnerPHID();
|
||||||
|
|
||||||
foreach ($transactions as $transaction) {
|
foreach ($transactions as $key => $transaction) {
|
||||||
$type = $transaction->getTransactionType();
|
$type = $transaction->getTransactionType();
|
||||||
$new = $transaction->getNewValue();
|
$new = $transaction->getNewValue();
|
||||||
$email_to[] = $transaction->getAuthorPHID();
|
$email_to[] = $transaction->getAuthorPHID();
|
||||||
|
@ -51,9 +51,17 @@ class ManiphestTransactionEditor {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (($old !== null) && ($old == $new)) {
|
if (($old !== null) && ($old == $new)) {
|
||||||
$transaction->setOldValue(null);
|
if (count($transactions) > 1 && !$transaction->hasComments()) {
|
||||||
$transaction->setNewValue(null);
|
// If we have at least one other transaction and this one isn't
|
||||||
$transaction->setTransactionType(ManiphestTransactionType::TYPE_NONE);
|
// doing anything and doesn't have any comments, just throw it
|
||||||
|
// away.
|
||||||
|
unset($transactions[$key]);
|
||||||
|
continue;
|
||||||
|
} else {
|
||||||
|
$transaction->setOldValue(null);
|
||||||
|
$transaction->setNewValue(null);
|
||||||
|
$transaction->setTransactionType(ManiphestTransactionType::TYPE_NONE);
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
switch ($type) {
|
switch ($type) {
|
||||||
case ManiphestTransactionType::TYPE_NONE:
|
case ManiphestTransactionType::TYPE_NONE:
|
||||||
|
|
Loading…
Reference in a new issue