1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2024-12-31 18:01:00 +01:00

Use standard tag elements instead of "maniphest project tag" to show tags in list views

Summary:
Standardizes tag rendering in Maniphest and Maniphest/Diffusion list views.

(This might need some size/spacing tweaks, I tried to make it look reasonable.)

Test Plan: See screenshots.

Reviewers: chad

Reviewed By: chad

Subscribers: epriestley

Differential Revision: https://secure.phabricator.com/D9741
This commit is contained in:
epriestley 2014-06-26 08:49:44 -07:00
parent 950d3668f9
commit 41adc1b4c3
13 changed files with 210 additions and 197 deletions

View file

@ -7,14 +7,14 @@
return array( return array(
'names' => 'names' =>
array( array(
'core.pkg.css' => '3f0f5da2', 'core.pkg.css' => 'ead20778',
'core.pkg.js' => '8c184823', 'core.pkg.js' => '8c184823',
'darkconsole.pkg.js' => 'df001cab', 'darkconsole.pkg.js' => 'df001cab',
'differential.pkg.css' => '4a93db37', 'differential.pkg.css' => '4a93db37',
'differential.pkg.js' => 'd1443567', 'differential.pkg.js' => 'd1443567',
'diffusion.pkg.css' => '471bc9eb', 'diffusion.pkg.css' => '471bc9eb',
'diffusion.pkg.js' => 'bfc0737b', 'diffusion.pkg.js' => 'bfc0737b',
'maniphest.pkg.css' => 'f88a8402', 'maniphest.pkg.css' => 'f5d89daf',
'maniphest.pkg.js' => 'df4aa49f', 'maniphest.pkg.js' => 'df4aa49f',
'rsrc/css/aphront/aphront-bars.css' => '231ac33c', 'rsrc/css/aphront/aphront-bars.css' => '231ac33c',
'rsrc/css/aphront/context-bar.css' => '1c3b0529', 'rsrc/css/aphront/context-bar.css' => '1c3b0529',
@ -95,7 +95,6 @@ return array(
'rsrc/css/application/ponder/vote.css' => '8ed6ed8b', 'rsrc/css/application/ponder/vote.css' => '8ed6ed8b',
'rsrc/css/application/profile/profile-view.css' => 'b459416e', 'rsrc/css/application/profile/profile-view.css' => 'b459416e',
'rsrc/css/application/projects/project-icon.css' => 'c2ecb7f1', 'rsrc/css/application/projects/project-icon.css' => 'c2ecb7f1',
'rsrc/css/application/projects/project-tag.css' => '095c9404',
'rsrc/css/application/releeph/releeph-core.css' => '9b3c5733', 'rsrc/css/application/releeph/releeph-core.css' => '9b3c5733',
'rsrc/css/application/releeph/releeph-preview-branch.css' => 'b7a6f4a5', 'rsrc/css/application/releeph/releeph-preview-branch.css' => 'b7a6f4a5',
'rsrc/css/application/releeph/releeph-request-differential-create-dialog.css' => '8d8b92cd', 'rsrc/css/application/releeph/releeph-request-differential-create-dialog.css' => '8d8b92cd',
@ -142,7 +141,7 @@ return array(
'rsrc/css/phui/phui-remarkup-preview.css' => '19ad512b', 'rsrc/css/phui/phui-remarkup-preview.css' => '19ad512b',
'rsrc/css/phui/phui-spacing.css' => '042804d6', 'rsrc/css/phui/phui-spacing.css' => '042804d6',
'rsrc/css/phui/phui-status.css' => '2f562399', 'rsrc/css/phui/phui-status.css' => '2f562399',
'rsrc/css/phui/phui-tag-view.css' => '8ac14ba8', 'rsrc/css/phui/phui-tag-view.css' => '4f920464',
'rsrc/css/phui/phui-text.css' => '23e9b4b7', 'rsrc/css/phui/phui-text.css' => '23e9b4b7',
'rsrc/css/phui/phui-timeline-view.css' => 'bbd990d0', 'rsrc/css/phui/phui-timeline-view.css' => 'bbd990d0',
'rsrc/css/phui/phui-workboard-view.css' => '2bf82d00', 'rsrc/css/phui/phui-workboard-view.css' => '2bf82d00',
@ -731,7 +730,6 @@ return array(
'phabricator-phtize' => 'd254d646', 'phabricator-phtize' => 'd254d646',
'phabricator-prefab' => '41ed7994', 'phabricator-prefab' => '41ed7994',
'phabricator-profile-css' => 'b459416e', 'phabricator-profile-css' => 'b459416e',
'phabricator-project-tag-css' => '095c9404',
'phabricator-remarkup-css' => '864d4f5e', 'phabricator-remarkup-css' => '864d4f5e',
'phabricator-search-results-css' => 'f240504c', 'phabricator-search-results-css' => 'f240504c',
'phabricator-shaped-request' => '7cbe244b', 'phabricator-shaped-request' => '7cbe244b',
@ -787,7 +785,7 @@ return array(
'phui-remarkup-preview-css' => '19ad512b', 'phui-remarkup-preview-css' => '19ad512b',
'phui-spacing-css' => '042804d6', 'phui-spacing-css' => '042804d6',
'phui-status-list-view-css' => '2f562399', 'phui-status-list-view-css' => '2f562399',
'phui-tag-view-css' => '8ac14ba8', 'phui-tag-view-css' => '4f920464',
'phui-text-css' => '23e9b4b7', 'phui-text-css' => '23e9b4b7',
'phui-timeline-view-css' => 'bbd990d0', 'phui-timeline-view-css' => 'bbd990d0',
'phui-workboard-view-css' => '2bf82d00', 'phui-workboard-view-css' => '2bf82d00',
@ -2322,7 +2320,6 @@ return array(
'maniphest.pkg.css' => 'maniphest.pkg.css' =>
array( array(
0 => 'maniphest-task-summary-css', 0 => 'maniphest-task-summary-css',
1 => 'phabricator-project-tag-css',
), ),
'maniphest.pkg.js' => 'maniphest.pkg.js' =>
array( array(

View file

@ -174,7 +174,6 @@ return array(
), ),
'maniphest.pkg.css' => array( 'maniphest.pkg.css' => array(
'maniphest-task-summary-css', 'maniphest-task-summary-css',
'phabricator-project-tag-css',
), ),
'maniphest.pkg.js' => array( 'maniphest.pkg.js' => array(
'javelin-behavior-maniphest-batch-selector', 'javelin-behavior-maniphest-batch-selector',

View file

@ -937,7 +937,6 @@ phutil_register_library_map(array(
'ManiphestTaskOwner' => 'applications/maniphest/constants/ManiphestTaskOwner.php', 'ManiphestTaskOwner' => 'applications/maniphest/constants/ManiphestTaskOwner.php',
'ManiphestTaskPriority' => 'applications/maniphest/constants/ManiphestTaskPriority.php', 'ManiphestTaskPriority' => 'applications/maniphest/constants/ManiphestTaskPriority.php',
'ManiphestTaskProject' => 'applications/maniphest/storage/ManiphestTaskProject.php', 'ManiphestTaskProject' => 'applications/maniphest/storage/ManiphestTaskProject.php',
'ManiphestTaskProjectsView' => 'applications/maniphest/view/ManiphestTaskProjectsView.php',
'ManiphestTaskQuery' => 'applications/maniphest/query/ManiphestTaskQuery.php', 'ManiphestTaskQuery' => 'applications/maniphest/query/ManiphestTaskQuery.php',
'ManiphestTaskResultListView' => 'applications/maniphest/view/ManiphestTaskResultListView.php', 'ManiphestTaskResultListView' => 'applications/maniphest/view/ManiphestTaskResultListView.php',
'ManiphestTaskSearchEngine' => 'applications/maniphest/query/ManiphestTaskSearchEngine.php', 'ManiphestTaskSearchEngine' => 'applications/maniphest/query/ManiphestTaskSearchEngine.php',
@ -1027,6 +1026,7 @@ phutil_register_library_map(array(
'PHUIFormLayoutView' => 'view/form/PHUIFormLayoutView.php', 'PHUIFormLayoutView' => 'view/form/PHUIFormLayoutView.php',
'PHUIFormMultiSubmitControl' => 'view/form/control/PHUIFormMultiSubmitControl.php', 'PHUIFormMultiSubmitControl' => 'view/form/control/PHUIFormMultiSubmitControl.php',
'PHUIFormPageView' => 'view/form/PHUIFormPageView.php', 'PHUIFormPageView' => 'view/form/PHUIFormPageView.php',
'PHUIHandleTagListView' => 'applications/phid/view/PHUIHandleTagListView.php',
'PHUIHeaderView' => 'view/phui/PHUIHeaderView.php', 'PHUIHeaderView' => 'view/phui/PHUIHeaderView.php',
'PHUIIconExample' => 'applications/uiexample/examples/PHUIIconExample.php', 'PHUIIconExample' => 'applications/uiexample/examples/PHUIIconExample.php',
'PHUIIconView' => 'view/phui/PHUIIconView.php', 'PHUIIconView' => 'view/phui/PHUIIconView.php',
@ -3705,7 +3705,6 @@ phutil_register_library_map(array(
'ManiphestTaskOwner' => 'ManiphestConstants', 'ManiphestTaskOwner' => 'ManiphestConstants',
'ManiphestTaskPriority' => 'ManiphestConstants', 'ManiphestTaskPriority' => 'ManiphestConstants',
'ManiphestTaskProject' => 'ManiphestDAO', 'ManiphestTaskProject' => 'ManiphestDAO',
'ManiphestTaskProjectsView' => 'ManiphestView',
'ManiphestTaskQuery' => 'PhabricatorCursorPagedPolicyAwareQuery', 'ManiphestTaskQuery' => 'PhabricatorCursorPagedPolicyAwareQuery',
'ManiphestTaskResultListView' => 'ManiphestView', 'ManiphestTaskResultListView' => 'ManiphestView',
'ManiphestTaskSearchEngine' => 'PhabricatorApplicationSearchEngine', 'ManiphestTaskSearchEngine' => 'PhabricatorApplicationSearchEngine',
@ -3804,6 +3803,7 @@ phutil_register_library_map(array(
'PHUIFormLayoutView' => 'AphrontView', 'PHUIFormLayoutView' => 'AphrontView',
'PHUIFormMultiSubmitControl' => 'AphrontFormControl', 'PHUIFormMultiSubmitControl' => 'AphrontFormControl',
'PHUIFormPageView' => 'AphrontView', 'PHUIFormPageView' => 'AphrontView',
'PHUIHandleTagListView' => 'AphrontTagView',
'PHUIHeaderView' => 'AphrontView', 'PHUIHeaderView' => 'AphrontView',
'PHUIIconExample' => 'PhabricatorUIExample', 'PHUIIconExample' => 'PhabricatorUIExample',
'PHUIIconView' => 'AphrontTagView', 'PHUIIconView' => 'AphrontTagView',
@ -3829,7 +3829,7 @@ phutil_register_library_map(array(
'PHUIStatusItemView' => 'AphrontTagView', 'PHUIStatusItemView' => 'AphrontTagView',
'PHUIStatusListView' => 'AphrontTagView', 'PHUIStatusListView' => 'AphrontTagView',
'PHUITagExample' => 'PhabricatorUIExample', 'PHUITagExample' => 'PhabricatorUIExample',
'PHUITagView' => 'AphrontView', 'PHUITagView' => 'AphrontTagView',
'PHUITextExample' => 'PhabricatorUIExample', 'PHUITextExample' => 'PhabricatorUIExample',
'PHUITextView' => 'AphrontTagView', 'PHUITextView' => 'AphrontTagView',
'PHUITimelineEventView' => 'AphrontView', 'PHUITimelineEventView' => 'AphrontView',

View file

@ -553,12 +553,11 @@ final class ManiphestTaskDetailController extends ManiphestController {
$column_groups = mgroup($columns, 'getProjectPHID'); $column_groups = mgroup($columns, 'getProjectPHID');
$project_rows = array(); $project_handles = array();
$project_annotations = array();
foreach ($project_phids as $project_phid) { foreach ($project_phids as $project_phid) {
$row = array();
$handle = $this->getHandle($project_phid); $handle = $this->getHandle($project_phid);
$row[] = $handle->renderLink(); $project_handles[] = $handle;
$columns = idx($column_groups, $project_phid, array()); $columns = idx($column_groups, $project_phid, array());
$column = head(array_intersect_key($columns, $in_column_phids)); $column = head(array_intersect_key($columns, $in_column_phids));
@ -572,12 +571,15 @@ final class ManiphestTaskDetailController extends ManiphestController {
), ),
$column_name); $column_name);
$row[] = ' '; $project_annotations[$project_phid] = array(
$row[] = $column_link; ' ',
$column_link);
}
} }
$project_rows[] = phutil_tag('div', array(), $row); $project_rows = id(new PHUIHandleTagListView())
} ->setHandles($project_handles)
->setAnnotations($project_annotations);
} else { } else {
$project_rows = phutil_tag('em', array(), pht('None')); $project_rows = phutil_tag('em', array(), pht('None'));
} }

View file

@ -35,6 +35,8 @@ final class ManiphestTaskListView extends ManiphestView {
public function render() { public function render() {
$handles = $this->handles; $handles = $this->handles;
require_celerity_resource('maniphest-task-summary-css');
$list = new PHUIObjectItemListView(); $list = new PHUIObjectItemListView();
$list->setFlush(true); $list->setFlush(true);
@ -74,13 +76,15 @@ final class ManiphestTaskListView extends ManiphestView {
$item->addSigil('maniphest-task'); $item->addSigil('maniphest-task');
} }
$projects_view = new ManiphestTaskProjectsView(); $project_handles = array_select_keys(
$projects_view->setHandles(
array_select_keys(
$handles, $handles,
$task->getProjectPHIDs())); $task->getProjectPHIDs());
$item->addAttribute($projects_view); $item->addAttribute(
id(new PHUIHandleTagListView())
->setLimit(4)
->setNoDataString(pht('No Projects'))
->setHandles($project_handles));
$item->setMetadata( $item->setMetadata(
array( array(

View file

@ -1,67 +0,0 @@
<?php
/**
* @group maniphest
*/
final class ManiphestTaskProjectsView extends ManiphestView {
private $handles;
public function setHandles(array $handles) {
assert_instances_of($handles, 'PhabricatorObjectHandle');
$this->handles = $handles;
return $this;
}
public function render() {
require_celerity_resource('phabricator-project-tag-css');
$max_visible_tags = 4;
$show = array_slice($this->handles, 0, $max_visible_tags);
$tags = array();
if ($show) {
foreach ($show as $handle) {
$tags[] = phutil_tag(
'a',
array(
'href' => $handle->getURI(),
'class' => 'phabricator-project-tag',
),
phutil_utf8_shorten($handle->getName(), 24));
}
} else {
$tags[] = phutil_tag(
'span',
array(
'class' => 'phabricator-project-tag phabricator-project-tag-grey',
),
pht('No Project'));
}
if (count($this->handles) > $max_visible_tags) {
require_celerity_resource('aphront-tooltip-css');
Javelin::initBehavior('phabricator-tooltips');
$all = array();
foreach ($this->handles as $handle) {
$all[] = $handle->getName();
}
$tags[] = javelin_tag(
'span',
array(
'class' => 'phabricator-project-tag',
'sigil' => 'has-tooltip',
'meta' => array(
'tip' => implode(', ', $all),
'size' => 200,
),
),
"\xE2\x80\xA6");
}
return $tags;
}
}

View file

@ -25,6 +25,10 @@ final class PhabricatorObjectHandle
} }
public function getIcon() { public function getIcon() {
if ($this->getPolicyFiltered()) {
return 'fa-lock';
}
if ($this->icon) { if ($this->icon) {
return $this->icon; return $this->icon;
} }
@ -45,6 +49,10 @@ final class PhabricatorObjectHandle
} }
public function getTagColor() { public function getTagColor() {
if ($this->getPolicyFiltered()) {
return 'disabled';
}
if ($this->tagColor) { if ($this->tagColor) {
return $this->tagColor; return $this->tagColor;
} }

View file

@ -0,0 +1,100 @@
<?php
final class PHUIHandleTagListView extends AphrontTagView {
private $handles;
private $annotations = array();
private $limit;
private $noDataString;
public function setHandles(array $handles) {
$this->handles = $handles;
return $this;
}
public function setAnnotations(array $annotations) {
$this->annotations = $annotations;
return $this;
}
public function setLimit($limit) {
$this->limit = $limit;
return $this;
}
public function setNoDataString($no_data) {
$this->noDataString = $no_data;
return $this;
}
protected function getTagName() {
return 'ul';
}
protected function getTagAttributes() {
return array(
'class' => 'phabricator-handle-tag-list',
);
}
protected function getTagContent() {
$handles = $this->handles;
// If the list is empty, we may render a "No Projects" tag.
if (!$handles) {
if (strlen($this->noDataString)) {
$no_data_tag = $this->newPlaceholderTag()
->setName($this->noDataString);
return $this->newItem($no_data_tag);
}
}
if ($this->limit) {
$handles = array_slice($handles, 0, $this->limit);
}
$list = array();
foreach ($handles as $handle) {
$list[] = $this->newItem(
array(
$handle->renderTag(),
idx($this->annotations, $handle->getPHID(), null),
));
}
if ($this->limit) {
if ($this->limit < count($this->handles)) {
$tip_text = implode(', ', mpull($this->handles, 'getName'));
$more = $this->newPlaceholderTag()
->setName("\xE2\x80\xA6")
->addSigil('has-tooltip')
->setMetadata(
array(
'tip' => $tip_text,
'size' => 200,
));
$list[] = $this->newItem($more);
}
}
return $list;
}
private function newItem($content) {
return phutil_tag(
'li',
array(
'class' => 'phabricator-handle-tag-list-item',
),
$content);
}
private function newPlaceholderTag() {
return id(new PHUITagView())
->setType(PHUITagView::TYPE_OBJECT)
->setShade(PHUITagView::COLOR_DISABLED);
}
}

View file

@ -43,21 +43,8 @@ final class PhabricatorProjectUIEventListener
} }
if ($handles) { if ($handles) {
$list = array(); $list = id(new PHUIHandleTagListView())
foreach ($handles as $handle) { ->setHandles($handles);
$list[] = phutil_tag(
'li',
array(
'class' => 'phabricator-handle-tag-list-item',
),
$handle->renderTag());
}
$list = phutil_tag(
'ul',
array(
'class' => 'phabricator-handle-tag-list',
),
$list);
} else { } else {
$list = phutil_tag('em', array(), pht('None')); $list = phutil_tag('em', array(), pht('None'));
} }

View file

@ -286,7 +286,7 @@ final class PhabricatorRepositorySearchEngine
$repository->getProjectPHIDs()); $repository->getProjectPHIDs());
if ($project_handles) { if ($project_handles) {
$item->addAttribute( $item->addAttribute(
id(new ManiphestTaskProjectsView()) id(new PHUIHandleTagListView())
->setHandles($project_handles)); ->setHandles($project_handles));
} }

View file

@ -1,6 +1,6 @@
<?php <?php
final class PHUITagView extends AphrontView { final class PHUITagView extends AphrontTagView {
const TYPE_PERSON = 'person'; const TYPE_PERSON = 'person';
const TYPE_OBJECT = 'object'; const TYPE_OBJECT = 'object';
@ -32,19 +32,9 @@ final class PHUITagView extends AphrontView {
private $dotColor; private $dotColor;
private $closed; private $closed;
private $external; private $external;
private $id;
private $icon; private $icon;
private $shade; private $shade;
public function setID($id) {
$this->id = $id;
return $this;
}
public function getID() {
return $this->id;
}
public function setType($type) { public function setType($type) {
$this->type = $type; $this->type = $type;
switch ($type) { switch ($type) {
@ -100,22 +90,56 @@ final class PHUITagView extends AphrontView {
return $this; return $this;
} }
public function render() { protected function getTagName() {
if (!$this->type) { return strlen($this->href) ? 'a' : 'span';
throw new Exception(pht('You must call setType() before render()!'));
} }
protected function getTagAttributes() {
require_celerity_resource('phui-tag-view-css'); require_celerity_resource('phui-tag-view-css');
$classes = array( $classes = array(
'phui-tag-view', 'phui-tag-view',
'phui-tag-type-'.$this->type, 'phui-tag-type-'.$this->type,
); );
$color = null;
if ($this->shade) { if ($this->shade) {
$classes[] = 'phui-tag-shade'; $classes[] = 'phui-tag-shade';
$classes[] = 'phui-tag-shade-'.$this->shade;; $classes[] = 'phui-tag-shade-'.$this->shade;
} else if ($this->backgroundColor) { }
if ($this->icon) {
$classes[] = 'phui-tag-icon-view';
}
if ($this->phid) {
Javelin::initBehavior('phabricator-hovercards');
$attributes = array(
'href' => $this->href,
'sigil' => 'hovercard',
'meta' => array(
'hoverPHID' => $this->phid,
),
'target' => $this->external ? '_blank' : null,
);
} else {
$attributes = array(
'href' => $this->href,
'target' => $this->external ? '_blank' : null,
);
}
return $attributes + array('class' => $classes);
}
public function getTagContent() {
if (!$this->type) {
throw new Exception(pht('You must call setType() before render()!'));
}
$color = null;
if (!$this->shade && $this->backgroundColor) {
$color = 'phui-tag-color-'.$this->backgroundColor; $color = 'phui-tag-color-'.$this->backgroundColor;
} }
@ -134,7 +158,6 @@ final class PHUITagView extends AphrontView {
if ($this->icon) { if ($this->icon) {
$icon = id(new PHUIIconView()) $icon = id(new PHUIIconView())
->setIconFont($this->icon); ->setIconFont($this->icon);
$classes[] = 'phui-tag-icon-view';
} else { } else {
$icon = null; $icon = null;
} }
@ -155,33 +178,7 @@ final class PHUITagView extends AphrontView {
$content); $content);
} }
if ($this->phid) { return array($icon, $content);
Javelin::initBehavior('phabricator-hovercards');
return javelin_tag(
'a',
array(
'id' => $this->id,
'href' => $this->href,
'class' => implode(' ', $classes),
'sigil' => 'hovercard',
'meta' => array(
'hoverPHID' => $this->phid,
),
'target' => $this->external ? '_blank' : null,
),
array($icon, $content));
} else {
return phutil_tag(
$this->href ? 'a' : 'span',
array(
'id' => $this->id,
'href' => $this->href,
'class' => implode(' ', $classes),
'target' => $this->external ? '_blank' : null,
),
array($icon, $content));
}
} }
public static function getTagTypes() { public static function getTagTypes() {

View file

@ -1,43 +0,0 @@
/**
* @provides phabricator-project-tag-css
*/
.phabricator-project-tag,
.phabricator-project-tag:link,
.phabricator-project-tag:visited {
font-weight: normal;
border: 1px solid #bfcfef;
padding: 1px 4px 2px;
background: #f9f9ff;
color: #667799;
text-decoration: none;
font-size: 11px;
display: inline;
cursor: pointer;
margin-right: 2px;
-webkit-border-radius: 4px;
-moz-border-radius: 4px;
border-radius: 4px;
white-space: nowrap;
}
.phabricator-project-tag.phabricator-project-tag-grey {
border: 1px solid #ccc;
background: #f7f7f7;
color: {$lightgreytext};
cursor: default;
}
.phabricator-project-tag.phabricator-project-tag-grey:hover {
background: #e7e7e7;
}
.phabricator-project-tag:last-child {
margin-right: 0px;
}
.phabricator-project-tag:hover {
background: #dfdfef;
}

View file

@ -304,3 +304,32 @@ a.phui-tag-view:hover.phui-tag-shade-disabled .phui-tag-core {
.phabricator-handle-tag-list-item + .phabricator-handle-tag-list-item { .phabricator-handle-tag-list-item + .phabricator-handle-tag-list-item {
margin-top: 4px; margin-top: 4px;
} }
.phui-object-item .phui-tag-view .phui-tag-core {
display: inline-block;
font-size: 12px;
line-height: 16px;
}
.phui-object-item .phui-tag-icon-view .phui-tag-core {
padding-left: 20px;
}
.phui-object-item .phui-tag-view .phui-icon-view {
font-size: 11px;
top: 3px;
left: 5px;
}
.phui-object-item .phabricator-handle-tag-list {
display: inline-block;
}
.phui-object-item .phabricator-handle-tag-list-item {
display: inline-block;
}
.phui-object-item .phabricator-handle-tag-list-item +
.phabricator-handle-tag-list-item {
margin: 0 0 0 4px;
}