mirror of
https://we.phorge.it/source/phorge.git
synced 2024-11-29 10:12:41 +01:00
Improve handle/status list display on devices in commit graph lists
Summary: Ref T13552. Provide a richer handle/status list item for commit lists. Test Plan: Viewed commits in various interfaces, saw richer information. Maniphest Tasks: T13552 Differential Revision: https://secure.phabricator.com/D21431
This commit is contained in:
parent
49af92e903
commit
0b64092d25
8 changed files with 234 additions and 17 deletions
|
@ -122,8 +122,9 @@ return array(
|
||||||
'rsrc/css/font/font-lato.css' => '23631304',
|
'rsrc/css/font/font-lato.css' => '23631304',
|
||||||
'rsrc/css/font/phui-font-icon-base.css' => '303c9b87',
|
'rsrc/css/font/phui-font-icon-base.css' => '303c9b87',
|
||||||
'rsrc/css/fuel/fuel-grid.css' => '66697240',
|
'rsrc/css/fuel/fuel-grid.css' => '66697240',
|
||||||
|
'rsrc/css/fuel/fuel-handle-list.css' => '2c4cbeca',
|
||||||
'rsrc/css/fuel/fuel-map.css' => 'd6e31510',
|
'rsrc/css/fuel/fuel-map.css' => 'd6e31510',
|
||||||
'rsrc/css/fuel/fuel-menu.css' => 'cb35abe3',
|
'rsrc/css/fuel/fuel-menu.css' => '21f5d199',
|
||||||
'rsrc/css/layout/phabricator-source-code-view.css' => '03d7ac28',
|
'rsrc/css/layout/phabricator-source-code-view.css' => '03d7ac28',
|
||||||
'rsrc/css/phui/button/phui-button-bar.css' => 'a4aa75c4',
|
'rsrc/css/phui/button/phui-button-bar.css' => 'a4aa75c4',
|
||||||
'rsrc/css/phui/button/phui-button-simple.css' => '1ff278aa',
|
'rsrc/css/phui/button/phui-button-simple.css' => '1ff278aa',
|
||||||
|
@ -578,8 +579,9 @@ return array(
|
||||||
'font-fontawesome' => '3883938a',
|
'font-fontawesome' => '3883938a',
|
||||||
'font-lato' => '23631304',
|
'font-lato' => '23631304',
|
||||||
'fuel-grid-css' => '66697240',
|
'fuel-grid-css' => '66697240',
|
||||||
|
'fuel-handle-list-css' => '2c4cbeca',
|
||||||
'fuel-map-css' => 'd6e31510',
|
'fuel-map-css' => 'd6e31510',
|
||||||
'fuel-menu-css' => 'cb35abe3',
|
'fuel-menu-css' => '21f5d199',
|
||||||
'global-drag-and-drop-css' => '1d2713a4',
|
'global-drag-and-drop-css' => '1d2713a4',
|
||||||
'harbormaster-css' => '8dfe16b2',
|
'harbormaster-css' => '8dfe16b2',
|
||||||
'herald-css' => '648d39e2',
|
'herald-css' => '648d39e2',
|
||||||
|
|
|
@ -1309,6 +1309,8 @@ phutil_register_library_map(array(
|
||||||
'FuelGridCellView' => 'view/fuel/FuelGridCellView.php',
|
'FuelGridCellView' => 'view/fuel/FuelGridCellView.php',
|
||||||
'FuelGridRowView' => 'view/fuel/FuelGridRowView.php',
|
'FuelGridRowView' => 'view/fuel/FuelGridRowView.php',
|
||||||
'FuelGridView' => 'view/fuel/FuelGridView.php',
|
'FuelGridView' => 'view/fuel/FuelGridView.php',
|
||||||
|
'FuelHandleListItemView' => 'view/fuel/FuelHandleListItemView.php',
|
||||||
|
'FuelHandleListView' => 'view/fuel/FuelHandleListView.php',
|
||||||
'FuelMapItemView' => 'view/fuel/FuelMapItemView.php',
|
'FuelMapItemView' => 'view/fuel/FuelMapItemView.php',
|
||||||
'FuelMapView' => 'view/fuel/FuelMapView.php',
|
'FuelMapView' => 'view/fuel/FuelMapView.php',
|
||||||
'FuelMenuItemView' => 'view/fuel/FuelMenuItemView.php',
|
'FuelMenuItemView' => 'view/fuel/FuelMenuItemView.php',
|
||||||
|
@ -7452,6 +7454,8 @@ phutil_register_library_map(array(
|
||||||
'FuelGridCellView' => 'FuelComponentView',
|
'FuelGridCellView' => 'FuelComponentView',
|
||||||
'FuelGridRowView' => 'FuelView',
|
'FuelGridRowView' => 'FuelView',
|
||||||
'FuelGridView' => 'FuelComponentView',
|
'FuelGridView' => 'FuelComponentView',
|
||||||
|
'FuelHandleListItemView' => 'FuelView',
|
||||||
|
'FuelHandleListView' => 'FuelComponentView',
|
||||||
'FuelMapItemView' => 'AphrontView',
|
'FuelMapItemView' => 'AphrontView',
|
||||||
'FuelMapView' => 'FuelComponentView',
|
'FuelMapView' => 'FuelComponentView',
|
||||||
'FuelMenuItemView' => 'FuelView',
|
'FuelMenuItemView' => 'FuelView',
|
||||||
|
|
|
@ -122,8 +122,16 @@ final class DiffusionCommitGraphView
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($show_auditors) {
|
|
||||||
$commits = $this->getCommitMap();
|
$commits = $this->getCommitMap();
|
||||||
|
|
||||||
|
foreach ($commits as $commit) {
|
||||||
|
$author_phid = $commit->getAuthorDisplayPHID();
|
||||||
|
if ($author_phid !== null) {
|
||||||
|
$phids[] = $author_phid;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($show_auditors) {
|
||||||
foreach ($commits as $commit) {
|
foreach ($commits as $commit) {
|
||||||
$audits = $commit->getAudits();
|
$audits = $commit->getAudits();
|
||||||
foreach ($audits as $auditor) {
|
foreach ($audits as $auditor) {
|
||||||
|
@ -188,12 +196,12 @@ final class DiffusionCommitGraphView
|
||||||
if ($commit) {
|
if ($commit) {
|
||||||
$revisions = $this->getRevisions($commit);
|
$revisions = $this->getRevisions($commit);
|
||||||
if ($revisions) {
|
if ($revisions) {
|
||||||
$revision = head($revisions);
|
$list_view = $handles->newSublist(mpull($revisions, 'getPHID'))
|
||||||
$handle = $handles[$revision->getPHID()];
|
->newListView();
|
||||||
|
|
||||||
$property_list->newItem()
|
$property_list->newItem()
|
||||||
->setName(pht('Revision'))
|
->setName(pht('Revisions'))
|
||||||
->setValue($handle->renderLink());
|
->setValue($list_view);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -422,6 +430,12 @@ final class DiffusionCommitGraphView
|
||||||
|
|
||||||
$viewer = $this->getViewer();
|
$viewer = $this->getViewer();
|
||||||
|
|
||||||
|
$author_phid = $commit->getAuthorDisplayPHID();
|
||||||
|
if ($author_phid) {
|
||||||
|
return $viewer->loadHandles(array($author_phid))
|
||||||
|
->newListView();
|
||||||
|
}
|
||||||
|
|
||||||
return $commit->newCommitAuthorView($viewer);
|
return $commit->newCommitAuthorView($viewer);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -504,12 +518,16 @@ final class DiffusionCommitGraphView
|
||||||
$status = $commit->getAuditStatusObject();
|
$status = $commit->getAuditStatusObject();
|
||||||
|
|
||||||
$text = $status->getName();
|
$text = $status->getName();
|
||||||
$color = $status->getColor();
|
|
||||||
$icon = $status->getIcon();
|
$icon = $status->getIcon();
|
||||||
|
|
||||||
|
$is_disabled = $status->isNoAudit();
|
||||||
|
if ($is_disabled) {
|
||||||
|
$uri = null;
|
||||||
|
$color = 'grey';
|
||||||
|
} else {
|
||||||
|
$color = $status->getColor();
|
||||||
$uri = $commit->getURI();
|
$uri = $commit->getURI();
|
||||||
|
}
|
||||||
$is_disabled = false;
|
|
||||||
} else {
|
} else {
|
||||||
$text = pht('No Audit');
|
$text = pht('No Audit');
|
||||||
$color = 'grey';
|
$color = 'grey';
|
||||||
|
@ -616,8 +634,7 @@ final class DiffusionCommitGraphView
|
||||||
|
|
||||||
$auditor_phids = mpull($auditors, 'getAuditorPHID');
|
$auditor_phids = mpull($auditors, 'getAuditorPHID');
|
||||||
$auditor_list = $handles->newSublist($auditor_phids)
|
$auditor_list = $handles->newSublist($auditor_phids)
|
||||||
->renderList()
|
->newListView();
|
||||||
->setAsInline(true);
|
|
||||||
|
|
||||||
return $auditor_list;
|
return $auditor_list;
|
||||||
}
|
}
|
||||||
|
|
|
@ -104,6 +104,10 @@ final class PhabricatorHandleList
|
||||||
->setHandleList($this);
|
->setHandleList($this);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function newListView() {
|
||||||
|
return id(new FuelHandleListView())
|
||||||
|
->addHandleList($this);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Return a @{class:PHUIHandleView} which can render a specific handle.
|
* Return a @{class:PHUIHandleView} which can render a specific handle.
|
||||||
|
|
99
src/view/fuel/FuelHandleListItemView.php
Normal file
99
src/view/fuel/FuelHandleListItemView.php
Normal file
|
@ -0,0 +1,99 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
final class FuelHandleListItemView
|
||||||
|
extends FuelView {
|
||||||
|
|
||||||
|
private $handle;
|
||||||
|
|
||||||
|
public function setHandle(PhabricatorObjectHandle $handle) {
|
||||||
|
$this->handle = $handle;
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function render() {
|
||||||
|
$cells = array();
|
||||||
|
|
||||||
|
$cells[] = phutil_tag(
|
||||||
|
'div',
|
||||||
|
array(
|
||||||
|
'class' => 'fuel-handle-list-item-cell fuel-handle-list-item-icon',
|
||||||
|
),
|
||||||
|
$this->newIconView());
|
||||||
|
|
||||||
|
$cells[] = phutil_tag(
|
||||||
|
'div',
|
||||||
|
array(
|
||||||
|
'class' => 'fuel-handle-list-item-cell fuel-handle-list-item-handle',
|
||||||
|
),
|
||||||
|
$this->newHandleView());
|
||||||
|
|
||||||
|
$cells[] = phutil_tag(
|
||||||
|
'div',
|
||||||
|
array(
|
||||||
|
'class' => 'fuel-handle-list-item-cell fuel-handle-list-item-note',
|
||||||
|
),
|
||||||
|
$this->newNoteView());
|
||||||
|
|
||||||
|
return phutil_tag(
|
||||||
|
'div',
|
||||||
|
array(
|
||||||
|
'class' => 'fuel-handle-list-item',
|
||||||
|
),
|
||||||
|
$cells);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
private function newIconView() {
|
||||||
|
$icon_icon = null;
|
||||||
|
$icon_image = null;
|
||||||
|
$icon_color = null;
|
||||||
|
|
||||||
|
$handle = $this->handle;
|
||||||
|
if ($handle) {
|
||||||
|
$icon_image = $handle->getImageURI();
|
||||||
|
if (!$icon_image) {
|
||||||
|
$icon_icon = $handle->getIcon();
|
||||||
|
$icon_color = $handle->getIconColor();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($icon_image === null && $icon_icon === null) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
$view = new PHUIIconView();
|
||||||
|
|
||||||
|
if ($icon_image !== null) {
|
||||||
|
$view->setImage($icon_image);
|
||||||
|
} else {
|
||||||
|
if ($icon_color === null) {
|
||||||
|
$icon_color = 'bluegrey';
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($icon_icon !== null) {
|
||||||
|
$view->setIcon($icon_icon);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($icon_color !== null) {
|
||||||
|
$view->setColor($icon_color);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
return $view;
|
||||||
|
}
|
||||||
|
|
||||||
|
private function newHandleView() {
|
||||||
|
$handle = $this->handle;
|
||||||
|
if ($handle) {
|
||||||
|
return $handle->renderLink();
|
||||||
|
}
|
||||||
|
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
private function newNoteView() {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
58
src/view/fuel/FuelHandleListView.php
Normal file
58
src/view/fuel/FuelHandleListView.php
Normal file
|
@ -0,0 +1,58 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
final class FuelHandleListView
|
||||||
|
extends FuelComponentView {
|
||||||
|
|
||||||
|
private $items = array();
|
||||||
|
|
||||||
|
public function addHandleList(PhabricatorHandleList $list) {
|
||||||
|
$this->items[] = array(
|
||||||
|
'type' => 'list',
|
||||||
|
'item' => $list,
|
||||||
|
);
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function render() {
|
||||||
|
require_celerity_resource('fuel-handle-list-css');
|
||||||
|
|
||||||
|
$items = $this->items;
|
||||||
|
|
||||||
|
$item_views = array();
|
||||||
|
foreach ($items as $item) {
|
||||||
|
$item_type = $item['type'];
|
||||||
|
$item_item = $item['item'];
|
||||||
|
|
||||||
|
switch ($item_type) {
|
||||||
|
case 'list':
|
||||||
|
foreach ($item_item as $handle) {
|
||||||
|
$item_views[] = id(new FuelHandleListItemView())
|
||||||
|
->setHandle($handle);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$body = phutil_tag(
|
||||||
|
'div',
|
||||||
|
array(
|
||||||
|
'class' => 'fuel-handle-list-body',
|
||||||
|
),
|
||||||
|
$item_views);
|
||||||
|
|
||||||
|
$list = phutil_tag(
|
||||||
|
'div',
|
||||||
|
array(
|
||||||
|
'class' => 'fuel-handle-list',
|
||||||
|
),
|
||||||
|
$body);
|
||||||
|
|
||||||
|
return $this->newComponentTag(
|
||||||
|
'div',
|
||||||
|
array(
|
||||||
|
'class' => 'fuel-handle-list-component',
|
||||||
|
),
|
||||||
|
$list);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
33
webroot/rsrc/css/fuel/fuel-handle-list.css
Normal file
33
webroot/rsrc/css/fuel/fuel-handle-list.css
Normal file
|
@ -0,0 +1,33 @@
|
||||||
|
/**
|
||||||
|
* @provides fuel-handle-list-css
|
||||||
|
*/
|
||||||
|
|
||||||
|
.fuel-handle-list {
|
||||||
|
display: table;
|
||||||
|
max-width: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.fuel-handle-list-body {
|
||||||
|
display: table-row-group;
|
||||||
|
}
|
||||||
|
|
||||||
|
.fuel-handle-list-item {
|
||||||
|
display: table-row;
|
||||||
|
}
|
||||||
|
|
||||||
|
.fuel-handle-list-item-cell {
|
||||||
|
display: table-cell;
|
||||||
|
vertical-align: top;
|
||||||
|
}
|
||||||
|
|
||||||
|
.fuel-handle-list-item-icon {
|
||||||
|
padding-right: 4px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.fuel-handle-list-item-icon > .phui-icon-view {
|
||||||
|
width: 18px;
|
||||||
|
height: 18px;
|
||||||
|
text-align: center;
|
||||||
|
display: inline-block;
|
||||||
|
background-size: 100%;
|
||||||
|
}
|
|
@ -23,15 +23,15 @@
|
||||||
border-radius: 3px;
|
border-radius: 3px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.fuel-menu-item.disabled > .fuel-menu-item-link {
|
|
||||||
color: {$lightgreytext};
|
|
||||||
}
|
|
||||||
|
|
||||||
.fuel-menu-item.has-link > .fuel-menu-item-link {
|
.fuel-menu-item.has-link > .fuel-menu-item-link {
|
||||||
color: {$darkbluetext};
|
color: {$darkbluetext};
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.fuel-menu-item.disabled > .fuel-menu-item-link {
|
||||||
|
color: {$lightgreytext};
|
||||||
|
}
|
||||||
|
|
||||||
.device-desktop .fuel-menu-item > .fuel-menu-item-link:hover {
|
.device-desktop .fuel-menu-item > .fuel-menu-item-link:hover {
|
||||||
text-decoration: none;
|
text-decoration: none;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue