mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-18 10:41:08 +01:00
Try layering state icons on PHUICircleIconView
Summary: I think this is reasonable for my current use case, but stacking icons overally is pretty clunky. Test Plan: UIExamples {F4978899} Reviewers: epriestley Reviewed By: epriestley Subscribers: Korvin Differential Revision: https://secure.phabricator.com/D18032
This commit is contained in:
parent
aefc006ba5
commit
81809713e0
4 changed files with 98 additions and 6 deletions
|
@ -9,7 +9,7 @@ return array(
|
||||||
'names' => array(
|
'names' => array(
|
||||||
'conpherence.pkg.css' => 'ff161f2d',
|
'conpherence.pkg.css' => 'ff161f2d',
|
||||||
'conpherence.pkg.js' => 'b5b51108',
|
'conpherence.pkg.js' => 'b5b51108',
|
||||||
'core.pkg.css' => 'b666574e',
|
'core.pkg.css' => '19f6f61f',
|
||||||
'core.pkg.js' => '21d34805',
|
'core.pkg.js' => '21d34805',
|
||||||
'darkconsole.pkg.js' => '1f9a31bc',
|
'darkconsole.pkg.js' => '1f9a31bc',
|
||||||
'differential.pkg.css' => '7d4cfa59',
|
'differential.pkg.css' => '7d4cfa59',
|
||||||
|
@ -158,7 +158,7 @@ return array(
|
||||||
'rsrc/css/phui/phui-header-view.css' => 'a3d1aecd',
|
'rsrc/css/phui/phui-header-view.css' => 'a3d1aecd',
|
||||||
'rsrc/css/phui/phui-hovercard.css' => 'f0592bcf',
|
'rsrc/css/phui/phui-hovercard.css' => 'f0592bcf',
|
||||||
'rsrc/css/phui/phui-icon-set-selector.css' => '87db8fee',
|
'rsrc/css/phui/phui-icon-set-selector.css' => '87db8fee',
|
||||||
'rsrc/css/phui/phui-icon.css' => '12b387a1',
|
'rsrc/css/phui/phui-icon.css' => '4c6d624c',
|
||||||
'rsrc/css/phui/phui-image-mask.css' => 'a8498f9c',
|
'rsrc/css/phui/phui-image-mask.css' => 'a8498f9c',
|
||||||
'rsrc/css/phui/phui-info-panel.css' => '27ea50a1',
|
'rsrc/css/phui/phui-info-panel.css' => '27ea50a1',
|
||||||
'rsrc/css/phui/phui-info-view.css' => '6e217679',
|
'rsrc/css/phui/phui-info-view.css' => '6e217679',
|
||||||
|
@ -862,7 +862,7 @@ return array(
|
||||||
'phui-hovercard' => '1bd28176',
|
'phui-hovercard' => '1bd28176',
|
||||||
'phui-hovercard-view-css' => 'f0592bcf',
|
'phui-hovercard-view-css' => 'f0592bcf',
|
||||||
'phui-icon-set-selector-css' => '87db8fee',
|
'phui-icon-set-selector-css' => '87db8fee',
|
||||||
'phui-icon-view-css' => '12b387a1',
|
'phui-icon-view-css' => '4c6d624c',
|
||||||
'phui-image-mask-css' => 'a8498f9c',
|
'phui-image-mask-css' => 'a8498f9c',
|
||||||
'phui-info-panel-css' => '27ea50a1',
|
'phui-info-panel-css' => '27ea50a1',
|
||||||
'phui-info-view-css' => '6e217679',
|
'phui-info-view-css' => '6e217679',
|
||||||
|
|
|
@ -130,6 +130,23 @@ final class PHUIIconExample extends PhabricatorUIExample {
|
||||||
->addClass('mmr');
|
->addClass('mmr');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$circles = array('fa-gear', 'fa-recycle');
|
||||||
|
$colors = array('green', 'pink', 'red', 'sky', 'violet');
|
||||||
|
foreach ($circles as $circle) {
|
||||||
|
$states = PHUIIconCircleView::getStateMap();
|
||||||
|
foreach ($states as $state => $name) {
|
||||||
|
$i = array_rand($colors);
|
||||||
|
$circleview[] =
|
||||||
|
id(new PHUIIconCircleView())
|
||||||
|
->setIcon($circle)
|
||||||
|
->setSize(PHUIIconCircleView::SMALL)
|
||||||
|
->setState($state)
|
||||||
|
->setColor($colors[$i])
|
||||||
|
->setHref('#')
|
||||||
|
->addClass('mmr');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
$squares = array('fa-briefcase', 'fa-code', 'fa-globe', 'fa-home');
|
$squares = array('fa-briefcase', 'fa-code', 'fa-globe', 'fa-home');
|
||||||
$squareview = array();
|
$squareview = array();
|
||||||
foreach ($squares as $icon) {
|
foreach ($squares as $icon) {
|
||||||
|
|
|
@ -6,10 +6,22 @@ final class PHUIIconCircleView extends AphrontTagView {
|
||||||
private $icon;
|
private $icon;
|
||||||
private $color;
|
private $color;
|
||||||
private $size;
|
private $size;
|
||||||
|
private $state;
|
||||||
|
|
||||||
const SMALL = 'circle-small';
|
const SMALL = 'circle-small';
|
||||||
const MEDIUM = 'circle-medium';
|
const MEDIUM = 'circle-medium';
|
||||||
|
|
||||||
|
const STATE_FAIL = 'fa-times-circle';
|
||||||
|
const STATE_INFO = 'fa-info-circle';
|
||||||
|
const STATE_STOP = 'fa-stop-circle';
|
||||||
|
const STATE_START = 'fa-play-circle';
|
||||||
|
const STATE_PAUSE = 'fa-pause-circle';
|
||||||
|
const STATE_SUCCESS = 'fa-check-circle';
|
||||||
|
const STATE_WARNING = 'fa-exclamation-circle';
|
||||||
|
const STATE_PLUS = 'fa-plus-circle';
|
||||||
|
const STATE_MINUS = 'fa-minus-circle';
|
||||||
|
const STATE_UNKNOWN = 'fa-question-circle';
|
||||||
|
|
||||||
public function setHref($href) {
|
public function setHref($href) {
|
||||||
$this->href = $href;
|
$this->href = $href;
|
||||||
return $this;
|
return $this;
|
||||||
|
@ -30,6 +42,11 @@ final class PHUIIconCircleView extends AphrontTagView {
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function setState($state) {
|
||||||
|
$this->state = $state;
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
protected function getTagName() {
|
protected function getTagName() {
|
||||||
$tag = 'span';
|
$tag = 'span';
|
||||||
if ($this->href) {
|
if ($this->href) {
|
||||||
|
@ -54,6 +71,10 @@ final class PHUIIconCircleView extends AphrontTagView {
|
||||||
$classes[] = $this->size;
|
$classes[] = $this->size;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ($this->state) {
|
||||||
|
$classes[] = 'phui-icon-circle-state';
|
||||||
|
}
|
||||||
|
|
||||||
return array(
|
return array(
|
||||||
'href' => $this->href,
|
'href' => $this->href,
|
||||||
'class' => $classes,
|
'class' => $classes,
|
||||||
|
@ -61,8 +82,32 @@ final class PHUIIconCircleView extends AphrontTagView {
|
||||||
}
|
}
|
||||||
|
|
||||||
protected function getTagContent() {
|
protected function getTagContent() {
|
||||||
|
$state = null;
|
||||||
|
if ($this->state) {
|
||||||
|
$state = id(new PHUIIconView())
|
||||||
|
->setIcon($this->state.' '.$this->color)
|
||||||
|
->addClass('phui-icon-circle-state-icon');
|
||||||
|
}
|
||||||
|
|
||||||
return id(new PHUIIconView())
|
return id(new PHUIIconView())
|
||||||
->setIcon($this->icon);
|
->setIcon($this->icon)
|
||||||
|
->addClass('phui-icon-circle-icon')
|
||||||
|
->appendChild($state);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static function getStateMap() {
|
||||||
|
return array(
|
||||||
|
self::STATE_FAIL => pht('Failure'),
|
||||||
|
self::STATE_INFO => pht('Information'),
|
||||||
|
self::STATE_STOP => pht('Stop'),
|
||||||
|
self::STATE_START => pht('Start'),
|
||||||
|
self::STATE_PAUSE => pht('Pause'),
|
||||||
|
self::STATE_SUCCESS => pht('Success'),
|
||||||
|
self::STATE_WARNING => pht('Warning'),
|
||||||
|
self::STATE_PLUS => pht('Plus'),
|
||||||
|
self::STATE_MINUS => pht('Minus'),
|
||||||
|
self::STATE_UNKNOWN => pht('Unknown'),
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -57,6 +57,7 @@ img.phui-image-disabled {
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
background: transparent;
|
background: transparent;
|
||||||
padding: 0;
|
padding: 0;
|
||||||
|
position: relative;
|
||||||
}
|
}
|
||||||
|
|
||||||
.phui-icon-circle.circle-medium {
|
.phui-icon-circle.circle-medium {
|
||||||
|
@ -65,7 +66,21 @@ img.phui-image-disabled {
|
||||||
border-radius: 36px;
|
border-radius: 36px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.phui-icon-circle .phui-icon-view {
|
.phui-icon-circle.phui-icon-circle-state {
|
||||||
|
border-color: transparent;
|
||||||
|
background-color: {$bluebackground};
|
||||||
|
}
|
||||||
|
|
||||||
|
.phui-icon-circle.phui-icon-circle-state .phui-icon-circle-icon {
|
||||||
|
color: {$bluetext};
|
||||||
|
font-size: 16px;
|
||||||
|
}
|
||||||
|
|
||||||
|
a.phui-icon-circle.phui-icon-circle-state:hover {
|
||||||
|
border-color: transparent !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.phui-icon-circle .phui-icon-circle-icon {
|
||||||
height: 24px;
|
height: 24px;
|
||||||
width: 24px;
|
width: 24px;
|
||||||
font-size: 11px;
|
font-size: 11px;
|
||||||
|
@ -74,7 +89,7 @@ img.phui-image-disabled {
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
}
|
}
|
||||||
|
|
||||||
.phui-icon-circle.circle-medium .phui-icon-view {
|
.phui-icon-circle.circle-medium .phui-icon-circle-icon {
|
||||||
font-size: 18px;
|
font-size: 18px;
|
||||||
line-height: 36px;
|
line-height: 36px;
|
||||||
}
|
}
|
||||||
|
@ -129,6 +144,21 @@ a.phui-icon-circle.hover-red:hover .phui-icon-view {
|
||||||
color: {$red};
|
color: {$red};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
a.phui-icon-circle .phui-icon-view.phui-icon-circle-state-icon {
|
||||||
|
position: absolute;
|
||||||
|
width: 14px;
|
||||||
|
height: 14px;
|
||||||
|
display: inline-block;
|
||||||
|
font-size: 12px;
|
||||||
|
right: -3px;
|
||||||
|
top: -4px;
|
||||||
|
text-shadow:
|
||||||
|
-1px -1px 0 #fff,
|
||||||
|
1px -1px 0 #fff,
|
||||||
|
-1px 1px 0 #fff,
|
||||||
|
1px 1px 0 #fff;
|
||||||
|
}
|
||||||
|
|
||||||
/* - Icon in a Square ------------------------------------------------------- */
|
/* - Icon in a Square ------------------------------------------------------- */
|
||||||
|
|
||||||
.phui-icon-view.phui-icon-square {
|
.phui-icon-view.phui-icon-square {
|
||||||
|
|
Loading…
Reference in a new issue