1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-11 23:31:03 +01:00

Automatically build mobile menus from navigation, and clean up external ProfileMenu API

Summary:
Depends on D20355. Ref T13275. Ref T13247. Currently, "Hamburger" menus are not automatically built from navigation menus. However, this is (I'm almost completely sure?) a reasonable and appropriate default behavior, and saves us some code around profile menus.

With this rule in place, we can remove `setApplicationMenu()` and `getApplicationMenu()` from `StandardPageView`, since they have no callers.

This also updates a lot of profile menu callsites to a new API which is added in the next change.

Test Plan: See the next two changes.

Reviewers: amckinley

Reviewed By: amckinley

Maniphest Tasks: T13275, T13247

Differential Revision: https://secure.phabricator.com/D20356
This commit is contained in:
epriestley 2019-03-31 11:48:09 -07:00
parent 47bf382435
commit 971a272bf6
18 changed files with 91 additions and 154 deletions

View file

@ -20,7 +20,7 @@ final class PhabricatorFavoritesMainMenuBarExtension
$dropdown = $this->newDropdown($viewer); $dropdown = $this->newDropdown($viewer);
if (!$dropdown) { if (!$dropdown) {
return null; return array();
} }
$favorites_menu = id(new PHUIButtonView()) $favorites_menu = id(new PHUIButtonView())
@ -59,7 +59,8 @@ final class PhabricatorFavoritesMainMenuBarExtension
$menu_engine->setController($controller); $menu_engine->setController($controller);
} }
$filter_view = $menu_engine->buildNavigation(); $filter_view = $menu_engine->newProfileMenuItemViewList()
->newNavigationView();
$menu_view = $filter_view->getMenu(); $menu_view = $filter_view->getMenu();
$item_views = $menu_view->getItems(); $item_views = $menu_view->getItems();

View file

@ -1,44 +1,4 @@
<?php <?php
abstract class PhabricatorHomeController extends PhabricatorController { abstract class PhabricatorHomeController
extends PhabricatorController {}
private $home;
private $profileMenu;
public function buildApplicationMenu() {
$menu = $this->newApplicationMenu();
$profile_menu = $this->getProfileMenu();
if ($profile_menu) {
$menu->setProfileMenu($profile_menu);
}
return $menu;
}
protected function getProfileMenu() {
if (!$this->profileMenu) {
$viewer = $this->getViewer();
$applications = id(new PhabricatorApplicationQuery())
->setViewer($viewer)
->withClasses(array('PhabricatorHomeApplication'))
->withInstalled(true)
->execute();
$home = head($applications);
if (!$home) {
return null;
}
$engine = id(new PhabricatorHomeProfileMenuEngine())
->setViewer($viewer)
->setController($this)
->setProfileObject($home)
->setCustomPHID($viewer->getPHID());
$this->profileMenu = $engine->buildNavigation();
}
return $this->profileMenu;
}
}

View file

@ -30,8 +30,9 @@ final class PhabricatorPeopleProfileBadgesController
$crumbs->addTextCrumb(pht('Badges')); $crumbs->addTextCrumb(pht('Badges'));
$crumbs->setBorder(true); $crumbs->setBorder(true);
$nav = $this->getProfileMenu(); $nav = $this->newNavigation(
$nav->selectFilter(PhabricatorPeopleProfileMenuEngine::ITEM_BADGES); $user,
PhabricatorPeopleProfileMenuEngine::ITEM_BADGES);
// Best option? // Best option?
$badges = id(new PhabricatorBadgesQuery()) $badges = id(new PhabricatorBadgesQuery())

View file

@ -32,8 +32,9 @@ final class PhabricatorPeopleProfileCommitsController
$crumbs->addTextCrumb(pht('Recent Commits')); $crumbs->addTextCrumb(pht('Recent Commits'));
$crumbs->setBorder(true); $crumbs->setBorder(true);
$nav = $this->getProfileMenu(); $nav = $this->newNavigation(
$nav->selectFilter(PhabricatorPeopleProfileMenuEngine::ITEM_COMMITS); $user,
PhabricatorPeopleProfileMenuEngine::ITEM_COMMITS);
$view = id(new PHUITwoColumnView()) $view = id(new PHUITwoColumnView())
->setHeader($header) ->setHeader($header)

View file

@ -4,7 +4,6 @@ abstract class PhabricatorPeopleProfileController
extends PhabricatorPeopleController { extends PhabricatorPeopleController {
private $user; private $user;
private $profileMenu;
public function shouldRequireAdmin() { public function shouldRequireAdmin() {
return false; return false;
@ -19,34 +18,6 @@ abstract class PhabricatorPeopleProfileController
return $this->user; return $this->user;
} }
public function buildApplicationMenu() {
$menu = $this->newApplicationMenu();
$profile_menu = $this->getProfileMenu();
if ($profile_menu) {
$menu->setProfileMenu($profile_menu);
}
return $menu;
}
protected function getProfileMenu() {
if (!$this->profileMenu) {
$user = $this->getUser();
if ($user) {
$viewer = $this->getViewer();
$engine = id(new PhabricatorPeopleProfileMenuEngine())
->setViewer($viewer)
->setProfileObject($user);
$this->profileMenu = $engine->buildNavigation();
}
}
return $this->profileMenu;
}
protected function buildApplicationCrumbs() { protected function buildApplicationCrumbs() {
$crumbs = parent::buildApplicationCrumbs(); $crumbs = parent::buildApplicationCrumbs();
@ -138,4 +109,24 @@ abstract class PhabricatorPeopleProfileController
return $header; return $header;
} }
final protected function newNavigation(
PhabricatorUser $user,
$item_identifier) {
$viewer = $this->getViewer();
$engine = id(new PhabricatorPeopleProfileMenuEngine())
->setViewer($viewer)
->setController($this)
->setProfileObject($user);
$view_list = $engine->newProfileMenuItemViewList();
$view_list->setSelectedViewWithItemIdentifier($item_identifier);
$navigation = $view_list->newNavigationView();
return $navigation;
}
} }

View file

@ -29,8 +29,9 @@ final class PhabricatorPeopleProfileManageController
$properties = $this->buildPropertyView($user); $properties = $this->buildPropertyView($user);
$name = $user->getUsername(); $name = $user->getUsername();
$nav = $this->getProfileMenu(); $nav = $this->newNavigation(
$nav->selectFilter(PhabricatorPeopleProfileMenuEngine::ITEM_MANAGE); $user,
PhabricatorPeopleProfileMenuEngine::ITEM_MANAGE);
$crumbs = $this->buildApplicationCrumbs(); $crumbs = $this->buildApplicationCrumbs();
$crumbs->addTextCrumb(pht('Manage')); $crumbs->addTextCrumb(pht('Manage'));

View file

@ -32,8 +32,9 @@ final class PhabricatorPeopleProfileRevisionsController
$crumbs->addTextCrumb(pht('Recent Revisions')); $crumbs->addTextCrumb(pht('Recent Revisions'));
$crumbs->setBorder(true); $crumbs->setBorder(true);
$nav = $this->getProfileMenu(); $nav = $this->newNavigation(
$nav->selectFilter(PhabricatorPeopleProfileMenuEngine::ITEM_REVISIONS); $user,
PhabricatorPeopleProfileMenuEngine::ITEM_REVISIONS);
$view = id(new PHUITwoColumnView()) $view = id(new PHUITwoColumnView())
->setHeader($header) ->setHeader($header)

View file

@ -32,8 +32,9 @@ final class PhabricatorPeopleProfileTasksController
$crumbs->addTextCrumb(pht('Assigned Tasks')); $crumbs->addTextCrumb(pht('Assigned Tasks'));
$crumbs->setBorder(true); $crumbs->setBorder(true);
$nav = $this->getProfileMenu(); $nav = $this->newNavigation(
$nav->selectFilter(PhabricatorPeopleProfileMenuEngine::ITEM_TASKS); $user,
PhabricatorPeopleProfileMenuEngine::ITEM_TASKS);
$view = id(new PHUITwoColumnView()) $view = id(new PHUITwoColumnView())
->setHeader($header) ->setHeader($header)

View file

@ -64,15 +64,16 @@ final class PhabricatorPeopleProfileViewController
$calendar, $calendar,
)); ));
$nav = $this->getProfileMenu(); $navigation = $this->newNavigation(
$nav->selectFilter(PhabricatorPeopleProfileMenuEngine::ITEM_PROFILE); $user,
PhabricatorPeopleProfileMenuEngine::ITEM_PROFILE);
$crumbs = $this->buildApplicationCrumbs(); $crumbs = $this->buildApplicationCrumbs();
$crumbs->setBorder(true); $crumbs->setBorder(true);
return $this->newPage() return $this->newPage()
->setTitle($user->getUsername()) ->setTitle($user->getUsername())
->setNavigation($nav) ->setNavigation($navigation)
->setCrumbs($crumbs) ->setCrumbs($crumbs)
->setPageObjectPHIDs( ->setPageObjectPHIDs(
array( array(

View file

@ -172,7 +172,9 @@ final class PhabricatorProjectBoardViewController
return $content; return $content;
} }
$nav = $this->newWorkboardProfileMenu(); $nav = $this->newNavigation(
$project,
PhabricatorProject::ITEM_WORKBOARD);
$crumbs = $this->buildApplicationCrumbs(); $crumbs = $this->buildApplicationCrumbs();
$crumbs->addTextCrumb(pht('Workboard')); $crumbs->addTextCrumb(pht('Workboard'));
@ -719,7 +721,9 @@ final class PhabricatorProjectBoardViewController
->appendChild($board) ->appendChild($board)
->addClass('project-board-wrapper'); ->addClass('project-board-wrapper');
$nav = $this->newWorkboardProfileMenu(); $nav = $this->newNavigation(
$project,
PhabricatorProject::ITEM_WORKBOARD);
$divider = id(new PHUIListItemView()) $divider = id(new PHUIListItemView())
->setType(PHUIListItemView::TYPE_DIVIDER); ->setType(PHUIListItemView::TYPE_DIVIDER);
@ -1503,15 +1507,4 @@ final class PhabricatorProjectBoardViewController
->addCancelButton($profile_uri); ->addCancelButton($profile_uri);
} }
private function newWorkboardProfileMenu() {
$default_item = id(new PhabricatorProfileMenuItemConfiguration())
->setBuiltinKey(PhabricatorProject::ITEM_WORKBOARD);
$menu = parent::getProfileMenu($default_item);
$menu->addClass('project-board-nav');
return $menu;
}
} }

View file

@ -84,30 +84,6 @@ abstract class PhabricatorProjectController extends PhabricatorController {
return null; return null;
} }
public function buildApplicationMenu() {
$menu = $this->newApplicationMenu();
$profile_menu = $this->getProfileMenu();
if ($profile_menu) {
$menu->setProfileMenu($profile_menu);
}
$menu->setSearchEngine(new PhabricatorProjectSearchEngine());
return $menu;
}
protected function getProfileMenu($default_item = null) {
if (!$this->profileMenu) {
$engine = $this->getProfileMenuEngine();
if ($engine) {
$this->profileMenu = $engine->buildNavigation($default_item);
}
}
return $this->profileMenu;
}
protected function buildApplicationCrumbs() { protected function buildApplicationCrumbs() {
return $this->newApplicationCrumbs('profile'); return $this->newApplicationCrumbs('profile');
} }
@ -207,4 +183,23 @@ abstract class PhabricatorProjectController extends PhabricatorController {
return implode(', ', $result); return implode(', ', $result);
} }
final protected function newNavigation(
PhabricatorProject $project,
$item_identifier) {
$engine = $this->getProfileMenuEngine();
$view_list = $engine->newProfileMenuItemViewList();
$view_list->setSelectedViewWithItemIdentifier($item_identifier);
$navigation = $view_list->newNavigationView();
if ($item_identifier === PhabricatorProject::ITEM_WORKBOARD) {
$navigation->addClass('project-board-nav');
}
return $navigation;
}
} }

View file

@ -37,8 +37,9 @@ final class PhabricatorProjectManageController
new PhabricatorProjectTransactionQuery()); new PhabricatorProjectTransactionQuery());
$timeline->setShouldTerminate(true); $timeline->setShouldTerminate(true);
$nav = $this->getProfileMenu(); $nav = $this->newNavigation(
$nav->selectFilter(PhabricatorProject::ITEM_MANAGE); $project,
PhabricatorProject::ITEM_MANAGE);
$crumbs = $this->buildApplicationCrumbs(); $crumbs = $this->buildApplicationCrumbs();
$crumbs->addTextCrumb(pht('Manage')); $crumbs->addTextCrumb(pht('Manage'));

View file

@ -36,8 +36,9 @@ final class PhabricatorProjectMembersViewController
->setUserPHIDs($project->getWatcherPHIDs()) ->setUserPHIDs($project->getWatcherPHIDs())
->setShowNote(true); ->setShowNote(true);
$nav = $this->getProfileMenu(); $nav = $this->newNavigation(
$nav->selectFilter(PhabricatorProject::ITEM_MEMBERS); $project,
PhabricatorProject::ITEM_MEMBERS);
$crumbs = $this->buildApplicationCrumbs(); $crumbs = $this->buildApplicationCrumbs();
$crumbs->addTextCrumb(pht('Members')); $crumbs->addTextCrumb(pht('Members'));

View file

@ -74,8 +74,9 @@ final class PhabricatorProjectProfileController
->setBackground(PHUIObjectBoxView::BLUE_PROPERTY) ->setBackground(PHUIObjectBoxView::BLUE_PROPERTY)
->setUserPHIDs($project->getWatcherPHIDs()); ->setUserPHIDs($project->getWatcherPHIDs());
$nav = $this->getProfileMenu(); $nav = $this->newNavigation(
$nav->selectFilter(PhabricatorProject::ITEM_PROFILE); $project,
PhabricatorProject::ITEM_PROFILE);
$stories = id(new PhabricatorFeedQuery()) $stories = id(new PhabricatorFeedQuery())
->setViewer($viewer) ->setViewer($viewer)

View file

@ -77,8 +77,9 @@ final class PhabricatorProjectSubprojectsController
$milestones, $milestones,
$subprojects); $subprojects);
$nav = $this->getProfileMenu(); $nav = $this->newNavigation(
$nav->selectFilter(PhabricatorProject::ITEM_SUBPROJECTS); $project,
PhabricatorProject::ITEM_SUBPROJECTS);
$crumbs = $this->buildApplicationCrumbs(); $crumbs = $this->buildApplicationCrumbs();
$crumbs->addTextCrumb(pht('Subprojects')); $crumbs->addTextCrumb(pht('Subprojects'));

View file

@ -18,7 +18,7 @@ final class PhabricatorProjectViewController
$project = $this->getProject(); $project = $this->getProject();
$engine = $this->getProfileMenuEngine(); $engine = $this->getProfileMenuEngine();
$default = $engine->getDefaultItem(); $default = $engine->getDefaultMenuItemConfiguration();
// If defaults are broken somehow, serve the manage page. See T13033 for // If defaults are broken somehow, serve the manage page. See T13033 for
// discussion. // discussion.

View file

@ -387,7 +387,6 @@ final class PhabricatorApplicationSearchController
require_celerity_resource('application-search-view-css'); require_celerity_resource('application-search-view-css');
return $this->newPage() return $this->newPage()
->setApplicationMenu($this->buildApplicationMenu())
->setTitle(pht('Query: %s', $title)) ->setTitle(pht('Query: %s', $title))
->setCrumbs($crumbs) ->setCrumbs($crumbs)
->setNavigation($nav) ->setNavigation($nav)
@ -611,7 +610,6 @@ final class PhabricatorApplicationSearchController
->setFooter($lists); ->setFooter($lists);
return $this->newPage() return $this->newPage()
->setApplicationMenu($this->buildApplicationMenu())
->setTitle(pht('Saved Queries')) ->setTitle(pht('Saved Queries'))
->setCrumbs($crumbs) ->setCrumbs($crumbs)
->setNavigation($nav) ->setNavigation($nav)

View file

@ -32,18 +32,6 @@ final class PhabricatorStandardPageView extends PhabricatorBarePageView
return $this->showFooter; return $this->showFooter;
} }
public function setApplicationMenu($application_menu) {
// NOTE: For now, this can either be a PHUIListView or a
// PHUIApplicationMenuView.
$this->applicationMenu = $application_menu;
return $this;
}
public function getApplicationMenu() {
return $this->applicationMenu;
}
public function setApplicationName($application_name) { public function setApplicationName($application_name) {
$this->applicationName = $application_name; $this->applicationName = $application_name;
return $this; return $this;
@ -345,7 +333,7 @@ final class PhabricatorStandardPageView extends PhabricatorBarePageView
$menu->setController($this->getController()); $menu->setController($this->getController());
} }
$application_menu = $this->getApplicationMenu(); $application_menu = $this->applicationMenu;
if ($application_menu) { if ($application_menu) {
if ($application_menu instanceof PHUIApplicationMenuView) { if ($application_menu instanceof PHUIApplicationMenuView) {
$crumbs = $this->getCrumbs(); $crumbs = $this->getCrumbs();
@ -865,13 +853,6 @@ final class PhabricatorStandardPageView extends PhabricatorBarePageView
public function produceAphrontResponse() { public function produceAphrontResponse() {
$controller = $this->getController(); $controller = $this->getController();
if (!$this->getApplicationMenu()) {
$application_menu = $controller->buildApplicationMenu();
if ($application_menu) {
$this->setApplicationMenu($application_menu);
}
}
$viewer = $this->getUser(); $viewer = $this->getUser();
if ($viewer && $viewer->getPHID()) { if ($viewer && $viewer->getPHID()) {
$object_phids = $this->pageObjects; $object_phids = $this->pageObjects;
@ -887,6 +868,14 @@ final class PhabricatorStandardPageView extends PhabricatorBarePageView
$response = id(new AphrontAjaxResponse()) $response = id(new AphrontAjaxResponse())
->setContent($content); ->setContent($content);
} else { } else {
// See T13247. Try to find some navigational menu items to create a
// mobile navigation menu from.
$application_menu = $controller->buildApplicationMenu();
if (!$application_menu) {
$application_menu = $this->getNavigation()->getMenu();
}
$this->applicationMenu = $application_menu;
$content = $this->render(); $content = $this->render();
$response = id(new AphrontWebpageResponse()) $response = id(new AphrontWebpageResponse())