mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-11 15:21:03 +01:00
Owners -- kill tabs
Summary: pretty standard MO, but a little tricky in that we dynamically pre-pend filters for "new", "edit", "search results" and "details" use cases. Test Plan: clicked around owners a bunch and verified proper filters showed up and that when clicked they worked as expected Reviewers: epriestley Reviewed By: epriestley CC: aran, epriestley Maniphest Tasks: T631 Differential Revision: https://secure.phabricator.com/D1516
This commit is contained in:
parent
deed4ffed0
commit
2c3a08b37b
9 changed files with 149 additions and 101 deletions
|
@ -1,7 +1,7 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright 2011 Facebook, Inc.
|
* Copyright 2012 Facebook, Inc.
|
||||||
*
|
*
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
* you may not use this file except in compliance with the License.
|
* you may not use this file except in compliance with the License.
|
||||||
|
@ -18,6 +18,15 @@
|
||||||
|
|
||||||
abstract class PhabricatorOwnersController extends PhabricatorController {
|
abstract class PhabricatorOwnersController extends PhabricatorController {
|
||||||
|
|
||||||
|
private $filter;
|
||||||
|
|
||||||
|
private function getSideNavFilter() {
|
||||||
|
return $this->filter;
|
||||||
|
}
|
||||||
|
protected function setSideNavFilter($filter) {
|
||||||
|
$this->filter = $filter;
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
public function buildStandardPageResponse($view, array $data) {
|
public function buildStandardPageResponse($view, array $data) {
|
||||||
|
|
||||||
$page = $this->buildStandardPageView();
|
$page = $this->buildStandardPageView();
|
||||||
|
@ -25,22 +34,65 @@ abstract class PhabricatorOwnersController extends PhabricatorController {
|
||||||
$page->setApplicationName('Owners');
|
$page->setApplicationName('Owners');
|
||||||
$page->setBaseURI('/owners/');
|
$page->setBaseURI('/owners/');
|
||||||
$page->setTitle(idx($data, 'title'));
|
$page->setTitle(idx($data, 'title'));
|
||||||
$page->setTabs(
|
|
||||||
array(
|
|
||||||
'index' => array(
|
|
||||||
'href' => '/owners/',
|
|
||||||
'name' => 'Package Index',
|
|
||||||
),
|
|
||||||
'related' => array(
|
|
||||||
'href' => '/owners/related/',
|
|
||||||
'name' => 'Related Commits',
|
|
||||||
),
|
|
||||||
),
|
|
||||||
idx($data, 'tab'));
|
|
||||||
$page->setGlyph("\xE2\x98\x81");
|
$page->setGlyph("\xE2\x98\x81");
|
||||||
$page->appendChild($view);
|
$nav = $this->renderSideNav();
|
||||||
|
$nav->appendChild($view);
|
||||||
|
$page->appendChild($nav);
|
||||||
|
|
||||||
$response = new AphrontWebpageResponse();
|
$response = new AphrontWebpageResponse();
|
||||||
return $response->setContent($page->render());
|
return $response->setContent($page->render());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function renderSideNav() {
|
||||||
|
$package_views = array(
|
||||||
|
array('name' => 'Owned',
|
||||||
|
'key' => 'view/owned'),
|
||||||
|
array('name' => 'All',
|
||||||
|
'key' => 'view/all'),
|
||||||
|
);
|
||||||
|
|
||||||
|
$package_views =
|
||||||
|
array_merge($this->getExtraPackageViews(),
|
||||||
|
$package_views);
|
||||||
|
|
||||||
|
$base_uri = new PhutilURI('/owners/');
|
||||||
|
|
||||||
|
$nav = new AphrontSideNavFilterView();
|
||||||
|
$nav->setBaseUri($base_uri);
|
||||||
|
$nav->addLabel('Packages');
|
||||||
|
foreach ($package_views as $view) {
|
||||||
|
$nav->addFilter($view['key'], $view['name']);
|
||||||
|
}
|
||||||
|
$nav->addSpacer();
|
||||||
|
$nav->addLabel('Related Commits');
|
||||||
|
$related_views = $this->getRelatedViews();
|
||||||
|
foreach ($related_views as $view) {
|
||||||
|
$href = clone $base_uri;
|
||||||
|
$href->setPath($href->getPath().$view['key']);
|
||||||
|
$href = (string)$href;
|
||||||
|
$nav->addFilter($view['key'],
|
||||||
|
$view['name'],
|
||||||
|
$href);
|
||||||
|
}
|
||||||
|
|
||||||
|
$filter = $this->getSideNavFilter();
|
||||||
|
$nav->selectFilter($filter, 'view/owned');
|
||||||
|
|
||||||
|
return $nav;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function getExtraPackageViews() {
|
||||||
|
return array();
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function getRelatedViews() {
|
||||||
|
$related_views = array(
|
||||||
|
array('name' => 'Related to Package',
|
||||||
|
'key' => 'related/view/all'),
|
||||||
|
array('name' => 'Needs Attention',
|
||||||
|
'key' => 'related/view/audit')
|
||||||
|
);
|
||||||
|
|
||||||
|
return $related_views;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,7 +8,9 @@
|
||||||
|
|
||||||
phutil_require_module('phabricator', 'aphront/response/webpage');
|
phutil_require_module('phabricator', 'aphront/response/webpage');
|
||||||
phutil_require_module('phabricator', 'applications/base/controller/base');
|
phutil_require_module('phabricator', 'applications/base/controller/base');
|
||||||
|
phutil_require_module('phabricator', 'view/layout/sidenavfilter');
|
||||||
|
|
||||||
|
phutil_require_module('phutil', 'parser/uri');
|
||||||
phutil_require_module('phutil', 'utils');
|
phutil_require_module('phutil', 'utils');
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright 2011 Facebook, Inc.
|
* Copyright 2012 Facebook, Inc.
|
||||||
*
|
*
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
* you may not use this file except in compliance with the License.
|
* you may not use this file except in compliance with the License.
|
||||||
|
@ -19,6 +19,7 @@
|
||||||
class PhabricatorOwnersDetailController extends PhabricatorOwnersController {
|
class PhabricatorOwnersDetailController extends PhabricatorOwnersController {
|
||||||
|
|
||||||
private $id;
|
private $id;
|
||||||
|
private $package;
|
||||||
|
|
||||||
public function willProcessRequest(array $data) {
|
public function willProcessRequest(array $data) {
|
||||||
$this->id = $data['id'];
|
$this->id = $data['id'];
|
||||||
|
@ -32,6 +33,7 @@ class PhabricatorOwnersDetailController extends PhabricatorOwnersController {
|
||||||
if (!$package) {
|
if (!$package) {
|
||||||
return new Aphront404Response();
|
return new Aphront404Response();
|
||||||
}
|
}
|
||||||
|
$this->package = $package;
|
||||||
|
|
||||||
$paths = $package->loadPaths();
|
$paths = $package->loadPaths();
|
||||||
$owners = $package->loadOwners();
|
$owners = $package->loadOwners();
|
||||||
|
@ -138,22 +140,22 @@ class PhabricatorOwnersDetailController extends PhabricatorOwnersController {
|
||||||
'Edit Package'));
|
'Edit Package'));
|
||||||
$panel->appendChild($table);
|
$panel->appendChild($table);
|
||||||
|
|
||||||
$nav = new AphrontSideNavView();
|
$key = 'package/'.$package->getID();
|
||||||
$nav->appendChild($panel);
|
$this->setSideNavFilter($key);
|
||||||
$nav->addNavItem(
|
|
||||||
phutil_render_tag(
|
|
||||||
'a',
|
|
||||||
array(
|
|
||||||
'href' => '/owners/package/'.$package->getID().'/',
|
|
||||||
'class' => 'aphront-side-nav-selected',
|
|
||||||
),
|
|
||||||
'Package Details'));
|
|
||||||
|
|
||||||
return $this->buildStandardPageResponse(
|
return $this->buildStandardPageResponse(
|
||||||
$nav,
|
$panel,
|
||||||
array(
|
array(
|
||||||
'title' => "Package '".$package->getName()."'",
|
'title' => "Package '".$package->getName()."'",
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected function getExtraPackageViews() {
|
||||||
|
$package = $this->package;
|
||||||
|
return array(
|
||||||
|
array('name' => 'Details',
|
||||||
|
'key' => 'package/'.$package->getID(),
|
||||||
|
));
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,7 +13,6 @@ phutil_require_module('phabricator', 'applications/phid/handle/data');
|
||||||
phutil_require_module('phabricator', 'infrastructure/javelin/markup');
|
phutil_require_module('phabricator', 'infrastructure/javelin/markup');
|
||||||
phutil_require_module('phabricator', 'view/control/table');
|
phutil_require_module('phabricator', 'view/control/table');
|
||||||
phutil_require_module('phabricator', 'view/layout/panel');
|
phutil_require_module('phabricator', 'view/layout/panel');
|
||||||
phutil_require_module('phabricator', 'view/layout/sidenav');
|
|
||||||
|
|
||||||
phutil_require_module('phutil', 'markup');
|
phutil_require_module('phutil', 'markup');
|
||||||
phutil_require_module('phutil', 'utils');
|
phutil_require_module('phutil', 'utils');
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright 2011 Facebook, Inc.
|
* Copyright 2012 Facebook, Inc.
|
||||||
*
|
*
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
* you may not use this file except in compliance with the License.
|
* you may not use this file except in compliance with the License.
|
||||||
|
@ -146,7 +146,14 @@ class PhabricatorOwnersEditController extends PhabricatorOwnersController {
|
||||||
$token_all_owners = array_select_keys($handles, $owners);
|
$token_all_owners = array_select_keys($handles, $owners);
|
||||||
$token_all_owners = mpull($token_all_owners, 'getFullName');
|
$token_all_owners = mpull($token_all_owners, 'getFullName');
|
||||||
|
|
||||||
$title = $package->getID() ? 'Edit Package' : 'New Package';
|
if ($package->getID()) {
|
||||||
|
$title = 'Edit Package';
|
||||||
|
$side_nav_filter = 'edit/'.$this->id;
|
||||||
|
} else {
|
||||||
|
$title = 'New Package';
|
||||||
|
$side_nav_filter = 'new';
|
||||||
|
}
|
||||||
|
$this->setSideNavFilter($side_nav_filter);
|
||||||
|
|
||||||
$repos = id(new PhabricatorRepository())->loadAll();
|
$repos = id(new PhabricatorRepository())->loadAll();
|
||||||
|
|
||||||
|
@ -268,4 +275,15 @@ class PhabricatorOwnersEditController extends PhabricatorOwnersController {
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected function getExtraPackageViews() {
|
||||||
|
if ($this->id) {
|
||||||
|
$extra = array(array('name' => 'Edit',
|
||||||
|
'key' => 'edit/'.$this->id));
|
||||||
|
} else {
|
||||||
|
$extra = array(array('name' => 'New',
|
||||||
|
'key' => 'new'));
|
||||||
|
}
|
||||||
|
|
||||||
|
return $extra;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright 2011 Facebook, Inc.
|
* Copyright 2012 Facebook, Inc.
|
||||||
*
|
*
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
* you may not use this file except in compliance with the License.
|
* you may not use this file except in compliance with the License.
|
||||||
|
@ -18,10 +18,11 @@
|
||||||
|
|
||||||
class PhabricatorOwnersListController extends PhabricatorOwnersController {
|
class PhabricatorOwnersListController extends PhabricatorOwnersController {
|
||||||
|
|
||||||
private $view;
|
protected $view;
|
||||||
|
|
||||||
public function willProcessRequest(array $data) {
|
public function willProcessRequest(array $data) {
|
||||||
$this->view = idx($data, 'view');
|
$this->view = idx($data, 'view', 'owned');
|
||||||
|
$this->setSideNavFilter('view/'.$this->view);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function processRequest() {
|
public function processRequest() {
|
||||||
|
@ -29,35 +30,6 @@ class PhabricatorOwnersListController extends PhabricatorOwnersController {
|
||||||
$request = $this->getRequest();
|
$request = $this->getRequest();
|
||||||
$user = $request->getUser();
|
$user = $request->getUser();
|
||||||
|
|
||||||
$views = array(
|
|
||||||
'owned' => 'Owned Packages',
|
|
||||||
'all' => 'All Packages',
|
|
||||||
'search' => 'Search Results',
|
|
||||||
);
|
|
||||||
|
|
||||||
if (empty($views[$this->view])) {
|
|
||||||
reset($views);
|
|
||||||
$this->view = key($views);
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($this->view != 'search') {
|
|
||||||
unset($views['search']);
|
|
||||||
}
|
|
||||||
|
|
||||||
$nav = new AphrontSideNavView();
|
|
||||||
foreach ($views as $key => $name) {
|
|
||||||
$nav->addNavItem(
|
|
||||||
phutil_render_tag(
|
|
||||||
'a',
|
|
||||||
array(
|
|
||||||
'href' => '/owners/view/'.$key.'/',
|
|
||||||
'class' => ($this->view == $key)
|
|
||||||
? 'aphront-side-nav-selected'
|
|
||||||
: null,
|
|
||||||
),
|
|
||||||
phutil_escape_html($name)));
|
|
||||||
}
|
|
||||||
|
|
||||||
$package = new PhabricatorOwnersPackage();
|
$package = new PhabricatorOwnersPackage();
|
||||||
$owner = new PhabricatorOwnersOwner();
|
$owner = new PhabricatorOwnersOwner();
|
||||||
$path = new PhabricatorOwnersPath();
|
$path = new PhabricatorOwnersPath();
|
||||||
|
@ -184,14 +156,13 @@ class PhabricatorOwnersListController extends PhabricatorOwnersController {
|
||||||
|
|
||||||
$filter->appendChild($form);
|
$filter->appendChild($form);
|
||||||
|
|
||||||
$nav->appendChild($filter);
|
|
||||||
$nav->appendChild($content);
|
|
||||||
|
|
||||||
return $this->buildStandardPageResponse(
|
return $this->buildStandardPageResponse(
|
||||||
$nav,
|
array(
|
||||||
|
$filter,
|
||||||
|
$content,
|
||||||
|
),
|
||||||
array(
|
array(
|
||||||
'title' => 'Package Index',
|
'title' => 'Package Index',
|
||||||
'tab' => 'index',
|
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -289,4 +260,17 @@ class PhabricatorOwnersListController extends PhabricatorOwnersController {
|
||||||
return $panel;
|
return $panel;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected function getExtraPackageViews() {
|
||||||
|
switch ($this->view) {
|
||||||
|
case 'search':
|
||||||
|
$extra = array(array('name' => 'Search Results',
|
||||||
|
'key' => 'view/search'));
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
$extra = array();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $extra;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,7 +20,6 @@ phutil_require_module('phabricator', 'view/form/control/text');
|
||||||
phutil_require_module('phabricator', 'view/form/control/tokenizer');
|
phutil_require_module('phabricator', 'view/form/control/tokenizer');
|
||||||
phutil_require_module('phabricator', 'view/layout/listfilter');
|
phutil_require_module('phabricator', 'view/layout/listfilter');
|
||||||
phutil_require_module('phabricator', 'view/layout/panel');
|
phutil_require_module('phabricator', 'view/layout/panel');
|
||||||
phutil_require_module('phabricator', 'view/layout/sidenav');
|
|
||||||
|
|
||||||
phutil_require_module('phutil', 'markup');
|
phutil_require_module('phutil', 'markup');
|
||||||
phutil_require_module('phutil', 'utils');
|
phutil_require_module('phutil', 'utils');
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright 2011 Facebook, Inc.
|
* Copyright 2012 Facebook, Inc.
|
||||||
*
|
*
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
* you may not use this file except in compliance with the License.
|
* you may not use this file except in compliance with the License.
|
||||||
|
@ -50,19 +50,39 @@ class PhabricatorOwnerRelatedListController
|
||||||
|
|
||||||
$search_view = $this->renderSearchView();
|
$search_view = $this->renderSearchView();
|
||||||
$list_panel = $this->renderListPanel();
|
$list_panel = $this->renderListPanel();
|
||||||
$nav = $this->renderSideNav();
|
|
||||||
|
|
||||||
$nav->appendChild($search_view);
|
$side_nav_filter = 'related/view/'.$this->view.$this->getQueryString();
|
||||||
$nav->appendChild($list_panel);
|
$this->setSideNavFilter($side_nav_filter);
|
||||||
|
|
||||||
return $this->buildStandardPageResponse(
|
return $this->buildStandardPageResponse(
|
||||||
$nav,
|
array(
|
||||||
|
$search_view,
|
||||||
|
$list_panel
|
||||||
|
),
|
||||||
array(
|
array(
|
||||||
'title' => 'Related Commits',
|
'title' => 'Related Commits',
|
||||||
'tab' => 'related',
|
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected function getRelatedViews() {
|
||||||
|
$related_views = parent::getRelatedViews();
|
||||||
|
if ($this->packagePHID) {
|
||||||
|
$query = $this->getQueryString();
|
||||||
|
foreach ($related_views as &$view) {
|
||||||
|
$view['key'] = $view['key'].$query;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return $related_views;
|
||||||
|
}
|
||||||
|
|
||||||
|
private function getQueryString() {
|
||||||
|
$query = null;
|
||||||
|
if ($this->packagePHID) {
|
||||||
|
$query = '/?phid=' . $this->packagePHID;
|
||||||
|
}
|
||||||
|
return $query;
|
||||||
|
}
|
||||||
|
|
||||||
private function renderListPanel() {
|
private function renderListPanel() {
|
||||||
if (!$this->packagePHID) {
|
if (!$this->packagePHID) {
|
||||||
return id(new AphrontErrorView())
|
return id(new AphrontErrorView())
|
||||||
|
@ -151,33 +171,6 @@ class PhabricatorOwnerRelatedListController
|
||||||
return $status_arr;
|
return $status_arr;
|
||||||
}
|
}
|
||||||
|
|
||||||
private function renderSideNav() {
|
|
||||||
$views = array(
|
|
||||||
'all' => 'Related to Package',
|
|
||||||
'audit' => 'Needs Attention',
|
|
||||||
);
|
|
||||||
|
|
||||||
$query = null;
|
|
||||||
if ($this->packagePHID) {
|
|
||||||
$query = '?phid=' . $this->packagePHID;
|
|
||||||
}
|
|
||||||
|
|
||||||
$nav = new AphrontSideNavView();
|
|
||||||
foreach ($views as $key => $name) {
|
|
||||||
$nav->addNavItem(
|
|
||||||
phutil_render_tag(
|
|
||||||
'a',
|
|
||||||
array(
|
|
||||||
'href' => '/owners/related/view/'.$key.'/'.$query,
|
|
||||||
'class' => ($this->view === $key
|
|
||||||
? 'aphront-side-nav-selected'
|
|
||||||
: null),
|
|
||||||
),
|
|
||||||
phutil_escape_html($name)));
|
|
||||||
}
|
|
||||||
return $nav;
|
|
||||||
}
|
|
||||||
|
|
||||||
private function renderSearchView() {
|
private function renderSearchView() {
|
||||||
if ($this->packagePHID) {
|
if ($this->packagePHID) {
|
||||||
$loader = new PhabricatorObjectHandleData(array($this->packagePHID));
|
$loader = new PhabricatorObjectHandleData(array($this->packagePHID));
|
||||||
|
|
|
@ -23,7 +23,6 @@ phutil_require_module('phabricator', 'view/form/control/tokenizer');
|
||||||
phutil_require_module('phabricator', 'view/form/error');
|
phutil_require_module('phabricator', 'view/form/error');
|
||||||
phutil_require_module('phabricator', 'view/layout/listfilter');
|
phutil_require_module('phabricator', 'view/layout/listfilter');
|
||||||
phutil_require_module('phabricator', 'view/layout/panel');
|
phutil_require_module('phabricator', 'view/layout/panel');
|
||||||
phutil_require_module('phabricator', 'view/layout/sidenav');
|
|
||||||
phutil_require_module('phabricator', 'view/utils');
|
phutil_require_module('phabricator', 'view/utils');
|
||||||
|
|
||||||
phutil_require_module('phutil', 'markup');
|
phutil_require_module('phutil', 'markup');
|
||||||
|
|
Loading…
Reference in a new issue