1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-09 14:21:02 +01:00

Modularize global quick create builtin items

Summary: Ref T5867. Instead of hard-coding projects, tasks and repositories, let EditEngines say "I want a quick create item" so third-party code can also hook into the menu without upstream changes.

Test Plan: Saw same default items in menu.

Reviewers: chad

Reviewed By: chad

Maniphest Tasks: T5867

Differential Revision: https://secure.phabricator.com/D17215
This commit is contained in:
epriestley 2017-01-17 14:17:24 -08:00
parent a886969c48
commit 9d3f09ab47
7 changed files with 51 additions and 112 deletions

View file

@ -2668,7 +2668,6 @@ phutil_register_library_map(array(
'PhabricatorFactSpec' => 'applications/fact/spec/PhabricatorFactSpec.php', 'PhabricatorFactSpec' => 'applications/fact/spec/PhabricatorFactSpec.php',
'PhabricatorFactUpdateIterator' => 'applications/fact/extract/PhabricatorFactUpdateIterator.php', 'PhabricatorFactUpdateIterator' => 'applications/fact/extract/PhabricatorFactUpdateIterator.php',
'PhabricatorFavoritesApplication' => 'applications/favorites/application/PhabricatorFavoritesApplication.php', 'PhabricatorFavoritesApplication' => 'applications/favorites/application/PhabricatorFavoritesApplication.php',
'PhabricatorFavoritesConstants' => 'applications/favorites/constants/PhabricatorFavoritesConstants.php',
'PhabricatorFavoritesController' => 'applications/favorites/controller/PhabricatorFavoritesController.php', 'PhabricatorFavoritesController' => 'applications/favorites/controller/PhabricatorFavoritesController.php',
'PhabricatorFavoritesMainController' => 'applications/favorites/controller/PhabricatorFavoritesMainController.php', 'PhabricatorFavoritesMainController' => 'applications/favorites/controller/PhabricatorFavoritesMainController.php',
'PhabricatorFavoritesMenuItemController' => 'applications/favorites/controller/PhabricatorFavoritesMenuItemController.php', 'PhabricatorFavoritesMenuItemController' => 'applications/favorites/controller/PhabricatorFavoritesMenuItemController.php',
@ -7683,7 +7682,6 @@ phutil_register_library_map(array(
'PhabricatorFactSpec' => 'Phobject', 'PhabricatorFactSpec' => 'Phobject',
'PhabricatorFactUpdateIterator' => 'PhutilBufferedIterator', 'PhabricatorFactUpdateIterator' => 'PhutilBufferedIterator',
'PhabricatorFavoritesApplication' => 'PhabricatorApplication', 'PhabricatorFavoritesApplication' => 'PhabricatorApplication',
'PhabricatorFavoritesConstants' => 'PhabricatorFavoritesController',
'PhabricatorFavoritesController' => 'PhabricatorController', 'PhabricatorFavoritesController' => 'PhabricatorController',
'PhabricatorFavoritesMainController' => 'PhabricatorFavoritesController', 'PhabricatorFavoritesMainController' => 'PhabricatorFavoritesController',
'PhabricatorFavoritesMenuItemController' => 'PhabricatorFavoritesController', 'PhabricatorFavoritesMenuItemController' => 'PhabricatorFavoritesController',

View file

@ -20,6 +20,10 @@ final class DiffusionRepositoryEditEngine
return false; return false;
} }
public function isDefaultQuickCreateEngine() {
return true;
}
public function getEngineName() { public function getEngineName() {
return pht('Repositories'); return pht('Repositories');
} }

View file

@ -1,11 +0,0 @@
<?php
final class PhabricatorFavoritesConstants
extends PhabricatorFavoritesController {
const ITEM_TASK = 'favorites.task';
const ITEM_PROJECT = 'favorites.project';
const ITEM_REPOSITORY = 'favorites.repository';
const ITEM_DIVIDER = 'favorites.divider';
}

View file

@ -22,38 +22,25 @@ final class PhabricatorFavoritesProfileMenuEngine
$items = array(); $items = array();
$viewer = $this->getViewer(); $viewer = $this->getViewer();
$create_task = array( $engines = PhabricatorEditEngine::getAllEditEngines();
'name' => null, $engines = msortv($engines, 'getQuickCreateOrderVector');
'formKey' =>
id(new ManiphestEditEngine())->getProfileMenuItemDefault(),
);
$create_project = array( foreach ($engines as $engine) {
'name' => null, foreach ($engine->getDefaultQuickCreateFormKeys() as $form_key) {
'formKey' => $form_hash = PhabricatorHash::digestForIndex($form_key);
id(new PhabricatorProjectEditEngine())->getProfileMenuItemDefault(), $builtin_key = "editengine.form({$form_hash})";
);
$create_repository = array( $properties = array(
'name' => null, 'name' => null,
'formKey' => 'formKey' => $form_key,
id(new DiffusionRepositoryEditEngine())->getProfileMenuItemDefault(), );
);
$items[] = $this->newItem() $items[] = $this->newItem()
->setBuiltinKey(PhabricatorFavoritesConstants::ITEM_TASK) ->setBuiltinKey($builtin_key)
->setMenuItemKey(PhabricatorEditEngineProfileMenuItem::MENUITEMKEY) ->setMenuItemKey(PhabricatorEditEngineProfileMenuItem::MENUITEMKEY)
->setMenuItemProperties($create_task); ->setMenuItemProperties($properties);
}
$items[] = $this->newItem() }
->setBuiltinKey(PhabricatorFavoritesConstants::ITEM_PROJECT)
->setMenuItemKey(PhabricatorEditEngineProfileMenuItem::MENUITEMKEY)
->setMenuItemProperties($create_project);
$items[] = $this->newItem()
->setBuiltinKey(PhabricatorFavoritesConstants::ITEM_REPOSITORY)
->setMenuItemKey(PhabricatorEditEngineProfileMenuItem::MENUITEMKEY)
->setMenuItemProperties($create_repository);
return $items; return $items;
} }

View file

@ -21,6 +21,10 @@ final class ManiphestEditEngine
return 'PhabricatorManiphestApplication'; return 'PhabricatorManiphestApplication';
} }
public function isDefaultQuickCreateEngine() {
return true;
}
protected function newEditableObject() { protected function newEditableObject() {
return ManiphestTask::initializeNewTask($this->getViewer()); return ManiphestTask::initializeNewTask($this->getViewer());
} }

View file

@ -26,6 +26,10 @@ final class PhabricatorProjectEditEngine
return $this->milestoneProject; return $this->milestoneProject;
} }
public function isDefaultQuickCreateEngine() {
return true;
}
public function getEngineName() { public function getEngineName() {
return pht('Projects'); return pht('Projects');
} }

View file

@ -77,6 +77,29 @@ abstract class PhabricatorEditEngine
return true; return true;
} }
public function isDefaultQuickCreateEngine() {
return false;
}
public function getDefaultQuickCreateFormKeys() {
$keys = array();
if ($this->isDefaultQuickCreateEngine()) {
$keys[] = self::EDITENGINECONFIG_DEFAULT;
}
foreach ($keys as $idx => $key) {
$keys[$idx] = $this->getEngineKey().'/'.$key;
}
return $keys;
}
public function getQuickCreateOrderVector() {
return id(new PhutilSortVector())
->addString($this->getObjectCreateShortText());
}
/** /**
* Force the engine to edit a particular object. * Force the engine to edit a particular object.
*/ */
@ -107,10 +130,6 @@ abstract class PhabricatorEditEngine
return $this->hideHeader; return $this->hideHeader;
} }
public function getProfileMenuItemDefault() {
return $this->getEngineKey().'/'.self::EDITENGINECONFIG_DEFAULT;
}
/* -( Managing Fields )---------------------------------------------------- */ /* -( Managing Fields )---------------------------------------------------- */
@ -283,14 +302,6 @@ abstract class PhabricatorEditEngine
} }
/**
* @task text
*/
protected function getQuickCreateMenuHeaderText() {
return $this->getObjectCreateShortText();
}
/** /**
* Return a human-readable header describing what this engine is used to do, * Return a human-readable header describing what this engine is used to do,
* like "Configure Maniphest Task Forms". * like "Configure Maniphest Task Forms".
@ -2100,50 +2111,6 @@ abstract class PhabricatorEditEngine
return $application->getIcon(); return $application->getIcon();
} }
public function hasQuickCreateActions() {
if (!$this->isEngineConfigurable()) {
return false;
}
return true;
}
public function newQuickCreateActions(array $configs) {
$items = array();
if (!$configs) {
return array();
}
// If the viewer is logged in and can't create objects, don't show the
// menu item. If they're logged out, we assume they could create objects
// if they logged in, so we show the item as a hint about how to
// accomplish the action.
if ($this->getViewer()->isLoggedIn()) {
if (!$this->hasCreateCapability()) {
return array();
}
}
if (count($configs) == 1) {
$config = head($configs);
$items[] = $this->newQuickCreateAction($config);
} else {
$group_name = $this->getQuickCreateMenuHeaderText();
$items[] = id(new PHUIListItemView())
->setType(PHUIListItemView::TYPE_LABEL)
->setName($group_name);
foreach ($configs as $config) {
$items[] = $this->newQuickCreateAction($config)
->setIndented(true);
}
}
return $items;
}
private function loadUsableConfigurationsForCreate() { private function loadUsableConfigurationsForCreate() {
$viewer = $this->getViewer(); $viewer = $this->getViewer();
@ -2159,20 +2126,6 @@ abstract class PhabricatorEditEngine
return $configs; return $configs;
} }
private function newQuickCreateAction(
PhabricatorEditEngineConfiguration $config) {
$item_name = $config->getName();
$item_icon = $config->getIcon();
$form_key = $config->getIdentifier();
$item_uri = $this->getEditURI(null, "form/{$form_key}/");
return id(new PHUIListItemView())
->setName($item_name)
->setIcon($item_icon)
->setHref($item_uri);
}
protected function getValidationExceptionShortMessage( protected function getValidationExceptionShortMessage(
PhabricatorApplicationTransactionValidationException $ex, PhabricatorApplicationTransactionValidationException $ex,
PhabricatorEditField $field) { PhabricatorEditField $field) {