mirror of
https://we.phorge.it/source/phorge.git
synced 2025-04-03 07:58:18 +02:00
Summary: Ref T4788. Fixes T10703. In the longer term I want to put this on top of ApplicationSearch, but that's somewhat complex and we're at a fairly good point to pause this feature for feedback. Inch toward that instead: provide more appropriate filters and defaults without rebuilding the underlying engine. Specifically: - No "assigned" for commits (barely makes sense). - No "assigned" for mocks (does not make sense). - Default to "open" for parent tasks, subtasks, close as duplicate, and merge into. Also, add a key to the `search_document` table to improve the performance of the "all open stuff of type X" query. "All Open Tasks" is about 100x faster on my machine with this key. Test Plan: - Clicked all object relationships, saw more sensible filters and defaults. - Saw "open" query about 100x faster locally (300ms to 3ms). Reviewers: chad Reviewed By: chad Maniphest Tasks: T4788, T10703 Differential Revision: https://secure.phabricator.com/D16202
76 lines
1.8 KiB
PHP
76 lines
1.8 KiB
PHP
<?php
|
|
|
|
final class ManiphestTaskMergeInRelationship
|
|
extends ManiphestTaskRelationship {
|
|
|
|
const RELATIONSHIPKEY = 'task.merge-in';
|
|
|
|
public function getEdgeConstant() {
|
|
return ManiphestTaskHasDuplicateTaskEdgeType::EDGECONST;
|
|
}
|
|
|
|
protected function getActionName() {
|
|
return pht('Merge Duplicates In');
|
|
}
|
|
|
|
protected function getActionIcon() {
|
|
return 'fa-compress';
|
|
}
|
|
|
|
public function canRelateObjects($src, $dst) {
|
|
return ($dst instanceof ManiphestTask);
|
|
}
|
|
|
|
public function shouldAppearInActionMenu() {
|
|
return false;
|
|
}
|
|
|
|
public function getDialogTitleText() {
|
|
return pht('Merge Duplicates Into This Task');
|
|
}
|
|
|
|
public function getDialogHeaderText() {
|
|
return pht('Tasks to Close and Merge');
|
|
}
|
|
|
|
public function getDialogButtonText() {
|
|
return pht('Close and Merge Selected Tasks');
|
|
}
|
|
|
|
protected function newRelationshipSource() {
|
|
return id(new ManiphestTaskRelationshipSource())
|
|
->setSelectedFilter('open');
|
|
}
|
|
|
|
public function getRequiredRelationshipCapabilities() {
|
|
return array(
|
|
PhabricatorPolicyCapability::CAN_VIEW,
|
|
PhabricatorPolicyCapability::CAN_EDIT,
|
|
);
|
|
}
|
|
|
|
public function canUndoRelationship() {
|
|
return false;
|
|
}
|
|
|
|
public function willUpdateRelationships($object, array $add, array $rem) {
|
|
return $this->newMergeFromTransactions($add);
|
|
}
|
|
|
|
public function didUpdateRelationships($object, array $add, array $rem) {
|
|
$viewer = $this->getViewer();
|
|
$content_source = $this->getContentSource();
|
|
|
|
foreach ($add as $task) {
|
|
$xactions = $this->newMergeIntoTransactions($object);
|
|
|
|
$task->getApplicationTransactionEditor()
|
|
->setActor($viewer)
|
|
->setContentSource($content_source)
|
|
->setContinueOnMissingFields(true)
|
|
->setContinueOnNoEffect(true)
|
|
->applyTransactions($task, $xactions);
|
|
}
|
|
}
|
|
|
|
}
|