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:
parent
47bf382435
commit
971a272bf6
18 changed files with 91 additions and 154 deletions
|
@ -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();
|
||||||
|
|
|
@ -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;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
|
@ -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())
|
||||||
|
|
|
@ -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)
|
||||||
|
|
|
@ -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;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -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'));
|
||||||
|
|
|
@ -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)
|
||||||
|
|
|
@ -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)
|
||||||
|
|
|
@ -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(
|
||||||
|
|
|
@ -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;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -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;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -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'));
|
||||||
|
|
|
@ -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'));
|
||||||
|
|
|
@ -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)
|
||||||
|
|
|
@ -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'));
|
||||||
|
|
|
@ -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.
|
||||||
|
|
|
@ -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)
|
||||||
|
|
|
@ -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())
|
||||||
|
|
Loading…
Reference in a new issue