mirror of
https://we.phorge.it/source/phorge.git
synced 2024-11-13 18:32:41 +01:00
f6a13fd1c7
Summary: Ref T2222. This will probably have some rough edges for a bit (e.g., weird cases I didn't remember or think of), but there's no change to the underlying data and we can easily revert if things get too messy. Test Plan: Looked at a variety of revisions and saw sensible output. Reviewers: btrahan Reviewed By: btrahan CC: aran Maniphest Tasks: T2222 Differential Revision: https://secure.phabricator.com/D8361
196 lines
5.7 KiB
PHP
196 lines
5.7 KiB
PHP
<?php
|
|
|
|
final class DifferentialAddCommentView extends AphrontView {
|
|
|
|
private $revision;
|
|
private $actions;
|
|
private $actionURI;
|
|
private $draft;
|
|
private $reviewers = array();
|
|
private $ccs = array();
|
|
|
|
public function setRevision($revision) {
|
|
$this->revision = $revision;
|
|
return $this;
|
|
}
|
|
|
|
public function setActions(array $actions) {
|
|
$this->actions = $actions;
|
|
return $this;
|
|
}
|
|
|
|
public function setActionURI($uri) {
|
|
$this->actionURI = $uri;
|
|
return $this;
|
|
}
|
|
|
|
public function setDraft(PhabricatorDraft $draft = null) {
|
|
$this->draft = $draft;
|
|
return $this;
|
|
}
|
|
|
|
public function setReviewers(array $names) {
|
|
$this->reviewers = $names;
|
|
return $this;
|
|
}
|
|
|
|
public function setCCs(array $names) {
|
|
$this->ccs = $names;
|
|
return $this;
|
|
}
|
|
|
|
public function render() {
|
|
|
|
$this->requireResource('differential-revision-add-comment-css');
|
|
|
|
$is_serious = PhabricatorEnv::getEnvConfig('phabricator.serious-business');
|
|
|
|
$revision = $this->revision;
|
|
|
|
$action = null;
|
|
if ($this->draft) {
|
|
$action = idx($this->draft->getMetadata(), 'action');
|
|
}
|
|
|
|
$enable_reviewers = DifferentialAction::allowReviewers($action);
|
|
$enable_ccs = ($action == DifferentialAction::ACTION_ADDCCS);
|
|
$add_reviewers_labels = array(
|
|
'add_reviewers' => pht('Add Reviewers'),
|
|
'request_review' => pht('Add Reviewers'),
|
|
'resign' => pht('Suggest Reviewers'),
|
|
);
|
|
|
|
$form = new AphrontFormView();
|
|
$form
|
|
->setWorkflow(true)
|
|
->setUser($this->user)
|
|
->setAction($this->actionURI)
|
|
->addHiddenInput('revision_id', $revision->getID())
|
|
->appendChild(
|
|
id(new AphrontFormSelectControl())
|
|
->setLabel(pht('Action'))
|
|
->setName('action')
|
|
->setValue($action)
|
|
->setID('comment-action')
|
|
->setOptions($this->actions))
|
|
->appendChild(
|
|
id(new AphrontFormTokenizerControl())
|
|
->setLabel($enable_reviewers ? $add_reviewers_labels[$action] :
|
|
$add_reviewers_labels['add_reviewers'])
|
|
->setName('reviewers')
|
|
->setControlID('add-reviewers')
|
|
->setControlStyle($enable_reviewers ? null : 'display: none')
|
|
->setID('add-reviewers-tokenizer')
|
|
->setDisableBehavior(true))
|
|
->appendChild(
|
|
id(new AphrontFormTokenizerControl())
|
|
->setLabel(pht('Add CCs'))
|
|
->setName('ccs')
|
|
->setControlID('add-ccs')
|
|
->setControlStyle($enable_ccs ? null : 'display: none')
|
|
->setID('add-ccs-tokenizer')
|
|
->setDisableBehavior(true))
|
|
->appendChild(
|
|
id(new PhabricatorRemarkupControl())
|
|
->setName('comment')
|
|
->setID('comment-content')
|
|
->setLabel(pht('Comment'))
|
|
->setValue($this->draft ? $this->draft->getDraft() : null)
|
|
->setUser($this->user))
|
|
->appendChild(
|
|
id(new AphrontFormSubmitControl())
|
|
->setValue($is_serious ? pht('Submit') : pht('Clowncopterize')));
|
|
|
|
Javelin::initBehavior(
|
|
'differential-add-reviewers-and-ccs',
|
|
array(
|
|
'dynamic' => array(
|
|
'add-reviewers-tokenizer' => array(
|
|
'actions' => array(
|
|
'request_review' => 1,
|
|
'add_reviewers' => 1,
|
|
'resign' => 1,
|
|
),
|
|
'src' => '/typeahead/common/usersorprojects/',
|
|
'value' => $this->reviewers,
|
|
'row' => 'add-reviewers',
|
|
'labels' => $add_reviewers_labels,
|
|
'placeholder' => pht('Type a user or project name...'),
|
|
),
|
|
'add-ccs-tokenizer' => array(
|
|
'actions' => array('add_ccs' => 1),
|
|
'src' => '/typeahead/common/mailable/',
|
|
'value' => $this->ccs,
|
|
'row' => 'add-ccs',
|
|
'placeholder' => pht('Type a user or mailing list...'),
|
|
),
|
|
),
|
|
'select' => 'comment-action',
|
|
));
|
|
|
|
$diff = $revision->loadActiveDiff();
|
|
$warnings = array();
|
|
|
|
Javelin::initBehavior(
|
|
'differential-accept-with-errors',
|
|
array(
|
|
'select' => 'comment-action',
|
|
'warnings' => 'warnings',
|
|
));
|
|
|
|
$rev_id = $revision->getID();
|
|
|
|
Javelin::initBehavior(
|
|
'differential-feedback-preview',
|
|
array(
|
|
'uri' => '/differential/comment/preview/'.$rev_id.'/',
|
|
'preview' => 'comment-preview',
|
|
'action' => 'comment-action',
|
|
'content' => 'comment-content',
|
|
'previewTokenizers' => array(
|
|
'reviewers' => 'add-reviewers-tokenizer',
|
|
'ccs' => 'add-ccs-tokenizer',
|
|
),
|
|
|
|
'inlineuri' => '/differential/comment/inline/preview/'.$rev_id.'/',
|
|
'inline' => 'inline-comment-preview',
|
|
));
|
|
|
|
$warning_container = array();
|
|
foreach ($warnings as $warning) {
|
|
if ($warning) {
|
|
$warning_container[] = $warning->render();
|
|
}
|
|
}
|
|
|
|
$header = id(new PHUIHeaderView())
|
|
->setHeader($is_serious ? pht('Add Comment') : pht('Leap Into Action'));
|
|
|
|
$anchor = id(new PhabricatorAnchorView())
|
|
->setAnchorName('comment')
|
|
->setNavigationMarker(true);
|
|
|
|
$warn = phutil_tag('div', array('id' => 'warnings'), $warning_container);
|
|
|
|
$loading = phutil_tag(
|
|
'span',
|
|
array('class' => 'aphront-panel-preview-loading-text'),
|
|
pht('Loading comment preview...'));
|
|
|
|
$preview = phutil_tag_div(
|
|
'aphront-panel-preview aphront-panel-flush',
|
|
array(
|
|
phutil_tag('div', array('id' => 'comment-preview'), $loading),
|
|
phutil_tag('div', array('id' => 'inline-comment-preview')),
|
|
));
|
|
|
|
|
|
$comment_box = id(new PHUIObjectBoxView())
|
|
->setHeader($header)
|
|
->appendChild($anchor)
|
|
->appendChild($warn)
|
|
->appendChild($form);
|
|
|
|
return array($comment_box, $preview);
|
|
}
|
|
}
|