1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-24 21:48:21 +01:00

Convert PHUIObjectBoxView to AphrontTagView

Summary: Attempting to clean PHUIObjectBoxView up a little as well as finally being able to `addClass` on the sucker. I'm running into some issue with `addTabs` though, which on Files isn't firing.

Test Plan: Bounce around tons of screens.

Reviewers: epriestley

Reviewed By: epriestley

Subscribers: Korvin

Differential Revision: https://secure.phabricator.com/D15291
This commit is contained in:
Chad Little 2016-02-17 12:43:38 -08:00
parent 9a16e5c1aa
commit 12d8520059
4 changed files with 133 additions and 141 deletions

View file

@ -5711,7 +5711,7 @@ phutil_register_library_map(array(
'PHUIListView' => 'AphrontTagView', 'PHUIListView' => 'AphrontTagView',
'PHUIListViewTestCase' => 'PhabricatorTestCase', 'PHUIListViewTestCase' => 'PhabricatorTestCase',
'PHUIMainMenuView' => 'AphrontView', 'PHUIMainMenuView' => 'AphrontView',
'PHUIObjectBoxView' => 'AphrontView', 'PHUIObjectBoxView' => 'AphrontTagView',
'PHUIObjectItemListExample' => 'PhabricatorUIExample', 'PHUIObjectItemListExample' => 'PhabricatorUIExample',
'PHUIObjectItemListView' => 'AphrontTagView', 'PHUIObjectItemListView' => 'AphrontTagView',
'PHUIObjectItemView' => 'AphrontTagView', 'PHUIObjectItemView' => 'AphrontTagView',

View file

@ -174,7 +174,7 @@ final class PhabricatorPeopleProfileViewController
$box = id(new PHUIObjectBoxView()) $box = id(new PHUIObjectBoxView())
->setHeader($header) ->setHeader($header)
->appendChild($list) ->appendChild($list)
->setBackground(PHUIBoxView::GREY); ->setBackground(PHUIObjectBoxView::GREY);
return $box; return $box;
} }
@ -218,7 +218,7 @@ final class PhabricatorPeopleProfileViewController
$box = id(new PHUIObjectBoxView()) $box = id(new PHUIObjectBoxView())
->setHeaderText(pht('Badges')) ->setHeaderText(pht('Badges'))
->appendChild($flex) ->appendChild($flex)
->setBackground(PHUIBoxView::GREY); ->setBackground(PHUIObjectBoxView::GREY);
return $box; return $box;
} }

View file

@ -59,14 +59,14 @@ final class PhabricatorProjectProfileController
->setUser($viewer) ->setUser($viewer)
->setProject($project) ->setProject($project)
->setLimit(5) ->setLimit(5)
->setBackground(PHUIBoxView::GREY) ->setBackground(PHUIObjectBoxView::GREY)
->setUserPHIDs($project->getMemberPHIDs()); ->setUserPHIDs($project->getMemberPHIDs());
$watcher_list = id(new PhabricatorProjectWatcherListView()) $watcher_list = id(new PhabricatorProjectWatcherListView())
->setUser($viewer) ->setUser($viewer)
->setProject($project) ->setProject($project)
->setLimit(5) ->setLimit(5)
->setBackground(PHUIBoxView::GREY) ->setBackground(PHUIObjectBoxView::GREY)
->setUserPHIDs($project->getWatcherPHIDs()); ->setUserPHIDs($project->getWatcherPHIDs());
$nav = $this->getProfileMenu(); $nav = $this->getProfileMenu();
@ -244,7 +244,7 @@ final class PhabricatorProjectProfileController
return id(new PHUIObjectBoxView()) return id(new PHUIObjectBoxView())
->setHeader($header) ->setHeader($header)
->setBackground(PHUIBoxView::GREY) ->setBackground(PHUIObjectBoxView::GREY)
->setObjectList($milestone_list); ->setObjectList($milestone_list);
} }
@ -292,7 +292,7 @@ final class PhabricatorProjectProfileController
return id(new PHUIObjectBoxView()) return id(new PHUIObjectBoxView())
->setHeader($header) ->setHeader($header)
->setBackground(PHUIBoxView::GREY) ->setBackground(PHUIObjectBoxView::GREY)
->setObjectList($subproject_list); ->setObjectList($subproject_list);
} }

View file

@ -1,6 +1,6 @@
<?php <?php
final class PHUIObjectBoxView extends AphrontView { final class PHUIObjectBoxView extends AphrontTagView {
private $headerText; private $headerText;
private $color; private $color;
@ -12,9 +12,6 @@ final class PHUIObjectBoxView extends AphrontView {
private $validationException; private $validationException;
private $header; private $header;
private $flush; private $flush;
private $id;
private $sigils = array();
private $metadata;
private $actionListID; private $actionListID;
private $objectList; private $objectList;
private $table; private $table;
@ -28,22 +25,18 @@ final class PHUIObjectBoxView extends AphrontView {
private $showHideOpen; private $showHideOpen;
private $tabs = array(); private $tabs = array();
private $tabMap = null;
private $tabLists = array();
private $propertyLists = array(); private $propertyLists = array();
private $propertyList = null;
const COLOR_RED = 'red'; const COLOR_RED = 'red';
const COLOR_BLUE = 'blue'; const COLOR_BLUE = 'blue';
const COLOR_GREEN = 'green'; const COLOR_GREEN = 'green';
const COLOR_YELLOW = 'yellow'; const COLOR_YELLOW = 'yellow';
public function addSigil($sigil) { const BLUE = 'phui-box-blue';
$this->sigils[] = $sigil; const GREY = 'phui-box-grey';
return $this;
}
public function setMetadata(array $metadata) {
$this->metadata = $metadata;
return $this;
}
public function addPropertyList( public function addPropertyList(
PHUIPropertyListView $property_list, PHUIPropertyListView $property_list,
@ -144,11 +137,6 @@ final class PHUIObjectBoxView extends AphrontView {
return $this; return $this;
} }
public function setID($id) {
$this->id = $id;
return $this;
}
public function setHeader($header) { public function setHeader($header) {
$this->header = $header; $this->header = $header;
return $this; return $this;
@ -195,7 +183,109 @@ final class PHUIObjectBoxView extends AphrontView {
return $this; return $this;
} }
public function render() { public function willRender() {
$tab_lists = array();
$property_lists = array();
$tab_map = array();
$default_key = 'tab.default';
// Find the selected tab, or select the first tab if none are selected.
if ($this->tabs) {
$selected_tab = null;
foreach ($this->tabs as $key => $tab) {
if ($tab->getSelected()) {
$selected_tab = $key;
break;
}
}
if ($selected_tab === null) {
head($this->tabs)->setSelected(true);
$selected_tab = head_key($this->tabs);
}
}
foreach ($this->propertyLists as $key => $list) {
$group = new PHUIPropertyGroupView();
$i = 0;
foreach ($list as $item) {
$group->addPropertyList($item);
if ($i > 0) {
$item->addClass('phui-property-list-section-noninitial');
}
$i++;
}
if ($this->tabs && $key != $default_key) {
$tab_id = celerity_generate_unique_node_id();
$tab_map[$key] = $tab_id;
if ($key === $selected_tab) {
$style = null;
} else {
$style = 'display: none';
}
$tab_lists[] = phutil_tag(
'div',
array(
'style' => $style,
'id' => $tab_id,
),
$group);
} else {
if ($this->tabs) {
$group->addClass('phui-property-group-noninitial');
}
$property_lists[] = $group;
}
$this->propertyList = $property_lists;
$this->tabMap = $tab_map;
$this->tabLists = $tab_lists;
}
}
protected function getTagAttributes() {
$classes = array();
$classes[] = 'phui-box';
$classes[] = 'phui-box-border';
$classes[] = 'phui-object-box';
$classes[] = 'mlt mll mlr';
if ($this->color) {
$classes[] = 'phui-object-box-'.$this->color;
}
if ($this->collapsed) {
$classes[] = 'phui-object-box-collapsed';
}
if ($this->flush) {
$classes[] = 'phui-object-box-flush';
}
if ($this->background) {
$classes[] = $this->background;
}
$sigil = null;
$metadata = null;
if ($this->tabs) {
$sigil = 'phui-object-box';
$metadata = array(
'tabMap' => $this->tabMap,
);
}
return array(
'class' => implode(' ', $classes),
'sigil' => $sigil,
'meta' => $metadata,
);
}
protected function getTagContent() {
require_celerity_resource('phui-box-css');
require_celerity_resource('phui-object-box-css'); require_celerity_resource('phui-object-box-css');
$header = $this->header; $header = $this->header;
@ -296,63 +386,6 @@ final class PHUIObjectBoxView extends AphrontView {
} }
} }
$tab_lists = array();
$property_lists = array();
$tab_map = array();
$default_key = 'tab.default';
// Find the selected tab, or select the first tab if none are selected.
if ($this->tabs) {
$selected_tab = null;
foreach ($this->tabs as $key => $tab) {
if ($tab->getSelected()) {
$selected_tab = $key;
break;
}
}
if ($selected_tab === null) {
head($this->tabs)->setSelected(true);
$selected_tab = head_key($this->tabs);
}
}
foreach ($this->propertyLists as $key => $list) {
$group = new PHUIPropertyGroupView();
$i = 0;
foreach ($list as $item) {
$group->addPropertyList($item);
if ($i > 0) {
$item->addClass('phui-property-list-section-noninitial');
}
$i++;
}
if ($this->tabs && $key != $default_key) {
$tab_id = celerity_generate_unique_node_id();
$tab_map[$key] = $tab_id;
if ($key === $selected_tab) {
$style = null;
} else {
$style = 'display: none';
}
$tab_lists[] = phutil_tag(
'div',
array(
'style' => $style,
'id' => $tab_id,
),
$group);
} else {
if ($this->tabs) {
$group->addClass('phui-property-group-noninitial');
}
$property_lists[] = $group;
}
}
$tabs = null; $tabs = null;
if ($this->tabs) { if ($this->tabs) {
$tabs = id(new PHUIListView()) $tabs = id(new PHUIListView())
@ -360,69 +393,28 @@ final class PHUIObjectBoxView extends AphrontView {
foreach ($this->tabs as $tab) { foreach ($this->tabs as $tab) {
$tabs->addMenuItem($tab); $tabs->addMenuItem($tab);
} }
Javelin::initBehavior('phui-object-box-tabs'); Javelin::initBehavior('phui-object-box-tabs');
} }
$content = id(new PHUIBoxView()) $content = array(
->appendChild( ($this->showHideOpen == false ? $this->anchor : null),
array( $header,
($this->showHideOpen == false ? $this->anchor : null), $this->infoView,
$header, $this->formErrors,
$this->infoView, $this->formSaved,
$this->formErrors, $exception_errors,
$this->formSaved, $this->form,
$exception_errors, $tabs,
$this->form, $this->tabLists,
$tabs, $showhide,
$tab_lists, ($this->showHideOpen == true ? $this->anchor : null),
$showhide, $this->propertyList,
($this->showHideOpen == true ? $this->anchor : null), $this->table,
$property_lists, $this->renderChildren(),
$this->table, );
$this->renderChildren(),
))
->setBorder(true)
->setID($this->id)
->addMargin(PHUI::MARGIN_LARGE_TOP)
->addMargin(PHUI::MARGIN_LARGE_LEFT)
->addMargin(PHUI::MARGIN_LARGE_RIGHT)
->addClass('phui-object-box');
if ($this->color) {
$content->addClass('phui-object-box-'.$this->color);
}
if ($this->background) {
$content->setColor($this->background);
}
if ($this->collapsed) {
$content->addClass('phui-object-box-collapsed');
}
if ($this->tabs) {
$content->addSigil('phui-object-box');
$content->setMetadata(
array(
'tabMap' => $tab_map,
));
}
if ($this->flush) {
$content->addClass('phui-object-box-flush');
}
foreach ($this->sigils as $sigil) {
$content->addSigil($sigil);
}
if ($this->metadata !== null) {
$content->setMetadata($this->metadata);
}
if ($this->objectList) { if ($this->objectList) {
$content->appendChild($this->objectList); $content[] = $this->objectList;
} }
return $content; return $content;