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();
|
|
|
|
|
|
|
|
$question = PonderQuestionQuery::loadSingle($user, $this->questionID);
|
|
|
|
if (!$question) {
|
|
|
|
return new Aphront404Response();
|
|
|
|
}
|
2012-10-07 23:35:01 +02:00
|
|
|
$question->attachRelated();
|
|
|
|
$question->attachVotes($user->getPHID());
|
adding comments to ponder
Summary: This is pretty spartan, but it does the job.
Test Plan:
Patch, update storage, add some comment
to your favorite question or answer.
Reviewers: nh, vrana, epriestley
Reviewed By: epriestley
CC: aran, Korvin, starruler, syrneus, me.here, victorzarate7
Maniphest Tasks: T1645
Differential Revision: https://secure.phabricator.com/D3471
2012-09-11 21:13:20 +02:00
|
|
|
$object_phids = array($user->getPHID(), $question->getAuthorPHID());
|
|
|
|
|
2012-08-10 19:44:04 +02:00
|
|
|
$answers = $question->getAnswers();
|
adding comments to ponder
Summary: This is pretty spartan, but it does the job.
Test Plan:
Patch, update storage, add some comment
to your favorite question or answer.
Reviewers: nh, vrana, epriestley
Reviewed By: epriestley
CC: aran, Korvin, starruler, syrneus, me.here, victorzarate7
Maniphest Tasks: T1645
Differential Revision: https://secure.phabricator.com/D3471
2012-09-11 21:13:20 +02:00
|
|
|
$comments = $question->getComments();
|
|
|
|
foreach ($comments as $comment) {
|
|
|
|
$object_phids[] = $comment->getAuthorPHID();
|
|
|
|
}
|
2012-08-10 19:44:04 +02:00
|
|
|
|
|
|
|
foreach ($answers as $answer) {
|
|
|
|
$object_phids[] = $answer->getAuthorPHID();
|
adding comments to ponder
Summary: This is pretty spartan, but it does the job.
Test Plan:
Patch, update storage, add some comment
to your favorite question or answer.
Reviewers: nh, vrana, epriestley
Reviewed By: epriestley
CC: aran, Korvin, starruler, syrneus, me.here, victorzarate7
Maniphest Tasks: T1645
Differential Revision: https://secure.phabricator.com/D3471
2012-09-11 21:13:20 +02:00
|
|
|
|
|
|
|
$comments = $answer->getComments();
|
|
|
|
foreach ($comments as $comment) {
|
|
|
|
$object_phids[] = $comment->getAuthorPHID();
|
|
|
|
}
|
2012-08-10 19:44:04 +02:00
|
|
|
}
|
|
|
|
|
2013-07-18 21:40:51 +02:00
|
|
|
$object_phids = array_merge($object_phids);
|
2012-10-08 23:47:21 +02:00
|
|
|
|
2012-10-05 22:12:31 +02:00
|
|
|
$this->loadHandles($object_phids);
|
2012-11-07 00:35:26 +01:00
|
|
|
$handles = $this->getLoadedHandles();
|
2012-08-10 19:44:04 +02:00
|
|
|
|
2013-07-29 00:02:18 +02:00
|
|
|
$question_xactions = $this->buildQuestionTransactions($question);
|
2012-08-10 19:44:04 +02:00
|
|
|
|
|
|
|
$responses_panel = new PonderAnswerListView();
|
|
|
|
$responses_panel
|
|
|
|
->setQuestion($question)
|
|
|
|
->setHandles($handles)
|
|
|
|
->setUser($user)
|
|
|
|
->setAnswers($answers);
|
|
|
|
|
|
|
|
$answer_add_panel = new PonderAddAnswerView();
|
|
|
|
$answer_add_panel
|
|
|
|
->setQuestion($question)
|
|
|
|
->setUser($user)
|
|
|
|
->setActionURI("/ponder/answer/add/");
|
|
|
|
|
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,
|
2012-08-10 19:44:04 +02:00
|
|
|
$responses_panel,
|
|
|
|
$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;
|
|
|
|
}
|
|
|
|
|
2012-08-10 19:44:04 +02:00
|
|
|
}
|