2013-06-01 00:03:59 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
final class PHUIDocumentView extends AphrontTagView {
|
|
|
|
|
2013-06-06 21:47:40 +02:00
|
|
|
/* For mobile displays, where do you want the sidebar */
|
|
|
|
const NAV_BOTTOM = 'nav_bottom';
|
|
|
|
const NAV_TOP = 'nav_top';
|
|
|
|
|
2013-06-01 00:03:59 +02:00
|
|
|
private $offset;
|
2013-06-05 17:41:43 +02:00
|
|
|
private $header;
|
|
|
|
private $sidenav;
|
|
|
|
private $topnav;
|
|
|
|
private $crumbs;
|
|
|
|
private $bookname;
|
|
|
|
private $bookdescription;
|
2013-06-06 21:47:40 +02:00
|
|
|
private $mobileview;
|
2015-03-02 21:08:04 +01:00
|
|
|
private $fluid;
|
2013-06-01 00:03:59 +02:00
|
|
|
|
|
|
|
public function setOffset($offset) {
|
|
|
|
$this->offset = $offset;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2013-09-17 18:12:37 +02:00
|
|
|
public function setHeader(PHUIHeaderView $header) {
|
2015-05-31 17:36:44 +02:00
|
|
|
$header->setTall(true);
|
2013-06-05 17:41:43 +02:00
|
|
|
$this->header = $header;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2013-06-06 21:47:40 +02:00
|
|
|
public function setSideNav(PHUIListView $list, $display = self::NAV_BOTTOM) {
|
2013-06-06 17:36:51 +02:00
|
|
|
$list->setType(PHUIListView::SIDENAV_LIST);
|
2013-06-05 17:41:43 +02:00
|
|
|
$this->sidenav = $list;
|
2013-06-06 21:47:40 +02:00
|
|
|
$this->mobileview = $display;
|
2013-06-05 17:41:43 +02:00
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function setTopNav(PHUIListView $list) {
|
2013-06-06 17:36:51 +02:00
|
|
|
$list->setType(PHUIListView::NAVBAR_LIST);
|
2013-06-05 17:41:43 +02:00
|
|
|
$this->topnav = $list;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function setCrumbs(PHUIListView $list) {
|
|
|
|
$this->crumbs = $list;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function setBook($name, $description) {
|
|
|
|
$this->bookname = $name;
|
|
|
|
$this->bookdescription = $description;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2015-03-02 21:08:04 +01:00
|
|
|
public function setFluid($fluid) {
|
|
|
|
$this->fluid = $fluid;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2015-01-13 20:54:39 +01:00
|
|
|
protected function getTagAttributes() {
|
2013-06-01 00:03:59 +02:00
|
|
|
$classes = array();
|
|
|
|
|
|
|
|
if ($this->offset) {
|
|
|
|
$classes[] = 'phui-document-offset';
|
2015-05-13 22:50:28 +02:00
|
|
|
}
|
2013-06-01 00:03:59 +02:00
|
|
|
|
2015-03-02 21:08:04 +01:00
|
|
|
if ($this->fluid) {
|
|
|
|
$classes[] = 'phui-document-fluid';
|
|
|
|
}
|
|
|
|
|
2013-06-01 00:03:59 +02:00
|
|
|
return array(
|
|
|
|
'class' => $classes,
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2015-01-13 20:54:39 +01:00
|
|
|
protected function getTagContent() {
|
2013-06-01 00:03:59 +02:00
|
|
|
require_celerity_resource('phui-document-view-css');
|
2014-03-06 20:39:48 +01:00
|
|
|
|
2013-06-05 17:41:43 +02:00
|
|
|
$classes = array();
|
|
|
|
$classes[] = 'phui-document-view';
|
|
|
|
if ($this->offset) {
|
|
|
|
$classes[] = 'phui-offset-view';
|
|
|
|
}
|
|
|
|
if ($this->sidenav) {
|
|
|
|
$classes[] = 'phui-sidenav-view';
|
|
|
|
}
|
|
|
|
|
|
|
|
$sidenav = null;
|
|
|
|
if ($this->sidenav) {
|
|
|
|
$sidenav = phutil_tag(
|
|
|
|
'div',
|
|
|
|
array(
|
2014-10-07 15:01:04 +02:00
|
|
|
'class' => 'phui-document-sidenav',
|
2013-06-05 17:41:43 +02:00
|
|
|
),
|
|
|
|
$this->sidenav);
|
|
|
|
}
|
|
|
|
|
|
|
|
$book = null;
|
|
|
|
if ($this->bookname) {
|
2015-05-31 17:36:44 +02:00
|
|
|
$book = pht('%s (%s)', $this->bookname, $this->bookdescription);
|
2013-06-05 17:41:43 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
$topnav = null;
|
|
|
|
if ($this->topnav) {
|
|
|
|
$topnav = phutil_tag(
|
|
|
|
'div',
|
|
|
|
array(
|
2014-10-07 15:01:04 +02:00
|
|
|
'class' => 'phui-document-topnav',
|
2013-06-05 17:41:43 +02:00
|
|
|
),
|
|
|
|
$this->topnav);
|
|
|
|
}
|
|
|
|
|
|
|
|
$crumbs = null;
|
|
|
|
if ($this->crumbs) {
|
|
|
|
$crumbs = phutil_tag(
|
|
|
|
'div',
|
|
|
|
array(
|
2014-10-07 15:01:04 +02:00
|
|
|
'class' => 'phui-document-crumbs',
|
2013-06-05 17:41:43 +02:00
|
|
|
),
|
|
|
|
$this->bookName);
|
|
|
|
}
|
|
|
|
|
[Redesign] Move basefont to Lato, remove Source Sans Pro
Summary: Working towards a more unified look and feel. This brings in Lato as a complete base font over Helvetica Neue, as well as removing Source Sans Pro from DocumentView and Conpherence. Design-wise Lato provides the nice readability at larger font sizes that Source Sans Pro did, with the ability to scale down to tables and UI widgets with ease. This gives us one font instead of two, and now Object descriptions and Timeline posts all can benefit from a consistent, readable font.
Test Plan:
Test main UI, smaller elements like tables, menus, DocumentViews, Previews, Conpherence.
{F498135}
{F498136}
Reviewers: btrahan, epriestley
Reviewed By: epriestley
Subscribers: epriestley, Korvin
Differential Revision: https://secure.phabricator.com/D13276
2015-06-13 21:32:45 +02:00
|
|
|
$main_content = $this->renderChildren();
|
2014-03-06 20:28:24 +01:00
|
|
|
|
2015-06-04 05:44:33 +02:00
|
|
|
if ($book) {
|
|
|
|
$this->header->setSubheader($book);
|
|
|
|
}
|
2013-06-05 17:41:43 +02:00
|
|
|
$content_inner = phutil_tag(
|
|
|
|
'div',
|
|
|
|
array(
|
|
|
|
'class' => 'phui-document-inner',
|
|
|
|
),
|
|
|
|
array(
|
|
|
|
$this->header,
|
|
|
|
$topnav,
|
2014-03-06 20:28:24 +01:00
|
|
|
$main_content,
|
2014-10-07 15:01:04 +02:00
|
|
|
$crumbs,
|
2013-06-05 17:41:43 +02:00
|
|
|
));
|
|
|
|
|
2013-06-06 21:47:40 +02:00
|
|
|
if ($this->mobileview == self::NAV_BOTTOM) {
|
|
|
|
$order = array($content_inner, $sidenav);
|
|
|
|
} else {
|
|
|
|
$order = array($sidenav, $content_inner);
|
|
|
|
}
|
|
|
|
|
2013-06-05 17:41:43 +02:00
|
|
|
$content = phutil_tag(
|
2013-06-01 00:03:59 +02:00
|
|
|
'div',
|
|
|
|
array(
|
|
|
|
'class' => 'phui-document-content',
|
|
|
|
),
|
2013-06-06 21:47:40 +02:00
|
|
|
$order);
|
2013-06-05 17:41:43 +02:00
|
|
|
|
|
|
|
$view = phutil_tag(
|
|
|
|
'div',
|
|
|
|
array(
|
|
|
|
'class' => implode(' ', $classes),
|
|
|
|
),
|
|
|
|
$content);
|
|
|
|
|
|
|
|
return $view;
|
2013-06-01 00:03:59 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|