mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-26 14:38:19 +01:00
78784aa1fe
Summary: So they're maybe a little easier to deal with? I'm going to take this formally to "plz @chad plz help" land. Test Plan: {F20329} Reviewers: btrahan, vrana, chad Reviewed By: vrana CC: aran Differential Revision: https://secure.phabricator.com/D3609
110 lines
3.3 KiB
PHP
110 lines
3.3 KiB
PHP
<?php
|
|
|
|
/*
|
|
* Copyright 2012 Facebook, Inc.
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
final class PhabricatorApplicationDifferential extends PhabricatorApplication {
|
|
|
|
public function getBaseURI() {
|
|
return '/differential/';
|
|
}
|
|
|
|
public function getShortDescription() {
|
|
return 'Review Code';
|
|
}
|
|
|
|
public function getAutospriteName() {
|
|
return 'differential';
|
|
}
|
|
|
|
public function getFactObjectsForAnalysis() {
|
|
return array(
|
|
new DifferentialRevision(),
|
|
);
|
|
}
|
|
|
|
public function getRoutes() {
|
|
return array(
|
|
'/D(?P<id>\d+)' => 'DifferentialRevisionViewController',
|
|
'/differential/' => array(
|
|
'' => 'DifferentialRevisionListController',
|
|
'filter/(?P<filter>\w+)/(?:(?P<username>[\w\.-_]+)/)?' =>
|
|
'DifferentialRevisionListController',
|
|
'stats/(?P<filter>\w+)/' => 'DifferentialRevisionStatsController',
|
|
'diff/' => array(
|
|
'(?P<id>\d+)/' => 'DifferentialDiffViewController',
|
|
'create/' => 'DifferentialDiffCreateController',
|
|
),
|
|
'changeset/' => 'DifferentialChangesetViewController',
|
|
'revision/edit/(?:(?P<id>\d+)/)?'
|
|
=> 'DifferentialRevisionEditController',
|
|
'comment/' => array(
|
|
'preview/(?P<id>\d+)/' => 'DifferentialCommentPreviewController',
|
|
'save/' => 'DifferentialCommentSaveController',
|
|
'inline/' => array(
|
|
'preview/(?P<id>\d+)/' =>
|
|
'DifferentialInlineCommentPreviewController',
|
|
'edit/(?P<id>\d+)/' => 'DifferentialInlineCommentEditController',
|
|
),
|
|
),
|
|
'subscribe/(?P<action>add|rem)/(?P<id>\d+)/'
|
|
=> 'DifferentialSubscribeController',
|
|
),
|
|
);
|
|
}
|
|
|
|
public function getApplicationGroup() {
|
|
return self::GROUP_CORE;
|
|
}
|
|
|
|
public function getApplicationOrder() {
|
|
return 0.100;
|
|
}
|
|
|
|
public function loadStatus(PhabricatorUser $user) {
|
|
$revisions = id(new DifferentialRevisionQuery())
|
|
->withResponsibleUsers(array($user->getPHID()))
|
|
->withStatus(DifferentialRevisionQuery::STATUS_OPEN)
|
|
->execute();
|
|
|
|
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;
|
|
}
|
|
|
|
}
|
|
|