mirror of
https://we.phorge.it/source/phorge.git
synced 2024-11-13 18:32:41 +01:00
8756d82cf6
Summary: I'm pretty sure that `@group` annotations are useless now... see D9855. Also fixed various other minor issues. Test Plan: Eye-ball it. Reviewers: #blessed_reviewers, epriestley, chad Reviewed By: #blessed_reviewers, epriestley Subscribers: epriestley, Korvin, hach-que Differential Revision: https://secure.phabricator.com/D9859
132 lines
3.3 KiB
PHP
132 lines
3.3 KiB
PHP
<?php
|
|
|
|
final class ManiphestTaskListView extends ManiphestView {
|
|
|
|
private $tasks;
|
|
private $handles;
|
|
private $showBatchControls;
|
|
private $showSubpriorityControls;
|
|
|
|
public function setTasks(array $tasks) {
|
|
assert_instances_of($tasks, 'ManiphestTask');
|
|
$this->tasks = $tasks;
|
|
return $this;
|
|
}
|
|
|
|
public function setHandles(array $handles) {
|
|
assert_instances_of($handles, 'PhabricatorObjectHandle');
|
|
$this->handles = $handles;
|
|
return $this;
|
|
}
|
|
|
|
public function setShowBatchControls($show_batch_controls) {
|
|
$this->showBatchControls = $show_batch_controls;
|
|
return $this;
|
|
}
|
|
|
|
public function setShowSubpriorityControls($show_subpriority_controls) {
|
|
$this->showSubpriorityControls = $show_subpriority_controls;
|
|
return $this;
|
|
}
|
|
|
|
public function render() {
|
|
$handles = $this->handles;
|
|
|
|
require_celerity_resource('maniphest-task-summary-css');
|
|
|
|
$list = new PHUIObjectItemListView();
|
|
$list->setFlush(true);
|
|
|
|
$status_map = ManiphestTaskStatus::getTaskStatusMap();
|
|
$color_map = ManiphestTaskPriority::getColorMap();
|
|
|
|
if ($this->showBatchControls) {
|
|
Javelin::initBehavior('maniphest-list-editor');
|
|
}
|
|
|
|
foreach ($this->tasks as $task) {
|
|
$item = new PHUIObjectItemView();
|
|
$item->setObjectName('T'.$task->getID());
|
|
$item->setHeader($task->getTitle());
|
|
$item->setHref('/T'.$task->getID());
|
|
|
|
if ($task->getOwnerPHID()) {
|
|
$owner = $handles[$task->getOwnerPHID()];
|
|
$item->addByline(pht('Assigned: %s', $owner->renderLink()));
|
|
}
|
|
|
|
$status = $task->getStatus();
|
|
if ($task->isClosed()) {
|
|
$item->setDisabled(true);
|
|
}
|
|
|
|
$item->setBarColor(idx($color_map, $task->getPriority(), 'grey'));
|
|
|
|
$item->addIcon(
|
|
'none',
|
|
phabricator_datetime($task->getDateModified(), $this->getUser()));
|
|
|
|
if ($this->showSubpriorityControls) {
|
|
$item->setGrippable(true);
|
|
}
|
|
if ($this->showSubpriorityControls || $this->showBatchControls) {
|
|
$item->addSigil('maniphest-task');
|
|
}
|
|
|
|
$project_handles = array_select_keys(
|
|
$handles,
|
|
$task->getProjectPHIDs());
|
|
|
|
$item->addAttribute(
|
|
id(new PHUIHandleTagListView())
|
|
->setLimit(4)
|
|
->setNoDataString(pht('No Projects'))
|
|
->setSlim(true)
|
|
->setHandles($project_handles));
|
|
|
|
$item->setMetadata(
|
|
array(
|
|
'taskID' => $task->getID(),
|
|
));
|
|
|
|
if ($this->showBatchControls) {
|
|
$item->addAction(
|
|
id(new PHUIListItemView())
|
|
->setIcon('fa-pencil')
|
|
->addSigil('maniphest-edit-task')
|
|
->setHref('/maniphest/task/edit/'.$task->getID().'/'));
|
|
}
|
|
|
|
$list->addItem($item);
|
|
}
|
|
|
|
return $list;
|
|
}
|
|
|
|
public static function loadTaskHandles(
|
|
PhabricatorUser $viewer,
|
|
array $tasks) {
|
|
assert_instances_of($tasks, 'ManiphestTask');
|
|
|
|
$phids = array();
|
|
foreach ($tasks as $task) {
|
|
$assigned_phid = $task->getOwnerPHID();
|
|
if ($assigned_phid) {
|
|
$phids[] = $assigned_phid;
|
|
}
|
|
foreach ($task->getProjectPHIDs() as $project_phid) {
|
|
$phids[] = $project_phid;
|
|
}
|
|
}
|
|
|
|
if (!$phids) {
|
|
return array();
|
|
}
|
|
|
|
return id(new PhabricatorHandleQuery())
|
|
->setViewer($viewer)
|
|
->withPHIDs($phids)
|
|
->execute();
|
|
}
|
|
|
|
}
|