Refine available filters and defaults for relationship selection
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
This commit is contained in:
		| @@ -38,7 +38,8 @@ final class ManiphestTaskCloseAsDuplicateRelationship | ||||
|   } | ||||
|  | ||||
|   protected function newRelationshipSource() { | ||||
|     return new ManiphestTaskRelationshipSource(); | ||||
|     return id(new ManiphestTaskRelationshipSource()) | ||||
|       ->setSelectedFilter('open'); | ||||
|   } | ||||
|  | ||||
|   public function getRequiredRelationshipCapabilities() { | ||||
|   | ||||
| @@ -38,7 +38,8 @@ final class ManiphestTaskHasParentRelationship | ||||
|   } | ||||
|  | ||||
|   protected function newRelationshipSource() { | ||||
|     return new ManiphestTaskRelationshipSource(); | ||||
|     return id(new ManiphestTaskRelationshipSource()) | ||||
|       ->setSelectedFilter('open'); | ||||
|   } | ||||
|  | ||||
| } | ||||
|   | ||||
| @@ -38,7 +38,8 @@ final class ManiphestTaskHasSubtaskRelationship | ||||
|   } | ||||
|  | ||||
|   protected function newRelationshipSource() { | ||||
|     return new ManiphestTaskRelationshipSource(); | ||||
|     return id(new ManiphestTaskRelationshipSource()) | ||||
|       ->setSelectedFilter('open'); | ||||
|   } | ||||
|  | ||||
| } | ||||
|   | ||||
| @@ -38,7 +38,8 @@ final class ManiphestTaskMergeInRelationship | ||||
|   } | ||||
|  | ||||
|   protected function newRelationshipSource() { | ||||
|     return new ManiphestTaskRelationshipSource(); | ||||
|     return id(new ManiphestTaskRelationshipSource()) | ||||
|       ->setSelectedFilter('open'); | ||||
|   } | ||||
|  | ||||
|   public function getRequiredRelationshipCapabilities() { | ||||
|   | ||||
| @@ -150,14 +150,6 @@ final class PhabricatorSearchRelationshipController | ||||
|     $handles = iterator_to_array($handles); | ||||
|     $handles = array_select_keys($handles, $dst_phids); | ||||
|  | ||||
|     // TODO: These are hard-coded for now. | ||||
|     $filters = array( | ||||
|       'assigned' => pht('Assigned to Me'), | ||||
|       'created' => pht('Created By Me'), | ||||
|       'open' => pht('All Open Objects'), | ||||
|       'all' => pht('All Objects'), | ||||
|     ); | ||||
|  | ||||
|     $dialog_title = $relationship->getDialogTitleText(); | ||||
|     $dialog_header = $relationship->getDialogHeaderText(); | ||||
|     $dialog_button = $relationship->getDialogButtonText(); | ||||
| @@ -165,12 +157,17 @@ final class PhabricatorSearchRelationshipController | ||||
|  | ||||
|     $source_uri = $relationship->getSourceURI($object); | ||||
|  | ||||
|     $source = $relationship->newSource(); | ||||
|  | ||||
|     $filters = $source->getFilters(); | ||||
|     $selected_filter = $source->getSelectedFilter(); | ||||
|  | ||||
|     return id(new PhabricatorObjectSelectorDialog()) | ||||
|       ->setUser($viewer) | ||||
|       ->setInitialPHIDs($initial_phids) | ||||
|       ->setHandles($handles) | ||||
|       ->setFilters($filters) | ||||
|       ->setSelectedFilter('created') | ||||
|       ->setSelectedFilter($selected_filter) | ||||
|       ->setExcluded($src_phid) | ||||
|       ->setCancelURI($done_uri) | ||||
|       ->setSearchURI($source_uri) | ||||
|   | ||||
| @@ -17,4 +17,10 @@ final class DiffusionCommitRelationshipSource | ||||
|     ); | ||||
|   } | ||||
|  | ||||
|   public function getFilters() { | ||||
|     $filters = parent::getFilters(); | ||||
|     unset($filters['assigned']); | ||||
|     return $filters; | ||||
|   } | ||||
|  | ||||
| } | ||||
|   | ||||
| @@ -3,6 +3,7 @@ | ||||
| abstract class PhabricatorObjectRelationshipSource extends Phobject { | ||||
|  | ||||
|   private $viewer; | ||||
|   private $selectedFilter; | ||||
|  | ||||
|   final public function setViewer(PhabricatorUser $viewer) { | ||||
|     $this->viewer = $viewer; | ||||
| @@ -16,4 +17,32 @@ abstract class PhabricatorObjectRelationshipSource extends Phobject { | ||||
|   abstract public function isEnabledForObject($object); | ||||
|   abstract public function getResultPHIDTypes(); | ||||
|  | ||||
|   protected function getDefaultFilter() { | ||||
|     return 'created'; | ||||
|   } | ||||
|  | ||||
|   final public function setSelectedFilter($selected_filter) { | ||||
|     $this->selectedFilter = $selected_filter; | ||||
|     return $this; | ||||
|   } | ||||
|  | ||||
|   final public function getSelectedFilter() { | ||||
|     if ($this->selectedFilter === null) { | ||||
|       return $this->getDefaultFilter(); | ||||
|     } | ||||
|  | ||||
|     return $this->selectedFilter; | ||||
|   } | ||||
|  | ||||
|   public function getFilters() { | ||||
|     // TODO: These are hard-coded for now, and all of this will probably be | ||||
|     // rewritten when we move to ApplicationSearch. | ||||
|     return array( | ||||
|       'assigned' => pht('Assigned to Me'), | ||||
|       'created' => pht('Created By Me'), | ||||
|       'open' => pht('All Open Objects'), | ||||
|       'all' => pht('All Objects'), | ||||
|     ); | ||||
|   } | ||||
|  | ||||
| } | ||||
|   | ||||
| @@ -17,4 +17,10 @@ final class PholioMockRelationshipSource | ||||
|     ); | ||||
|   } | ||||
|  | ||||
|   public function getFilters() { | ||||
|     $filters = parent::getFilters(); | ||||
|     unset($filters['assigned']); | ||||
|     return $filters; | ||||
|   } | ||||
|  | ||||
| } | ||||
|   | ||||
| @@ -26,6 +26,9 @@ final class PhabricatorSearchDocument extends PhabricatorSearchDAO { | ||||
|         'documentCreated' => array( | ||||
|           'columns' => array('documentCreated'), | ||||
|         ), | ||||
|         'key_type' => array( | ||||
|           'columns' => array('documentType', 'documentCreated'), | ||||
|         ), | ||||
|       ), | ||||
|     ) + parent::getConfiguration(); | ||||
|   } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 epriestley
					epriestley