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:
parent
950d3668f9
commit
41adc1b4c3
13 changed files with 210 additions and 197 deletions
|
@ -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(
|
||||||
|
|
|
@ -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',
|
||||||
|
|
|
@ -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',
|
||||||
|
|
|
@ -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'));
|
||||||
}
|
}
|
||||||
|
|
|
@ -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(
|
||||||
|
|
|
@ -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;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
100
src/applications/phid/view/PHUIHandleTagListView.php
Normal file
100
src/applications/phid/view/PHUIHandleTagListView.php
Normal 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);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -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'));
|
||||||
}
|
}
|
||||||
|
|
|
@ -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));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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() {
|
||||||
|
|
|
@ -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;
|
|
||||||
}
|
|
|
@ -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;
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue