From 6985c711171b6f866303cfe002f21429629b68a4 Mon Sep 17 00:00:00 2001 From: epriestley Date: Mon, 25 Nov 2013 19:22:06 -0800 Subject: [PATCH] Turn the macro selector into a tokenizer Summary: Ref T3562. Here's the 10 minute "value" option. Test Plan: See screenshots. Reviewers: chad, btrahan Reviewed By: chad CC: aran Maniphest Tasks: T3562 Differential Revision: https://secure.phabricator.com/D7658 --- .../PhabricatorMacroMemeDialogController.php | 13 +++++++------ ...atorTypeaheadCommonDatasourceController.php | 18 ++++++++++++++++++ .../control/AphrontFormTokenizerControl.php | 1 + 3 files changed, 26 insertions(+), 6 deletions(-) diff --git a/src/applications/macro/controller/PhabricatorMacroMemeDialogController.php b/src/applications/macro/controller/PhabricatorMacroMemeDialogController.php index 4fd9259bb8..307290dd72 100644 --- a/src/applications/macro/controller/PhabricatorMacroMemeDialogController.php +++ b/src/applications/macro/controller/PhabricatorMacroMemeDialogController.php @@ -7,20 +7,20 @@ final class PhabricatorMacroMemeDialogController $request = $this->getRequest(); $user = $request->getUser(); - $name = $request->getStr('macro'); + $phid = head($request->getArr('macro')); $above = $request->getStr('above'); $below = $request->getStr('below'); $e_macro = true; $errors = array(); if ($request->isDialogFormPost()) { - if (!$name) { + if (!$phid) { $e_macro = pht('Required'); $errors[] = pht('Macro name is required.'); } else { $macro = id(new PhabricatorMacroQuery()) ->setViewer($user) - ->withNames(array($name)) + ->withPHIDs(array($phid)) ->executeOne(); if (!$macro) { $e_macro = pht('Invalid'); @@ -31,7 +31,7 @@ final class PhabricatorMacroMemeDialogController if (!$errors) { $options = new PhutilSimpleOptions(); $data = array( - 'src' => $name, + 'src' => $macro->getName(), 'above' => $above, 'below' => $below, ); @@ -46,10 +46,11 @@ final class PhabricatorMacroMemeDialogController $view = id(new PHUIFormLayoutView()) ->appendChild( - id(new AphrontFormTextControl()) + id(new AphrontFormTokenizerControl()) ->setLabel(pht('Macro')) ->setName('macro') - ->setValue($name) + ->setLimit(1) + ->setDatasource('/typeahead/common/macros/') ->setError($e_macro)) ->appendChild( id(new AphrontFormTextControl()) diff --git a/src/applications/typeahead/controller/PhabricatorTypeaheadCommonDatasourceController.php b/src/applications/typeahead/controller/PhabricatorTypeaheadCommonDatasourceController.php index d9830ad85c..32db073e3b 100644 --- a/src/applications/typeahead/controller/PhabricatorTypeaheadCommonDatasourceController.php +++ b/src/applications/typeahead/controller/PhabricatorTypeaheadCommonDatasourceController.php @@ -36,6 +36,7 @@ final class PhabricatorTypeaheadCommonDatasourceController $need_symbols = false; $need_jump_objects = false; $need_build_plans = false; + $need_macros = false; switch ($this->type) { case 'mainsearch': $need_users = true; @@ -97,6 +98,9 @@ final class PhabricatorTypeaheadCommonDatasourceController case 'buildplans': $need_build_plans = true; break; + case 'macros': + $need_macros = true; + break; } $results = array(); @@ -113,6 +117,7 @@ final class PhabricatorTypeaheadCommonDatasourceController ->setPHID(ManiphestTaskOwner::PROJECT_NO_PROJECT); } + if ($need_users) { $columns = array( 'isSystemAgent', @@ -234,6 +239,19 @@ final class PhabricatorTypeaheadCommonDatasourceController } } + if ($need_macros) { + $macros = id(new PhabricatorMacroQuery()) + ->setViewer($viewer) + ->withStatus(PhabricatorMacroQuery::STATUS_ACTIVE) + ->execute(); + $macros = mpull($macros, 'getName', 'getPHID'); + foreach ($macros as $phid => $name) { + $results[] = id(new PhabricatorTypeaheadResult()) + ->setPHID($phid) + ->setName($name); + } + } + if ($need_projs) { $projs = id(new PhabricatorProjectQuery()) ->setViewer($viewer) diff --git a/src/view/form/control/AphrontFormTokenizerControl.php b/src/view/form/control/AphrontFormTokenizerControl.php index bf1773ef28..c43fd68405 100644 --- a/src/view/form/control/AphrontFormTokenizerControl.php +++ b/src/view/form/control/AphrontFormTokenizerControl.php @@ -97,6 +97,7 @@ final class AphrontFormTokenizerControl extends AphrontFormControl { 'packages' => pht('Type a package name...'), 'arcanistproject' => pht('Type an arc project name...'), 'accountsorprojects' => pht('Type a user or project name...'), + 'macros' => pht('Type a macro name...'), ); return idx($map, $request);