2012-07-30 19:43:49 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
final class PhabricatorApplicationDifferential extends PhabricatorApplication {
|
|
|
|
|
2012-08-02 23:07:21 +02:00
|
|
|
public function getBaseURI() {
|
|
|
|
return '/differential/';
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getShortDescription() {
|
|
|
|
return 'Review Code';
|
|
|
|
}
|
|
|
|
|
2012-08-14 23:23:55 +02:00
|
|
|
public function getAutospriteName() {
|
|
|
|
return 'differential';
|
2012-08-02 23:07:21 +02:00
|
|
|
}
|
|
|
|
|
2012-10-10 23:10:24 +02:00
|
|
|
public function getHelpURI() {
|
|
|
|
return PhabricatorEnv::getDoclink('article/Differential_User_Guide.html');
|
|
|
|
}
|
|
|
|
|
2012-07-30 19:43:49 +02:00
|
|
|
public function getFactObjectsForAnalysis() {
|
|
|
|
return array(
|
|
|
|
new DifferentialRevision(),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2012-08-05 23:03:39 +02:00
|
|
|
public function getRoutes() {
|
|
|
|
return array(
|
2012-10-06 01:06:16 +02:00
|
|
|
'/D(?P<id>[1-9]\d*)' => 'DifferentialRevisionViewController',
|
2012-08-05 23:03:39 +02:00
|
|
|
'/differential/' => array(
|
|
|
|
'' => 'DifferentialRevisionListController',
|
2012-08-16 18:29:27 +02:00
|
|
|
'filter/(?P<filter>\w+)/(?:(?P<username>[\w\.-_]+)/)?' =>
|
2012-08-05 23:03:39 +02:00
|
|
|
'DifferentialRevisionListController',
|
|
|
|
'stats/(?P<filter>\w+)/' => 'DifferentialRevisionStatsController',
|
|
|
|
'diff/' => array(
|
2012-10-06 01:06:16 +02:00
|
|
|
'(?P<id>[1-9]\d*)/' => 'DifferentialDiffViewController',
|
2012-08-05 23:03:39 +02:00
|
|
|
'create/' => 'DifferentialDiffCreateController',
|
|
|
|
),
|
|
|
|
'changeset/' => 'DifferentialChangesetViewController',
|
2012-10-06 01:06:16 +02:00
|
|
|
'revision/edit/(?:(?P<id>[1-9]\d*)/)?'
|
2012-08-05 23:03:39 +02:00
|
|
|
=> 'DifferentialRevisionEditController',
|
|
|
|
'comment/' => array(
|
2012-10-06 01:06:16 +02:00
|
|
|
'preview/(?P<id>[1-9]\d*)/' => 'DifferentialCommentPreviewController',
|
2012-08-05 23:03:39 +02:00
|
|
|
'save/' => 'DifferentialCommentSaveController',
|
|
|
|
'inline/' => array(
|
2012-10-06 01:06:16 +02:00
|
|
|
'preview/(?P<id>[1-9]\d*)/'
|
|
|
|
=> 'DifferentialInlineCommentPreviewController',
|
|
|
|
'edit/(?P<id>[1-9]\d*)/'
|
|
|
|
=> 'DifferentialInlineCommentEditController',
|
2012-08-05 23:03:39 +02:00
|
|
|
),
|
|
|
|
),
|
2012-10-06 01:06:16 +02:00
|
|
|
'subscribe/(?P<action>add|rem)/(?P<id>[1-9]\d*)/'
|
2012-08-05 23:03:39 +02:00
|
|
|
=> 'DifferentialSubscribeController',
|
|
|
|
),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2012-10-04 00:46:19 +02:00
|
|
|
public function getApplicationGroup() {
|
|
|
|
return self::GROUP_CORE;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getApplicationOrder() {
|
Add basic support for new navigation menu
Summary:
Add a new left-side application menu. This menu shows which application you're in and provides a quick way to get to other applications.
On desktops, menus are always shown but the app menu can be collapsed to be very small.
On tablets, navigation buttons allow you to choose between the menus and the content.
On phones, navigation buttons allow you to choose between the app menu, the local menu, and the content.
This needs some code and UI cleanup, but has no effect yet so I think it's okay to land as-is, I'll clean it up a bit as I start integrating it. I want to play around with it a bit and see if it's good/useful or horrible anyway.
Test Plan: Will include screenshots.
Reviewers: vrana, btrahan, chad
Reviewed By: btrahan
CC: aran, alanh
Maniphest Tasks: T1569
Differential Revision: https://secure.phabricator.com/D3223
2012-08-11 16:06:12 +02:00
|
|
|
return 0.100;
|
|
|
|
}
|
|
|
|
|
2012-08-02 23:07:21 +02:00
|
|
|
public function loadStatus(PhabricatorUser $user) {
|
|
|
|
$revisions = id(new DifferentialRevisionQuery())
|
|
|
|
->withResponsibleUsers(array($user->getPHID()))
|
|
|
|
->withStatus(DifferentialRevisionQuery::STATUS_OPEN)
|
|
|
|
->execute();
|
2012-08-01 02:58:21 +02:00
|
|
|
|
2012-08-02 23:07:21 +02:00
|
|
|
list($active, $waiting) = DifferentialRevisionQuery::splitResponsible(
|
|
|
|
$revisions,
|
|
|
|
$user->getPHID());
|
|
|
|
|
|
|
|
$status = array();
|
|
|
|
|
|
|
|
$active = count($active);
|
|
|
|
$type = $active
|
|
|
|
? PhabricatorApplicationStatusView::TYPE_NEEDS_ATTENTION
|
|
|
|
: PhabricatorApplicationStatusView::TYPE_EMPTY;
|
|
|
|
$status[] = id(new PhabricatorApplicationStatusView())
|
|
|
|
->setType($type)
|
|
|
|
->setText(pht('%d Review(s) Need Attention', $active))
|
|
|
|
->setCount($active);
|
|
|
|
|
|
|
|
$waiting = count($waiting);
|
|
|
|
$type = $waiting
|
|
|
|
? PhabricatorApplicationStatusView::TYPE_INFO
|
|
|
|
: PhabricatorApplicationStatusView::TYPE_EMPTY;
|
|
|
|
$status[] = id(new PhabricatorApplicationStatusView())
|
|
|
|
->setType($type)
|
|
|
|
->setText(pht('%d Review(s) Waiting on Others', $waiting));
|
|
|
|
|
|
|
|
return $status;
|
2012-08-01 02:58:21 +02:00
|
|
|
}
|
|
|
|
|
2012-07-30 19:43:49 +02:00
|
|
|
}
|
|
|
|
|