mirror of
https://we.phorge.it/source/phorge.git
synced 2024-12-19 12:00:55 +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
|
||||
|
||||
/*
|
||||
* Copyright 2011 Facebook, Inc.
|
||||
* Copyright 2012 Facebook, Inc.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
|
@ -18,6 +18,15 @@
|
|||
|
||||
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) {
|
||||
|
||||
$page = $this->buildStandardPageView();
|
||||
|
@ -25,22 +34,65 @@ abstract class PhabricatorOwnersController extends PhabricatorController {
|
|||
$page->setApplicationName('Owners');
|
||||
$page->setBaseURI('/owners/');
|
||||
$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->appendChild($view);
|
||||
$nav = $this->renderSideNav();
|
||||
$nav->appendChild($view);
|
||||
$page->appendChild($nav);
|
||||
|
||||
$response = new AphrontWebpageResponse();
|
||||
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', 'applications/base/controller/base');
|
||||
phutil_require_module('phabricator', 'view/layout/sidenavfilter');
|
||||
|
||||
phutil_require_module('phutil', 'parser/uri');
|
||||
phutil_require_module('phutil', 'utils');
|
||||
|
||||
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
<?php
|
||||
|
||||
/*
|
||||
* Copyright 2011 Facebook, Inc.
|
||||
* Copyright 2012 Facebook, Inc.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
|
@ -19,6 +19,7 @@
|
|||
class PhabricatorOwnersDetailController extends PhabricatorOwnersController {
|
||||
|
||||
private $id;
|
||||
private $package;
|
||||
|
||||
public function willProcessRequest(array $data) {
|
||||
$this->id = $data['id'];
|
||||
|
@ -32,6 +33,7 @@ class PhabricatorOwnersDetailController extends PhabricatorOwnersController {
|
|||
if (!$package) {
|
||||
return new Aphront404Response();
|
||||
}
|
||||
$this->package = $package;
|
||||
|
||||
$paths = $package->loadPaths();
|
||||
$owners = $package->loadOwners();
|
||||
|
@ -138,22 +140,22 @@ class PhabricatorOwnersDetailController extends PhabricatorOwnersController {
|
|||
'Edit Package'));
|
||||
$panel->appendChild($table);
|
||||
|
||||
$nav = new AphrontSideNavView();
|
||||
$nav->appendChild($panel);
|
||||
$nav->addNavItem(
|
||||
phutil_render_tag(
|
||||
'a',
|
||||
array(
|
||||
'href' => '/owners/package/'.$package->getID().'/',
|
||||
'class' => 'aphront-side-nav-selected',
|
||||
),
|
||||
'Package Details'));
|
||||
$key = 'package/'.$package->getID();
|
||||
$this->setSideNavFilter($key);
|
||||
|
||||
return $this->buildStandardPageResponse(
|
||||
$nav,
|
||||
$panel,
|
||||
array(
|
||||
'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', 'view/control/table');
|
||||
phutil_require_module('phabricator', 'view/layout/panel');
|
||||
phutil_require_module('phabricator', 'view/layout/sidenav');
|
||||
|
||||
phutil_require_module('phutil', 'markup');
|
||||
phutil_require_module('phutil', 'utils');
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
<?php
|
||||
|
||||
/*
|
||||
* Copyright 2011 Facebook, Inc.
|
||||
* Copyright 2012 Facebook, Inc.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (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 = 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();
|
||||
|
||||
|
@ -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
|
||||
|
||||
/*
|
||||
* Copyright 2011 Facebook, Inc.
|
||||
* Copyright 2012 Facebook, Inc.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
|
@ -18,10 +18,11 @@
|
|||
|
||||
class PhabricatorOwnersListController extends PhabricatorOwnersController {
|
||||
|
||||
private $view;
|
||||
protected $view;
|
||||
|
||||
public function willProcessRequest(array $data) {
|
||||
$this->view = idx($data, 'view');
|
||||
$this->view = idx($data, 'view', 'owned');
|
||||
$this->setSideNavFilter('view/'.$this->view);
|
||||
}
|
||||
|
||||
public function processRequest() {
|
||||
|
@ -29,35 +30,6 @@ class PhabricatorOwnersListController extends PhabricatorOwnersController {
|
|||
$request = $this->getRequest();
|
||||
$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();
|
||||
$owner = new PhabricatorOwnersOwner();
|
||||
$path = new PhabricatorOwnersPath();
|
||||
|
@ -184,14 +156,13 @@ class PhabricatorOwnersListController extends PhabricatorOwnersController {
|
|||
|
||||
$filter->appendChild($form);
|
||||
|
||||
$nav->appendChild($filter);
|
||||
$nav->appendChild($content);
|
||||
|
||||
return $this->buildStandardPageResponse(
|
||||
$nav,
|
||||
array(
|
||||
$filter,
|
||||
$content,
|
||||
),
|
||||
array(
|
||||
'title' => 'Package Index',
|
||||
'tab' => 'index',
|
||||
));
|
||||
}
|
||||
|
||||
|
@ -289,4 +260,17 @@ class PhabricatorOwnersListController extends PhabricatorOwnersController {
|
|||
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/layout/listfilter');
|
||||
phutil_require_module('phabricator', 'view/layout/panel');
|
||||
phutil_require_module('phabricator', 'view/layout/sidenav');
|
||||
|
||||
phutil_require_module('phutil', 'markup');
|
||||
phutil_require_module('phutil', 'utils');
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
<?php
|
||||
|
||||
/*
|
||||
* Copyright 2011 Facebook, Inc.
|
||||
* Copyright 2012 Facebook, Inc.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
|
@ -50,19 +50,39 @@ class PhabricatorOwnerRelatedListController
|
|||
|
||||
$search_view = $this->renderSearchView();
|
||||
$list_panel = $this->renderListPanel();
|
||||
$nav = $this->renderSideNav();
|
||||
|
||||
$nav->appendChild($search_view);
|
||||
$nav->appendChild($list_panel);
|
||||
$side_nav_filter = 'related/view/'.$this->view.$this->getQueryString();
|
||||
$this->setSideNavFilter($side_nav_filter);
|
||||
|
||||
return $this->buildStandardPageResponse(
|
||||
$nav,
|
||||
array(
|
||||
$search_view,
|
||||
$list_panel
|
||||
),
|
||||
array(
|
||||
'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() {
|
||||
if (!$this->packagePHID) {
|
||||
return id(new AphrontErrorView())
|
||||
|
@ -151,33 +171,6 @@ class PhabricatorOwnerRelatedListController
|
|||
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() {
|
||||
if ($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/layout/listfilter');
|
||||
phutil_require_module('phabricator', 'view/layout/panel');
|
||||
phutil_require_module('phabricator', 'view/layout/sidenav');
|
||||
phutil_require_module('phabricator', 'view/utils');
|
||||
|
||||
phutil_require_module('phutil', 'markup');
|
||||
|
|
Loading…
Reference in a new issue