mirror of
https://we.phorge.it/source/phorge.git
synced 2024-12-19 12:00:55 +01:00
Remove Differential "Title" custom field
Summary: Ref T11114. Obsoleted by Modular Transactions + EditEngine + CommitMessageField + we just "hard code" the title of revisions into the page because we're craaazy. Test Plan: - Made an edit on `stable`. - Viewed the edit on this change, it still had the proper UI strings. - Edited/created/updated revisions. Reviewers: chad Reviewed By: chad Maniphest Tasks: T11114 Differential Revision: https://secure.phabricator.com/D17083
This commit is contained in:
parent
f552a20c61
commit
9e4c16c4c3
5 changed files with 22 additions and 129 deletions
|
@ -572,7 +572,6 @@ phutil_register_library_map(array(
|
|||
'DifferentialTestPlanCommitMessageField' => 'applications/differential/field/DifferentialTestPlanCommitMessageField.php',
|
||||
'DifferentialTestPlanField' => 'applications/differential/customfield/DifferentialTestPlanField.php',
|
||||
'DifferentialTitleCommitMessageField' => 'applications/differential/field/DifferentialTitleCommitMessageField.php',
|
||||
'DifferentialTitleField' => 'applications/differential/customfield/DifferentialTitleField.php',
|
||||
'DifferentialTransaction' => 'applications/differential/storage/DifferentialTransaction.php',
|
||||
'DifferentialTransactionComment' => 'applications/differential/storage/DifferentialTransactionComment.php',
|
||||
'DifferentialTransactionEditor' => 'applications/differential/editor/DifferentialTransactionEditor.php',
|
||||
|
@ -5236,7 +5235,6 @@ phutil_register_library_map(array(
|
|||
'DifferentialTestPlanCommitMessageField' => 'DifferentialCommitMessageField',
|
||||
'DifferentialTestPlanField' => 'DifferentialCoreCustomField',
|
||||
'DifferentialTitleCommitMessageField' => 'DifferentialCommitMessageField',
|
||||
'DifferentialTitleField' => 'DifferentialCoreCustomField',
|
||||
'DifferentialTransaction' => 'PhabricatorModularTransaction',
|
||||
'DifferentialTransactionComment' => 'PhabricatorApplicationTransactionComment',
|
||||
'DifferentialTransactionEditor' => 'PhabricatorApplicationTransactionEditor',
|
||||
|
|
|
@ -25,7 +25,6 @@ final class PhabricatorDifferentialConfigOptions
|
|||
$custom_field_type = 'custom:PhabricatorCustomFieldConfigOptionType';
|
||||
|
||||
$fields = array(
|
||||
new DifferentialTitleField(),
|
||||
new DifferentialSummaryField(),
|
||||
new DifferentialTestPlanField(),
|
||||
new DifferentialReviewersField(),
|
||||
|
|
|
@ -1,125 +0,0 @@
|
|||
<?php
|
||||
|
||||
final class DifferentialTitleField
|
||||
extends DifferentialCoreCustomField {
|
||||
|
||||
public function getFieldKey() {
|
||||
return 'differential:title';
|
||||
}
|
||||
|
||||
public function getFieldKeyForConduit() {
|
||||
return 'title';
|
||||
}
|
||||
|
||||
public function getFieldName() {
|
||||
return pht('Title');
|
||||
}
|
||||
|
||||
public function getFieldDescription() {
|
||||
return pht('Stores the revision title.');
|
||||
}
|
||||
|
||||
public static function getDefaultTitle() {
|
||||
return pht('<<Replace this line with your Revision Title>>');
|
||||
}
|
||||
|
||||
protected function readValueFromRevision(
|
||||
DifferentialRevision $revision) {
|
||||
return $revision->getTitle();
|
||||
}
|
||||
|
||||
protected function writeValueToRevision(
|
||||
DifferentialRevision $revision,
|
||||
$value) {
|
||||
$revision->setTitle($value);
|
||||
}
|
||||
|
||||
protected function getCoreFieldRequiredErrorString() {
|
||||
return pht('You must choose a title for this revision.');
|
||||
}
|
||||
|
||||
public function readValueFromRequest(AphrontRequest $request) {
|
||||
$this->setValue($request->getStr($this->getFieldKey()));
|
||||
}
|
||||
|
||||
protected function isCoreFieldRequired() {
|
||||
return true;
|
||||
}
|
||||
|
||||
public function renderEditControl(array $handles) {
|
||||
return id(new AphrontFormTextAreaControl())
|
||||
->setHeight(AphrontFormTextAreaControl::HEIGHT_VERY_SHORT)
|
||||
->setName($this->getFieldKey())
|
||||
->setValue($this->getValue())
|
||||
->setError($this->getFieldError())
|
||||
->setLabel($this->getFieldName());
|
||||
}
|
||||
|
||||
public function getApplicationTransactionTitle(
|
||||
PhabricatorApplicationTransaction $xaction) {
|
||||
$author_phid = $xaction->getAuthorPHID();
|
||||
$old = $xaction->getOldValue();
|
||||
$new = $xaction->getNewValue();
|
||||
|
||||
if (strlen($old)) {
|
||||
return pht(
|
||||
'%s retitled this revision from "%s" to "%s".',
|
||||
$xaction->renderHandleLink($author_phid),
|
||||
$old,
|
||||
$new);
|
||||
} else {
|
||||
return pht(
|
||||
'%s created this revision.',
|
||||
$xaction->renderHandleLink($author_phid));
|
||||
}
|
||||
}
|
||||
|
||||
public function getApplicationTransactionTitleForFeed(
|
||||
PhabricatorApplicationTransaction $xaction) {
|
||||
|
||||
$object_phid = $xaction->getObjectPHID();
|
||||
$author_phid = $xaction->getAuthorPHID();
|
||||
$old = $xaction->getOldValue();
|
||||
$new = $xaction->getNewValue();
|
||||
|
||||
if (strlen($old)) {
|
||||
return pht(
|
||||
'%s retitled %s, from "%s" to "%s".',
|
||||
$xaction->renderHandleLink($author_phid),
|
||||
$xaction->renderHandleLink($object_phid),
|
||||
$old,
|
||||
$new);
|
||||
} else {
|
||||
return pht(
|
||||
'%s created %s.',
|
||||
$xaction->renderHandleLink($author_phid),
|
||||
$xaction->renderHandleLink($object_phid));
|
||||
}
|
||||
}
|
||||
|
||||
public function shouldAppearInCommitMessage() {
|
||||
return true;
|
||||
}
|
||||
|
||||
public function shouldOverwriteWhenCommitMessageIsEdited() {
|
||||
return true;
|
||||
}
|
||||
|
||||
public function validateCommitMessageValue($value) {
|
||||
if (!strlen($value)) {
|
||||
throw new DifferentialFieldValidationException(
|
||||
pht(
|
||||
'You must provide a revision title in the first line '.
|
||||
'of your commit message.'));
|
||||
}
|
||||
|
||||
if (preg_match('/^<<.*>>$/', $value)) {
|
||||
throw new DifferentialFieldValidationException(
|
||||
pht(
|
||||
'Replace the line "%s" with a human-readable revision title which '.
|
||||
'describes the changes you are making.',
|
||||
self::getDefaultTitle()));
|
||||
}
|
||||
}
|
||||
|
||||
}
|
|
@ -22,6 +22,23 @@ final class DifferentialTransaction
|
|||
return 'DifferentialRevisionTransactionType';
|
||||
}
|
||||
|
||||
protected function newFallbackModularTransactionType() {
|
||||
// TODO: This allows us to render modern strings for older transactions
|
||||
// without doing a migration. At some point, we should do a migration and
|
||||
// throw this away.
|
||||
|
||||
$xaction_type = $this->getTransactionType();
|
||||
if ($xaction_type == PhabricatorTransactions::TYPE_CUSTOMFIELD) {
|
||||
switch ($this->getMetadataValue('customfield:key')) {
|
||||
case 'differential:title':
|
||||
return new DifferentialRevisionTitleTransaction();
|
||||
}
|
||||
}
|
||||
|
||||
return parent::newFallbackModularTransactionType();
|
||||
}
|
||||
|
||||
|
||||
public function setIsCommandeerSideEffect($is_side_effect) {
|
||||
$this->isCommandeerSideEffect = $is_side_effect;
|
||||
return $this;
|
||||
|
|
|
@ -46,7 +46,7 @@ abstract class PhabricatorModularTransaction
|
|||
$key = $this->getTransactionType();
|
||||
|
||||
if (empty($types[$key])) {
|
||||
$type = new PhabricatorCoreVoidTransaction();
|
||||
$type = $this->newFallbackModularTransactionType();
|
||||
} else {
|
||||
$type = clone $types[$key];
|
||||
}
|
||||
|
@ -56,6 +56,10 @@ abstract class PhabricatorModularTransaction
|
|||
return $type;
|
||||
}
|
||||
|
||||
protected function newFallbackModularTransactionType() {
|
||||
return new PhabricatorCoreVoidTransaction();
|
||||
}
|
||||
|
||||
final public function generateOldValue($object) {
|
||||
return $this->getTransactionImplementation()->generateOldValue($object);
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue