mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-13 08:11:04 +01:00
Allow Herald rules to add comments
Summary: See PHI242. All use cases for this that I know of are pretty hacky, but they don't seem perilous, and it's easier than webhooks. See P1895, T10183, and T9853 for me previously refusing to implement this since all those use cases were also pretty bad. Test Plan: - Wrote a rule to add comments, saw it add comments. - Reviewed summary, re-edited rule, reviewed transcript to check that all the strings worked OK. - Wrote a new rule for a non-commentable object (a blog) to make sure I wasn't offered the "Add a comment" action. Reviewers: amckinley Reviewed By: amckinley Differential Revision: https://secure.phabricator.com/D18823
This commit is contained in:
parent
60e5c0ec1b
commit
c9a0d68340
8 changed files with 133 additions and 13 deletions
|
@ -80,7 +80,7 @@ return array(
|
|||
'rsrc/css/application/flag/flag.css' => 'bba8f811',
|
||||
'rsrc/css/application/harbormaster/harbormaster.css' => 'f491c9f4',
|
||||
'rsrc/css/application/herald/herald-test.css' => 'a52e323e',
|
||||
'rsrc/css/application/herald/herald.css' => 'dc31f6e9',
|
||||
'rsrc/css/application/herald/herald.css' => 'cd8d0134',
|
||||
'rsrc/css/application/maniphest/batch-editor.css' => 'b0f0b6d5',
|
||||
'rsrc/css/application/maniphest/report.css' => '9b9580b7',
|
||||
'rsrc/css/application/maniphest/task-edit.css' => 'fda62a9b',
|
||||
|
@ -416,7 +416,7 @@ return array(
|
|||
'rsrc/js/application/drydock/drydock-live-operation-status.js' => '901935ef',
|
||||
'rsrc/js/application/files/behavior-icon-composer.js' => '8499b6ab',
|
||||
'rsrc/js/application/files/behavior-launch-icon-composer.js' => '48086888',
|
||||
'rsrc/js/application/herald/HeraldRuleEditor.js' => 'd6a7e717',
|
||||
'rsrc/js/application/herald/HeraldRuleEditor.js' => '2dff5579',
|
||||
'rsrc/js/application/herald/PathTypeahead.js' => 'f7fc67ec',
|
||||
'rsrc/js/application/herald/herald-rule-editor.js' => '7ebaeed3',
|
||||
'rsrc/js/application/maniphest/behavior-batch-editor.js' => '782ab6e7',
|
||||
|
@ -578,8 +578,8 @@ return array(
|
|||
'font-lato' => 'c7ccd872',
|
||||
'global-drag-and-drop-css' => 'b556a948',
|
||||
'harbormaster-css' => 'f491c9f4',
|
||||
'herald-css' => 'dc31f6e9',
|
||||
'herald-rule-editor' => 'd6a7e717',
|
||||
'herald-css' => 'cd8d0134',
|
||||
'herald-rule-editor' => '2dff5579',
|
||||
'herald-test-css' => 'a52e323e',
|
||||
'inline-comment-summary-css' => 'f23d4e8f',
|
||||
'javelin-aphlict' => 'e1d4b11a',
|
||||
|
@ -1106,6 +1106,15 @@ return array(
|
|||
'javelin-install',
|
||||
'javelin-event',
|
||||
),
|
||||
'2dff5579' => array(
|
||||
'multirow-row-manager',
|
||||
'javelin-install',
|
||||
'javelin-util',
|
||||
'javelin-dom',
|
||||
'javelin-stratcom',
|
||||
'javelin-json',
|
||||
'phabricator-prefab',
|
||||
),
|
||||
'2ee659ce' => array(
|
||||
'javelin-install',
|
||||
),
|
||||
|
@ -2001,15 +2010,6 @@ return array(
|
|||
'javelin-dom',
|
||||
'javelin-stratcom',
|
||||
),
|
||||
'd6a7e717' => array(
|
||||
'multirow-row-manager',
|
||||
'javelin-install',
|
||||
'javelin-util',
|
||||
'javelin-dom',
|
||||
'javelin-stratcom',
|
||||
'javelin-json',
|
||||
'phabricator-prefab',
|
||||
),
|
||||
'd7a74243' => array(
|
||||
'javelin-behavior',
|
||||
'javelin-stratcom',
|
||||
|
|
|
@ -1337,6 +1337,7 @@ phutil_register_library_map(array(
|
|||
'HeraldApplyTranscript' => 'applications/herald/storage/transcript/HeraldApplyTranscript.php',
|
||||
'HeraldBasicFieldGroup' => 'applications/herald/field/HeraldBasicFieldGroup.php',
|
||||
'HeraldBuildableState' => 'applications/herald/state/HeraldBuildableState.php',
|
||||
'HeraldCommentAction' => 'applications/herald/action/HeraldCommentAction.php',
|
||||
'HeraldCommitAdapter' => 'applications/diffusion/herald/HeraldCommitAdapter.php',
|
||||
'HeraldCondition' => 'applications/herald/storage/HeraldCondition.php',
|
||||
'HeraldConditionTranscript' => 'applications/herald/storage/transcript/HeraldConditionTranscript.php',
|
||||
|
@ -1378,6 +1379,7 @@ phutil_register_library_map(array(
|
|||
'HeraldProjectsField' => 'applications/project/herald/HeraldProjectsField.php',
|
||||
'HeraldRecursiveConditionsException' => 'applications/herald/engine/exception/HeraldRecursiveConditionsException.php',
|
||||
'HeraldRelatedFieldGroup' => 'applications/herald/field/HeraldRelatedFieldGroup.php',
|
||||
'HeraldRemarkupFieldValue' => 'applications/herald/value/HeraldRemarkupFieldValue.php',
|
||||
'HeraldRemarkupRule' => 'applications/herald/remarkup/HeraldRemarkupRule.php',
|
||||
'HeraldRepetitionPolicyConfig' => 'applications/herald/config/HeraldRepetitionPolicyConfig.php',
|
||||
'HeraldRule' => 'applications/herald/storage/HeraldRule.php',
|
||||
|
@ -6488,6 +6490,7 @@ phutil_register_library_map(array(
|
|||
'HeraldApplyTranscript' => 'Phobject',
|
||||
'HeraldBasicFieldGroup' => 'HeraldFieldGroup',
|
||||
'HeraldBuildableState' => 'HeraldState',
|
||||
'HeraldCommentAction' => 'HeraldAction',
|
||||
'HeraldCommitAdapter' => array(
|
||||
'HeraldAdapter',
|
||||
'HarbormasterBuildableAdapterInterface',
|
||||
|
@ -6535,6 +6538,7 @@ phutil_register_library_map(array(
|
|||
'HeraldProjectsField' => 'HeraldField',
|
||||
'HeraldRecursiveConditionsException' => 'Exception',
|
||||
'HeraldRelatedFieldGroup' => 'HeraldFieldGroup',
|
||||
'HeraldRemarkupFieldValue' => 'HeraldFieldValue',
|
||||
'HeraldRemarkupRule' => 'PhabricatorObjectRemarkupRule',
|
||||
'HeraldRepetitionPolicyConfig' => 'Phobject',
|
||||
'HeraldRule' => array(
|
||||
|
|
|
@ -9,6 +9,7 @@ abstract class HeraldAction extends Phobject {
|
|||
const STANDARD_NONE = 'standard.none';
|
||||
const STANDARD_PHID_LIST = 'standard.phid.list';
|
||||
const STANDARD_TEXT = 'standard.text';
|
||||
const STANDARD_REMARKUP = 'standard.remarkup';
|
||||
|
||||
const DO_STANDARD_EMPTY = 'do.standard.empty';
|
||||
const DO_STANDARD_NO_EFFECT = 'do.standard.no-effect';
|
||||
|
@ -60,6 +61,8 @@ abstract class HeraldAction extends Phobject {
|
|||
return new HeraldEmptyFieldValue();
|
||||
case self::STANDARD_TEXT:
|
||||
return new HeraldTextFieldValue();
|
||||
case self::STANDARD_REMARKUP:
|
||||
return new HeraldRemarkupFieldValue();
|
||||
case self::STANDARD_PHID_LIST:
|
||||
$tokenizer = id(new HeraldTokenizerFieldValue())
|
||||
->setKey($this->getHeraldActionName())
|
||||
|
|
79
src/applications/herald/action/HeraldCommentAction.php
Normal file
79
src/applications/herald/action/HeraldCommentAction.php
Normal file
|
@ -0,0 +1,79 @@
|
|||
<?php
|
||||
|
||||
final class HeraldCommentAction extends HeraldAction {
|
||||
|
||||
const ACTIONCONST = 'comment';
|
||||
const DO_COMMENT = 'do.comment';
|
||||
|
||||
public function getHeraldActionName() {
|
||||
return pht('Add comment');
|
||||
}
|
||||
|
||||
public function getActionGroupKey() {
|
||||
return HeraldUtilityActionGroup::ACTIONGROUPKEY;
|
||||
}
|
||||
|
||||
public function supportsObject($object) {
|
||||
if (!($object instanceof PhabricatorApplicationTransactionInterface)) {
|
||||
return false;
|
||||
}
|
||||
|
||||
$xaction = $object->getApplicationTransactionTemplate();
|
||||
try {
|
||||
$comment = $xaction->getApplicationTransactionCommentObject();
|
||||
if (!$comment) {
|
||||
return false;
|
||||
}
|
||||
} catch (PhutilMethodNotImplementedException $ex) {
|
||||
return false;
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
public function supportsRuleType($rule_type) {
|
||||
return ($rule_type != HeraldRuleTypeConfig::RULE_TYPE_PERSONAL);
|
||||
}
|
||||
|
||||
public function applyEffect($object, HeraldEffect $effect) {
|
||||
$adapter = $this->getAdapter();
|
||||
$comment_text = $effect->getTarget();
|
||||
|
||||
$xaction = $adapter->newTransaction()
|
||||
->setTransactionType(PhabricatorTransactions::TYPE_COMMENT);
|
||||
|
||||
$comment = $xaction->getApplicationTransactionCommentObject()
|
||||
->setContent($comment_text);
|
||||
|
||||
$xaction->attachComment($comment);
|
||||
|
||||
$adapter->queueTransaction($xaction);
|
||||
|
||||
$this->logEffect(self::DO_COMMENT, $comment_text);
|
||||
}
|
||||
|
||||
public function getHeraldActionStandardType() {
|
||||
return self::STANDARD_REMARKUP;
|
||||
}
|
||||
|
||||
protected function getActionEffectMap() {
|
||||
return array(
|
||||
self::DO_COMMENT => array(
|
||||
'icon' => 'fa-comment',
|
||||
'color' => 'blue',
|
||||
'name' => pht('Added Comment'),
|
||||
),
|
||||
);
|
||||
}
|
||||
|
||||
public function renderActionDescription($value) {
|
||||
$summary = PhabricatorMarkupEngine::summarize($value);
|
||||
return pht('Add comment: %s', $summary);
|
||||
}
|
||||
|
||||
protected function renderActionEffectDescription($type, $data) {
|
||||
$summary = PhabricatorMarkupEngine::summarize($data);
|
||||
return pht('Added a comment: %s', $summary);
|
||||
}
|
||||
|
||||
}
|
|
@ -8,6 +8,7 @@ abstract class HeraldFieldValue extends Phobject {
|
|||
const CONTROL_TEXT = 'herald.control.text';
|
||||
const CONTROL_SELECT = 'herald.control.select';
|
||||
const CONTROL_TOKENIZER = 'herald.control.tokenizer';
|
||||
const CONTROL_REMARKUP = 'herald.control.remarkup';
|
||||
|
||||
abstract public function getFieldValueKey();
|
||||
abstract public function getControlType();
|
||||
|
|
22
src/applications/herald/value/HeraldRemarkupFieldValue.php
Normal file
22
src/applications/herald/value/HeraldRemarkupFieldValue.php
Normal file
|
@ -0,0 +1,22 @@
|
|||
<?php
|
||||
|
||||
final class HeraldRemarkupFieldValue
|
||||
extends HeraldFieldValue {
|
||||
|
||||
public function getFieldValueKey() {
|
||||
return 'remarkup';
|
||||
}
|
||||
|
||||
public function getControlType() {
|
||||
return self::CONTROL_REMARKUP;
|
||||
}
|
||||
|
||||
public function renderFieldValue($value) {
|
||||
return $value;
|
||||
}
|
||||
|
||||
public function renderEditorValue($value) {
|
||||
return $value;
|
||||
}
|
||||
|
||||
}
|
|
@ -37,6 +37,12 @@
|
|||
padding: 2px 4px;
|
||||
}
|
||||
|
||||
.herald-action-table td textarea {
|
||||
width: 95%;
|
||||
height: 8em;
|
||||
padding: 2px 4px;
|
||||
}
|
||||
|
||||
.herald-action-table td.target {
|
||||
width: 100%;
|
||||
}
|
||||
|
|
|
@ -217,6 +217,11 @@ JX.install('HeraldRuleEditor', {
|
|||
get_fn = function() { return input.value; };
|
||||
set_fn = function(v) { input.value = v; };
|
||||
break;
|
||||
case 'herald.control.remarkup':
|
||||
input = JX.$N('textarea');
|
||||
get_fn = function() { return input.value; };
|
||||
set_fn = function(v) { input.value = v; };
|
||||
break;
|
||||
case 'herald.control.select':
|
||||
var options;
|
||||
|
||||
|
|
Loading…
Reference in a new issue