2013-08-26 11:53:11 -07:00
|
|
|
<?php
|
|
|
|
|
2013-09-25 11:23:29 -07:00
|
|
|
final class PHUIObjectBoxView extends AphrontView {
|
2013-08-26 11:53:11 -07:00
|
|
|
|
|
|
|
private $headerText;
|
2014-06-24 09:39:32 -07:00
|
|
|
private $headerColor;
|
2014-01-10 09:17:37 -08:00
|
|
|
private $formErrors = null;
|
|
|
|
private $formSaved = false;
|
|
|
|
private $errorView;
|
2013-08-26 11:53:11 -07:00
|
|
|
private $form;
|
2013-09-18 15:31:58 -07:00
|
|
|
private $validationException;
|
2013-09-28 15:55:38 -07:00
|
|
|
private $header;
|
|
|
|
private $flush;
|
2014-01-09 08:51:57 -08:00
|
|
|
private $id;
|
2014-04-18 06:44:45 -07:00
|
|
|
private $sigils = array();
|
|
|
|
private $metadata;
|
2015-01-12 07:24:35 -08:00
|
|
|
private $actionListID;
|
Provide more structure to PHUIObjectBoxView
Summary:
Three changes here.
- Add `setActionList()`, and use that to set the action list.
- Add `setPropertyList()`, and use that to set the property list.
These will let us add some apropriate CSS so we can fix the border issue, and get rid of a bunch of goofy `.x + .y` selectors.
- Replace `addContent()` with `appendChild()`.
This is just a consistency thing; `AphrontView` already provides `appendChild()`, and `addContent()` did the same thing.
Test Plan:
- Viewed "All Config".
- Viewed a countdown.
- Viewed a revision (add comment, change list, table of contents, comment, local commits, open revisions affecting these files, update history).
- Viewed Diffusion (browse, change, history, repository, lint).
- Viewed Drydock (resource, lease).
- Viewed Files.
- Viewed Herald.
- Viewed Legalpad.
- Viewed macro (edit, edit audio, view).
- Viewed Maniphest.
- Viewed Applications.
- Viewed Paste.
- Viewed People.
- Viewed Phulux.
- Viewed Pholio.
- Viewed Phame (blog, post).
- Viewed Phortune (account, product).
- Viewed Ponder (questions, answers, comments).
- Viewed Releeph.
- Viewed Projects.
- Viewed Slowvote.
NOTE: Images in Files aren't on a black background anymore -- I assume that's on purpose?
NOTE: Some jankiness in Phortune, I'll clean that up when I get back to it. Not related to this diff.
Reviewers: chad
Reviewed By: chad
CC: aran
Differential Revision: https://secure.phabricator.com/D7174
2013-09-30 09:36:04 -07:00
|
|
|
|
2013-10-19 12:07:50 -07:00
|
|
|
private $tabs = array();
|
|
|
|
private $propertyLists = array();
|
|
|
|
|
2014-04-18 06:44:45 -07:00
|
|
|
public function addSigil($sigil) {
|
|
|
|
$this->sigils[] = $sigil;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function setMetadata(array $metadata) {
|
|
|
|
$this->metadata = $metadata;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2013-10-19 12:07:50 -07:00
|
|
|
public function addPropertyList(
|
|
|
|
PHUIPropertyListView $property_list,
|
2013-10-19 12:08:06 -07:00
|
|
|
$tab = null) {
|
2013-10-19 12:07:50 -07:00
|
|
|
|
2013-10-19 12:08:06 -07:00
|
|
|
if (!($tab instanceof PHUIListItemView) &&
|
|
|
|
($tab !== null)) {
|
|
|
|
assert_stringlike($tab);
|
|
|
|
$tab = id(new PHUIListItemView())->setName($tab);
|
2013-10-19 12:07:50 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
if ($tab) {
|
|
|
|
if ($tab->getKey()) {
|
|
|
|
$key = $tab->getKey();
|
|
|
|
} else {
|
|
|
|
$key = 'tab.default.'.spl_object_hash($tab);
|
|
|
|
$tab->setKey($key);
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
$key = 'tab.default';
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($tab) {
|
|
|
|
if (empty($this->tabs[$key])) {
|
|
|
|
$tab->addSigil('phui-object-box-tab');
|
|
|
|
$tab->setMetadata(
|
|
|
|
array(
|
|
|
|
'tabKey' => $key,
|
|
|
|
));
|
|
|
|
|
|
|
|
if (!$tab->getHref()) {
|
|
|
|
$tab->setHref('#');
|
|
|
|
}
|
|
|
|
|
2013-10-19 12:08:06 -07:00
|
|
|
if (!$tab->getType()) {
|
|
|
|
$tab->setType(PHUIListItemView::TYPE_LINK);
|
|
|
|
}
|
|
|
|
|
2013-10-19 12:07:50 -07:00
|
|
|
$this->tabs[$key] = $tab;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->propertyLists[$key][] = $property_list;
|
|
|
|
|
2015-01-12 07:24:35 -08:00
|
|
|
$action_list = $property_list->getActionList();
|
|
|
|
if ($action_list) {
|
|
|
|
$this->actionListID = celerity_generate_unique_node_id();
|
|
|
|
$action_list->setId($this->actionListID);
|
|
|
|
}
|
|
|
|
|
Provide more structure to PHUIObjectBoxView
Summary:
Three changes here.
- Add `setActionList()`, and use that to set the action list.
- Add `setPropertyList()`, and use that to set the property list.
These will let us add some apropriate CSS so we can fix the border issue, and get rid of a bunch of goofy `.x + .y` selectors.
- Replace `addContent()` with `appendChild()`.
This is just a consistency thing; `AphrontView` already provides `appendChild()`, and `addContent()` did the same thing.
Test Plan:
- Viewed "All Config".
- Viewed a countdown.
- Viewed a revision (add comment, change list, table of contents, comment, local commits, open revisions affecting these files, update history).
- Viewed Diffusion (browse, change, history, repository, lint).
- Viewed Drydock (resource, lease).
- Viewed Files.
- Viewed Herald.
- Viewed Legalpad.
- Viewed macro (edit, edit audio, view).
- Viewed Maniphest.
- Viewed Applications.
- Viewed Paste.
- Viewed People.
- Viewed Phulux.
- Viewed Pholio.
- Viewed Phame (blog, post).
- Viewed Phortune (account, product).
- Viewed Ponder (questions, answers, comments).
- Viewed Releeph.
- Viewed Projects.
- Viewed Slowvote.
NOTE: Images in Files aren't on a black background anymore -- I assume that's on purpose?
NOTE: Some jankiness in Phortune, I'll clean that up when I get back to it. Not related to this diff.
Reviewers: chad
Reviewed By: chad
CC: aran
Differential Revision: https://secure.phabricator.com/D7174
2013-09-30 09:36:04 -07:00
|
|
|
return $this;
|
|
|
|
}
|
2013-08-26 11:53:11 -07:00
|
|
|
|
|
|
|
public function setHeaderText($text) {
|
|
|
|
$this->headerText = $text;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2014-06-24 09:39:32 -07:00
|
|
|
public function setHeaderColor($color) {
|
|
|
|
$this->headerColor = $color;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2014-01-10 09:17:37 -08:00
|
|
|
public function setFormErrors(array $errors, $title = null) {
|
2014-10-09 16:58:26 -07:00
|
|
|
if ($errors) {
|
2015-03-01 14:45:56 -08:00
|
|
|
$this->formErrors = id(new PHUIInfoView())
|
2014-01-10 09:17:37 -08:00
|
|
|
->setTitle($title)
|
|
|
|
->setErrors($errors);
|
|
|
|
}
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function setFormSaved($saved, $text = null) {
|
|
|
|
if (!$text) {
|
|
|
|
$text = pht('Changes saved.');
|
|
|
|
}
|
|
|
|
if ($saved) {
|
2015-03-01 14:45:56 -08:00
|
|
|
$save = id(new PHUIInfoView())
|
|
|
|
->setSeverity(PHUIInfoView::SEVERITY_NOTICE)
|
2014-01-10 09:17:37 -08:00
|
|
|
->appendChild($text);
|
|
|
|
$this->formSaved = $save;
|
|
|
|
}
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2015-03-01 14:45:56 -08:00
|
|
|
public function setErrorView(PHUIInfoView $view) {
|
2014-01-10 09:17:37 -08:00
|
|
|
$this->errorView = $view;
|
2013-08-26 11:53:11 -07:00
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2013-08-26 15:45:58 -07:00
|
|
|
public function setForm($form) {
|
2013-08-26 11:53:11 -07:00
|
|
|
$this->form = $form;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2014-01-09 08:51:57 -08:00
|
|
|
public function setID($id) {
|
|
|
|
$this->id = $id;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2014-06-24 09:39:32 -07:00
|
|
|
public function setHeader($header) {
|
2013-09-28 15:55:38 -07:00
|
|
|
$this->header = $header;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function setFlush($flush) {
|
|
|
|
$this->flush = $flush;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2013-09-18 15:31:58 -07:00
|
|
|
public function setValidationException(
|
|
|
|
PhabricatorApplicationTransactionValidationException $ex = null) {
|
|
|
|
$this->validationException = $ex;
|
|
|
|
return $this;
|
|
|
|
}
|
2013-08-26 11:53:11 -07:00
|
|
|
|
2013-09-18 15:31:58 -07:00
|
|
|
public function render() {
|
2013-08-26 11:53:11 -07:00
|
|
|
|
2013-09-28 15:55:38 -07:00
|
|
|
require_celerity_resource('phui-object-box-css');
|
|
|
|
|
2014-06-24 09:39:32 -07:00
|
|
|
if ($this->headerColor) {
|
|
|
|
$header_color = $this->headerColor;
|
|
|
|
} else {
|
|
|
|
$header_color = PHUIActionHeaderView::HEADER_LIGHTBLUE;
|
|
|
|
}
|
|
|
|
|
2013-09-28 15:55:38 -07:00
|
|
|
if ($this->header) {
|
|
|
|
$header = $this->header;
|
2014-06-24 09:39:32 -07:00
|
|
|
$header->setHeaderColor($header_color);
|
2013-09-28 15:55:38 -07:00
|
|
|
} else {
|
|
|
|
$header = id(new PHUIHeaderView())
|
|
|
|
->setHeader($this->headerText)
|
2014-06-24 09:39:32 -07:00
|
|
|
->setHeaderColor($header_color);
|
2013-09-28 15:55:38 -07:00
|
|
|
}
|
2013-08-26 11:53:11 -07:00
|
|
|
|
2015-01-12 07:24:35 -08:00
|
|
|
if ($this->actionListID) {
|
|
|
|
$icon_id = celerity_generate_unique_node_id();
|
|
|
|
$icon = id(new PHUIIconView())
|
|
|
|
->setIconFont('fa-bars');
|
|
|
|
$meta = array(
|
|
|
|
'map' => array(
|
|
|
|
$this->actionListID => 'phabricator-action-list-toggle',
|
2015-01-12 08:21:17 -08:00
|
|
|
$icon_id => 'phuix-dropdown-open',
|
2015-01-12 07:24:35 -08:00
|
|
|
),);
|
|
|
|
$mobile_menu = id(new PHUIButtonView())
|
|
|
|
->setTag('a')
|
|
|
|
->setText(pht('Actions'))
|
|
|
|
->setHref('#')
|
|
|
|
->setIcon($icon)
|
|
|
|
->addClass('phui-mobile-menu')
|
|
|
|
->setID($icon_id)
|
2015-01-12 08:21:17 -08:00
|
|
|
->addSigil('jx-toggle-class')
|
|
|
|
->setMetadata($meta);
|
2015-01-12 07:24:35 -08:00
|
|
|
$header->addActionLink($mobile_menu);
|
|
|
|
}
|
|
|
|
|
2013-09-18 15:31:58 -07:00
|
|
|
$ex = $this->validationException;
|
|
|
|
$exception_errors = null;
|
|
|
|
if ($ex) {
|
|
|
|
$messages = array();
|
|
|
|
foreach ($ex->getErrors() as $error) {
|
|
|
|
$messages[] = $error->getMessage();
|
|
|
|
}
|
|
|
|
if ($messages) {
|
2015-03-01 14:45:56 -08:00
|
|
|
$exception_errors = id(new PHUIInfoView())
|
2013-09-18 15:31:58 -07:00
|
|
|
->setErrors($messages);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-10-19 12:08:06 -07:00
|
|
|
$tab_lists = array();
|
2013-10-19 12:07:50 -07:00
|
|
|
$property_lists = array();
|
|
|
|
$tab_map = array();
|
2013-10-19 12:08:06 -07:00
|
|
|
|
|
|
|
$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);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-10-19 12:07:50 -07:00
|
|
|
foreach ($this->propertyLists as $key => $list) {
|
|
|
|
$group = new PHUIPropertyGroupView();
|
2013-11-04 08:52:46 -08:00
|
|
|
$i = 0;
|
2013-10-19 12:07:50 -07:00
|
|
|
foreach ($list as $item) {
|
|
|
|
$group->addPropertyList($item);
|
2013-11-04 08:52:46 -08:00
|
|
|
if ($i > 0) {
|
|
|
|
$item->addClass('phui-property-list-section-noninitial');
|
|
|
|
}
|
|
|
|
$i++;
|
2013-10-19 12:07:50 -07:00
|
|
|
}
|
|
|
|
|
2013-10-19 12:08:06 -07:00
|
|
|
if ($this->tabs && $key != $default_key) {
|
2013-10-19 12:07:50 -07:00
|
|
|
$tab_id = celerity_generate_unique_node_id();
|
|
|
|
$tab_map[$key] = $tab_id;
|
|
|
|
|
2013-10-19 12:08:06 -07:00
|
|
|
if ($key === $selected_tab) {
|
2013-10-19 12:07:50 -07:00
|
|
|
$style = null;
|
|
|
|
} else {
|
|
|
|
$style = 'display: none';
|
|
|
|
}
|
|
|
|
|
2013-10-19 12:08:06 -07:00
|
|
|
$tab_lists[] = phutil_tag(
|
2013-10-19 12:07:50 -07:00
|
|
|
'div',
|
|
|
|
array(
|
|
|
|
'style' => $style,
|
|
|
|
'id' => $tab_id,
|
|
|
|
),
|
|
|
|
$group);
|
|
|
|
} else {
|
2013-10-19 12:08:06 -07:00
|
|
|
if ($this->tabs) {
|
|
|
|
$group->addClass('phui-property-group-noninitial');
|
|
|
|
}
|
2013-10-19 12:07:50 -07:00
|
|
|
$property_lists[] = $group;
|
2013-10-11 07:53:56 -07:00
|
|
|
}
|
2013-10-06 11:12:00 -07:00
|
|
|
}
|
|
|
|
|
2013-10-19 12:07:50 -07:00
|
|
|
$tabs = null;
|
|
|
|
if ($this->tabs) {
|
|
|
|
$tabs = id(new PHUIListView())
|
|
|
|
->setType(PHUIListView::NAVBAR_LIST);
|
|
|
|
foreach ($this->tabs as $tab) {
|
|
|
|
$tabs->addMenuItem($tab);
|
|
|
|
}
|
|
|
|
|
|
|
|
Javelin::initBehavior('phui-object-box-tabs');
|
|
|
|
}
|
|
|
|
|
2013-08-26 11:53:11 -07:00
|
|
|
$content = id(new PHUIBoxView())
|
2013-09-18 15:31:58 -07:00
|
|
|
->appendChild(
|
|
|
|
array(
|
|
|
|
$header,
|
2014-01-10 09:17:37 -08:00
|
|
|
$this->errorView,
|
|
|
|
$this->formErrors,
|
|
|
|
$this->formSaved,
|
2013-09-18 15:31:58 -07:00
|
|
|
$exception_errors,
|
|
|
|
$this->form,
|
2013-10-19 12:07:50 -07:00
|
|
|
$tabs,
|
2013-10-19 12:08:06 -07:00
|
|
|
$tab_lists,
|
2013-10-19 12:07:50 -07:00
|
|
|
$property_lists,
|
Provide more structure to PHUIObjectBoxView
Summary:
Three changes here.
- Add `setActionList()`, and use that to set the action list.
- Add `setPropertyList()`, and use that to set the property list.
These will let us add some apropriate CSS so we can fix the border issue, and get rid of a bunch of goofy `.x + .y` selectors.
- Replace `addContent()` with `appendChild()`.
This is just a consistency thing; `AphrontView` already provides `appendChild()`, and `addContent()` did the same thing.
Test Plan:
- Viewed "All Config".
- Viewed a countdown.
- Viewed a revision (add comment, change list, table of contents, comment, local commits, open revisions affecting these files, update history).
- Viewed Diffusion (browse, change, history, repository, lint).
- Viewed Drydock (resource, lease).
- Viewed Files.
- Viewed Herald.
- Viewed Legalpad.
- Viewed macro (edit, edit audio, view).
- Viewed Maniphest.
- Viewed Applications.
- Viewed Paste.
- Viewed People.
- Viewed Phulux.
- Viewed Pholio.
- Viewed Phame (blog, post).
- Viewed Phortune (account, product).
- Viewed Ponder (questions, answers, comments).
- Viewed Releeph.
- Viewed Projects.
- Viewed Slowvote.
NOTE: Images in Files aren't on a black background anymore -- I assume that's on purpose?
NOTE: Some jankiness in Phortune, I'll clean that up when I get back to it. Not related to this diff.
Reviewers: chad
Reviewed By: chad
CC: aran
Differential Revision: https://secure.phabricator.com/D7174
2013-09-30 09:36:04 -07:00
|
|
|
$this->renderChildren(),
|
2013-09-18 15:31:58 -07:00
|
|
|
))
|
2013-08-26 11:53:11 -07:00
|
|
|
->setBorder(true)
|
2014-01-09 08:51:57 -08:00
|
|
|
->setID($this->id)
|
2013-08-26 11:53:11 -07:00
|
|
|
->addMargin(PHUI::MARGIN_LARGE_TOP)
|
|
|
|
->addMargin(PHUI::MARGIN_LARGE_LEFT)
|
|
|
|
->addMargin(PHUI::MARGIN_LARGE_RIGHT)
|
2013-09-25 11:23:29 -07:00
|
|
|
->addClass('phui-object-box');
|
2013-08-26 11:53:11 -07:00
|
|
|
|
2013-10-19 12:07:50 -07:00
|
|
|
if ($this->tabs) {
|
|
|
|
$content->addSigil('phui-object-box');
|
|
|
|
$content->setMetadata(
|
|
|
|
array(
|
|
|
|
'tabMap' => $tab_map,
|
|
|
|
));
|
|
|
|
}
|
|
|
|
|
2013-09-28 15:55:38 -07:00
|
|
|
if ($this->flush) {
|
|
|
|
$content->addClass('phui-object-box-flush');
|
|
|
|
}
|
2013-08-26 11:53:11 -07:00
|
|
|
|
2014-06-24 09:39:32 -07:00
|
|
|
$content->addClass('phui-object-box-'.$header_color);
|
|
|
|
|
2014-04-18 06:44:45 -07:00
|
|
|
foreach ($this->sigils as $sigil) {
|
|
|
|
$content->addSigil($sigil);
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($this->metadata !== null) {
|
|
|
|
$content->setMetadata($this->metadata);
|
|
|
|
}
|
|
|
|
|
2013-09-28 15:55:38 -07:00
|
|
|
return $content;
|
2013-08-26 11:53:11 -07:00
|
|
|
}
|
|
|
|
}
|