mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-05 20:31:03 +01:00
Generate a default "Backlog" column for boards and put all tasks into it
Summary: Ref T1344. Autogenerates a "Backlog" column if one does not exist. Assigns all tasks to the backlog column. For now, this column is always called "Backlog", but we could let it be called other things later. Test Plan: Loaded a project, got a backlog column, created some columns. Reviewers: btrahan, chad Reviewed By: chad CC: aran Maniphest Tasks: T1344 Differential Revision: https://secure.phabricator.com/D7938
This commit is contained in:
parent
3f180496e5
commit
a751073d11
4 changed files with 52 additions and 12 deletions
|
@ -30,7 +30,21 @@ final class PhabricatorProjectBoardController
|
||||||
->withProjectPHIDs(array($project->getPHID()))
|
->withProjectPHIDs(array($project->getPHID()))
|
||||||
->execute();
|
->execute();
|
||||||
|
|
||||||
msort($columns, 'getSequence');
|
$columns = mpull($columns, null, 'getSequence');
|
||||||
|
|
||||||
|
// If there's no default column, create one now.
|
||||||
|
if (empty($columns[0])) {
|
||||||
|
$unguarded = AphrontWriteGuard::beginScopedUnguardedWrites();
|
||||||
|
$column = PhabricatorProjectColumn::initializeNewColumn($viewer)
|
||||||
|
->setSequence(0)
|
||||||
|
->setProjectPHID($project->getPHID())
|
||||||
|
->save();
|
||||||
|
$column->attachProject($project);
|
||||||
|
$columns[0] = $column;
|
||||||
|
unset($unguarded);
|
||||||
|
}
|
||||||
|
|
||||||
|
ksort($columns);
|
||||||
|
|
||||||
$tasks = id(new ManiphestTaskQuery())
|
$tasks = id(new ManiphestTaskQuery())
|
||||||
->setViewer($viewer)
|
->setViewer($viewer)
|
||||||
|
@ -40,15 +54,11 @@ final class PhabricatorProjectBoardController
|
||||||
->execute();
|
->execute();
|
||||||
$tasks = mpull($tasks, null, 'getPHID');
|
$tasks = mpull($tasks, null, 'getPHID');
|
||||||
|
|
||||||
// TODO: This is so made up.
|
|
||||||
$task_map = array();
|
$task_map = array();
|
||||||
|
$default_phid = $columns[0]->getPHID();
|
||||||
|
|
||||||
foreach ($tasks as $task) {
|
foreach ($tasks as $task) {
|
||||||
if ($columns) {
|
$task_map[$default_phid][] = $task->getPHID();
|
||||||
$random_column = $columns[array_rand($columns)]->getPHID();
|
|
||||||
} else {
|
|
||||||
$random_column = 0;
|
|
||||||
}
|
|
||||||
$task_map[$random_column][] = $task->getPHID();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$board = id(new PHUIWorkboardView())
|
$board = id(new PHUIWorkboardView())
|
||||||
|
@ -57,7 +67,8 @@ final class PhabricatorProjectBoardController
|
||||||
|
|
||||||
foreach ($columns as $column) {
|
foreach ($columns as $column) {
|
||||||
$panel = id(new PHUIWorkpanelView())
|
$panel = id(new PHUIWorkpanelView())
|
||||||
->setHeader($column->getName())
|
->setHeader($column->getDisplayName())
|
||||||
|
->setHeaderColor($column->getHeaderColor())
|
||||||
->setEditURI('edit/'.$column->getID().'/');
|
->setEditURI('edit/'.$column->getID().'/');
|
||||||
|
|
||||||
$cards = id(new PHUIObjectItemListView())
|
$cards = id(new PHUIObjectItemListView())
|
||||||
|
@ -114,7 +125,7 @@ final class PhabricatorProjectBoardController
|
||||||
$board_box,
|
$board_box,
|
||||||
),
|
),
|
||||||
array(
|
array(
|
||||||
'title' => pht('Board'),
|
'title' => pht('%s Board', $project->getName()),
|
||||||
'device' => true,
|
'device' => true,
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
|
|
|
@ -45,7 +45,7 @@ final class PhabricatorProjectBoardEditController
|
||||||
return new Aphront404Response();
|
return new Aphront404Response();
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
$column = new PhabricatorProjectColumn();
|
$column = PhabricatorProjectColumn::initializeNewColumn($viewer);
|
||||||
}
|
}
|
||||||
|
|
||||||
$errors = array();
|
$errors = array();
|
||||||
|
|
|
@ -10,6 +10,11 @@ final class PhabricatorProjectColumn
|
||||||
|
|
||||||
private $project = self::ATTACHABLE;
|
private $project = self::ATTACHABLE;
|
||||||
|
|
||||||
|
public static function initializeNewColumn(PhabricatorUser $user) {
|
||||||
|
return id(new PhabricatorProjectColumn())
|
||||||
|
->setName('');
|
||||||
|
}
|
||||||
|
|
||||||
public function getConfiguration() {
|
public function getConfiguration() {
|
||||||
return array(
|
return array(
|
||||||
self::CONFIG_AUX_PHID => true,
|
self::CONFIG_AUX_PHID => true,
|
||||||
|
@ -30,6 +35,24 @@ final class PhabricatorProjectColumn
|
||||||
return $this->assertAttached($this->project);
|
return $this->assertAttached($this->project);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function isDefaultColumn() {
|
||||||
|
return ($this->getSequence() == 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getDisplayName() {
|
||||||
|
if ($this->isDefaultColumn()) {
|
||||||
|
return pht('Backlog');
|
||||||
|
}
|
||||||
|
return $this->getName();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getHeaderColor() {
|
||||||
|
if ($this->isDefaultColumn()) {
|
||||||
|
return PhabricatorActionHeaderView::HEADER_DARK_GREY;
|
||||||
|
}
|
||||||
|
return PhabricatorActionHeaderView::HEADER_GREY;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/* -( PhabricatorPolicyInterface )----------------------------------------- */
|
/* -( PhabricatorPolicyInterface )----------------------------------------- */
|
||||||
|
|
||||||
|
|
|
@ -6,6 +6,7 @@ final class PHUIWorkpanelView extends AphrontView {
|
||||||
private $header;
|
private $header;
|
||||||
private $editURI;
|
private $editURI;
|
||||||
private $footerAction;
|
private $footerAction;
|
||||||
|
private $headerColor = PhabricatorActionHeaderView::HEADER_GREY;
|
||||||
|
|
||||||
public function setCards(PHUIObjectItemListView $cards) {
|
public function setCards(PHUIObjectItemListView $cards) {
|
||||||
$this->cards[] = $cards;
|
$this->cards[] = $cards;
|
||||||
|
@ -27,6 +28,11 @@ final class PHUIWorkpanelView extends AphrontView {
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function setHeaderColor($header_color) {
|
||||||
|
$this->headerColor = $header_color;
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
public function render() {
|
public function render() {
|
||||||
require_celerity_resource('phui-workpanel-view-css');
|
require_celerity_resource('phui-workpanel-view-css');
|
||||||
|
|
||||||
|
@ -48,7 +54,7 @@ final class PHUIWorkpanelView extends AphrontView {
|
||||||
|
|
||||||
$header = id(new PhabricatorActionHeaderView())
|
$header = id(new PhabricatorActionHeaderView())
|
||||||
->setHeaderTitle($this->header)
|
->setHeaderTitle($this->header)
|
||||||
->setHeaderColor(PhabricatorActionHeaderView::HEADER_GREY)
|
->setHeaderColor($this->headerColor)
|
||||||
->addAction($header_edit);
|
->addAction($header_edit);
|
||||||
|
|
||||||
$body = phutil_tag(
|
$body = phutil_tag(
|
||||||
|
|
Loading…
Reference in a new issue