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

Basic NUX blank states

Summary: Implement in Badges

Test Plan:
Test with nux=true.

{F1033431}

Reviewers: epriestley

Reviewed By: epriestley

Subscribers: johnny-bit, Korvin

Differential Revision: https://secure.phabricator.com/D14833
This commit is contained in:
Chad Little 2015-12-21 07:35:45 -08:00
parent 006321cce7
commit c6f3a03209
6 changed files with 150 additions and 8 deletions

View file

@ -123,6 +123,7 @@ return array(
'rsrc/css/phui/phui-action-list.css' => 'c5eba19d', 'rsrc/css/phui/phui-action-list.css' => 'c5eba19d',
'rsrc/css/phui/phui-action-panel.css' => '91c7b835', 'rsrc/css/phui/phui-action-panel.css' => '91c7b835',
'rsrc/css/phui/phui-badge.css' => 'f25c3476', 'rsrc/css/phui/phui-badge.css' => 'f25c3476',
'rsrc/css/phui/phui-big-info-view.css' => '86cf0dd3',
'rsrc/css/phui/phui-box.css' => 'a5bb366d', 'rsrc/css/phui/phui-box.css' => 'a5bb366d',
'rsrc/css/phui/phui-button.css' => '16020a60', 'rsrc/css/phui/phui-button.css' => '16020a60',
'rsrc/css/phui/phui-crumbs-view.css' => '414406b5', 'rsrc/css/phui/phui-crumbs-view.css' => '414406b5',
@ -791,6 +792,7 @@ return array(
'phriction-document-css' => 'd1861e06', 'phriction-document-css' => 'd1861e06',
'phui-action-panel-css' => '91c7b835', 'phui-action-panel-css' => '91c7b835',
'phui-badge-view-css' => 'f25c3476', 'phui-badge-view-css' => 'f25c3476',
'phui-big-info-view-css' => '86cf0dd3',
'phui-box-css' => 'a5bb366d', 'phui-box-css' => 'a5bb366d',
'phui-button-css' => '16020a60', 'phui-button-css' => '16020a60',
'phui-calendar-css' => 'ccabe893', 'phui-calendar-css' => 'ccabe893',

View file

@ -1444,6 +1444,7 @@ phutil_register_library_map(array(
'PHUIBadgeExample' => 'applications/uiexample/examples/PHUIBadgeExample.php', 'PHUIBadgeExample' => 'applications/uiexample/examples/PHUIBadgeExample.php',
'PHUIBadgeMiniView' => 'view/phui/PHUIBadgeMiniView.php', 'PHUIBadgeMiniView' => 'view/phui/PHUIBadgeMiniView.php',
'PHUIBadgeView' => 'view/phui/PHUIBadgeView.php', 'PHUIBadgeView' => 'view/phui/PHUIBadgeView.php',
'PHUIBigInfoView' => 'view/phui/PHUIBigInfoView.php',
'PHUIBoxExample' => 'applications/uiexample/examples/PHUIBoxExample.php', 'PHUIBoxExample' => 'applications/uiexample/examples/PHUIBoxExample.php',
'PHUIBoxView' => 'view/phui/PHUIBoxView.php', 'PHUIBoxView' => 'view/phui/PHUIBoxView.php',
'PHUIButtonBarExample' => 'applications/uiexample/examples/PHUIButtonBarExample.php', 'PHUIButtonBarExample' => 'applications/uiexample/examples/PHUIButtonBarExample.php',
@ -5503,6 +5504,7 @@ phutil_register_library_map(array(
'PHUIBadgeExample' => 'PhabricatorUIExample', 'PHUIBadgeExample' => 'PhabricatorUIExample',
'PHUIBadgeMiniView' => 'AphrontTagView', 'PHUIBadgeMiniView' => 'AphrontTagView',
'PHUIBadgeView' => 'AphrontTagView', 'PHUIBadgeView' => 'AphrontTagView',
'PHUIBigInfoView' => 'AphrontTagView',
'PHUIBoxExample' => 'PhabricatorUIExample', 'PHUIBoxExample' => 'PhabricatorUIExample',
'PHUIBoxView' => 'AphrontTagView', 'PHUIBoxView' => 'AphrontTagView',
'PHUIButtonBarExample' => 'PhabricatorUIExample', 'PHUIButtonBarExample' => 'PhabricatorUIExample',

View file

@ -140,4 +140,24 @@ final class PhabricatorBadgesSearchEngine
} }
protected function getNewUserBody() {
$create_button = id(new PHUIButtonView())
->setTag('a')
->setText(pht('Create a Badge'))
->setHref('/badges/create/')
->setColor(PHUIButtonView::GREEN);
$icon = $this->getApplication()->getFontIcon();
$app_name = $this->getApplication()->getName();
$view = id(new PHUIBigInfoView())
->setIcon($icon)
->setTitle(pht('Welcome to %s', $app_name))
->setDescription(
pht('Badges let you award and distinguish special users '.
'throughout your instance.'))
->addAction($create_button);
return $view;
}
} }

View file

@ -1355,19 +1355,13 @@ abstract class PhabricatorApplicationSearchEngine extends Phobject {
} }
final public function renderNewUserView() { final public function renderNewUserView() {
$head = $this->getNewUserHeader();
$body = $this->getNewUserBody(); $body = $this->getNewUserBody();
if (!strlen($head) && !strlen($body)) { if (!$body) {
return null; return null;
} }
$viewer = $this->requireViewer(); return $body;
return id(new PHUIBoxView())
->addMargin(PHUI::MARGIN_LARGE)
->appendChild($head)
->appendChild(new PHUIRemarkupView($viewer, $body));
} }
protected function getNewUserHeader() { protected function getNewUserHeader() {

View file

@ -0,0 +1,95 @@
<?php
final class PHUIBigInfoView extends AphrontTagView {
private $icon;
private $title;
private $description;
private $actions = array();
public function setIcon($icon) {
$this->icon = $icon;
return $this;
}
public function setTitle($title) {
$this->title = $title;
return $this;
}
public function setDescription($description) {
$this->description = $description;
return $this;
}
public function addAction(PHUIButtonView $button) {
$this->actions[] = $button;
return $this;
}
protected function getTagName() {
return 'div';
}
protected function getTagAttributes() {
$classes = array();
$classes[] = 'phui-big-info-view';
return array(
'class' => implode(' ', $classes),
);
}
protected function getTagContent() {
require_celerity_resource('phui-big-info-view-css');
$icon = id(new PHUIIconView())
->setIconFont($this->icon)
->addClass('phui-big-info-icon');
$icon = phutil_tag(
'div',
array(
'class' => 'phui-big-info-icon-container',
),
$icon);
$title = phutil_tag(
'div',
array(
'class' => 'phui-big-info-title',
),
$this->title);
$description = phutil_tag(
'div',
array(
'class' => 'phui-big-info-description',
),
$this->description);
$buttons = array();
foreach ($this->actions as $button) {
$buttons[] = phutil_tag(
'div',
array(
'class' => 'phui-big-info-button',
),
$button);
}
$actions = null;
if ($buttons) {
$actions = phutil_tag(
'div',
array(
'class' => 'phui-big-info-actions',
),
$buttons);
}
return array($icon, $title, $description, $actions);
}
}

View file

@ -0,0 +1,29 @@
/**
* @provides phui-big-info-view-css
*/
.phui-big-info-view {
padding: 64px 32px;
margin: 16px 4px;
background-color: {$sh-greybackground};
text-align: center;
}
.phui-big-info-icon {
font-size: 48px;
}
.phui-big-info-title {
font-size: 18px;
padding: 4px;
font-weight: bold;
}
.phui-big-info-description {
font-size: {$biggerfontsize};
padding: 4px;
}
.phui-big-info-actions {
padding: 24px 0 0;
}