2016-12-29 10:35:47 -08:00
|
|
|
<?php
|
|
|
|
|
|
|
|
final class DifferentialRevisionResignTransaction
|
2016-12-29 13:14:09 -08:00
|
|
|
extends DifferentialRevisionReviewTransaction {
|
2016-12-29 10:35:47 -08:00
|
|
|
|
|
|
|
const TRANSACTIONTYPE = 'differential.revision.resign';
|
|
|
|
const ACTIONKEY = 'resign';
|
|
|
|
|
|
|
|
protected function getRevisionActionLabel() {
|
|
|
|
return pht('Resign as Reviewer');
|
|
|
|
}
|
|
|
|
|
|
|
|
protected function getRevisionActionDescription() {
|
|
|
|
return pht('You will resign as a reviewer for this change.');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getIcon() {
|
|
|
|
return 'fa-flag';
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getColor() {
|
|
|
|
return 'orange';
|
|
|
|
}
|
|
|
|
|
Order actions sensibly within Differential revision comment action groups
Summary:
Ref T11114. See D17114 for some discussion.
For review actions: accept, reject, resign.
For revision actions, order is basically least-severe to most-severe action pairs: plan changes, request review, close, reopen, abandon, reclaim, commandeer.
Test Plan: Viewed revisions as an author and a reviewer, saw sensible action order within action groups.
Reviewers: chad
Reviewed By: chad
Maniphest Tasks: T11114
Differential Revision: https://secure.phabricator.com/D17115
2016-12-29 13:36:36 -08:00
|
|
|
protected function getRevisionActionOrder() {
|
|
|
|
return 700;
|
|
|
|
}
|
|
|
|
|
2017-01-02 11:36:02 -08:00
|
|
|
public function getCommandKeyword() {
|
|
|
|
return 'resign';
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getCommandAliases() {
|
|
|
|
return array();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getCommandSummary() {
|
|
|
|
return pht('Resign from a revision.');
|
|
|
|
}
|
|
|
|
|
2016-12-29 10:35:47 -08:00
|
|
|
public function generateOldValue($object) {
|
|
|
|
$actor = $this->getActor();
|
|
|
|
return !$this->isViewerAnyReviewer($object, $actor);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function applyExternalEffects($object, $value) {
|
|
|
|
$status = DifferentialReviewerStatus::STATUS_RESIGNED;
|
|
|
|
$actor = $this->getActor();
|
|
|
|
$this->applyReviewerEffect($object, $actor, $value, $status);
|
|
|
|
}
|
|
|
|
|
|
|
|
protected function validateAction($object, PhabricatorUser $viewer) {
|
|
|
|
if ($object->isClosed()) {
|
|
|
|
throw new Exception(
|
|
|
|
pht(
|
|
|
|
'You can not resign from this revision because it has already '.
|
|
|
|
'been closed. You can only resign from open revisions.'));
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!$this->isViewerAnyReviewer($object, $viewer)) {
|
|
|
|
throw new Exception(
|
|
|
|
pht(
|
|
|
|
'You can not resign from this revision because you are not a '.
|
|
|
|
'reviewer. You can only resign from revisions where you are a '.
|
|
|
|
'reviewer.'));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getTitle() {
|
|
|
|
return pht(
|
|
|
|
'%s resigned from this revision.',
|
|
|
|
$this->renderAuthor());
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getTitleForFeed() {
|
|
|
|
return pht(
|
|
|
|
'%s resigned from %s.',
|
|
|
|
$this->renderAuthor(),
|
|
|
|
$this->renderObject());
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|