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

For actions in list views, render name as tooltip if available

Summary: While the icons are sometimes pretty obvious ("X" for delete, "pencil" for edit), some are more obscure ("Disable", "Ignore"), especially if you haven't seen the interface before. If a name is available, render it as a tooltip.

Test Plan: {F49905}

Reviewers: chad, btrahan

Reviewed By: chad

CC: aran

Differential Revision: https://secure.phabricator.com/D6434
This commit is contained in:
epriestley 2013-07-12 11:28:18 -07:00
parent 147302dfa6
commit a9690a81c6
2 changed files with 39 additions and 14 deletions

View file

@ -427,7 +427,10 @@ final class PhabricatorObjectItemView extends AphrontTagView {
$actions = array(); $actions = array();
if ($this->actions) { if ($this->actions) {
Javelin::initBehavior('phabricator-tooltips');
foreach (array_reverse($this->actions) as $action) { foreach (array_reverse($this->actions) as $action) {
$action->setRenderNameAsTooltip(true);
$actions[] = $action; $actions[] = $action;
} }
$actions = phutil_tag( $actions = phutil_tag(

View file

@ -19,6 +19,17 @@ final class PHUIListItemView extends AphrontTagView {
private $selected; private $selected;
private $containerAttrs; private $containerAttrs;
private $disabled; private $disabled;
private $renderNameAsTooltip;
public function setRenderNameAsTooltip($render_name_as_tooltip) {
$this->renderNameAsTooltip = $render_name_as_tooltip;
return $this;
}
public function getRenderNameAsTooltip() {
return $this->renderNameAsTooltip;
}
public function setSelected($selected) { public function setSelected($selected) {
$this->selected = $selected; $this->selected = $selected;
@ -117,8 +128,16 @@ final class PHUIListItemView extends AphrontTagView {
protected function getTagContent() { protected function getTagContent() {
$name = null; $name = null;
$icon = null; $icon = null;
$meta = null;
$sigil = null;
if ($this->name) { if ($this->name) {
if ($this->getRenderNameAsTooltip()) {
$sigil = 'has-tooltip';
$meta = array(
'tip' => $this->name,
);
} else {
$external = null; $external = null;
if ($this->isExternal) { if ($this->isExternal) {
$external = " \xE2\x86\x97"; $external = " \xE2\x86\x97";
@ -134,6 +153,7 @@ final class PHUIListItemView extends AphrontTagView {
$external, $external,
)); ));
} }
}
if ($this->icon) { if ($this->icon) {
$icon_name = $this->icon; $icon_name = $this->icon;
@ -147,11 +167,13 @@ final class PHUIListItemView extends AphrontTagView {
->setSpriteIcon($icon_name); ->setSpriteIcon($icon_name);
} }
return phutil_tag( return javelin_tag(
$this->href ? 'a' : 'div', $this->href ? 'a' : 'div',
array( array(
'href' => $this->href, 'href' => $this->href,
'class' => $this->href ? 'phui-list-item-href' : null, 'class' => $this->href ? 'phui-list-item-href' : null,
'meta' => $meta,
'sigil' => $sigil,
), ),
array( array(
$icon, $icon,