mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-13 16:21:07 +01:00
Update EditEngine pages to take a page header separate
Summary: This simplifies EditEngine pages in general by removing the dual header, and extending to allow setting of a custom PHUIHeaderView if needed (like settings). Test Plan: Review all settings pages, review task, project pages. This should all be fine, but is a big change maybe some layouts I'm not considering. Tested these all mobile, destkop as well. {F5166181} Reviewers: epriestley Reviewed By: epriestley Spies: Korvin Differential Revision: https://secure.phabricator.com/D18527
This commit is contained in:
parent
6e25d4c67b
commit
a903388d4f
6 changed files with 50 additions and 18 deletions
|
@ -9,7 +9,7 @@ return array(
|
|||
'names' => array(
|
||||
'conpherence.pkg.css' => 'e68cf1fa',
|
||||
'conpherence.pkg.js' => 'b5b51108',
|
||||
'core.pkg.css' => '03264689',
|
||||
'core.pkg.css' => 'b2235af0',
|
||||
'core.pkg.js' => '6c085267',
|
||||
'darkconsole.pkg.js' => '1f9a31bc',
|
||||
'differential.pkg.css' => '45951e9e',
|
||||
|
@ -177,7 +177,7 @@ return array(
|
|||
'rsrc/css/phui/phui-status.css' => 'd5263e49',
|
||||
'rsrc/css/phui/phui-tag-view.css' => 'b4719c50',
|
||||
'rsrc/css/phui/phui-timeline-view.css' => 'f21db7ca',
|
||||
'rsrc/css/phui/phui-two-column-view.css' => 'bf86c483',
|
||||
'rsrc/css/phui/phui-two-column-view.css' => '1ade9c5f',
|
||||
'rsrc/css/phui/workboards/phui-workboard-color.css' => '783cdff5',
|
||||
'rsrc/css/phui/workboards/phui-workboard.css' => '3bc85455',
|
||||
'rsrc/css/phui/workboards/phui-workcard.css' => 'cca5fa92',
|
||||
|
@ -872,7 +872,7 @@ return array(
|
|||
'phui-tag-view-css' => 'b4719c50',
|
||||
'phui-theme-css' => '9f261c6b',
|
||||
'phui-timeline-view-css' => 'f21db7ca',
|
||||
'phui-two-column-view-css' => 'bf86c483',
|
||||
'phui-two-column-view-css' => '1ade9c5f',
|
||||
'phui-workboard-color-css' => '783cdff5',
|
||||
'phui-workboard-view-css' => '3bc85455',
|
||||
'phui-workcard-view-css' => 'cca5fa92',
|
||||
|
|
|
@ -63,12 +63,13 @@ final class PhabricatorSettingsEditEngine
|
|||
}
|
||||
|
||||
protected function getObjectEditTitleText($object) {
|
||||
$user = $object->getUser();
|
||||
if ($user) {
|
||||
return pht('Edit Settings (%s)', $user->getUserName());
|
||||
} else {
|
||||
return pht('Edit Global Settings');
|
||||
$page = $this->getSelectedPage();
|
||||
|
||||
if ($page) {
|
||||
return $page->getLabel();
|
||||
}
|
||||
|
||||
return pht('Settings');
|
||||
}
|
||||
|
||||
protected function getObjectEditShortText($object) {
|
||||
|
@ -97,6 +98,20 @@ final class PhabricatorSettingsEditEngine
|
|||
return pht('Settings');
|
||||
}
|
||||
|
||||
protected function getPageHeader($object) {
|
||||
$user = $object->getUser();
|
||||
if ($user) {
|
||||
$text = pht('Edit Settings (%s)', $user->getUserName());
|
||||
} else {
|
||||
$text = pht('Edit Global Settings');
|
||||
}
|
||||
|
||||
$header = id(new PHUIHeaderView())
|
||||
->setHeader($text);
|
||||
|
||||
return $header;
|
||||
}
|
||||
|
||||
protected function getEditorURI() {
|
||||
throw new PhutilMethodNotImplementedException();
|
||||
}
|
||||
|
|
|
@ -312,6 +312,15 @@ abstract class PhabricatorEditEngine
|
|||
}
|
||||
|
||||
|
||||
/**
|
||||
* @task text
|
||||
*/
|
||||
protected function getPageHeader($object) {
|
||||
return null;
|
||||
}
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* Return a human-readable header describing what this engine is used to do,
|
||||
* like "Configure Maniphest Task Forms".
|
||||
|
@ -1169,6 +1178,9 @@ abstract class PhabricatorEditEngine
|
|||
|
||||
$form = $this->buildEditForm($object, $fields);
|
||||
|
||||
$crumbs = $this->buildCrumbs($object, $final = true);
|
||||
$crumbs->setBorder(true);
|
||||
|
||||
if ($request->isAjax()) {
|
||||
return $this->getController()
|
||||
->newDialog()
|
||||
|
@ -1180,21 +1192,18 @@ abstract class PhabricatorEditEngine
|
|||
->addSubmitButton($submit_button);
|
||||
}
|
||||
|
||||
$crumbs = $this->buildCrumbs($object, $final = true);
|
||||
|
||||
$header = id(new PHUIHeaderView())
|
||||
$box_header = id(new PHUIHeaderView())
|
||||
->setHeader($header_text);
|
||||
$crumbs->setBorder(true);
|
||||
|
||||
if ($action_button) {
|
||||
$header->addActionLink($action_button);
|
||||
$box_header->addActionLink($action_button);
|
||||
}
|
||||
|
||||
$box = id(new PHUIObjectBoxView())
|
||||
->setUser($viewer)
|
||||
->setHeaderText($this->getObjectName())
|
||||
->setHeader($box_header)
|
||||
->setValidationException($validation_exception)
|
||||
->setBackground(PHUIObjectBoxView::BLUE_PROPERTY)
|
||||
->setBackground(PHUIObjectBoxView::WHITE_CONFIG)
|
||||
->appendChild($form);
|
||||
|
||||
// This is fairly questionable, but in use by Settings.
|
||||
|
@ -1209,8 +1218,9 @@ abstract class PhabricatorEditEngine
|
|||
|
||||
$view = new PHUITwoColumnView();
|
||||
|
||||
if ($header) {
|
||||
$view->setHeader($header);
|
||||
$page_header = $this->getPageHeader($object);
|
||||
if ($page_header) {
|
||||
$view->setHeader($page_header);
|
||||
}
|
||||
|
||||
$page = $controller->newPage()
|
||||
|
|
|
@ -59,7 +59,6 @@ final class PHUIInfoView extends AphrontTagView {
|
|||
} else {
|
||||
$icon = id(new PHUIIconView())
|
||||
->setIcon($icon);
|
||||
$this->icon = $icon;
|
||||
}
|
||||
|
||||
return $this;
|
||||
|
|
|
@ -106,6 +106,10 @@ final class PHUITwoColumnView extends AphrontTagView {
|
|||
$classes[] = 'with-subheader';
|
||||
}
|
||||
|
||||
if (!$this->header) {
|
||||
$classes[] = 'without-header';
|
||||
}
|
||||
|
||||
return array(
|
||||
'class' => implode(' ', $classes),
|
||||
);
|
||||
|
|
|
@ -13,6 +13,10 @@
|
|||
margin-bottom: 24px;
|
||||
}
|
||||
|
||||
.phui-two-column-view.without-header {
|
||||
margin-top: 24px;
|
||||
}
|
||||
|
||||
.device .phui-two-column-view .phui-two-column-header {
|
||||
margin-bottom: 12px;
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue