mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-01 02:10:59 +01:00
Status icons for pinboards.
Summary: Adds image count and token count under the pinboard image. Extended pinboard-item-view for any icon/count pair. Test Plan: Review Pholio and Macro, tested Chrome and IE9. Reviewers: epriestley Reviewed By: epriestley CC: aran, Korvin Maniphest Tasks: T2645 Differential Revision: https://secure.phabricator.com/D5237
This commit is contained in:
parent
6a30324361
commit
8cceea3110
4 changed files with 61 additions and 9 deletions
|
@ -2898,7 +2898,7 @@ celerity_register_resource_map(array(
|
||||||
),
|
),
|
||||||
'phabricator-pinboard-view-css' =>
|
'phabricator-pinboard-view-css' =>
|
||||||
array(
|
array(
|
||||||
'uri' => '/res/b7425941/rsrc/css/layout/phabricator-pinboard-view.css',
|
'uri' => '/res/61ecd7cf/rsrc/css/layout/phabricator-pinboard-view.css',
|
||||||
'type' => 'css',
|
'type' => 'css',
|
||||||
'requires' =>
|
'requires' =>
|
||||||
array(
|
array(
|
||||||
|
|
|
@ -19,6 +19,7 @@ final class PholioMockListController extends PholioController {
|
||||||
$query = id(new PholioMockQuery())
|
$query = id(new PholioMockQuery())
|
||||||
->setViewer($user)
|
->setViewer($user)
|
||||||
->needCoverFiles(true)
|
->needCoverFiles(true)
|
||||||
|
->needImages(true)
|
||||||
->needTokenCounts(true);
|
->needTokenCounts(true);
|
||||||
|
|
||||||
$nav = $this->buildSideNav();
|
$nav = $this->buildSideNav();
|
||||||
|
@ -53,19 +54,16 @@ final class PholioMockListController extends PholioController {
|
||||||
$item->setHeader('M'.$mock->getID().' '.$mock->getName())
|
$item->setHeader('M'.$mock->getID().' '.$mock->getName())
|
||||||
->setURI('/M'.$mock->getID())
|
->setURI('/M'.$mock->getID())
|
||||||
->setImageURI($mock->getCoverFile()->getThumb280x210URI())
|
->setImageURI($mock->getCoverFile()->getThumb280x210URI())
|
||||||
->setImageSize(280, 210);
|
->setImageSize(280, 210)
|
||||||
|
->addIconCount('image', count($mock->getImages()))
|
||||||
|
->addIconCount('like', $mock->getTokenCount());
|
||||||
|
|
||||||
if ($mock->getAuthorPHID()) {
|
if ($mock->getAuthorPHID()) {
|
||||||
$author_handle = $this->getHandle($mock->getAuthorPHID());
|
$author_handle = $this->getHandle($mock->getAuthorPHID());
|
||||||
$item->appendChild(
|
|
||||||
pht('Created by %s', $author_handle->renderLink()));
|
|
||||||
}
|
|
||||||
$datetime = phabricator_date($mock->getDateCreated(), $user);
|
$datetime = phabricator_date($mock->getDateCreated(), $user);
|
||||||
$item->appendChild(
|
$item->appendChild(
|
||||||
phutil_tag(
|
pht('By %s on %s', $author_handle->renderLink(), $datetime));
|
||||||
'div',
|
}
|
||||||
array(),
|
|
||||||
pht('Created on %s', $datetime)));
|
|
||||||
$board->addItem($item);
|
$board->addItem($item);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -5,6 +5,7 @@ final class PhabricatorPinboardItemView extends AphrontView {
|
||||||
private $imageURI;
|
private $imageURI;
|
||||||
private $uri;
|
private $uri;
|
||||||
private $header;
|
private $header;
|
||||||
|
private $iconBlock = array();
|
||||||
|
|
||||||
private $imageWidth;
|
private $imageWidth;
|
||||||
private $imageHeight;
|
private $imageHeight;
|
||||||
|
@ -30,6 +31,11 @@ final class PhabricatorPinboardItemView extends AphrontView {
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function addIconCount($icon, $count) {
|
||||||
|
$this->iconBlock[] = array($icon, $count);
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
public function render() {
|
public function render() {
|
||||||
$header = null;
|
$header = null;
|
||||||
if ($this->header) {
|
if ($this->header) {
|
||||||
|
@ -55,6 +61,33 @@ final class PhabricatorPinboardItemView extends AphrontView {
|
||||||
'height' => $this->imageHeight,
|
'height' => $this->imageHeight,
|
||||||
)));
|
)));
|
||||||
|
|
||||||
|
$icons = array();
|
||||||
|
if ($this->iconBlock) {
|
||||||
|
$icon_list = array();
|
||||||
|
foreach ($this->iconBlock as $block) {
|
||||||
|
$icon = phutil_tag(
|
||||||
|
'span',
|
||||||
|
array(
|
||||||
|
'class' =>
|
||||||
|
'phabricator-pinboard-icon sprite-icon action-'.$block[0].'-grey',
|
||||||
|
),
|
||||||
|
'');
|
||||||
|
$count = phutil_tag('span', array(), $block[1]);
|
||||||
|
$icon_list[] = phutil_tag(
|
||||||
|
'span',
|
||||||
|
array(
|
||||||
|
'class' => 'phabricator-pinboard-item-count',
|
||||||
|
),
|
||||||
|
array($icon, $count));
|
||||||
|
}
|
||||||
|
$icons = phutil_tag(
|
||||||
|
'div',
|
||||||
|
array(
|
||||||
|
'class' => 'phabricator-pinboard-icons',
|
||||||
|
),
|
||||||
|
$icon_list);
|
||||||
|
}
|
||||||
|
|
||||||
$content = $this->renderChildren();
|
$content = $this->renderChildren();
|
||||||
if ($content) {
|
if ($content) {
|
||||||
$content = phutil_tag(
|
$content = phutil_tag(
|
||||||
|
@ -74,6 +107,7 @@ final class PhabricatorPinboardItemView extends AphrontView {
|
||||||
array(
|
array(
|
||||||
$header,
|
$header,
|
||||||
$image,
|
$image,
|
||||||
|
$icons,
|
||||||
$content,
|
$content,
|
||||||
)));
|
)));
|
||||||
}
|
}
|
||||||
|
|
|
@ -62,3 +62,23 @@
|
||||||
color: #777;
|
color: #777;
|
||||||
font-size: 11px;
|
font-size: 11px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.phabricator-pinboard-item-count {
|
||||||
|
float: left;
|
||||||
|
margin-left: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.phabricator-pinboard-icons {
|
||||||
|
padding: 0 10px 10px 0;
|
||||||
|
color: #aaa;
|
||||||
|
border-bottom: 1px solid #e7e7e7;
|
||||||
|
margin-bottom: 5px;
|
||||||
|
overflow: hidden;
|
||||||
|
}
|
||||||
|
|
||||||
|
.phabricator-pinboard-icon {
|
||||||
|
height: 14px;
|
||||||
|
width: 14px;
|
||||||
|
float: left;
|
||||||
|
padding-left: 2px;
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue