mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-19 19:21:10 +01:00
Remove all hardcoded behaviors associated with task priorities
Summary: Ref T3583. Currently, we have some hard-coded behaviors associated with the "Unbreak Now" and "Needs Triage" priorities. Remove them: - Users seem somewhat confused by these on occasion, and never seem to think they're cool/useful (that I've seen, at least). - I think they have low utility in general, see T3583. - Saves three queries on the home page, which can no longer use row counting since they must be policy filtered. - Primarily, this paves the way for allowing installs to customize priorities, which is an occasional request. Also deletes a lot of code with no callsites. Test Plan: Mostly `grep`. Loaded home page. Viewed reports and task list. Reviewers: btrahan Reviewed By: btrahan CC: chad, aran Maniphest Tasks: T3583 Differential Revision: https://secure.phabricator.com/D6981
This commit is contained in:
parent
91880b5a51
commit
092f540199
7 changed files with 12 additions and 159 deletions
src
webroot/rsrc/css/application/maniphest
|
@ -2926,7 +2926,7 @@ celerity_register_resource_map(array(
|
|||
),
|
||||
'maniphest-transaction-detail-css' =>
|
||||
array(
|
||||
'uri' => '/res/30242771/rsrc/css/application/maniphest/transaction-detail.css',
|
||||
'uri' => '/res/f2c9582c/rsrc/css/application/maniphest/transaction-detail.css',
|
||||
'type' => 'css',
|
||||
'requires' =>
|
||||
array(
|
||||
|
@ -4380,7 +4380,7 @@ celerity_register_resource_map(array(
|
|||
'uri' => '/res/pkg/f32597c9/javelin.pkg.js',
|
||||
'type' => 'js',
|
||||
),
|
||||
'0a9e494f' =>
|
||||
'ad2ed1da' =>
|
||||
array(
|
||||
'name' => 'maniphest.pkg.css',
|
||||
'symbols' =>
|
||||
|
@ -4389,7 +4389,7 @@ celerity_register_resource_map(array(
|
|||
1 => 'maniphest-transaction-detail-css',
|
||||
2 => 'phabricator-project-tag-css',
|
||||
),
|
||||
'uri' => '/res/pkg/0a9e494f/maniphest.pkg.css',
|
||||
'uri' => '/res/pkg/ad2ed1da/maniphest.pkg.css',
|
||||
'type' => 'css',
|
||||
),
|
||||
'83a3853e' =>
|
||||
|
@ -4505,8 +4505,8 @@ celerity_register_resource_map(array(
|
|||
'javelin-vector' => 'f32597c9',
|
||||
'javelin-workflow' => 'f32597c9',
|
||||
'lightbox-attachment-css' => '1200d176',
|
||||
'maniphest-task-summary-css' => '0a9e494f',
|
||||
'maniphest-transaction-detail-css' => '0a9e494f',
|
||||
'maniphest-task-summary-css' => 'ad2ed1da',
|
||||
'maniphest-transaction-detail-css' => 'ad2ed1da',
|
||||
'phabricator-action-list-view-css' => '1200d176',
|
||||
'phabricator-application-launch-view-css' => '1200d176',
|
||||
'phabricator-busy' => '8977e356',
|
||||
|
@ -4532,7 +4532,7 @@ celerity_register_resource_map(array(
|
|||
'phabricator-object-selector-css' => '44bfe40c',
|
||||
'phabricator-phtize' => '8977e356',
|
||||
'phabricator-prefab' => '8977e356',
|
||||
'phabricator-project-tag-css' => '0a9e494f',
|
||||
'phabricator-project-tag-css' => 'ad2ed1da',
|
||||
'phabricator-property-list-view-css' => '1200d176',
|
||||
'phabricator-remarkup-css' => '1200d176',
|
||||
'phabricator-shaped-request' => '5e9e5c4e',
|
||||
|
|
|
@ -32,12 +32,8 @@ final class PhabricatorDirectoryMainController
|
|||
|
||||
$maniphest = 'PhabricatorApplicationManiphest';
|
||||
if (PhabricatorApplication::isClassInstalled($maniphest)) {
|
||||
$unbreak_panel = $this->buildUnbreakNowPanel();
|
||||
$triage_panel = $this->buildNeedsTriagePanel($projects);
|
||||
$tasks_panel = $this->buildTasksPanel();
|
||||
} else {
|
||||
$unbreak_panel = null;
|
||||
$triage_panel = null;
|
||||
$tasks_panel = null;
|
||||
}
|
||||
|
||||
|
@ -54,8 +50,6 @@ final class PhabricatorDirectoryMainController
|
|||
$content = array(
|
||||
$jump_panel,
|
||||
$welcome_panel,
|
||||
$unbreak_panel,
|
||||
$triage_panel,
|
||||
$revision_panel,
|
||||
$tasks_panel,
|
||||
$audit_panel,
|
||||
|
@ -96,88 +90,6 @@ final class PhabricatorDirectoryMainController
|
|||
}
|
||||
}
|
||||
|
||||
private function buildUnbreakNowPanel() {
|
||||
$user = $this->getRequest()->getUser();
|
||||
|
||||
$task_query = id(new ManiphestTaskQuery())
|
||||
->setViewer($user)
|
||||
->withStatus(ManiphestTaskQuery::STATUS_OPEN)
|
||||
->withPriority(ManiphestTaskPriority::PRIORITY_UNBREAK_NOW)
|
||||
->setLimit(10);
|
||||
|
||||
$tasks = $task_query->execute();
|
||||
|
||||
if (!$tasks) {
|
||||
return $this->renderMiniPanel(
|
||||
'No "Unbreak Now!" Tasks',
|
||||
'Nothing appears to be critically broken right now.');
|
||||
}
|
||||
|
||||
$panel = new AphrontPanelView();
|
||||
$panel->setHeader('Unbreak Now!');
|
||||
$panel->setCaption('Open tasks with "Unbreak Now!" priority.');
|
||||
$panel->addButton(
|
||||
phutil_tag(
|
||||
'a',
|
||||
array(
|
||||
'href' => '/maniphest/view/all/',
|
||||
'class' => 'grey button',
|
||||
),
|
||||
"View All Unbreak Now \xC2\xBB"));
|
||||
|
||||
$panel->appendChild($this->buildTaskListView($tasks));
|
||||
$panel->setNoBackground();
|
||||
|
||||
return $panel;
|
||||
}
|
||||
|
||||
private function buildNeedsTriagePanel(array $projects) {
|
||||
assert_instances_of($projects, 'PhabricatorProject');
|
||||
|
||||
$user = $this->getRequest()->getUser();
|
||||
|
||||
if ($projects) {
|
||||
$task_query = id(new ManiphestTaskQuery())
|
||||
->setViewer($user)
|
||||
->withStatus(ManiphestTaskQuery::STATUS_OPEN)
|
||||
->withPriority(ManiphestTaskPriority::PRIORITY_TRIAGE)
|
||||
->withAnyProjects(mpull($projects, 'getPHID'))
|
||||
->setLimit(10);
|
||||
$tasks = $task_query->execute();
|
||||
} else {
|
||||
$tasks = array();
|
||||
}
|
||||
|
||||
if (!$tasks) {
|
||||
return $this->renderMiniPanel(
|
||||
'No "Needs Triage" Tasks',
|
||||
hsprintf(
|
||||
'No tasks in <a href="/project/">projects you are a member of</a> '.
|
||||
'need triage.'));
|
||||
}
|
||||
|
||||
$panel = new AphrontPanelView();
|
||||
$panel->setHeader('Needs Triage');
|
||||
$panel->setCaption(hsprintf(
|
||||
'Open tasks with "Needs Triage" priority in '.
|
||||
'<a href="/project/">projects you are a member of</a>.'));
|
||||
|
||||
$panel->addButton(
|
||||
phutil_tag(
|
||||
'a',
|
||||
array(
|
||||
// TODO: This should filter to just your projects' need-triage
|
||||
// tasks?
|
||||
'href' => '/maniphest/view/projecttriage/',
|
||||
'class' => 'grey button',
|
||||
),
|
||||
"View All Triage \xC2\xBB"));
|
||||
$panel->appendChild($this->buildTaskListView($tasks));
|
||||
$panel->setNoBackground();
|
||||
|
||||
return $panel;
|
||||
}
|
||||
|
||||
private function buildRevisionPanel() {
|
||||
$user = $this->getRequest()->getUser();
|
||||
$user_phid = $user->getPHID();
|
||||
|
|
|
@ -85,31 +85,13 @@ final class PhabricatorApplicationManiphest extends PhabricatorApplication {
|
|||
$query = id(new ManiphestTaskQuery())
|
||||
->setViewer($user)
|
||||
->withStatus(ManiphestTaskQuery::STATUS_OPEN)
|
||||
->withPriority(ManiphestTaskPriority::PRIORITY_UNBREAK_NOW)
|
||||
->setLimit(1)
|
||||
->setCalculateRows(true);
|
||||
$query->execute();
|
||||
->withOwners(array($user->getPHID()));
|
||||
$count = count($query->execute());
|
||||
|
||||
$count = $query->getRowCount();
|
||||
$type = PhabricatorApplicationStatusView::TYPE_NEEDS_ATTENTION;
|
||||
$status[] = id(new PhabricatorApplicationStatusView())
|
||||
->setType($type)
|
||||
->setText(pht('%d Unbreak Now Task(s)!', $count))
|
||||
->setCount($count);
|
||||
|
||||
$query = id(new ManiphestTaskQuery())
|
||||
->setViewer($user)
|
||||
->withStatus(ManiphestTaskQuery::STATUS_OPEN)
|
||||
->withOwners(array($user->getPHID()))
|
||||
->setLimit(1)
|
||||
->setCalculateRows(true);
|
||||
$query->execute();
|
||||
|
||||
$count = $query->getRowCount();
|
||||
$type = PhabricatorApplicationStatusView::TYPE_WARNING;
|
||||
$status[] = id(new PhabricatorApplicationStatusView())
|
||||
->setType($type)
|
||||
->setText(pht('%d Assigned Task(s)', $count))
|
||||
->setText(pht('%s Assigned Task(s)', new PhutilNumber($count)))
|
||||
->setCount($count);
|
||||
|
||||
return $status;
|
||||
|
|
|
@ -44,47 +44,13 @@ final class ManiphestTaskPriority extends ManiphestConstants {
|
|||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the priorities and some bits for bitwise fun.
|
||||
*
|
||||
* @return map Priorities to bits.
|
||||
*/
|
||||
public static function getLoadMap() {
|
||||
return array(
|
||||
self::PRIORITY_UNBREAK_NOW => 16,
|
||||
self::PRIORITY_TRIAGE => 8,
|
||||
self::PRIORITY_HIGH => 4,
|
||||
self::PRIORITY_NORMAL => 2,
|
||||
self::PRIORITY_LOW => 1,
|
||||
self::PRIORITY_WISH => 0,
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the lowest defined priority.
|
||||
*
|
||||
* @return int The value of the lowest priority constant.
|
||||
*/
|
||||
public static function getLowestPriority() {
|
||||
return self::PRIORITY_WISH;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the highest defined priority.
|
||||
*
|
||||
* @return int The value of the highest priority constant.
|
||||
*/
|
||||
public static function getHighestPriority() {
|
||||
return self::PRIORITY_UNBREAK_NOW;
|
||||
}
|
||||
/**
|
||||
* Return the default priority for this instance of Phabricator.
|
||||
*
|
||||
* @return int The value of the default priority constant.
|
||||
*/
|
||||
public static function getDefaultPriority() {
|
||||
return PhabricatorEnv::getEnvConfig(
|
||||
'maniphest.default-priority');
|
||||
return PhabricatorEnv::getEnvConfig('maniphest.default-priority');
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
|
@ -64,7 +64,7 @@ final class ManiphestCreateMailReceiver extends PhabricatorMailReceiver {
|
|||
|
||||
$task->setAuthorPHID($sender->getPHID());
|
||||
$task->setOriginalEmailSource($mail->getHeader('From'));
|
||||
$task->setPriority(ManiphestTaskPriority::PRIORITY_TRIAGE);
|
||||
$task->setPriority(ManiphestTaskPriority::getDefaultPriority());
|
||||
|
||||
$editor = new ManiphestTransactionEditor();
|
||||
$editor->setActor($sender);
|
||||
|
|
|
@ -455,7 +455,7 @@ final class ManiphestTransactionDetailView extends ManiphestView {
|
|||
$old_name = ManiphestTaskPriority::getTaskPriorityName($old);
|
||||
$new_name = ManiphestTaskPriority::getTaskPriorityName($new);
|
||||
|
||||
if ($old == ManiphestTaskPriority::PRIORITY_TRIAGE) {
|
||||
if ($old == ManiphestTaskPriority::getDefaultPriority()) {
|
||||
$verb = 'Triaged';
|
||||
$desc = 'triaged this task as "'.$new_name.'" priority';
|
||||
} else if ($old > $new) {
|
||||
|
@ -467,9 +467,6 @@ final class ManiphestTransactionDetailView extends ManiphestView {
|
|||
$desc = 'raised the priority of this task from "'.$old_name.'" to '.
|
||||
'"'.$new_name.'"';
|
||||
}
|
||||
if ($new == ManiphestTaskPriority::PRIORITY_UNBREAK_NOW) {
|
||||
$classes[] = 'unbreaknow';
|
||||
}
|
||||
break;
|
||||
case ManiphestTransactionType::TYPE_ATTACH:
|
||||
if ($this->preview) {
|
||||
|
|
|
@ -47,10 +47,6 @@
|
|||
border-color: #660099;
|
||||
}
|
||||
|
||||
.phabricator-transaction-view .unbreaknow {
|
||||
border-color: #aa0000;
|
||||
}
|
||||
|
||||
.phabricator-transaction-view .duplicate {
|
||||
border-color: #333333;
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue