1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-01 02:10:59 +01:00

Add setHeader to PHUITwoColumnView for consistent page layouts

Summary: Working towards making PHUITwoColumnView into a page layout engine. Adds header support.

Test Plan: Use new header on Profile and Profiles. No visual changes, less duplicated code.

Reviewers: epriestley

Reviewed By: epriestley

Subscribers: Korvin

Differential Revision: https://secure.phabricator.com/D15292
This commit is contained in:
Chad Little 2016-02-17 13:05:24 -08:00
parent 12d8520059
commit f5e2f9587c
6 changed files with 30 additions and 33 deletions

View file

@ -94,7 +94,7 @@ return array(
'rsrc/css/application/policy/policy.css' => '957ea14c', 'rsrc/css/application/policy/policy.css' => '957ea14c',
'rsrc/css/application/ponder/ponder-view.css' => '4486434b', 'rsrc/css/application/ponder/ponder-view.css' => '4486434b',
'rsrc/css/application/project/project-card-view.css' => '9418c97d', 'rsrc/css/application/project/project-card-view.css' => '9418c97d',
'rsrc/css/application/project/project-view.css' => '4c832c27', 'rsrc/css/application/project/project-view.css' => '83bb6654',
'rsrc/css/application/releeph/releeph-core.css' => '9b3c5733', 'rsrc/css/application/releeph/releeph-core.css' => '9b3c5733',
'rsrc/css/application/releeph/releeph-preview-branch.css' => 'b7a6f4a5', 'rsrc/css/application/releeph/releeph-preview-branch.css' => 'b7a6f4a5',
'rsrc/css/application/releeph/releeph-request-differential-create-dialog.css' => '8d8b92cd', 'rsrc/css/application/releeph/releeph-request-differential-create-dialog.css' => '8d8b92cd',
@ -154,7 +154,7 @@ return array(
'rsrc/css/phui/phui-status.css' => '888cedb8', 'rsrc/css/phui/phui-status.css' => '888cedb8',
'rsrc/css/phui/phui-tag-view.css' => '9d5d4400', 'rsrc/css/phui/phui-tag-view.css' => '9d5d4400',
'rsrc/css/phui/phui-timeline-view.css' => '2efceff8', 'rsrc/css/phui/phui-timeline-view.css' => '2efceff8',
'rsrc/css/phui/phui-two-column-view.css' => 'c75bfc5b', 'rsrc/css/phui/phui-two-column-view.css' => '0763177e',
'rsrc/css/phui/workboards/phui-workboard-color.css' => 'ac6fe6a7', 'rsrc/css/phui/workboards/phui-workboard-color.css' => 'ac6fe6a7',
'rsrc/css/phui/workboards/phui-workboard.css' => 'e6d89647', 'rsrc/css/phui/workboards/phui-workboard.css' => 'e6d89647',
'rsrc/css/phui/workboards/phui-workcard.css' => '3646fb96', 'rsrc/css/phui/workboards/phui-workcard.css' => '3646fb96',
@ -841,7 +841,7 @@ return array(
'phui-tag-view-css' => '9d5d4400', 'phui-tag-view-css' => '9d5d4400',
'phui-theme-css' => 'ab7b848c', 'phui-theme-css' => 'ab7b848c',
'phui-timeline-view-css' => '2efceff8', 'phui-timeline-view-css' => '2efceff8',
'phui-two-column-view-css' => 'c75bfc5b', 'phui-two-column-view-css' => '0763177e',
'phui-workboard-color-css' => 'ac6fe6a7', 'phui-workboard-color-css' => 'ac6fe6a7',
'phui-workboard-view-css' => 'e6d89647', 'phui-workboard-view-css' => 'e6d89647',
'phui-workcard-view-css' => '3646fb96', 'phui-workcard-view-css' => '3646fb96',
@ -857,7 +857,7 @@ return array(
'policy-transaction-detail-css' => '82100a43', 'policy-transaction-detail-css' => '82100a43',
'ponder-view-css' => '4486434b', 'ponder-view-css' => '4486434b',
'project-card-view-css' => '9418c97d', 'project-card-view-css' => '9418c97d',
'project-view-css' => '4c832c27', 'project-view-css' => '83bb6654',
'releeph-core' => '9b3c5733', 'releeph-core' => '9b3c5733',
'releeph-preview-branch' => 'b7a6f4a5', 'releeph-preview-branch' => 'b7a6f4a5',
'releeph-request-differential-create-dialog' => '8d8b92cd', 'releeph-request-differential-create-dialog' => '8d8b92cd',

View file

@ -56,9 +56,11 @@ final class PhabricatorPeopleProfileViewController
$projects = $this->buildProjectsView($user); $projects = $this->buildProjectsView($user);
$badges = $this->buildBadgesView($user); $badges = $this->buildBadgesView($user);
require_celerity_resource('project-view-css');
$columns = id(new PHUITwoColumnView()) $home = id(new PHUITwoColumnView())
->addClass('project-view-badges') ->setHeader($header)
->addClass('project-view-home')
->setMainColumn( ->setMainColumn(
array( array(
$properties, $properties,
@ -76,17 +78,6 @@ final class PhabricatorPeopleProfileViewController
$crumbs = $this->buildApplicationCrumbs(); $crumbs = $this->buildApplicationCrumbs();
$crumbs->setBorder(true); $crumbs->setBorder(true);
require_celerity_resource('project-view-css');
$home = phutil_tag(
'div',
array(
'class' => 'project-view-home',
),
array(
$header,
$columns,
));
return $this->newPage() return $this->newPage()
->setTitle($user->getUsername()) ->setTitle($user->getUsername())
->setNavigation($nav) ->setNavigation($nav)
@ -217,6 +208,7 @@ final class PhabricatorPeopleProfileViewController
$box = id(new PHUIObjectBoxView()) $box = id(new PHUIObjectBoxView())
->setHeaderText(pht('Badges')) ->setHeaderText(pht('Badges'))
->addClass('project-view-badges')
->appendChild($flex) ->appendChild($flex)
->setBackground(PHUIObjectBoxView::GREY); ->setBackground(PHUIObjectBoxView::GREY);

View file

@ -83,8 +83,11 @@ final class PhabricatorProjectProfileController
$feed = $this->renderStories($stories); $feed = $this->renderStories($stories);
$feed = phutil_tag_div('project-view-feed', $feed); $feed = phutil_tag_div('project-view-feed', $feed);
require_celerity_resource('project-view-css');
$columns = id(new PHUITwoColumnView()) $home = id(new PHUITwoColumnView())
->setHeader($header)
->addClass('project-view-home')
->setMainColumn( ->setMainColumn(
array( array(
$properties, $properties,
@ -101,17 +104,6 @@ final class PhabricatorProjectProfileController
$crumbs = $this->buildApplicationCrumbs(); $crumbs = $this->buildApplicationCrumbs();
$crumbs->setBorder(true); $crumbs->setBorder(true);
require_celerity_resource('project-view-css');
$home = phutil_tag(
'div',
array(
'class' => 'project-view-home',
),
array(
$header,
$columns,
));
return $this->newPage() return $this->newPage()
->setNavigation($nav) ->setNavigation($nav)
->setCrumbs($crumbs) ->setCrumbs($crumbs)

View file

@ -5,6 +5,7 @@ final class PHUITwoColumnView extends AphrontTagView {
private $mainColumn; private $mainColumn;
private $sideColumn; private $sideColumn;
private $display; private $display;
private $header;
const DISPLAY_LEFT = 'phui-side-column-left'; const DISPLAY_LEFT = 'phui-side-column-left';
const DISPLAY_RIGHT = 'phui-side-column-right'; const DISPLAY_RIGHT = 'phui-side-column-right';
@ -19,6 +20,11 @@ final class PHUITwoColumnView extends AphrontTagView {
return $this; return $this;
} }
public function setHeader(PHUIHeaderView $header) {
$this->header = $header;
return $this;
}
public function setDisplay($display) { public function setDisplay($display) {
$this->display = $display; $this->display = $display;
return $this; return $this;
@ -35,7 +41,6 @@ final class PHUITwoColumnView extends AphrontTagView {
protected function getTagAttributes() { protected function getTagAttributes() {
$classes = array(); $classes = array();
$classes[] = 'phui-two-column-view'; $classes[] = 'phui-two-column-view';
$classes[] = 'grouped';
$classes[] = $this->getDisplay(); $classes[] = $this->getDisplay();
return array( return array(
@ -66,6 +71,14 @@ final class PHUITwoColumnView extends AphrontTagView {
$order = array($main, $side); $order = array($main, $side);
} }
return phutil_tag_div('phui-two-column-row', $order); $inner = phutil_tag_div('phui-two-column-row', $order);
$table = phutil_tag_div('phui-two-column-content', $inner);
$header = null;
if ($this->header) {
$header = phutil_tag_div('phui-two-column-header', $this->header);
}
return array($header, $table);
} }
} }

View file

@ -51,7 +51,7 @@
} }
.project-view-feed .phui-object-box.phui-box-border { .project-view-feed .phui-object-box.phui-box-border {
padding: 0 16px 8px 16px; padding: 0 4px 8px 4px;
border: none; border: none;
} }

View file

@ -2,7 +2,7 @@
* @provides phui-two-column-view-css * @provides phui-two-column-view-css
*/ */
.phui-two-column-view { .phui-two-column-content {
display: table; display: table;
width: 100%; width: 100%;
} }