mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-11 23:31:03 +01:00
Add project tags to PonderQuestion
Summary: T2628, adding project tags to ponder questions Test Plan: Create ponder question, add project tag, save, project tag should show in question properties on question view. Reviewers: epriestley, #blessed_reviewers Reviewed By: epriestley, #blessed_reviewers Subscribers: Korvin, epriestley Differential Revision: https://secure.phabricator.com/D9447
This commit is contained in:
parent
6df8c4a426
commit
0bdf18fdd2
3 changed files with 35 additions and 6 deletions
|
@ -25,6 +25,10 @@ final class PonderQuestionEditController extends PonderController {
|
||||||
if (!$question) {
|
if (!$question) {
|
||||||
return new Aphront404Response();
|
return new Aphront404Response();
|
||||||
}
|
}
|
||||||
|
$v_projects = PhabricatorEdgeQuery::loadDestinationPHIDs(
|
||||||
|
$question->getPHID(),
|
||||||
|
PhabricatorEdgeConfig::TYPE_OBJECT_HAS_PROJECT);
|
||||||
|
$v_projects = array_reverse($v_projects);
|
||||||
} else {
|
} else {
|
||||||
$question = id(new PonderQuestion())
|
$question = id(new PonderQuestion())
|
||||||
->setStatus(PonderQuestionStatus::STATUS_OPEN)
|
->setStatus(PonderQuestionStatus::STATUS_OPEN)
|
||||||
|
@ -32,6 +36,7 @@ final class PonderQuestionEditController extends PonderController {
|
||||||
->setVoteCount(0)
|
->setVoteCount(0)
|
||||||
->setAnswerCount(0)
|
->setAnswerCount(0)
|
||||||
->setHeat(0.0);
|
->setHeat(0.0);
|
||||||
|
$v_projects = array();
|
||||||
}
|
}
|
||||||
|
|
||||||
$v_title = $question->getTitle();
|
$v_title = $question->getTitle();
|
||||||
|
@ -42,6 +47,7 @@ final class PonderQuestionEditController extends PonderController {
|
||||||
if ($request->isFormPost()) {
|
if ($request->isFormPost()) {
|
||||||
$v_title = $request->getStr('title');
|
$v_title = $request->getStr('title');
|
||||||
$v_content = $request->getStr('content');
|
$v_content = $request->getStr('content');
|
||||||
|
$v_projects = $request->getArr('projects');
|
||||||
|
|
||||||
$len = phutil_utf8_strlen($v_title);
|
$len = phutil_utf8_strlen($v_title);
|
||||||
if ($len < 1) {
|
if ($len < 1) {
|
||||||
|
@ -64,6 +70,12 @@ final class PonderQuestionEditController extends PonderController {
|
||||||
->setTransactionType(PonderQuestionTransaction::TYPE_CONTENT)
|
->setTransactionType(PonderQuestionTransaction::TYPE_CONTENT)
|
||||||
->setNewValue($v_content);
|
->setNewValue($v_content);
|
||||||
|
|
||||||
|
$proj_edge_type = PhabricatorEdgeConfig::TYPE_OBJECT_HAS_PROJECT;
|
||||||
|
$xactions[] = id(new PonderQuestionTransaction())
|
||||||
|
->setTransactionType(PhabricatorTransactions::TYPE_EDGE)
|
||||||
|
->setMetadataValue('edge:type', $proj_edge_type)
|
||||||
|
->setNewValue(array('=' => array_fuse($v_projects)));
|
||||||
|
|
||||||
$editor = id(new PonderQuestionEditor())
|
$editor = id(new PonderQuestionEditor())
|
||||||
->setActor($user)
|
->setActor($user)
|
||||||
->setContentSourceFromRequest($request)
|
->setContentSourceFromRequest($request)
|
||||||
|
@ -90,11 +102,25 @@ final class PonderQuestionEditController extends PonderController {
|
||||||
->setID('content')
|
->setID('content')
|
||||||
->setValue($v_content)
|
->setValue($v_content)
|
||||||
->setLabel(pht('Description'))
|
->setLabel(pht('Description'))
|
||||||
->setUser($user))
|
->setUser($user));
|
||||||
->appendChild(
|
|
||||||
id(new AphrontFormSubmitControl())
|
if ($v_projects) {
|
||||||
->addCancelButton($this->getApplicationURI())
|
$project_handles = $this->loadViewerHandles($v_projects);
|
||||||
->setValue(pht('Ask Away!')));
|
} else {
|
||||||
|
$project_handles = array();
|
||||||
|
}
|
||||||
|
|
||||||
|
$form->appendChild(
|
||||||
|
id(new AphrontFormTokenizerControl())
|
||||||
|
->setLabel(pht('Projects'))
|
||||||
|
->setName('projects')
|
||||||
|
->setValue($project_handles)
|
||||||
|
->setDatasource('/typeahead/common/projects/'));
|
||||||
|
|
||||||
|
$form ->appendChild(
|
||||||
|
id(new AphrontFormSubmitControl())
|
||||||
|
->addCancelButton($this->getApplicationURI())
|
||||||
|
->setValue(pht('Ask Away!')));
|
||||||
|
|
||||||
$preview = id(new PHUIRemarkupPreviewPanel())
|
$preview = id(new PHUIRemarkupPreviewPanel())
|
||||||
->setHeader(pht('Question Preview'))
|
->setHeader(pht('Question Preview'))
|
||||||
|
|
|
@ -141,6 +141,8 @@ final class PonderQuestionEditor
|
||||||
|
|
||||||
$object->setAnswerCount($count);
|
$object->setAnswerCount($count);
|
||||||
break;
|
break;
|
||||||
|
case PhabricatorTransactions::TYPE_EDGE:
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -7,7 +7,8 @@ final class PonderQuestion extends PonderDAO
|
||||||
PhabricatorSubscribableInterface,
|
PhabricatorSubscribableInterface,
|
||||||
PhabricatorFlaggableInterface,
|
PhabricatorFlaggableInterface,
|
||||||
PhabricatorPolicyInterface,
|
PhabricatorPolicyInterface,
|
||||||
PhabricatorTokenReceiverInterface {
|
PhabricatorTokenReceiverInterface,
|
||||||
|
PhabricatorProjectInterface {
|
||||||
|
|
||||||
const MARKUP_FIELD_CONTENT = 'markup:content';
|
const MARKUP_FIELD_CONTENT = 'markup:content';
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue