2012-08-10 10:44:04 -07: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-28 15:38:47 -07:00
|
|
|
$question = id(new PonderQuestionQuery())
|
|
|
|
->setViewer($user)
|
|
|
|
->withIDs(array($this->questionID))
|
2013-07-28 16:17:51 -07:00
|
|
|
->needAnswers(true)
|
2013-07-28 19:28:00 -07:00
|
|
|
->needViewerVotes(true)
|
2013-07-28 15:38:47 -07:00
|
|
|
->executeOne();
|
2012-08-10 10:44:04 -07:00
|
|
|
if (!$question) {
|
|
|
|
return new Aphront404Response();
|
|
|
|
}
|
|
|
|
|
2013-07-28 16:17:51 -07:00
|
|
|
$question->attachVotes($user->getPHID());
|
2012-08-10 10:44:04 -07:00
|
|
|
|
2013-07-28 15:02:18 -07:00
|
|
|
$question_xactions = $this->buildQuestionTransactions($question);
|
2013-07-28 16:17:51 -07:00
|
|
|
$answers = $this->buildAnswers($question->getAnswers());
|
2012-08-10 10:44:04 -07:00
|
|
|
|
2013-07-28 16:30:30 -07:00
|
|
|
$authors = mpull($question->getAnswers(), null, 'getAuthorPHID');
|
|
|
|
if (isset($authors[$user->getPHID()])) {
|
2013-07-28 18:47:43 -07: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-28 16:30:30 -07:00
|
|
|
} else {
|
|
|
|
$answer_add_panel = new PonderAddAnswerView();
|
|
|
|
$answer_add_panel
|
|
|
|
->setQuestion($question)
|
|
|
|
->setUser($user)
|
2014-06-09 11:36:49 -07:00
|
|
|
->setActionURI('/ponder/answer/add/');
|
2013-07-28 16:30:30 -07:00
|
|
|
}
|
2012-08-10 10:44:04 -07:00
|
|
|
|
2013-09-17 09:12:37 -07:00
|
|
|
$header = id(new PHUIHeaderView())
|
2012-10-05 13:12:31 -07:00
|
|
|
->setHeader($question->getTitle());
|
|
|
|
|
|
|
|
$actions = $this->buildActionListView($question);
|
2013-10-11 07:53:56 -07:00
|
|
|
$properties = $this->buildPropertyListView($question, $actions);
|
2012-10-05 13:12:31 -07:00
|
|
|
|
2013-09-28 15:55:38 -07:00
|
|
|
$object_box = id(new PHUIObjectBoxView())
|
|
|
|
->setHeader($header)
|
2013-10-11 07:53:56 -07:00
|
|
|
->addPropertyList($properties);
|
2013-09-28 15:55:38 -07:00
|
|
|
|
2013-04-10 13:08:36 -07:00
|
|
|
$crumbs = $this->buildApplicationCrumbs($this->buildSideNavView());
|
|
|
|
$crumbs->setActionList($actions);
|
2013-12-18 17:47:34 -08:00
|
|
|
$crumbs->addTextCrumb('Q'.$this->questionID, '/Q'.$this->questionID);
|
2013-04-10 13:08:36 -07:00
|
|
|
|
2013-07-18 12:40:51 -07:00
|
|
|
return $this->buildApplicationPage(
|
2012-08-10 10:44:04 -07:00
|
|
|
array(
|
2013-04-10 13:08:36 -07:00
|
|
|
$crumbs,
|
2013-09-28 15:55:38 -07:00
|
|
|
$object_box,
|
2013-07-28 15:02:18 -07:00
|
|
|
$question_xactions,
|
2013-07-28 16:17:51 -07:00
|
|
|
$answers,
|
2014-10-08 00:01:04 +11:00
|
|
|
$answer_add_panel,
|
2013-07-18 12:40:51 -07:00
|
|
|
),
|
2012-08-10 10:44:04 -07:00
|
|
|
array(
|
2013-05-20 07:55:23 -07:00
|
|
|
'title' => 'Q'.$question->getID().' '.$question->getTitle(),
|
2014-01-10 10:19:00 -08:00
|
|
|
'pageObjects' => array_merge(
|
|
|
|
array($question->getPHID()),
|
|
|
|
mpull($question->getAnswers(), 'getPHID')),
|
2012-08-10 10:44:04 -07:00
|
|
|
));
|
|
|
|
}
|
2012-10-05 13:12:31 -07:00
|
|
|
|
|
|
|
private function buildActionListView(PonderQuestion $question) {
|
2013-07-12 11:39:47 -07:00
|
|
|
$request = $this->getRequest();
|
2013-07-28 15:02:18 -07:00
|
|
|
$viewer = $request->getUser();
|
2013-07-27 18:37:17 -07:00
|
|
|
|
2013-07-28 15:02:18 -07:00
|
|
|
$id = $question->getID();
|
|
|
|
|
|
|
|
$can_edit = PhabricatorPolicyFilter::hasCapability(
|
|
|
|
$viewer,
|
|
|
|
$question,
|
|
|
|
PhabricatorPolicyCapability::CAN_EDIT);
|
|
|
|
|
|
|
|
$view = id(new PhabricatorActionListView())
|
|
|
|
->setUser($request->getUser())
|
2013-07-12 11:39:47 -07:00
|
|
|
->setObject($question)
|
|
|
|
->setObjectURI($request->getRequestURI());
|
2013-07-27 18:37:17 -07:00
|
|
|
|
2013-07-28 15:02:18 -07:00
|
|
|
$view->addAction(
|
|
|
|
id(new PhabricatorActionView())
|
2014-05-12 10:08:32 -07:00
|
|
|
->setIcon('fa-pencil')
|
2013-07-28 15:02:18 -07:00
|
|
|
->setName(pht('Edit Question'))
|
|
|
|
->setHref($this->getApplicationURI("/question/edit/{$id}/"))
|
|
|
|
->setDisabled(!$can_edit)
|
|
|
|
->setWorkflow(!$can_edit));
|
|
|
|
|
|
|
|
if ($question->getStatus() == PonderQuestionStatus::STATUS_OPEN) {
|
2014-05-12 10:08:32 -07:00
|
|
|
$name = pht('Close Question');
|
|
|
|
$icon = 'fa-times';
|
|
|
|
$href = 'close';
|
2013-07-28 15:02:18 -07:00
|
|
|
} else {
|
2014-05-12 10:08:32 -07:00
|
|
|
$name = pht('Reopen Question');
|
|
|
|
$icon = 'fa-check-circle-o';
|
|
|
|
$href = 'open';
|
2013-07-27 18:37:17 -07:00
|
|
|
}
|
|
|
|
|
2013-07-28 15:02:18 -07: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-28 18:32:55 -07:00
|
|
|
$view->addAction(
|
|
|
|
id(new PhabricatorActionView())
|
2014-05-12 10:08:32 -07:00
|
|
|
->setIcon('fa-list')
|
2013-07-28 18:32:55 -07:00
|
|
|
->setName(pht('View History'))
|
|
|
|
->setHref($this->getApplicationURI("/question/history/{$id}/")));
|
|
|
|
|
2013-07-28 15:02:18 -07:00
|
|
|
return $view;
|
2012-10-05 13:12:31 -07:00
|
|
|
}
|
|
|
|
|
2012-10-08 14:47:21 -07:00
|
|
|
private function buildPropertyListView(
|
2013-10-11 07:53:56 -07:00
|
|
|
PonderQuestion $question,
|
|
|
|
PhabricatorActionListView $actions) {
|
2012-10-08 14:47:21 -07:00
|
|
|
|
2012-10-05 13:12:31 -07:00
|
|
|
$viewer = $this->getRequest()->getUser();
|
2013-10-11 07:53:56 -07:00
|
|
|
$view = id(new PHUIPropertyListView())
|
2013-05-09 14:40:43 -07:00
|
|
|
->setUser($viewer)
|
2013-10-11 07:53:56 -07:00
|
|
|
->setObject($question)
|
|
|
|
->setActionList($actions);
|
2013-07-27 18:37:17 -07:00
|
|
|
|
2013-07-28 16:55:13 -07:00
|
|
|
$this->loadHandles(array($question->getAuthorPHID()));
|
|
|
|
|
2013-07-27 18:37:17 -07:00
|
|
|
$view->addProperty(
|
|
|
|
pht('Status'),
|
|
|
|
PonderQuestionStatus::getQuestionStatusFullName($question->getStatus()));
|
|
|
|
|
2012-10-05 13:12:31 -07:00
|
|
|
$view->addProperty(
|
|
|
|
pht('Author'),
|
|
|
|
$this->getHandle($question->getAuthorPHID())->renderLink());
|
|
|
|
|
|
|
|
$view->addProperty(
|
|
|
|
pht('Created'),
|
|
|
|
phabricator_datetime($question->getDateCreated(), $viewer));
|
|
|
|
|
2013-07-28 15:02:18 -07:00
|
|
|
$view->invokeWillRenderEvent();
|
|
|
|
|
2013-07-28 19:28:00 -07:00
|
|
|
$votable = id(new PonderVotableView())
|
|
|
|
->setPHID($question->getPHID())
|
|
|
|
->setURI($this->getApplicationURI('vote/'))
|
|
|
|
->setCount($question->getVoteCount())
|
|
|
|
->setVote($question->getUserVote());
|
|
|
|
|
2013-10-30 08:10:05 -07:00
|
|
|
$view->addSectionHeader(pht('Question'));
|
2013-07-28 15:02:18 -07:00
|
|
|
$view->addTextContent(
|
2013-07-28 19:28:00 -07:00
|
|
|
array(
|
|
|
|
$votable,
|
2013-07-30 15:50:27 -07:00
|
|
|
phutil_tag(
|
|
|
|
'div',
|
|
|
|
array(
|
|
|
|
'class' => 'phabricator-remarkup',
|
|
|
|
),
|
|
|
|
PhabricatorMarkupEngine::renderOneObject(
|
|
|
|
$question,
|
|
|
|
$question->getMarkupField(),
|
|
|
|
$viewer)),
|
2013-07-28 19:28:00 -07:00
|
|
|
));
|
2013-07-28 15:02:18 -07:00
|
|
|
|
|
|
|
|
2012-10-05 13:12:31 -07:00
|
|
|
return $view;
|
|
|
|
}
|
2013-07-28 15:02:18 -07:00
|
|
|
|
|
|
|
private function buildQuestionTransactions(PonderQuestion $question) {
|
Transactions - deploy buildTransactionTimeline to remaining applications
Summary:
Ref T4712. Specifically...
- Differential
- needed getApplicationTransactionViewObject() implemented
- Audit
- needed getApplicationTransactionViewObject() implemented
- Repository
- one object needed PhabricatorApplicationTransactionInterface implemented
- setShouldTerminate(true)
- Ponder
- BONUS BUG FIX - leaving a comment on an answer had a bad redirect URI
- both PonderQuestion and PonderAnswer needed PhabricatorApplicationTransactionInterface implemented
- setShouldTerminate(true) on both "history" controllers
- left a "TODO" on buildAnswers on the question view controller, which is non-standard and should be re-written eventually
- Phortune
- BONUS BUG FIX - fix new user "createNewAccount" code to not fatal
- PhortuneAccount, PhortuneMerchant, and PhortuneCart needed PhabricatorApplicationTransactionInterface implemented
- setShouldTerminate(true) on Account view, merchant view, and cart view controller
- Fund
- Legalpad
- Nuance
- NuanceSource needed PhabricatorApplicationTransactionInterface implemented
- Releeph (this product is kind of a mess...)
- HACKQUEST - had to manually create an arcanist project to even be able to make a "product" and get started...!
- BONUS BUG FIX - make sure to "setName" on product edit
- ReleephProject (should be ReleepProduct...?), ReleephBranch, and ReleepRequest needed PhabricatorApplicationTransactionInterface implemented
- Harbormaster
- HarbormasterBuildable, HarbormasterBuild, HarbormasterBuildPlan, and HarbormasterBuildStep all needed PhabricatorApplicationTransactionInterface implemented
- setShouldTerminate(true) all over the place
Test Plan: foreach application, viewed the timeline(s) and made sure they still rendered
Reviewers: epriestley
Reviewed By: epriestley
Subscribers: Korvin, epriestley
Maniphest Tasks: T4712
Differential Revision: https://secure.phabricator.com/D10925
2014-12-03 15:35:47 -08:00
|
|
|
$viewer = $this->getViewer();
|
2013-07-28 17:58:34 -07:00
|
|
|
$id = $question->getID();
|
2013-07-28 15:02:18 -07:00
|
|
|
|
Transactions - deploy buildTransactionTimeline to remaining applications
Summary:
Ref T4712. Specifically...
- Differential
- needed getApplicationTransactionViewObject() implemented
- Audit
- needed getApplicationTransactionViewObject() implemented
- Repository
- one object needed PhabricatorApplicationTransactionInterface implemented
- setShouldTerminate(true)
- Ponder
- BONUS BUG FIX - leaving a comment on an answer had a bad redirect URI
- both PonderQuestion and PonderAnswer needed PhabricatorApplicationTransactionInterface implemented
- setShouldTerminate(true) on both "history" controllers
- left a "TODO" on buildAnswers on the question view controller, which is non-standard and should be re-written eventually
- Phortune
- BONUS BUG FIX - fix new user "createNewAccount" code to not fatal
- PhortuneAccount, PhortuneMerchant, and PhortuneCart needed PhabricatorApplicationTransactionInterface implemented
- setShouldTerminate(true) on Account view, merchant view, and cart view controller
- Fund
- Legalpad
- Nuance
- NuanceSource needed PhabricatorApplicationTransactionInterface implemented
- Releeph (this product is kind of a mess...)
- HACKQUEST - had to manually create an arcanist project to even be able to make a "product" and get started...!
- BONUS BUG FIX - make sure to "setName" on product edit
- ReleephProject (should be ReleepProduct...?), ReleephBranch, and ReleepRequest needed PhabricatorApplicationTransactionInterface implemented
- Harbormaster
- HarbormasterBuildable, HarbormasterBuild, HarbormasterBuildPlan, and HarbormasterBuildStep all needed PhabricatorApplicationTransactionInterface implemented
- setShouldTerminate(true) all over the place
Test Plan: foreach application, viewed the timeline(s) and made sure they still rendered
Reviewers: epriestley
Reviewed By: epriestley
Subscribers: Korvin, epriestley
Maniphest Tasks: T4712
Differential Revision: https://secure.phabricator.com/D10925
2014-12-03 15:35:47 -08:00
|
|
|
$timeline = $this->buildTransactionTimeline(
|
|
|
|
$question,
|
|
|
|
id(new PonderQuestionTransactionQuery())
|
|
|
|
->withTransactionTypes(array(PhabricatorTransactions::TYPE_COMMENT)));
|
|
|
|
$xactions = $timeline->getTransactions();
|
2013-07-28 15:02:18 -07:00
|
|
|
|
2013-07-28 17:58:34 -07:00
|
|
|
$add_comment = id(new PhabricatorApplicationTransactionCommentView())
|
|
|
|
->setUser($viewer)
|
2013-07-28 18:21:22 -07:00
|
|
|
->setObjectPHID($question->getPHID())
|
2013-07-28 17:58:34 -07:00
|
|
|
->setShowPreview(false)
|
2013-11-21 16:09:04 -08:00
|
|
|
->setHeaderText(pht('Question Comment'))
|
2013-07-28 17:58:34 -07:00
|
|
|
->setAction($this->getApplicationURI("/question/comment/{$id}/"))
|
|
|
|
->setSubmitButtonName(pht('Comment'));
|
|
|
|
|
2013-07-28 18:47:43 -07:00
|
|
|
return $this->wrapComments(
|
|
|
|
count($xactions),
|
|
|
|
array(
|
|
|
|
$timeline,
|
2013-11-21 16:09:04 -08:00
|
|
|
$add_comment,
|
2013-07-28 18:47:43 -07:00
|
|
|
));
|
2013-07-28 15:02:18 -07:00
|
|
|
}
|
|
|
|
|
Transactions - deploy buildTransactionTimeline to remaining applications
Summary:
Ref T4712. Specifically...
- Differential
- needed getApplicationTransactionViewObject() implemented
- Audit
- needed getApplicationTransactionViewObject() implemented
- Repository
- one object needed PhabricatorApplicationTransactionInterface implemented
- setShouldTerminate(true)
- Ponder
- BONUS BUG FIX - leaving a comment on an answer had a bad redirect URI
- both PonderQuestion and PonderAnswer needed PhabricatorApplicationTransactionInterface implemented
- setShouldTerminate(true) on both "history" controllers
- left a "TODO" on buildAnswers on the question view controller, which is non-standard and should be re-written eventually
- Phortune
- BONUS BUG FIX - fix new user "createNewAccount" code to not fatal
- PhortuneAccount, PhortuneMerchant, and PhortuneCart needed PhabricatorApplicationTransactionInterface implemented
- setShouldTerminate(true) on Account view, merchant view, and cart view controller
- Fund
- Legalpad
- Nuance
- NuanceSource needed PhabricatorApplicationTransactionInterface implemented
- Releeph (this product is kind of a mess...)
- HACKQUEST - had to manually create an arcanist project to even be able to make a "product" and get started...!
- BONUS BUG FIX - make sure to "setName" on product edit
- ReleephProject (should be ReleepProduct...?), ReleephBranch, and ReleepRequest needed PhabricatorApplicationTransactionInterface implemented
- Harbormaster
- HarbormasterBuildable, HarbormasterBuild, HarbormasterBuildPlan, and HarbormasterBuildStep all needed PhabricatorApplicationTransactionInterface implemented
- setShouldTerminate(true) all over the place
Test Plan: foreach application, viewed the timeline(s) and made sure they still rendered
Reviewers: epriestley
Reviewed By: epriestley
Subscribers: Korvin, epriestley
Maniphest Tasks: T4712
Differential Revision: https://secure.phabricator.com/D10925
2014-12-03 15:35:47 -08:00
|
|
|
/**
|
|
|
|
* This is fairly non-standard; building N timelines at once (N = number of
|
|
|
|
* answers) is tricky business.
|
|
|
|
*
|
|
|
|
* TODO - re-factor this to ajax in one answer panel at a time in a more
|
|
|
|
* standard fashion. This is necessary to scale this application.
|
|
|
|
*/
|
2013-07-28 16:17:51 -07: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-28 18:32:55 -07:00
|
|
|
->withTransactionTypes(array(PhabricatorTransactions::TYPE_COMMENT))
|
2013-07-28 16:17:51 -07: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-28 17:40:11 -07:00
|
|
|
$id = $answer->getID();
|
2013-07-28 16:17:51 -07:00
|
|
|
|
|
|
|
$out[] = phutil_tag('br');
|
|
|
|
$out[] = phutil_tag('br');
|
2013-09-18 15:15:25 -07:00
|
|
|
$out[] = id(new PhabricatorAnchorView())
|
|
|
|
->setAnchorName("A$id");
|
2013-09-28 15:55:38 -07:00
|
|
|
$header = id(new PHUIHeaderView())
|
|
|
|
->setHeader($this->getHandle($author_phid)->getFullName());
|
|
|
|
|
|
|
|
$actions = $this->buildAnswerActions($answer);
|
2013-10-11 07:53:56 -07:00
|
|
|
$properties = $this->buildAnswerProperties($answer, $actions);
|
2013-07-28 16:17:51 -07:00
|
|
|
|
2013-09-28 15:55:38 -07:00
|
|
|
$object_box = id(new PHUIObjectBoxView())
|
|
|
|
->setHeader($header)
|
2013-10-11 07:53:56 -07:00
|
|
|
->addPropertyList($properties);
|
2013-07-28 17:40:11 -07:00
|
|
|
|
2013-09-28 15:55:38 -07:00
|
|
|
$out[] = $object_box;
|
2013-07-28 18:47:43 -07:00
|
|
|
$details = array();
|
|
|
|
|
|
|
|
$details[] = id(new PhabricatorApplicationTransactionView())
|
2013-07-28 16:17:51 -07:00
|
|
|
->setUser($viewer)
|
2013-07-28 18:21:22 -07:00
|
|
|
->setObjectPHID($answer->getPHID())
|
2013-07-28 16:17:51 -07:00
|
|
|
->setTransactions($xactions)
|
|
|
|
->setMarkupEngine($engine);
|
|
|
|
|
2013-09-28 15:55:38 -07:00
|
|
|
$form = id(new PhabricatorApplicationTransactionCommentView())
|
2013-07-28 17:40:11 -07:00
|
|
|
->setUser($viewer)
|
2013-07-28 18:21:22 -07:00
|
|
|
->setObjectPHID($answer->getPHID())
|
2013-07-28 17:40:11 -07:00
|
|
|
->setShowPreview(false)
|
2013-11-21 16:09:04 -08:00
|
|
|
->setHeaderText(pht('Answer Comment'))
|
2013-07-28 17:40:11 -07:00
|
|
|
->setAction($this->getApplicationURI("/answer/comment/{$id}/"))
|
|
|
|
->setSubmitButtonName(pht('Comment'));
|
2013-07-28 18:47:43 -07:00
|
|
|
|
2013-11-21 16:09:04 -08:00
|
|
|
$details[] = $form;
|
2013-09-28 15:55:38 -07:00
|
|
|
|
2013-07-28 18:47:43 -07:00
|
|
|
$out[] = $this->wrapComments(
|
|
|
|
count($xactions),
|
|
|
|
$details);
|
2013-07-28 16:17:51 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
$out[] = phutil_tag('br');
|
|
|
|
$out[] = phutil_tag('br');
|
|
|
|
|
|
|
|
return $out;
|
|
|
|
}
|
|
|
|
|
|
|
|
private function buildAnswerActions(PonderAnswer $answer) {
|
|
|
|
$request = $this->getRequest();
|
|
|
|
$viewer = $request->getUser();
|
|
|
|
|
2013-07-28 17:23:04 -07:00
|
|
|
$id = $answer->getID();
|
|
|
|
|
2013-07-28 16:17:51 -07: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())
|
2014-05-12 10:08:32 -07:00
|
|
|
->setIcon('fa-pencil')
|
2013-07-28 16:17:51 -07:00
|
|
|
->setName(pht('Edit Answer'))
|
|
|
|
->setHref($this->getApplicationURI("/answer/edit/{$id}/"))
|
|
|
|
->setDisabled(!$can_edit)
|
|
|
|
->setWorkflow(!$can_edit));
|
|
|
|
|
2013-07-28 18:32:55 -07:00
|
|
|
$view->addAction(
|
|
|
|
id(new PhabricatorActionView())
|
2014-05-12 10:08:32 -07:00
|
|
|
->setIcon('fa-list')
|
2013-07-28 18:32:55 -07:00
|
|
|
->setName(pht('View History'))
|
|
|
|
->setHref($this->getApplicationURI("/answer/history/{$id}/")));
|
|
|
|
|
2013-07-28 16:17:51 -07:00
|
|
|
return $view;
|
|
|
|
}
|
|
|
|
|
2013-10-11 07:53:56 -07:00
|
|
|
private function buildAnswerProperties(
|
|
|
|
PonderAnswer $answer,
|
|
|
|
PhabricatorActionListView $actions) {
|
|
|
|
|
2013-07-28 16:17:51 -07:00
|
|
|
$viewer = $this->getRequest()->getUser();
|
2013-10-11 07:53:56 -07:00
|
|
|
$view = id(new PHUIPropertyListView())
|
2013-07-28 16:17:51 -07:00
|
|
|
->setUser($viewer)
|
2013-10-11 07:53:56 -07:00
|
|
|
->setObject($answer)
|
|
|
|
->setActionList($actions);
|
2013-07-28 16:17:51 -07:00
|
|
|
|
|
|
|
$view->addProperty(
|
|
|
|
pht('Created'),
|
|
|
|
phabricator_datetime($answer->getDateCreated(), $viewer));
|
|
|
|
|
|
|
|
$view->invokeWillRenderEvent();
|
|
|
|
|
2013-07-28 19:28:00 -07:00
|
|
|
$votable = id(new PonderVotableView())
|
|
|
|
->setPHID($answer->getPHID())
|
|
|
|
->setURI($this->getApplicationURI('vote/'))
|
|
|
|
->setCount($answer->getVoteCount())
|
|
|
|
->setVote($answer->getUserVote());
|
|
|
|
|
2013-10-30 08:10:05 -07:00
|
|
|
$view->addSectionHeader(pht('Answer'));
|
2013-07-28 16:17:51 -07:00
|
|
|
$view->addTextContent(
|
2013-07-28 19:28:00 -07:00
|
|
|
array(
|
|
|
|
$votable,
|
|
|
|
phutil_tag(
|
|
|
|
'div',
|
|
|
|
array(
|
|
|
|
'class' => 'phabricator-remarkup',
|
|
|
|
),
|
|
|
|
PhabricatorMarkupEngine::renderOneObject(
|
|
|
|
$answer,
|
|
|
|
$answer->getMarkupField(),
|
|
|
|
$viewer)),
|
|
|
|
));
|
2013-07-28 16:17:51 -07:00
|
|
|
|
|
|
|
return $view;
|
|
|
|
}
|
|
|
|
|
2013-07-28 18:47:43 -07: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 10:44:04 -07:00
|
|
|
}
|