mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-23 13:08:18 +01:00
a29b5b070f
Test Plan: Looked at a diff with inline comment. Reviewers: epriestley Reviewed By: epriestley CC: Korvin, epriestley, aran Differential Revision: https://secure.phabricator.com/D7549
209 lines
5.4 KiB
PHP
209 lines
5.4 KiB
PHP
<?php
|
|
|
|
final class DiffusionCommentView extends AphrontView {
|
|
|
|
private $comment;
|
|
private $commentNumber;
|
|
private $handles;
|
|
private $isPreview;
|
|
private $pathMap;
|
|
|
|
private $inlineComments;
|
|
private $markupEngine;
|
|
|
|
public function setComment(PhabricatorAuditComment $comment) {
|
|
$this->comment = $comment;
|
|
return $this;
|
|
}
|
|
|
|
public function setCommentNumber($comment_number) {
|
|
$this->commentNumber = $comment_number;
|
|
return $this;
|
|
}
|
|
|
|
public function setHandles(array $handles) {
|
|
assert_instances_of($handles, 'PhabricatorObjectHandle');
|
|
$this->handles = $handles;
|
|
return $this;
|
|
}
|
|
|
|
public function setIsPreview($is_preview) {
|
|
$this->isPreview = $is_preview;
|
|
return $this;
|
|
}
|
|
|
|
public function setInlineComments(array $inline_comments) {
|
|
assert_instances_of($inline_comments, 'PhabricatorInlineCommentInterface');
|
|
$this->inlineComments = $inline_comments;
|
|
return $this;
|
|
}
|
|
|
|
public function setPathMap(array $path_map) {
|
|
$this->pathMap = $path_map;
|
|
return $this;
|
|
}
|
|
|
|
public function setMarkupEngine(PhabricatorMarkupEngine $markup_engine) {
|
|
$this->markupEngine = $markup_engine;
|
|
return $this;
|
|
}
|
|
|
|
public function getMarkupEngine() {
|
|
return $this->markupEngine;
|
|
}
|
|
|
|
public function getRequiredHandlePHIDs() {
|
|
return array($this->comment->getActorPHID());
|
|
}
|
|
|
|
private function getHandle($phid) {
|
|
if (empty($this->handles[$phid])) {
|
|
throw new Exception("Unloaded handle '{$phid}'!");
|
|
}
|
|
return $this->handles[$phid];
|
|
}
|
|
|
|
public function render() {
|
|
$comment = $this->comment;
|
|
$author = $this->getHandle($comment->getActorPHID());
|
|
$author_link = $author->renderLink();
|
|
|
|
$actions = $this->renderActions();
|
|
$content = $this->renderContent();
|
|
$classes = $this->renderClasses();
|
|
|
|
$xaction_view = id(new PhabricatorTransactionView())
|
|
->setUser($this->user)
|
|
->setImageURI($author->getImageURI())
|
|
->setActions($actions)
|
|
->appendChild($content);
|
|
|
|
if ($this->isPreview) {
|
|
$xaction_view->setIsPreview(true);
|
|
} else {
|
|
$xaction_view
|
|
->setAnchor('comment-'.$this->commentNumber, '#'.$this->commentNumber)
|
|
->setEpoch($comment->getDateCreated());
|
|
}
|
|
|
|
foreach ($classes as $class) {
|
|
$xaction_view->addClass($class);
|
|
}
|
|
|
|
return $xaction_view->render();
|
|
}
|
|
|
|
private function renderActions() {
|
|
$comment = $this->comment;
|
|
$author = $this->getHandle($comment->getActorPHID());
|
|
$author_link = $author->renderLink();
|
|
|
|
$action = $comment->getAction();
|
|
$verb = PhabricatorAuditActionConstants::getActionPastTenseVerb($action);
|
|
|
|
$metadata = $comment->getMetadata();
|
|
$added_auditors = idx(
|
|
$metadata,
|
|
PhabricatorAuditComment::METADATA_ADDED_AUDITORS,
|
|
array());
|
|
$added_ccs = idx(
|
|
$metadata,
|
|
PhabricatorAuditComment::METADATA_ADDED_CCS,
|
|
array());
|
|
|
|
$actions = array();
|
|
if ($action == PhabricatorAuditActionConstants::ADD_CCS) {
|
|
$rendered_ccs = $this->renderHandleList($added_ccs);
|
|
$actions[] = pht("%s added CCs: %s.", $author_link, $rendered_ccs);
|
|
} else if ($action == PhabricatorAuditActionConstants::ADD_AUDITORS) {
|
|
$rendered_auditors = $this->renderHandleList($added_auditors);
|
|
$actions[] = pht(
|
|
"%s added auditors: %s.",
|
|
$author_link,
|
|
$rendered_auditors);
|
|
} else {
|
|
$actions[] = hsprintf("%s %s this commit.", $author_link, $verb);
|
|
}
|
|
|
|
foreach ($actions as $key => $action) {
|
|
$actions[$key] = phutil_tag('div', array(), $action);
|
|
}
|
|
|
|
return $actions;
|
|
}
|
|
|
|
private function renderContent() {
|
|
$comment = $this->comment;
|
|
$engine = $this->getMarkupEngine();
|
|
|
|
if (!strlen($comment->getContent()) && empty($this->inlineComments)) {
|
|
return null;
|
|
} else {
|
|
return phutil_tag_div('phabricator-remarkup', array(
|
|
$engine->getOutput(
|
|
$comment,
|
|
PhabricatorAuditComment::MARKUP_FIELD_BODY),
|
|
$this->renderInlines(),
|
|
));
|
|
}
|
|
}
|
|
|
|
private function renderInlines() {
|
|
if (!$this->inlineComments) {
|
|
return null;
|
|
}
|
|
|
|
$engine = $this->getMarkupEngine();
|
|
|
|
$inlines_by_path = mgroup($this->inlineComments, 'getPathID');
|
|
|
|
$view = new PhabricatorInlineSummaryView();
|
|
foreach ($inlines_by_path as $path_id => $inlines) {
|
|
$path = idx($this->pathMap, $path_id);
|
|
if ($path === null) {
|
|
continue;
|
|
}
|
|
|
|
$items = array();
|
|
foreach ($inlines as $inline) {
|
|
$items[] = array(
|
|
'id' => $inline->getID(),
|
|
'line' => $inline->getLineNumber(),
|
|
'length' => $inline->getLineLength(),
|
|
'content' => $engine->getOutput(
|
|
$inline,
|
|
PhabricatorInlineCommentInterface::MARKUP_FIELD_BODY),
|
|
);
|
|
}
|
|
|
|
$view->addCommentGroup($path, $items);
|
|
}
|
|
|
|
return $view;
|
|
}
|
|
|
|
private function renderHandleList(array $phids) {
|
|
$result = array();
|
|
foreach ($phids as $phid) {
|
|
$result[] = $this->handles[$phid]->renderLink();
|
|
}
|
|
return phutil_implode_html(', ', $result);
|
|
}
|
|
|
|
private function renderClasses() {
|
|
$comment = $this->comment;
|
|
|
|
$classes = array();
|
|
switch ($comment->getAction()) {
|
|
case PhabricatorAuditActionConstants::ACCEPT:
|
|
$classes[] = 'audit-accept';
|
|
break;
|
|
case PhabricatorAuditActionConstants::CONCERN:
|
|
$classes[] = 'audit-concern';
|
|
break;
|
|
}
|
|
|
|
return $classes;
|
|
}
|
|
|
|
}
|