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:
parent
9a16e5c1aa
commit
12d8520059
4 changed files with 133 additions and 141 deletions
|
@ -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',
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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;
|
||||||
|
|
Loading…
Add table
Reference in a new issue