2012-08-10 19:44:04 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
final class PonderQuestionViewController extends PonderController {
|
|
|
|
|
|
|
|
private $questionID;
|
|
|
|
|
|
|
|
public function willProcessRequest(array $data) {
|
|
|
|
$this->questionID = $data['id'];
|
|
|
|
}
|
|
|
|
|
|
|
|
public function processRequest() {
|
|
|
|
|
|
|
|
$request = $this->getRequest();
|
|
|
|
$user = $request->getUser();
|
|
|
|
|
2013-07-29 00:38:47 +02:00
|
|
|
$question = id(new PonderQuestionQuery())
|
|
|
|
->setViewer($user)
|
|
|
|
->withIDs(array($this->questionID))
|
2013-07-29 01:17:51 +02:00
|
|
|
->needAnswers(true)
|
2013-07-29 00:38:47 +02:00
|
|
|
->executeOne();
|
2012-08-10 19:44:04 +02:00
|
|
|
if (!$question) {
|
|
|
|
return new Aphront404Response();
|
|
|
|
}
|
|
|
|
|
2013-07-29 01:17:51 +02:00
|
|
|
$question->attachVotes($user->getPHID());
|
2012-08-10 19:44:04 +02:00
|
|
|
|
2013-07-29 00:02:18 +02:00
|
|
|
$question_xactions = $this->buildQuestionTransactions($question);
|
2013-07-29 01:17:51 +02:00
|
|
|
$answers = $this->buildAnswers($question->getAnswers());
|
2012-08-10 19:44:04 +02:00
|
|
|
|
2013-07-29 01:30:30 +02:00
|
|
|
$authors = mpull($question->getAnswers(), null, 'getAuthorPHID');
|
|
|
|
if (isset($authors[$user->getPHID()])) {
|
|
|
|
// TODO: Make this pretty
|
|
|
|
$answer_add_panel = pht(
|
|
|
|
'You have already answered this question.');
|
|
|
|
} else {
|
|
|
|
$answer_add_panel = new PonderAddAnswerView();
|
|
|
|
$answer_add_panel
|
|
|
|
->setQuestion($question)
|
|
|
|
->setUser($user)
|
|
|
|
->setActionURI("/ponder/answer/add/");
|
|
|
|
}
|
2012-08-10 19:44:04 +02:00
|
|
|
|
2012-10-05 22:12:31 +02:00
|
|
|
$header = id(new PhabricatorHeaderView())
|
|
|
|
->setHeader($question->getTitle());
|
|
|
|
|
|
|
|
$actions = $this->buildActionListView($question);
|
2013-07-18 21:40:51 +02:00
|
|
|
$properties = $this->buildPropertyListView($question);
|
2012-10-05 22:12:31 +02:00
|
|
|
|
2013-04-10 22:08:36 +02:00
|
|
|
$crumbs = $this->buildApplicationCrumbs($this->buildSideNavView());
|
|
|
|
$crumbs->setActionList($actions);
|
|
|
|
$crumbs->addCrumb(
|
|
|
|
id(new PhabricatorCrumbView())
|
|
|
|
->setName('Q'.$this->questionID)
|
|
|
|
->setHref('/Q'.$this->questionID));
|
|
|
|
|
2013-07-18 21:40:51 +02:00
|
|
|
return $this->buildApplicationPage(
|
2012-08-10 19:44:04 +02:00
|
|
|
array(
|
2013-04-10 22:08:36 +02:00
|
|
|
$crumbs,
|
2012-10-05 22:12:31 +02:00
|
|
|
$header,
|
|
|
|
$actions,
|
|
|
|
$properties,
|
2013-07-29 00:02:18 +02:00
|
|
|
$question_xactions,
|
2013-07-29 01:17:51 +02:00
|
|
|
$answers,
|
2012-08-10 19:44:04 +02:00
|
|
|
$answer_add_panel
|
2013-07-18 21:40:51 +02:00
|
|
|
),
|
2012-08-10 19:44:04 +02:00
|
|
|
array(
|
2012-10-01 05:12:18 +02:00
|
|
|
'device' => true,
|
2013-05-20 16:55:23 +02:00
|
|
|
'title' => 'Q'.$question->getID().' '.$question->getTitle(),
|
|
|
|
'dust' => true,
|
2012-08-10 19:44:04 +02:00
|
|
|
));
|
|
|
|
}
|
2012-10-05 22:12:31 +02:00
|
|
|
|
|
|
|
private function buildActionListView(PonderQuestion $question) {
|
2013-07-12 20:39:47 +02:00
|
|
|
$request = $this->getRequest();
|
2013-07-29 00:02:18 +02:00
|
|
|
$viewer = $request->getUser();
|
2013-07-28 03:37:17 +02:00
|
|
|
|
2013-07-29 00:02:18 +02:00
|
|
|
$id = $question->getID();
|
|
|
|
|
|
|
|
$can_edit = PhabricatorPolicyFilter::hasCapability(
|
|
|
|
$viewer,
|
|
|
|
$question,
|
|
|
|
PhabricatorPolicyCapability::CAN_EDIT);
|
|
|
|
|
|
|
|
$view = id(new PhabricatorActionListView())
|
|
|
|
->setUser($request->getUser())
|
2013-07-12 20:39:47 +02:00
|
|
|
->setObject($question)
|
|
|
|
->setObjectURI($request->getRequestURI());
|
2013-07-28 03:37:17 +02:00
|
|
|
|
2013-07-29 00:02:18 +02:00
|
|
|
$view->addAction(
|
|
|
|
id(new PhabricatorActionView())
|
|
|
|
->setIcon('edit')
|
|
|
|
->setName(pht('Edit Question'))
|
|
|
|
->setHref($this->getApplicationURI("/question/edit/{$id}/"))
|
|
|
|
->setDisabled(!$can_edit)
|
|
|
|
->setWorkflow(!$can_edit));
|
|
|
|
|
|
|
|
if ($question->getStatus() == PonderQuestionStatus::STATUS_OPEN) {
|
|
|
|
$name = pht("Close Question");
|
|
|
|
$icon = "delete";
|
|
|
|
$href = "close";
|
|
|
|
} else {
|
|
|
|
$name = pht("Reopen Question");
|
|
|
|
$icon = "enable";
|
|
|
|
$href = "open";
|
2013-07-28 03:37:17 +02:00
|
|
|
}
|
|
|
|
|
2013-07-29 00:02:18 +02:00
|
|
|
$view->addAction(
|
|
|
|
id(new PhabricatorActionView())
|
|
|
|
->setName($name)
|
|
|
|
->setIcon($icon)
|
|
|
|
->setRenderAsForm($can_edit)
|
|
|
|
->setWorkflow(!$can_edit)
|
|
|
|
->setDisabled(!$can_edit)
|
|
|
|
->setHref($this->getApplicationURI("/question/{$href}/{$id}/")));
|
|
|
|
|
|
|
|
return $view;
|
2012-10-05 22:12:31 +02:00
|
|
|
}
|
|
|
|
|
2012-10-08 23:47:21 +02:00
|
|
|
private function buildPropertyListView(
|
2013-07-18 21:40:51 +02:00
|
|
|
PonderQuestion $question) {
|
2012-10-08 23:47:21 +02:00
|
|
|
|
2012-10-05 22:12:31 +02:00
|
|
|
$viewer = $this->getRequest()->getUser();
|
2013-05-09 23:40:43 +02:00
|
|
|
$view = id(new PhabricatorPropertyListView())
|
|
|
|
->setUser($viewer)
|
|
|
|
->setObject($question);
|
2013-07-28 03:37:17 +02:00
|
|
|
|
|
|
|
$view->addProperty(
|
|
|
|
pht('Status'),
|
|
|
|
PonderQuestionStatus::getQuestionStatusFullName($question->getStatus()));
|
|
|
|
|
2012-10-05 22:12:31 +02:00
|
|
|
$view->addProperty(
|
|
|
|
pht('Author'),
|
|
|
|
$this->getHandle($question->getAuthorPHID())->renderLink());
|
|
|
|
|
|
|
|
$view->addProperty(
|
|
|
|
pht('Created'),
|
|
|
|
phabricator_datetime($question->getDateCreated(), $viewer));
|
|
|
|
|
2013-07-29 00:02:18 +02:00
|
|
|
$view->invokeWillRenderEvent();
|
|
|
|
|
|
|
|
$view->addTextContent(
|
|
|
|
PhabricatorMarkupEngine::renderOneObject(
|
|
|
|
$question,
|
|
|
|
$question->getMarkupField(),
|
|
|
|
$viewer));
|
|
|
|
|
|
|
|
|
2012-10-05 22:12:31 +02:00
|
|
|
return $view;
|
|
|
|
}
|
2013-07-29 00:02:18 +02:00
|
|
|
|
|
|
|
private function buildQuestionTransactions(PonderQuestion $question) {
|
|
|
|
$viewer = $this->getRequest()->getUser();
|
|
|
|
|
|
|
|
$xactions = id(new PonderQuestionTransactionQuery())
|
|
|
|
->setViewer($viewer)
|
|
|
|
->withObjectPHIDs(array($question->getPHID()))
|
|
|
|
->execute();
|
|
|
|
|
|
|
|
$engine = id(new PhabricatorMarkupEngine())
|
|
|
|
->setViewer($viewer);
|
|
|
|
foreach ($xactions as $xaction) {
|
|
|
|
if ($xaction->getComment()) {
|
|
|
|
$engine->addObject(
|
|
|
|
$xaction->getComment(),
|
|
|
|
PhabricatorApplicationTransactionComment::MARKUP_FIELD_COMMENT);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
$engine->process();
|
|
|
|
|
|
|
|
$timeline = id(new PhabricatorApplicationTransactionView())
|
|
|
|
->setUser($viewer)
|
|
|
|
->setTransactions($xactions)
|
|
|
|
->setMarkupEngine($engine);
|
|
|
|
|
|
|
|
// TODO: Add comment form.
|
|
|
|
|
|
|
|
return $timeline;
|
|
|
|
}
|
|
|
|
|
2013-07-29 01:17:51 +02:00
|
|
|
private function buildAnswers(array $answers) {
|
|
|
|
$request = $this->getRequest();
|
|
|
|
$viewer = $request->getUser();
|
|
|
|
|
|
|
|
$out = array();
|
|
|
|
|
|
|
|
$phids = mpull($answers, 'getAuthorPHID');
|
|
|
|
$this->loadHandles($phids);
|
|
|
|
|
|
|
|
$xactions = id(new PonderAnswerTransactionQuery())
|
|
|
|
->setViewer($viewer)
|
|
|
|
->withObjectPHIDs(mpull($answers, 'getPHID'))
|
|
|
|
->execute();
|
|
|
|
|
|
|
|
$engine = id(new PhabricatorMarkupEngine())
|
|
|
|
->setViewer($viewer);
|
|
|
|
foreach ($xactions as $xaction) {
|
|
|
|
if ($xaction->getComment()) {
|
|
|
|
$engine->addObject(
|
|
|
|
$xaction->getComment(),
|
|
|
|
PhabricatorApplicationTransactionComment::MARKUP_FIELD_COMMENT);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
$engine->process();
|
|
|
|
|
|
|
|
$xaction_groups = mgroup($xactions, 'getObjectPHID');
|
|
|
|
|
|
|
|
foreach ($answers as $answer) {
|
|
|
|
$author_phid = $answer->getAuthorPHID();
|
|
|
|
$xactions = idx($xaction_groups, $answer->getPHID(), array());
|
|
|
|
|
|
|
|
$out[] = phutil_tag('br');
|
|
|
|
$out[] = phutil_tag('br');
|
|
|
|
$out[] = id(new PhabricatorHeaderView())
|
|
|
|
->setHeader($this->getHandle($author_phid)->getFullName())
|
|
|
|
->setImage($this->getHandle($author_phid)->getImageURI());
|
|
|
|
|
|
|
|
$out[] = $this->buildAnswerActions($answer);
|
|
|
|
$out[] = $this->buildAnswerProperties($answer);
|
|
|
|
$out[] = id(new PhabricatorApplicationTransactionView())
|
|
|
|
->setUser($viewer)
|
|
|
|
->setTransactions($xactions)
|
|
|
|
->setMarkupEngine($engine);
|
|
|
|
|
|
|
|
// TODO: Add comment form
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
$out[] = phutil_tag('br');
|
|
|
|
$out[] = phutil_tag('br');
|
|
|
|
|
|
|
|
return $out;
|
|
|
|
}
|
|
|
|
|
|
|
|
private function buildAnswerActions(PonderAnswer $answer) {
|
|
|
|
$request = $this->getRequest();
|
|
|
|
$viewer = $request->getUser();
|
|
|
|
|
|
|
|
$can_edit = PhabricatorPolicyFilter::hasCapability(
|
|
|
|
$viewer,
|
|
|
|
$answer,
|
|
|
|
PhabricatorPolicyCapability::CAN_EDIT);
|
|
|
|
|
|
|
|
$view = id(new PhabricatorActionListView())
|
|
|
|
->setUser($request->getUser())
|
|
|
|
->setObject($answer)
|
|
|
|
->setObjectURI($request->getRequestURI());
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
|
|
|
TODO
|
|
|
|
|
|
|
|
$view->addAction(
|
|
|
|
id(new PhabricatorActionView())
|
|
|
|
->setIcon('edit')
|
|
|
|
->setName(pht('Edit Answer'))
|
|
|
|
->setHref($this->getApplicationURI("/answer/edit/{$id}/"))
|
|
|
|
->setDisabled(!$can_edit)
|
|
|
|
->setWorkflow(!$can_edit));
|
|
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
return $view;
|
|
|
|
}
|
|
|
|
|
|
|
|
private function buildAnswerProperties(PonderAnswer $answer) {
|
|
|
|
$viewer = $this->getRequest()->getUser();
|
|
|
|
$view = id(new PhabricatorPropertyListView())
|
|
|
|
->setUser($viewer)
|
|
|
|
->setObject($answer);
|
|
|
|
|
|
|
|
$view->addProperty(
|
|
|
|
pht('Created'),
|
|
|
|
phabricator_datetime($answer->getDateCreated(), $viewer));
|
|
|
|
|
|
|
|
$view->invokeWillRenderEvent();
|
|
|
|
|
|
|
|
$view->addTextContent(
|
2013-07-29 01:30:30 +02:00
|
|
|
phutil_tag(
|
|
|
|
'div',
|
|
|
|
array(
|
|
|
|
'class' => 'phabricator-remarkup',
|
|
|
|
),
|
|
|
|
PhabricatorMarkupEngine::renderOneObject(
|
|
|
|
$answer,
|
|
|
|
$answer->getMarkupField(),
|
|
|
|
$viewer)));
|
2013-07-29 01:17:51 +02:00
|
|
|
|
|
|
|
return $view;
|
|
|
|
}
|
|
|
|
|
2012-08-10 19:44:04 +02:00
|
|
|
}
|