1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2024-12-23 05:50:55 +01:00

Make PHUIIconView extend AprontTagView

Summary: Less code, more options.

Test Plan: Test UIExamples page (action headers, tokens, icons and images). No visible difference.

Reviewers: epriestley, btrahan, vrana

Reviewed By: epriestley

CC: aran, Korvin

Differential Revision: https://secure.phabricator.com/D5742
This commit is contained in:
Chad Little 2013-04-22 09:49:06 -07:00
parent e8dd67b88c
commit fdde45c623
2 changed files with 16 additions and 37 deletions

View file

@ -2374,7 +2374,7 @@ phutil_register_library_map(array(
'PHUIBoxView' => 'AphrontTagView',
'PHUIFeedStoryView' => 'AphrontView',
'PHUIIconExample' => 'PhabricatorUIExample',
'PHUIIconView' => 'AphrontView',
'PHUIIconView' => 'AphrontTagView',
'PackageCreateMail' => 'PackageMail',
'PackageDeleteMail' => 'PackageMail',
'PackageMail' => 'PhabricatorMail',

View file

@ -1,6 +1,6 @@
<?php
final class PHUIIconView extends AphrontView {
final class PHUIIconView extends AphrontTagView {
const SPRITE_MINICONS = 'minicons';
const SPRITE_ACTIONS = 'actions';
@ -10,8 +10,7 @@ final class PHUIIconView extends AphrontView {
const HEAD_SMALL = 'phuihead-small';
const HEAD_MEDIUM = 'phuihead-medium';
private $href;
private $workflow;
private $href = null;
private $image;
private $headSize = null;
private $spriteIcon;
@ -22,11 +21,6 @@ final class PHUIIconView extends AphrontView {
return $this;
}
public function setWorkflow($workflow) {
$this->workflow = $workflow;
return $this;
}
public function setImage($image) {
$this->image = $image;
return $this;
@ -47,46 +41,31 @@ final class PHUIIconView extends AphrontView {
return $this;
}
public function render() {
require_celerity_resource('phui-icon-view-css');
public function getTagName() {
$tag = 'span';
if ($this->href) {
$tag = 'a';
}
return $tag;
}
$classes = array();
$classes[] = 'phui-icon-item-link';
public function getTagAttributes() {
require_celerity_resource('phui-icon-view-css');
$this->addClass('phui-icon-item-link');
if ($this->spriteIcon) {
require_celerity_resource('sprite-'.$this->spriteSheet.'-css');
$classes[] = 'sprite-'.$this->spriteSheet;
$classes[] = $this->spriteSheet.'-'.$this->spriteIcon;
$action_icon = phutil_tag(
$tag,
array(
'href' => $this->href ? $this->href : null,
'class' => implode(' ', $classes),
'sigil' => $this->workflow ? 'workflow' : null,
),
'');
$this->addClass('sprite-'.$this->spriteSheet);
$this->addClass($this->spriteSheet.'-'.$this->spriteIcon);
} else {
if ($this->headSize) {
$classes[] = $this->headSize;
$this->addClass($this->headSize);
}
$action_icon = phutil_tag(
$tag,
array(
'href' => $this->href ? $this->href : null,
'class' => implode(' ', $classes),
'sigil' => $this->workflow ? 'workflow' : null,
'style' => 'background-image: url('.$this->image.');'
),
'');
$this->setStyle('background-image: url('.$this->image.');');
}
return $action_icon;
$attribs = array('href' => $this->href);
return $attribs;
}
}