2012-12-07 22:35:17 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
final class PhabricatorCrumbsView extends AphrontView {
|
|
|
|
|
|
|
|
private $crumbs = array();
|
|
|
|
private $actions = array();
|
2013-04-09 21:42:03 +02:00
|
|
|
private $actionListID = null;
|
2012-12-07 22:35:17 +01:00
|
|
|
|
|
|
|
protected function canAppendChild() {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2013-12-19 02:47:34 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Convenience method for adding a simple crumb with just text, or text and
|
|
|
|
* a link.
|
|
|
|
*
|
|
|
|
* @param string Text of the crumb.
|
|
|
|
* @param string? Optional href for the crumb.
|
|
|
|
* @return this
|
|
|
|
*/
|
|
|
|
public function addTextCrumb($text, $href = null) {
|
|
|
|
return $this->addCrumb(
|
|
|
|
id(new PhabricatorCrumbView())
|
|
|
|
->setName($text)
|
|
|
|
->setHref($href));
|
|
|
|
}
|
|
|
|
|
2012-12-07 22:35:17 +01:00
|
|
|
public function addCrumb(PhabricatorCrumbView $crumb) {
|
|
|
|
$this->crumbs[] = $crumb;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2013-06-05 17:41:43 +02:00
|
|
|
public function addAction(PHUIListItemView $action) {
|
2012-12-07 22:35:17 +01:00
|
|
|
$this->actions[] = $action;
|
2013-04-09 21:42:03 +02:00
|
|
|
return $this;
|
|
|
|
}
|
2012-12-07 22:35:17 +01:00
|
|
|
|
2013-04-09 21:42:03 +02:00
|
|
|
public function setActionList(PhabricatorActionListView $list) {
|
|
|
|
$this->actionListID = celerity_generate_unique_node_id();
|
|
|
|
$list->setId($this->actionListID);
|
2012-12-07 22:35:17 +01:00
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function render() {
|
|
|
|
require_celerity_resource('phabricator-crumbs-view-css');
|
|
|
|
|
|
|
|
$action_view = null;
|
2013-04-10 22:08:36 +02:00
|
|
|
if (($this->actions) || ($this->actionListID)) {
|
2012-12-07 22:35:17 +01:00
|
|
|
$actions = array();
|
|
|
|
foreach ($this->actions as $action) {
|
|
|
|
$icon = null;
|
|
|
|
if ($action->getIcon()) {
|
2013-10-15 03:21:06 +02:00
|
|
|
$icon_name = $action->getIcon();
|
|
|
|
if ($action->getDisabled()) {
|
|
|
|
$icon_name .= '-grey';
|
|
|
|
}
|
|
|
|
|
2013-01-18 03:57:09 +01:00
|
|
|
$icon = phutil_tag(
|
2012-12-07 22:35:17 +01:00
|
|
|
'span',
|
|
|
|
array(
|
2013-10-15 03:21:06 +02:00
|
|
|
'class' => 'sprite-icons icons-'.$icon_name,
|
2012-12-07 22:35:17 +01:00
|
|
|
),
|
|
|
|
'');
|
|
|
|
}
|
2013-03-26 21:15:15 +01:00
|
|
|
$name = phutil_tag(
|
|
|
|
'span',
|
|
|
|
array(
|
|
|
|
'class' => 'phabricator-crumbs-action-name'
|
|
|
|
),
|
2013-06-05 00:28:24 +02:00
|
|
|
$action->getName());
|
2013-04-09 21:42:03 +02:00
|
|
|
|
2013-05-24 19:50:18 +02:00
|
|
|
$action_sigils = $action->getSigils();
|
|
|
|
if ($action->getWorkflow()) {
|
|
|
|
$action_sigils[] = 'workflow';
|
|
|
|
}
|
|
|
|
$action_classes = $action->getClasses();
|
|
|
|
$action_classes[] = 'phabricator-crumbs-action';
|
2013-10-15 03:21:06 +02:00
|
|
|
|
|
|
|
if ($action->getDisabled()) {
|
|
|
|
$action_classes[] = 'phabricator-crumbs-action-disabled';
|
|
|
|
}
|
|
|
|
|
2013-01-25 21:57:17 +01:00
|
|
|
$actions[] = javelin_tag(
|
2012-12-07 22:35:17 +01:00
|
|
|
'a',
|
|
|
|
array(
|
|
|
|
'href' => $action->getHref(),
|
2013-05-24 19:50:18 +02:00
|
|
|
'class' => implode(' ', $action_classes),
|
|
|
|
'sigil' => implode(' ', $action_sigils),
|
|
|
|
'style' => $action->getStyle()
|
2012-12-07 22:35:17 +01:00
|
|
|
),
|
2013-01-25 21:57:17 +01:00
|
|
|
array(
|
|
|
|
$icon,
|
2013-03-26 21:15:15 +01:00
|
|
|
$name,
|
2013-01-25 21:57:17 +01:00
|
|
|
));
|
2012-12-07 22:35:17 +01:00
|
|
|
}
|
|
|
|
|
2013-04-09 21:42:03 +02:00
|
|
|
if ($this->actionListID) {
|
|
|
|
$icon_id = celerity_generate_unique_node_id();
|
|
|
|
$icon = phutil_tag(
|
|
|
|
'span',
|
|
|
|
array(
|
Add action icons to object list views
Summary:
We have a few interfaces where add "Edit", "Delete" or some other action to a list. Currently, this happens via icons, but these are cumbersome and weird, are inconsistent, can't be workflow'd, are hard to hit on desktops and virtually impossible to hit on mobile, and generally just feel iffy to me. Prominent examples are Projects and Flags. I'd like to try adding an "edit" action to Maniphest (to provide quick edit from list views, basically). It looks like some of Releeph would benefit here, as well.
Instead, provide first-class actions:
{F42978}
They produce targets which my meaty ham-fists can plausibly hit on mobile, too:
{F42979}
(We could do some kind of swipe-to-expose thing eventually, but I think putting them by default is OK?)
Test Plan: Added UIExamples. Checked desktop/mobile.
Reviewers: chad, btrahan, edward
Reviewed By: btrahan
CC: aran
Differential Revision: https://secure.phabricator.com/D5890
2013-05-10 21:57:01 +02:00
|
|
|
'class' => 'sprite-icons action-action-menu'
|
2013-04-09 21:42:03 +02:00
|
|
|
),
|
|
|
|
'');
|
|
|
|
$name = phutil_tag(
|
|
|
|
'span',
|
|
|
|
array(
|
|
|
|
'class' => 'phabricator-crumbs-action-name'
|
|
|
|
),
|
|
|
|
pht('Actions'));
|
|
|
|
|
|
|
|
$actions[] = javelin_tag(
|
|
|
|
'a',
|
|
|
|
array(
|
|
|
|
'href' => '#',
|
|
|
|
'class' =>
|
|
|
|
'phabricator-crumbs-action phabricator-crumbs-action-menu',
|
|
|
|
'sigil' => 'jx-toggle-class',
|
|
|
|
'id' => $icon_id,
|
|
|
|
'meta' => array(
|
|
|
|
'map' => array(
|
|
|
|
$this->actionListID => 'phabricator-action-list-toggle',
|
|
|
|
$icon_id => 'phabricator-crumbs-action-menu-open'
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
array(
|
|
|
|
$icon,
|
|
|
|
$name,
|
|
|
|
));
|
|
|
|
}
|
|
|
|
|
2013-01-31 18:07:31 +01:00
|
|
|
$action_view = phutil_tag(
|
2012-12-07 22:35:17 +01:00
|
|
|
'div',
|
|
|
|
array(
|
|
|
|
'class' => 'phabricator-crumbs-actions',
|
|
|
|
),
|
2013-03-09 22:52:41 +01:00
|
|
|
$actions);
|
2012-12-07 22:35:17 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if ($this->crumbs) {
|
|
|
|
last($this->crumbs)->setIsLastCrumb(true);
|
|
|
|
}
|
|
|
|
|
2013-01-31 18:07:31 +01:00
|
|
|
return phutil_tag(
|
2012-12-07 22:35:17 +01:00
|
|
|
'div',
|
|
|
|
array(
|
2012-12-07 22:35:49 +01:00
|
|
|
'class' => 'phabricator-crumbs-view '.
|
|
|
|
'sprite-gradient gradient-breadcrumbs',
|
2012-12-07 22:35:17 +01:00
|
|
|
),
|
2013-03-09 22:52:41 +01:00
|
|
|
array(
|
|
|
|
$action_view,
|
|
|
|
$this->crumbs,
|
|
|
|
));
|
2012-12-07 22:35:17 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|