mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-01 02:10:59 +01:00
Convert workboard column options into a dropdown menu
Summary: Ref T5024, T4427, T5474, T5523. Instead of separate icons in the column header for "Create Task" and "Edit Column Settings", use a dropdown menu. - T5024 will likely add a "View Standalone" option. - T4427 needs header space to show a count. - T5474 likely needs "Edit Triggers..." (this seems reasonable to separate from editing the name, etc.) - T5523 likely adds "Move all tasks..." eventually. Test Plan: {F187414} Reviewers: btrahan, chad Reviewed By: chad Subscribers: epriestley Maniphest Tasks: T5523, T5474, T5024, T4427 Differential Revision: https://secure.phabricator.com/D10190
This commit is contained in:
parent
417b6bbe41
commit
abfff87f26
5 changed files with 80 additions and 43 deletions
|
@ -415,7 +415,7 @@ return array(
|
||||||
'rsrc/js/application/policy/behavior-policy-rule-editor.js' => 'fe9a552f',
|
'rsrc/js/application/policy/behavior-policy-rule-editor.js' => 'fe9a552f',
|
||||||
'rsrc/js/application/ponder/behavior-votebox.js' => '4e9b766b',
|
'rsrc/js/application/ponder/behavior-votebox.js' => '4e9b766b',
|
||||||
'rsrc/js/application/projects/behavior-boards-dropdown.js' => '0ec56e1d',
|
'rsrc/js/application/projects/behavior-boards-dropdown.js' => '0ec56e1d',
|
||||||
'rsrc/js/application/projects/behavior-project-boards.js' => 'f47fa23b',
|
'rsrc/js/application/projects/behavior-project-boards.js' => 'd4bf1f3c',
|
||||||
'rsrc/js/application/projects/behavior-project-create.js' => '065227cc',
|
'rsrc/js/application/projects/behavior-project-create.js' => '065227cc',
|
||||||
'rsrc/js/application/projects/behavior-reorder-columns.js' => '09eee344',
|
'rsrc/js/application/projects/behavior-reorder-columns.js' => '09eee344',
|
||||||
'rsrc/js/application/releeph/releeph-preview-branch.js' => 'b2b4fbaf',
|
'rsrc/js/application/releeph/releeph-preview-branch.js' => 'b2b4fbaf',
|
||||||
|
@ -639,7 +639,7 @@ return array(
|
||||||
'javelin-behavior-policy-control' => 'f3fef818',
|
'javelin-behavior-policy-control' => 'f3fef818',
|
||||||
'javelin-behavior-policy-rule-editor' => 'fe9a552f',
|
'javelin-behavior-policy-rule-editor' => 'fe9a552f',
|
||||||
'javelin-behavior-ponder-votebox' => '4e9b766b',
|
'javelin-behavior-ponder-votebox' => '4e9b766b',
|
||||||
'javelin-behavior-project-boards' => 'f47fa23b',
|
'javelin-behavior-project-boards' => 'd4bf1f3c',
|
||||||
'javelin-behavior-project-create' => '065227cc',
|
'javelin-behavior-project-create' => '065227cc',
|
||||||
'javelin-behavior-refresh-csrf' => '7814b593',
|
'javelin-behavior-refresh-csrf' => '7814b593',
|
||||||
'javelin-behavior-releeph-preview-branch' => 'b2b4fbaf',
|
'javelin-behavior-releeph-preview-branch' => 'b2b4fbaf',
|
||||||
|
@ -1700,6 +1700,14 @@ return array(
|
||||||
'javelin-dom',
|
'javelin-dom',
|
||||||
'javelin-view',
|
'javelin-view',
|
||||||
),
|
),
|
||||||
|
'd4bf1f3c' => array(
|
||||||
|
'javelin-behavior',
|
||||||
|
'javelin-dom',
|
||||||
|
'javelin-util',
|
||||||
|
'javelin-stratcom',
|
||||||
|
'javelin-workflow',
|
||||||
|
'phabricator-draggable-list',
|
||||||
|
),
|
||||||
'd4eecc63' => array(
|
'd4eecc63' => array(
|
||||||
'javelin-behavior',
|
'javelin-behavior',
|
||||||
'javelin-dom',
|
'javelin-dom',
|
||||||
|
@ -1844,14 +1852,6 @@ return array(
|
||||||
'phuix-action-view',
|
'phuix-action-view',
|
||||||
'javelin-workflow',
|
'javelin-workflow',
|
||||||
),
|
),
|
||||||
'f47fa23b' => array(
|
|
||||||
'javelin-behavior',
|
|
||||||
'javelin-dom',
|
|
||||||
'javelin-util',
|
|
||||||
'javelin-stratcom',
|
|
||||||
'javelin-workflow',
|
|
||||||
'phabricator-draggable-list',
|
|
||||||
),
|
|
||||||
'f51afce0' => array(
|
'f51afce0' => array(
|
||||||
'javelin-behavior',
|
'javelin-behavior',
|
||||||
'javelin-request',
|
'javelin-request',
|
||||||
|
|
|
@ -223,14 +223,8 @@ final class PhabricatorProjectBoardViewController
|
||||||
->setHeader($column->getDisplayName())
|
->setHeader($column->getDisplayName())
|
||||||
->setHeaderColor($column->getHeaderColor());
|
->setHeaderColor($column->getHeaderColor());
|
||||||
|
|
||||||
$panel->setEditURI($board_uri.'column/'.$column->getID().'/');
|
$column_menu = $this->buildColumnMenu($project, $column);
|
||||||
|
$panel->addHeaderAction($column_menu);
|
||||||
$panel->setHeaderAction(id(new PHUIIconView())
|
|
||||||
->setIconFont('fa-plus')
|
|
||||||
->setHref('/maniphest/task/create/')
|
|
||||||
->addSigil('column-add-task')
|
|
||||||
->setMetadata(
|
|
||||||
array('columnPHID' => $column->getPHID())));
|
|
||||||
|
|
||||||
$cards = id(new PHUIObjectItemListView())
|
$cards = id(new PHUIObjectItemListView())
|
||||||
->setUser($viewer)
|
->setUser($viewer)
|
||||||
|
@ -511,6 +505,59 @@ final class PhabricatorProjectBoardViewController
|
||||||
return $manage_button;
|
return $manage_button;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private function buildColumnMenu(
|
||||||
|
PhabricatorProject $project,
|
||||||
|
PhabricatorProjectColumn $column) {
|
||||||
|
|
||||||
|
$request = $this->getRequest();
|
||||||
|
$viewer = $request->getUser();
|
||||||
|
|
||||||
|
$can_edit = PhabricatorPolicyFilter::hasCapability(
|
||||||
|
$viewer,
|
||||||
|
$project,
|
||||||
|
PhabricatorPolicyCapability::CAN_EDIT);
|
||||||
|
|
||||||
|
$column_items = array();
|
||||||
|
|
||||||
|
$column_items[] = id(new PhabricatorActionView())
|
||||||
|
->setIcon('fa-plus')
|
||||||
|
->setName(pht('Create Task...'))
|
||||||
|
->setHref('/maniphest/task/create/')
|
||||||
|
->addSigil('column-add-task')
|
||||||
|
->setMetadata(
|
||||||
|
array(
|
||||||
|
'columnPHID' => $column->getPHID(),
|
||||||
|
))
|
||||||
|
->setDisabled(!$can_edit);
|
||||||
|
|
||||||
|
$edit_uri = $this->getApplicationURI(
|
||||||
|
'board/'.$this->id.'/column/'.$column->getID().'/');
|
||||||
|
|
||||||
|
$column_items[] = id(new PhabricatorActionView())
|
||||||
|
->setIcon('fa-pencil')
|
||||||
|
->setName(pht('Edit Column'))
|
||||||
|
->setHref($edit_uri)
|
||||||
|
->setDisabled(!$can_edit)
|
||||||
|
->setWorkflow(!$can_edit);
|
||||||
|
|
||||||
|
$column_menu = id(new PhabricatorActionListView())
|
||||||
|
->setUser($viewer);
|
||||||
|
foreach ($column_items as $item) {
|
||||||
|
$column_menu->addAction($item);
|
||||||
|
}
|
||||||
|
|
||||||
|
$column_button = id(new PHUIIconView())
|
||||||
|
->setIconFont('fa-caret-down')
|
||||||
|
->setHref('#')
|
||||||
|
->addSigil('boards-dropdown-menu')
|
||||||
|
->setMetadata(
|
||||||
|
array(
|
||||||
|
'items' => hsprintf('%s', $column_menu),
|
||||||
|
));
|
||||||
|
|
||||||
|
return $column_button;
|
||||||
|
}
|
||||||
|
|
||||||
private function initializeWorkboardDialog(PhabricatorProject $project) {
|
private function initializeWorkboardDialog(PhabricatorProject $project) {
|
||||||
|
|
||||||
$instructions = pht('This workboard has not been setup yet.');
|
$instructions = pht('This workboard has not been setup yet.');
|
||||||
|
|
|
@ -255,7 +255,7 @@ final class PHUITimelineEventView extends AphrontView {
|
||||||
|
|
||||||
if ($items || $has_menu) {
|
if ($items || $has_menu) {
|
||||||
$icon = id(new PHUIIconView())
|
$icon = id(new PHUIIconView())
|
||||||
->setIconFont('fa-cog');
|
->setIconFont('fa-caret-down');
|
||||||
$aural = javelin_tag(
|
$aural = javelin_tag(
|
||||||
'span',
|
'span',
|
||||||
array(
|
array(
|
||||||
|
|
|
@ -4,15 +4,9 @@ final class PHUIWorkpanelView extends AphrontTagView {
|
||||||
|
|
||||||
private $cards = array();
|
private $cards = array();
|
||||||
private $header;
|
private $header;
|
||||||
private $editURI;
|
|
||||||
private $headerAction;
|
|
||||||
private $footerAction;
|
private $footerAction;
|
||||||
private $headerColor = PHUIActionHeaderView::HEADER_GREY;
|
private $headerColor = PHUIActionHeaderView::HEADER_GREY;
|
||||||
|
private $headerActions = array();
|
||||||
public function setHeaderAction(PHUIIconView $header_action) {
|
|
||||||
$this->headerAction = $header_action;
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function setCards(PHUIObjectItemListView $cards) {
|
public function setCards(PHUIObjectItemListView $cards) {
|
||||||
$this->cards[] = $cards;
|
$this->cards[] = $cards;
|
||||||
|
@ -24,11 +18,6 @@ final class PHUIWorkpanelView extends AphrontTagView {
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function setEditURI($edit_uri) {
|
|
||||||
$this->editURI = $edit_uri;
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function setFooterAction(PHUIListItemView $footer_action) {
|
public function setFooterAction(PHUIListItemView $footer_action) {
|
||||||
$this->footerAction = $footer_action;
|
$this->footerAction = $footer_action;
|
||||||
return $this;
|
return $this;
|
||||||
|
@ -39,6 +28,11 @@ final class PHUIWorkpanelView extends AphrontTagView {
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function addHeaderAction(PHUIIconView $action) {
|
||||||
|
$this->headerActions[] = $action;
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
public function getTagAttributes() {
|
public function getTagAttributes() {
|
||||||
return array(
|
return array(
|
||||||
'class' => 'phui-workpanel-view',
|
'class' => 'phui-workpanel-view',
|
||||||
|
@ -61,20 +55,12 @@ final class PHUIWorkpanelView extends AphrontTagView {
|
||||||
$footer_tag);
|
$footer_tag);
|
||||||
}
|
}
|
||||||
|
|
||||||
$header_edit = null;
|
|
||||||
if ($this->editURI) {
|
|
||||||
$header_edit = id(new PHUIIconView())
|
|
||||||
->setIconFont('fa-pencil')
|
|
||||||
->setHref($this->editURI);
|
|
||||||
}
|
|
||||||
$header = id(new PHUIActionHeaderView())
|
$header = id(new PHUIActionHeaderView())
|
||||||
->setHeaderTitle($this->header)
|
->setHeaderTitle($this->header)
|
||||||
->setHeaderColor($this->headerColor);
|
->setHeaderColor($this->headerColor);
|
||||||
if ($header_edit) {
|
|
||||||
$header->addAction($header_edit);
|
foreach ($this->headerActions as $action) {
|
||||||
}
|
$header->addAction($action);
|
||||||
if ($this->headerAction) {
|
|
||||||
$header->addAction($this->headerAction);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$classes[] = 'phui-workpanel-'.$this->headerColor;
|
$classes[] = 'phui-workpanel-'.$this->headerColor;
|
||||||
|
|
|
@ -163,7 +163,11 @@ JX.behavior('project-boards', function(config) {
|
||||||
'click',
|
'click',
|
||||||
['column-add-task'],
|
['column-add-task'],
|
||||||
function (e) {
|
function (e) {
|
||||||
e.kill();
|
|
||||||
|
// We want the 'boards-dropdown-menu' behavior to see this event and
|
||||||
|
// close the dropdown, but don't want to follow the link.
|
||||||
|
e.prevent();
|
||||||
|
|
||||||
var column_phid = e.getNodeData('column-add-task').columnPHID;
|
var column_phid = e.getNodeData('column-add-task').columnPHID;
|
||||||
var request_data = {
|
var request_data = {
|
||||||
responseType: 'card',
|
responseType: 'card',
|
||||||
|
|
Loading…
Reference in a new issue