2011-01-31 18:05:20 -08:00
|
|
|
<?php
|
|
|
|
|
2012-03-09 15:46:25 -08:00
|
|
|
final class DifferentialCommentPreviewController
|
|
|
|
extends DifferentialController {
|
2011-01-31 18:05:20 -08:00
|
|
|
|
|
|
|
private $id;
|
|
|
|
|
|
|
|
public function willProcessRequest(array $data) {
|
|
|
|
$this->id = $data['id'];
|
|
|
|
}
|
|
|
|
|
|
|
|
public function processRequest() {
|
|
|
|
|
|
|
|
$request = $this->getRequest();
|
|
|
|
|
|
|
|
$author_phid = $request->getUser()->getPHID();
|
|
|
|
|
2011-12-22 17:59:00 -08:00
|
|
|
$action = $request->getStr('action');
|
2011-01-31 18:05:20 -08:00
|
|
|
|
|
|
|
|
|
|
|
$comment = new DifferentialComment();
|
|
|
|
$comment->setContent($request->getStr('content'));
|
2011-12-22 17:59:00 -08:00
|
|
|
$comment->setAction($action);
|
2011-01-31 18:05:20 -08:00
|
|
|
$comment->setAuthorPHID($author_phid);
|
|
|
|
|
2011-12-22 17:59:00 -08:00
|
|
|
$handles = array($author_phid);
|
|
|
|
|
2012-09-20 14:11:11 -07:00
|
|
|
$reviewers = $request->getStrList('reviewers');
|
|
|
|
if (DifferentialAction::allowReviewers($action) && $reviewers) {
|
2011-12-22 17:59:00 -08:00
|
|
|
$comment->setMetadata(array(
|
|
|
|
DifferentialComment::METADATA_ADDED_REVIEWERS => $reviewers));
|
|
|
|
$handles = array_merge($handles, $reviewers);
|
|
|
|
}
|
|
|
|
|
2012-09-20 14:11:11 -07:00
|
|
|
$ccs = $request->getStrList('ccs');
|
2011-12-22 17:59:00 -08:00
|
|
|
if ($action == DifferentialAction::ACTION_ADDCCS && $ccs) {
|
|
|
|
$comment->setMetadata(array(
|
|
|
|
DifferentialComment::METADATA_ADDED_CCS => $ccs));
|
|
|
|
$handles = array_merge($handles, $ccs);
|
|
|
|
}
|
|
|
|
|
2012-09-04 19:02:56 -07:00
|
|
|
$handles = $this->loadViewerHandles($handles);
|
2011-12-22 17:59:00 -08:00
|
|
|
|
2012-10-23 17:33:58 -07:00
|
|
|
$engine = new PhabricatorMarkupEngine();
|
|
|
|
$engine->setViewer($request->getUser());
|
|
|
|
$engine->addObject($comment, DifferentialComment::MARKUP_FIELD_BODY);
|
|
|
|
$engine->process();
|
|
|
|
|
2011-01-31 18:05:20 -08:00
|
|
|
$view = new DifferentialRevisionCommentView();
|
Use phabricator_ time functions in more places
Summary:
Replace some more date() calls with locale-aware calls.
Also, at least on my system, the DateTimeZone / DateTime stuff didn't actually
work and always rendered in UTC. Fixed that.
Test Plan:
Viewed daemon console, differential revisions, files, and maniphest timestamps
in multiple timezones.
Reviewed By: toulouse
Reviewers: toulouse, fratrik, jungejason, aran, tuomaspelkonen
CC: aran, toulouse
Differential Revision: 530
2011-06-26 09:22:52 -07:00
|
|
|
$view->setUser($request->getUser());
|
2011-01-31 18:05:20 -08:00
|
|
|
$view->setComment($comment);
|
|
|
|
$view->setHandles($handles);
|
|
|
|
$view->setMarkupEngine($engine);
|
|
|
|
$view->setPreview(true);
|
2011-04-14 17:22:57 -07:00
|
|
|
$view->setTargetDiff(null);
|
2011-01-31 18:05:20 -08:00
|
|
|
|
2012-10-01 15:50:47 -07:00
|
|
|
$metadata = array(
|
|
|
|
'reviewers' => $reviewers,
|
|
|
|
'ccs' => $ccs,
|
|
|
|
);
|
|
|
|
if ($action != DifferentialAction::ACTION_COMMENT) {
|
|
|
|
$metadata['action'] = $action;
|
|
|
|
}
|
|
|
|
|
|
|
|
id(new PhabricatorDraft())
|
2011-02-05 16:57:21 -08:00
|
|
|
->setAuthorPHID($author_phid)
|
|
|
|
->setDraftKey('differential-comment-'.$this->id)
|
|
|
|
->setDraft($comment->getContent())
|
2012-10-01 15:50:47 -07:00
|
|
|
->setMetadata($metadata)
|
|
|
|
->replaceOrDelete();
|
2011-02-05 16:57:21 -08:00
|
|
|
|
2011-01-31 18:05:20 -08:00
|
|
|
return id(new AphrontAjaxResponse())
|
|
|
|
->setContent($view->render());
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|