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 04:28:00 +02:00
|
|
|
->needViewerVotes(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()])) {
|
2013-07-29 03:47:43 +02:00
|
|
|
$answer_add_panel = id(new AphrontErrorView())
|
|
|
|
->setSeverity(AphrontErrorView::SEVERITY_NODATA)
|
|
|
|
->appendChild(
|
|
|
|
pht(
|
|
|
|
'You have already answered this question. You can not answer '.
|
|
|
|
'twice, but you can edit your existing answer.'));
|
2013-07-29 01:30:30 +02:00
|
|
|
} 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
|
|
|
|
2013-09-17 18:12:37 +02:00
|
|
|
$header = id(new PHUIHeaderView())
|
2012-10-05 22:12:31 +02:00
|
|
|
->setHeader($question->getTitle());
|
|
|
|
|
|
|
|
$actions = $this->buildActionListView($question);
|
2013-10-11 16:53:56 +02:00
|
|
|
$properties = $this->buildPropertyListView($question, $actions);
|
2012-10-05 22:12:31 +02:00
|
|
|
|
2013-09-29 00:55:38 +02:00
|
|
|
$object_box = id(new PHUIObjectBoxView())
|
|
|
|
->setHeader($header)
|
2013-10-11 16:53:56 +02:00
|
|
|
->addPropertyList($properties);
|
2013-09-29 00:55:38 +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,
|
2013-09-29 00:55:38 +02:00
|
|
|
$object_box,
|
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(),
|
2013-08-12 17:20:10 +02:00
|
|
|
'pageObjects' => array($question->getPHID()),
|
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}/")));
|
|
|
|
|
2013-07-29 03:32:55 +02:00
|
|
|
$view->addAction(
|
|
|
|
id(new PhabricatorActionView())
|
|
|
|
->setIcon('transcript')
|
|
|
|
->setName(pht('View History'))
|
|
|
|
->setHref($this->getApplicationURI("/question/history/{$id}/")));
|
|
|
|
|
2013-07-29 00:02:18 +02:00
|
|
|
return $view;
|
2012-10-05 22:12:31 +02:00
|
|
|
}
|
|
|
|
|
2012-10-08 23:47:21 +02:00
|
|
|
private function buildPropertyListView(
|
2013-10-11 16:53:56 +02:00
|
|
|
PonderQuestion $question,
|
|
|
|
PhabricatorActionListView $actions) {
|
2012-10-08 23:47:21 +02:00
|
|
|
|
2012-10-05 22:12:31 +02:00
|
|
|
$viewer = $this->getRequest()->getUser();
|
2013-10-11 16:53:56 +02:00
|
|
|
$view = id(new PHUIPropertyListView())
|
2013-05-09 23:40:43 +02:00
|
|
|
->setUser($viewer)
|
2013-10-11 16:53:56 +02:00
|
|
|
->setObject($question)
|
|
|
|
->setActionList($actions);
|
2013-07-28 03:37:17 +02:00
|
|
|
|
2013-07-29 01:55:13 +02:00
|
|
|
$this->loadHandles(array($question->getAuthorPHID()));
|
|
|
|
|
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();
|
|
|
|
|
2013-07-29 04:28:00 +02:00
|
|
|
$votable = id(new PonderVotableView())
|
|
|
|
->setPHID($question->getPHID())
|
|
|
|
->setURI($this->getApplicationURI('vote/'))
|
|
|
|
->setCount($question->getVoteCount())
|
|
|
|
->setVote($question->getUserVote());
|
|
|
|
|
2013-10-30 16:10:05 +01:00
|
|
|
$view->addSectionHeader(pht('Question'));
|
2013-07-29 00:02:18 +02:00
|
|
|
$view->addTextContent(
|
2013-07-29 04:28:00 +02:00
|
|
|
array(
|
|
|
|
$votable,
|
2013-07-31 00:50:27 +02:00
|
|
|
phutil_tag(
|
|
|
|
'div',
|
|
|
|
array(
|
|
|
|
'class' => 'phabricator-remarkup',
|
|
|
|
),
|
|
|
|
PhabricatorMarkupEngine::renderOneObject(
|
|
|
|
$question,
|
|
|
|
$question->getMarkupField(),
|
|
|
|
$viewer)),
|
2013-07-29 04:28:00 +02:00
|
|
|
));
|
2013-07-29 00:02:18 +02:00
|
|
|
|
|
|
|
|
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();
|
2013-07-29 02:58:34 +02:00
|
|
|
$id = $question->getID();
|
2013-07-29 00:02:18 +02:00
|
|
|
|
|
|
|
$xactions = id(new PonderQuestionTransactionQuery())
|
|
|
|
->setViewer($viewer)
|
2013-07-29 03:32:55 +02:00
|
|
|
->withTransactionTypes(array(PhabricatorTransactions::TYPE_COMMENT))
|
2013-07-29 00:02:18 +02:00
|
|
|
->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)
|
2013-07-29 03:21:22 +02:00
|
|
|
->setObjectPHID($question->getPHID())
|
2013-07-29 00:02:18 +02:00
|
|
|
->setTransactions($xactions)
|
|
|
|
->setMarkupEngine($engine);
|
|
|
|
|
2013-07-29 02:58:34 +02:00
|
|
|
$add_comment = id(new PhabricatorApplicationTransactionCommentView())
|
|
|
|
->setUser($viewer)
|
2013-07-29 03:21:22 +02:00
|
|
|
->setObjectPHID($question->getPHID())
|
2013-07-29 02:58:34 +02:00
|
|
|
->setShowPreview(false)
|
|
|
|
->setAction($this->getApplicationURI("/question/comment/{$id}/"))
|
|
|
|
->setSubmitButtonName(pht('Comment'));
|
|
|
|
|
2013-09-29 00:55:38 +02:00
|
|
|
$object_box = id(new PHUIObjectBoxView())
|
|
|
|
->setFlush(true)
|
|
|
|
->setHeaderText(pht('Question Comment'))
|
Provide more structure to PHUIObjectBoxView
Summary:
Three changes here.
- Add `setActionList()`, and use that to set the action list.
- Add `setPropertyList()`, and use that to set the property list.
These will let us add some apropriate CSS so we can fix the border issue, and get rid of a bunch of goofy `.x + .y` selectors.
- Replace `addContent()` with `appendChild()`.
This is just a consistency thing; `AphrontView` already provides `appendChild()`, and `addContent()` did the same thing.
Test Plan:
- Viewed "All Config".
- Viewed a countdown.
- Viewed a revision (add comment, change list, table of contents, comment, local commits, open revisions affecting these files, update history).
- Viewed Diffusion (browse, change, history, repository, lint).
- Viewed Drydock (resource, lease).
- Viewed Files.
- Viewed Herald.
- Viewed Legalpad.
- Viewed macro (edit, edit audio, view).
- Viewed Maniphest.
- Viewed Applications.
- Viewed Paste.
- Viewed People.
- Viewed Phulux.
- Viewed Pholio.
- Viewed Phame (blog, post).
- Viewed Phortune (account, product).
- Viewed Ponder (questions, answers, comments).
- Viewed Releeph.
- Viewed Projects.
- Viewed Slowvote.
NOTE: Images in Files aren't on a black background anymore -- I assume that's on purpose?
NOTE: Some jankiness in Phortune, I'll clean that up when I get back to it. Not related to this diff.
Reviewers: chad
Reviewed By: chad
CC: aran
Differential Revision: https://secure.phabricator.com/D7174
2013-09-30 18:36:04 +02:00
|
|
|
->appendChild($add_comment);
|
2013-09-29 00:55:38 +02:00
|
|
|
|
2013-07-29 03:47:43 +02:00
|
|
|
return $this->wrapComments(
|
|
|
|
count($xactions),
|
|
|
|
array(
|
|
|
|
$timeline,
|
2013-09-29 00:55:38 +02:00
|
|
|
$object_box,
|
2013-07-29 03:47:43 +02:00
|
|
|
));
|
2013-07-29 00:02:18 +02:00
|
|
|
}
|
|
|
|
|
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)
|
2013-07-29 03:32:55 +02:00
|
|
|
->withTransactionTypes(array(PhabricatorTransactions::TYPE_COMMENT))
|
2013-07-29 01:17:51 +02:00
|
|
|
->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());
|
2013-07-29 02:40:11 +02:00
|
|
|
$id = $answer->getID();
|
2013-07-29 01:17:51 +02:00
|
|
|
|
|
|
|
$out[] = phutil_tag('br');
|
|
|
|
$out[] = phutil_tag('br');
|
2013-09-19 00:15:25 +02:00
|
|
|
$out[] = id(new PhabricatorAnchorView())
|
|
|
|
->setAnchorName("A$id");
|
2013-09-29 00:55:38 +02:00
|
|
|
$header = id(new PHUIHeaderView())
|
|
|
|
->setHeader($this->getHandle($author_phid)->getFullName());
|
|
|
|
|
|
|
|
$actions = $this->buildAnswerActions($answer);
|
2013-10-11 16:53:56 +02:00
|
|
|
$properties = $this->buildAnswerProperties($answer, $actions);
|
2013-07-29 01:17:51 +02:00
|
|
|
|
2013-09-29 00:55:38 +02:00
|
|
|
$object_box = id(new PHUIObjectBoxView())
|
|
|
|
->setHeader($header)
|
2013-10-11 16:53:56 +02:00
|
|
|
->addPropertyList($properties);
|
2013-07-29 02:40:11 +02:00
|
|
|
|
2013-09-29 00:55:38 +02:00
|
|
|
$out[] = $object_box;
|
2013-07-29 03:47:43 +02:00
|
|
|
$details = array();
|
|
|
|
|
|
|
|
$details[] = id(new PhabricatorApplicationTransactionView())
|
2013-07-29 01:17:51 +02:00
|
|
|
->setUser($viewer)
|
2013-07-29 03:21:22 +02:00
|
|
|
->setObjectPHID($answer->getPHID())
|
2013-07-29 01:17:51 +02:00
|
|
|
->setTransactions($xactions)
|
|
|
|
->setMarkupEngine($engine);
|
|
|
|
|
2013-09-29 00:55:38 +02:00
|
|
|
$form = id(new PhabricatorApplicationTransactionCommentView())
|
2013-07-29 02:40:11 +02:00
|
|
|
->setUser($viewer)
|
2013-07-29 03:21:22 +02:00
|
|
|
->setObjectPHID($answer->getPHID())
|
2013-07-29 02:40:11 +02:00
|
|
|
->setShowPreview(false)
|
|
|
|
->setAction($this->getApplicationURI("/answer/comment/{$id}/"))
|
|
|
|
->setSubmitButtonName(pht('Comment'));
|
2013-07-29 03:47:43 +02:00
|
|
|
|
2013-09-29 00:55:38 +02:00
|
|
|
$comment_box = id(new PHUIObjectBoxView())
|
|
|
|
->setFlush(true)
|
|
|
|
->setHeaderText(pht('Answer Comment'))
|
Provide more structure to PHUIObjectBoxView
Summary:
Three changes here.
- Add `setActionList()`, and use that to set the action list.
- Add `setPropertyList()`, and use that to set the property list.
These will let us add some apropriate CSS so we can fix the border issue, and get rid of a bunch of goofy `.x + .y` selectors.
- Replace `addContent()` with `appendChild()`.
This is just a consistency thing; `AphrontView` already provides `appendChild()`, and `addContent()` did the same thing.
Test Plan:
- Viewed "All Config".
- Viewed a countdown.
- Viewed a revision (add comment, change list, table of contents, comment, local commits, open revisions affecting these files, update history).
- Viewed Diffusion (browse, change, history, repository, lint).
- Viewed Drydock (resource, lease).
- Viewed Files.
- Viewed Herald.
- Viewed Legalpad.
- Viewed macro (edit, edit audio, view).
- Viewed Maniphest.
- Viewed Applications.
- Viewed Paste.
- Viewed People.
- Viewed Phulux.
- Viewed Pholio.
- Viewed Phame (blog, post).
- Viewed Phortune (account, product).
- Viewed Ponder (questions, answers, comments).
- Viewed Releeph.
- Viewed Projects.
- Viewed Slowvote.
NOTE: Images in Files aren't on a black background anymore -- I assume that's on purpose?
NOTE: Some jankiness in Phortune, I'll clean that up when I get back to it. Not related to this diff.
Reviewers: chad
Reviewed By: chad
CC: aran
Differential Revision: https://secure.phabricator.com/D7174
2013-09-30 18:36:04 +02:00
|
|
|
->appendChild($form);
|
2013-09-29 00:55:38 +02:00
|
|
|
|
|
|
|
$details[] = $comment_box;
|
|
|
|
|
2013-07-29 03:47:43 +02:00
|
|
|
$out[] = $this->wrapComments(
|
|
|
|
count($xactions),
|
|
|
|
$details);
|
2013-07-29 01:17:51 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
$out[] = phutil_tag('br');
|
|
|
|
$out[] = phutil_tag('br');
|
|
|
|
|
|
|
|
return $out;
|
|
|
|
}
|
|
|
|
|
|
|
|
private function buildAnswerActions(PonderAnswer $answer) {
|
|
|
|
$request = $this->getRequest();
|
|
|
|
$viewer = $request->getUser();
|
|
|
|
|
2013-07-29 02:23:04 +02:00
|
|
|
$id = $answer->getID();
|
|
|
|
|
2013-07-29 01:17:51 +02:00
|
|
|
$can_edit = PhabricatorPolicyFilter::hasCapability(
|
|
|
|
$viewer,
|
|
|
|
$answer,
|
|
|
|
PhabricatorPolicyCapability::CAN_EDIT);
|
|
|
|
|
|
|
|
$view = id(new PhabricatorActionListView())
|
|
|
|
->setUser($request->getUser())
|
|
|
|
->setObject($answer)
|
|
|
|
->setObjectURI($request->getRequestURI());
|
|
|
|
|
|
|
|
$view->addAction(
|
|
|
|
id(new PhabricatorActionView())
|
|
|
|
->setIcon('edit')
|
|
|
|
->setName(pht('Edit Answer'))
|
|
|
|
->setHref($this->getApplicationURI("/answer/edit/{$id}/"))
|
|
|
|
->setDisabled(!$can_edit)
|
|
|
|
->setWorkflow(!$can_edit));
|
|
|
|
|
2013-07-29 03:32:55 +02:00
|
|
|
$view->addAction(
|
|
|
|
id(new PhabricatorActionView())
|
|
|
|
->setIcon('transcript')
|
|
|
|
->setName(pht('View History'))
|
|
|
|
->setHref($this->getApplicationURI("/answer/history/{$id}/")));
|
|
|
|
|
2013-07-29 01:17:51 +02:00
|
|
|
return $view;
|
|
|
|
}
|
|
|
|
|
2013-10-11 16:53:56 +02:00
|
|
|
private function buildAnswerProperties(
|
|
|
|
PonderAnswer $answer,
|
|
|
|
PhabricatorActionListView $actions) {
|
|
|
|
|
2013-07-29 01:17:51 +02:00
|
|
|
$viewer = $this->getRequest()->getUser();
|
2013-10-11 16:53:56 +02:00
|
|
|
$view = id(new PHUIPropertyListView())
|
2013-07-29 01:17:51 +02:00
|
|
|
->setUser($viewer)
|
2013-10-11 16:53:56 +02:00
|
|
|
->setObject($answer)
|
|
|
|
->setActionList($actions);
|
2013-07-29 01:17:51 +02:00
|
|
|
|
|
|
|
$view->addProperty(
|
|
|
|
pht('Created'),
|
|
|
|
phabricator_datetime($answer->getDateCreated(), $viewer));
|
|
|
|
|
|
|
|
$view->invokeWillRenderEvent();
|
|
|
|
|
2013-07-29 04:28:00 +02:00
|
|
|
$votable = id(new PonderVotableView())
|
|
|
|
->setPHID($answer->getPHID())
|
|
|
|
->setURI($this->getApplicationURI('vote/'))
|
|
|
|
->setCount($answer->getVoteCount())
|
|
|
|
->setVote($answer->getUserVote());
|
|
|
|
|
2013-10-30 16:10:05 +01:00
|
|
|
$view->addSectionHeader(pht('Answer'));
|
2013-07-29 01:17:51 +02:00
|
|
|
$view->addTextContent(
|
2013-07-29 04:28:00 +02:00
|
|
|
array(
|
|
|
|
$votable,
|
|
|
|
phutil_tag(
|
|
|
|
'div',
|
|
|
|
array(
|
|
|
|
'class' => 'phabricator-remarkup',
|
|
|
|
),
|
|
|
|
PhabricatorMarkupEngine::renderOneObject(
|
|
|
|
$answer,
|
|
|
|
$answer->getMarkupField(),
|
|
|
|
$viewer)),
|
|
|
|
));
|
2013-07-29 01:17:51 +02:00
|
|
|
|
|
|
|
return $view;
|
|
|
|
}
|
|
|
|
|
2013-07-29 03:47:43 +02:00
|
|
|
private function wrapComments($n, $stuff) {
|
|
|
|
if ($n == 0) {
|
|
|
|
$text = pht('Add a Comment');
|
|
|
|
} else {
|
|
|
|
$text = pht('Show %s Comments', new PhutilNumber($n));
|
|
|
|
}
|
|
|
|
|
|
|
|
$show_id = celerity_generate_unique_node_id();
|
|
|
|
$hide_id = celerity_generate_unique_node_id();
|
|
|
|
|
|
|
|
Javelin::initBehavior('phabricator-reveal-content');
|
|
|
|
require_celerity_resource('ponder-comment-table-css');
|
|
|
|
|
|
|
|
$show = phutil_tag(
|
|
|
|
'div',
|
|
|
|
array(
|
|
|
|
'id' => $show_id,
|
|
|
|
'class' => 'ponder-show-comments',
|
|
|
|
),
|
|
|
|
javelin_tag(
|
|
|
|
'a',
|
|
|
|
array(
|
|
|
|
'href' => '#',
|
|
|
|
'sigil' => 'reveal-content',
|
|
|
|
'meta' => array(
|
|
|
|
'showIDs' => array($hide_id),
|
|
|
|
'hideIDs' => array($show_id),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
$text));
|
|
|
|
|
|
|
|
$hide = phutil_tag(
|
|
|
|
'div',
|
|
|
|
array(
|
|
|
|
'id' => $hide_id,
|
|
|
|
'style' => 'display: none',
|
|
|
|
),
|
|
|
|
$stuff);
|
|
|
|
|
|
|
|
return array($show, $hide);
|
|
|
|
}
|
|
|
|
|
2012-08-10 19:44:04 +02:00
|
|
|
}
|