mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-15 17:21:10 +01:00
Restore voting to Ponder
Summary: Ref T3578. Restores the voting UI and makes it a little prettier. Test Plan: {F52089} Reviewers: btrahan, chad Reviewed By: chad CC: aran Maniphest Tasks: T3578 Differential Revision: https://secure.phabricator.com/D6614
This commit is contained in:
parent
ba8803af96
commit
5037ba1cf8
16 changed files with 190 additions and 428 deletions
|
@ -3432,7 +3432,7 @@ celerity_register_resource_map(array(
|
||||||
),
|
),
|
||||||
'phabricator-property-list-view-css' =>
|
'phabricator-property-list-view-css' =>
|
||||||
array(
|
array(
|
||||||
'uri' => '/res/a04cc81d/rsrc/css/layout/phabricator-property-list-view.css',
|
'uri' => '/res/1b2f0fa9/rsrc/css/layout/phabricator-property-list-view.css',
|
||||||
'type' => 'css',
|
'type' => 'css',
|
||||||
'requires' =>
|
'requires' =>
|
||||||
array(
|
array(
|
||||||
|
@ -3920,7 +3920,7 @@ celerity_register_resource_map(array(
|
||||||
),
|
),
|
||||||
'ponder-vote-css' =>
|
'ponder-vote-css' =>
|
||||||
array(
|
array(
|
||||||
'uri' => '/res/26945177/rsrc/css/application/ponder/vote.css',
|
'uri' => '/res/28b71b13/rsrc/css/application/ponder/vote.css',
|
||||||
'type' => 'css',
|
'type' => 'css',
|
||||||
'requires' =>
|
'requires' =>
|
||||||
array(
|
array(
|
||||||
|
@ -4191,7 +4191,7 @@ celerity_register_resource_map(array(
|
||||||
), array(
|
), array(
|
||||||
'packages' =>
|
'packages' =>
|
||||||
array(
|
array(
|
||||||
'bbc1cd98' =>
|
'4bd2b460' =>
|
||||||
array(
|
array(
|
||||||
'name' => 'core.pkg.css',
|
'name' => 'core.pkg.css',
|
||||||
'symbols' =>
|
'symbols' =>
|
||||||
|
@ -4239,7 +4239,7 @@ celerity_register_resource_map(array(
|
||||||
40 => 'phabricator-property-list-view-css',
|
40 => 'phabricator-property-list-view-css',
|
||||||
41 => 'phabricator-tag-view-css',
|
41 => 'phabricator-tag-view-css',
|
||||||
),
|
),
|
||||||
'uri' => '/res/pkg/bbc1cd98/core.pkg.css',
|
'uri' => '/res/pkg/4bd2b460/core.pkg.css',
|
||||||
'type' => 'css',
|
'type' => 'css',
|
||||||
),
|
),
|
||||||
'75ccea43' =>
|
'75ccea43' =>
|
||||||
|
@ -4430,16 +4430,16 @@ celerity_register_resource_map(array(
|
||||||
),
|
),
|
||||||
'reverse' =>
|
'reverse' =>
|
||||||
array(
|
array(
|
||||||
'aphront-dialog-view-css' => 'bbc1cd98',
|
'aphront-dialog-view-css' => '4bd2b460',
|
||||||
'aphront-error-view-css' => 'bbc1cd98',
|
'aphront-error-view-css' => '4bd2b460',
|
||||||
'aphront-form-view-css' => 'bbc1cd98',
|
'aphront-form-view-css' => '4bd2b460',
|
||||||
'aphront-list-filter-view-css' => 'bbc1cd98',
|
'aphront-list-filter-view-css' => '4bd2b460',
|
||||||
'aphront-pager-view-css' => 'bbc1cd98',
|
'aphront-pager-view-css' => '4bd2b460',
|
||||||
'aphront-panel-view-css' => 'bbc1cd98',
|
'aphront-panel-view-css' => '4bd2b460',
|
||||||
'aphront-table-view-css' => 'bbc1cd98',
|
'aphront-table-view-css' => '4bd2b460',
|
||||||
'aphront-tokenizer-control-css' => 'bbc1cd98',
|
'aphront-tokenizer-control-css' => '4bd2b460',
|
||||||
'aphront-tooltip-css' => 'bbc1cd98',
|
'aphront-tooltip-css' => '4bd2b460',
|
||||||
'aphront-typeahead-control-css' => 'bbc1cd98',
|
'aphront-typeahead-control-css' => '4bd2b460',
|
||||||
'differential-changeset-view-css' => 'dd27a69b',
|
'differential-changeset-view-css' => 'dd27a69b',
|
||||||
'differential-core-view-css' => 'dd27a69b',
|
'differential-core-view-css' => 'dd27a69b',
|
||||||
'differential-inline-comment-editor' => '48040be9',
|
'differential-inline-comment-editor' => '48040be9',
|
||||||
|
@ -4453,7 +4453,7 @@ celerity_register_resource_map(array(
|
||||||
'differential-table-of-contents-css' => 'dd27a69b',
|
'differential-table-of-contents-css' => 'dd27a69b',
|
||||||
'diffusion-commit-view-css' => 'c8ce2d88',
|
'diffusion-commit-view-css' => 'c8ce2d88',
|
||||||
'diffusion-icons-css' => 'c8ce2d88',
|
'diffusion-icons-css' => 'c8ce2d88',
|
||||||
'global-drag-and-drop-css' => 'bbc1cd98',
|
'global-drag-and-drop-css' => '4bd2b460',
|
||||||
'inline-comment-summary-css' => 'dd27a69b',
|
'inline-comment-summary-css' => 'dd27a69b',
|
||||||
'javelin-aphlict' => '75ccea43',
|
'javelin-aphlict' => '75ccea43',
|
||||||
'javelin-behavior' => 'a9f14d76',
|
'javelin-behavior' => 'a9f14d76',
|
||||||
|
@ -4526,55 +4526,55 @@ celerity_register_resource_map(array(
|
||||||
'javelin-util' => 'a9f14d76',
|
'javelin-util' => 'a9f14d76',
|
||||||
'javelin-vector' => 'a9f14d76',
|
'javelin-vector' => 'a9f14d76',
|
||||||
'javelin-workflow' => 'a9f14d76',
|
'javelin-workflow' => 'a9f14d76',
|
||||||
'lightbox-attachment-css' => 'bbc1cd98',
|
'lightbox-attachment-css' => '4bd2b460',
|
||||||
'maniphest-task-summary-css' => '06bacb9a',
|
'maniphest-task-summary-css' => '06bacb9a',
|
||||||
'maniphest-transaction-detail-css' => '06bacb9a',
|
'maniphest-transaction-detail-css' => '06bacb9a',
|
||||||
'phabricator-action-list-view-css' => 'bbc1cd98',
|
'phabricator-action-list-view-css' => '4bd2b460',
|
||||||
'phabricator-application-launch-view-css' => 'bbc1cd98',
|
'phabricator-application-launch-view-css' => '4bd2b460',
|
||||||
'phabricator-busy' => '75ccea43',
|
'phabricator-busy' => '75ccea43',
|
||||||
'phabricator-content-source-view-css' => 'dd27a69b',
|
'phabricator-content-source-view-css' => 'dd27a69b',
|
||||||
'phabricator-core-css' => 'bbc1cd98',
|
'phabricator-core-css' => '4bd2b460',
|
||||||
'phabricator-crumbs-view-css' => 'bbc1cd98',
|
'phabricator-crumbs-view-css' => '4bd2b460',
|
||||||
'phabricator-drag-and-drop-file-upload' => '48040be9',
|
'phabricator-drag-and-drop-file-upload' => '48040be9',
|
||||||
'phabricator-dropdown-menu' => '75ccea43',
|
'phabricator-dropdown-menu' => '75ccea43',
|
||||||
'phabricator-file-upload' => '75ccea43',
|
'phabricator-file-upload' => '75ccea43',
|
||||||
'phabricator-filetree-view-css' => 'bbc1cd98',
|
'phabricator-filetree-view-css' => '4bd2b460',
|
||||||
'phabricator-flag-css' => 'bbc1cd98',
|
'phabricator-flag-css' => '4bd2b460',
|
||||||
'phabricator-form-view-css' => 'bbc1cd98',
|
'phabricator-form-view-css' => '4bd2b460',
|
||||||
'phabricator-header-view-css' => 'bbc1cd98',
|
'phabricator-header-view-css' => '4bd2b460',
|
||||||
'phabricator-hovercard' => '75ccea43',
|
'phabricator-hovercard' => '75ccea43',
|
||||||
'phabricator-jump-nav' => 'bbc1cd98',
|
'phabricator-jump-nav' => '4bd2b460',
|
||||||
'phabricator-keyboard-shortcut' => '75ccea43',
|
'phabricator-keyboard-shortcut' => '75ccea43',
|
||||||
'phabricator-keyboard-shortcut-manager' => '75ccea43',
|
'phabricator-keyboard-shortcut-manager' => '75ccea43',
|
||||||
'phabricator-main-menu-view' => 'bbc1cd98',
|
'phabricator-main-menu-view' => '4bd2b460',
|
||||||
'phabricator-menu-item' => '75ccea43',
|
'phabricator-menu-item' => '75ccea43',
|
||||||
'phabricator-nav-view-css' => 'bbc1cd98',
|
'phabricator-nav-view-css' => '4bd2b460',
|
||||||
'phabricator-notification' => '75ccea43',
|
'phabricator-notification' => '75ccea43',
|
||||||
'phabricator-notification-css' => 'bbc1cd98',
|
'phabricator-notification-css' => '4bd2b460',
|
||||||
'phabricator-notification-menu-css' => 'bbc1cd98',
|
'phabricator-notification-menu-css' => '4bd2b460',
|
||||||
'phabricator-object-item-list-view-css' => 'bbc1cd98',
|
'phabricator-object-item-list-view-css' => '4bd2b460',
|
||||||
'phabricator-object-selector-css' => 'dd27a69b',
|
'phabricator-object-selector-css' => 'dd27a69b',
|
||||||
'phabricator-phtize' => '75ccea43',
|
'phabricator-phtize' => '75ccea43',
|
||||||
'phabricator-prefab' => '75ccea43',
|
'phabricator-prefab' => '75ccea43',
|
||||||
'phabricator-project-tag-css' => '06bacb9a',
|
'phabricator-project-tag-css' => '06bacb9a',
|
||||||
'phabricator-property-list-view-css' => 'bbc1cd98',
|
'phabricator-property-list-view-css' => '4bd2b460',
|
||||||
'phabricator-remarkup-css' => 'bbc1cd98',
|
'phabricator-remarkup-css' => '4bd2b460',
|
||||||
'phabricator-shaped-request' => '48040be9',
|
'phabricator-shaped-request' => '48040be9',
|
||||||
'phabricator-side-menu-view-css' => 'bbc1cd98',
|
'phabricator-side-menu-view-css' => '4bd2b460',
|
||||||
'phabricator-standard-page-view' => 'bbc1cd98',
|
'phabricator-standard-page-view' => '4bd2b460',
|
||||||
'phabricator-tag-view-css' => 'bbc1cd98',
|
'phabricator-tag-view-css' => '4bd2b460',
|
||||||
'phabricator-textareautils' => '75ccea43',
|
'phabricator-textareautils' => '75ccea43',
|
||||||
'phabricator-tooltip' => '75ccea43',
|
'phabricator-tooltip' => '75ccea43',
|
||||||
'phabricator-transaction-view-css' => 'bbc1cd98',
|
'phabricator-transaction-view-css' => '4bd2b460',
|
||||||
'phabricator-zindex-css' => 'bbc1cd98',
|
'phabricator-zindex-css' => '4bd2b460',
|
||||||
'phui-button-css' => 'bbc1cd98',
|
'phui-button-css' => '4bd2b460',
|
||||||
'phui-form-css' => 'bbc1cd98',
|
'phui-form-css' => '4bd2b460',
|
||||||
'phui-icon-view-css' => 'bbc1cd98',
|
'phui-icon-view-css' => '4bd2b460',
|
||||||
'phui-spacing-css' => 'bbc1cd98',
|
'phui-spacing-css' => '4bd2b460',
|
||||||
'sprite-apps-large-css' => 'bbc1cd98',
|
'sprite-apps-large-css' => '4bd2b460',
|
||||||
'sprite-gradient-css' => 'bbc1cd98',
|
'sprite-gradient-css' => '4bd2b460',
|
||||||
'sprite-icons-css' => 'bbc1cd98',
|
'sprite-icons-css' => '4bd2b460',
|
||||||
'sprite-menu-css' => 'bbc1cd98',
|
'sprite-menu-css' => '4bd2b460',
|
||||||
'syntax-highlighting-css' => 'bbc1cd98',
|
'syntax-highlighting-css' => '4bd2b460',
|
||||||
),
|
),
|
||||||
));
|
));
|
||||||
|
|
|
@ -1868,13 +1868,11 @@ phutil_register_library_map(array(
|
||||||
'PhrictionSearchEngine' => 'applications/phriction/query/PhrictionSearchEngine.php',
|
'PhrictionSearchEngine' => 'applications/phriction/query/PhrictionSearchEngine.php',
|
||||||
'PhrictionSearchIndexer' => 'applications/phriction/search/PhrictionSearchIndexer.php',
|
'PhrictionSearchIndexer' => 'applications/phriction/search/PhrictionSearchIndexer.php',
|
||||||
'PonderAddAnswerView' => 'applications/ponder/view/PonderAddAnswerView.php',
|
'PonderAddAnswerView' => 'applications/ponder/view/PonderAddAnswerView.php',
|
||||||
'PonderAddCommentView' => 'applications/ponder/view/PonderAddCommentView.php',
|
|
||||||
'PonderAnswer' => 'applications/ponder/storage/PonderAnswer.php',
|
'PonderAnswer' => 'applications/ponder/storage/PonderAnswer.php',
|
||||||
'PonderAnswerCommentController' => 'applications/ponder/controller/PonderAnswerCommentController.php',
|
'PonderAnswerCommentController' => 'applications/ponder/controller/PonderAnswerCommentController.php',
|
||||||
'PonderAnswerEditController' => 'applications/ponder/controller/PonderAnswerEditController.php',
|
'PonderAnswerEditController' => 'applications/ponder/controller/PonderAnswerEditController.php',
|
||||||
'PonderAnswerEditor' => 'applications/ponder/editor/PonderAnswerEditor.php',
|
'PonderAnswerEditor' => 'applications/ponder/editor/PonderAnswerEditor.php',
|
||||||
'PonderAnswerHistoryController' => 'applications/ponder/controller/PonderAnswerHistoryController.php',
|
'PonderAnswerHistoryController' => 'applications/ponder/controller/PonderAnswerHistoryController.php',
|
||||||
'PonderAnswerListView' => 'applications/ponder/view/PonderAnswerListView.php',
|
|
||||||
'PonderAnswerQuery' => 'applications/ponder/query/PonderAnswerQuery.php',
|
'PonderAnswerQuery' => 'applications/ponder/query/PonderAnswerQuery.php',
|
||||||
'PonderAnswerSaveController' => 'applications/ponder/controller/PonderAnswerSaveController.php',
|
'PonderAnswerSaveController' => 'applications/ponder/controller/PonderAnswerSaveController.php',
|
||||||
'PonderAnswerTransaction' => 'applications/ponder/storage/PonderAnswerTransaction.php',
|
'PonderAnswerTransaction' => 'applications/ponder/storage/PonderAnswerTransaction.php',
|
||||||
|
@ -1884,7 +1882,6 @@ phutil_register_library_map(array(
|
||||||
'PonderAnsweredMail' => 'applications/ponder/mail/PonderAnsweredMail.php',
|
'PonderAnsweredMail' => 'applications/ponder/mail/PonderAnsweredMail.php',
|
||||||
'PonderComment' => 'applications/ponder/storage/PonderComment.php',
|
'PonderComment' => 'applications/ponder/storage/PonderComment.php',
|
||||||
'PonderCommentEditor' => 'applications/ponder/editor/PonderCommentEditor.php',
|
'PonderCommentEditor' => 'applications/ponder/editor/PonderCommentEditor.php',
|
||||||
'PonderCommentListView' => 'applications/ponder/view/PonderCommentListView.php',
|
|
||||||
'PonderCommentMail' => 'applications/ponder/mail/PonderCommentMail.php',
|
'PonderCommentMail' => 'applications/ponder/mail/PonderCommentMail.php',
|
||||||
'PonderCommentQuery' => 'applications/ponder/query/PonderCommentQuery.php',
|
'PonderCommentQuery' => 'applications/ponder/query/PonderCommentQuery.php',
|
||||||
'PonderConstants' => 'applications/ponder/constants/PonderConstants.php',
|
'PonderConstants' => 'applications/ponder/constants/PonderConstants.php',
|
||||||
|
@ -1898,7 +1895,6 @@ phutil_register_library_map(array(
|
||||||
'PonderPostBodyView' => 'applications/ponder/view/PonderPostBodyView.php',
|
'PonderPostBodyView' => 'applications/ponder/view/PonderPostBodyView.php',
|
||||||
'PonderQuestion' => 'applications/ponder/storage/PonderQuestion.php',
|
'PonderQuestion' => 'applications/ponder/storage/PonderQuestion.php',
|
||||||
'PonderQuestionCommentController' => 'applications/ponder/controller/PonderQuestionCommentController.php',
|
'PonderQuestionCommentController' => 'applications/ponder/controller/PonderQuestionCommentController.php',
|
||||||
'PonderQuestionDetailView' => 'applications/ponder/view/PonderQuestionDetailView.php',
|
|
||||||
'PonderQuestionEditController' => 'applications/ponder/controller/PonderQuestionEditController.php',
|
'PonderQuestionEditController' => 'applications/ponder/controller/PonderQuestionEditController.php',
|
||||||
'PonderQuestionEditor' => 'applications/ponder/editor/PonderQuestionEditor.php',
|
'PonderQuestionEditor' => 'applications/ponder/editor/PonderQuestionEditor.php',
|
||||||
'PonderQuestionHistoryController' => 'applications/ponder/controller/PonderQuestionHistoryController.php',
|
'PonderQuestionHistoryController' => 'applications/ponder/controller/PonderQuestionHistoryController.php',
|
||||||
|
@ -3986,7 +3982,6 @@ phutil_register_library_map(array(
|
||||||
'PhrictionSearchEngine' => 'PhabricatorApplicationSearchEngine',
|
'PhrictionSearchEngine' => 'PhabricatorApplicationSearchEngine',
|
||||||
'PhrictionSearchIndexer' => 'PhabricatorSearchDocumentIndexer',
|
'PhrictionSearchIndexer' => 'PhabricatorSearchDocumentIndexer',
|
||||||
'PonderAddAnswerView' => 'AphrontView',
|
'PonderAddAnswerView' => 'AphrontView',
|
||||||
'PonderAddCommentView' => 'AphrontView',
|
|
||||||
'PonderAnswer' =>
|
'PonderAnswer' =>
|
||||||
array(
|
array(
|
||||||
0 => 'PonderDAO',
|
0 => 'PonderDAO',
|
||||||
|
@ -4000,7 +3995,6 @@ phutil_register_library_map(array(
|
||||||
'PonderAnswerEditController' => 'PonderController',
|
'PonderAnswerEditController' => 'PonderController',
|
||||||
'PonderAnswerEditor' => 'PhabricatorApplicationTransactionEditor',
|
'PonderAnswerEditor' => 'PhabricatorApplicationTransactionEditor',
|
||||||
'PonderAnswerHistoryController' => 'PonderController',
|
'PonderAnswerHistoryController' => 'PonderController',
|
||||||
'PonderAnswerListView' => 'AphrontView',
|
|
||||||
'PonderAnswerQuery' => 'PhabricatorCursorPagedPolicyAwareQuery',
|
'PonderAnswerQuery' => 'PhabricatorCursorPagedPolicyAwareQuery',
|
||||||
'PonderAnswerSaveController' => 'PonderController',
|
'PonderAnswerSaveController' => 'PonderController',
|
||||||
'PonderAnswerTransaction' => 'PhabricatorApplicationTransaction',
|
'PonderAnswerTransaction' => 'PhabricatorApplicationTransaction',
|
||||||
|
@ -4014,7 +4008,6 @@ phutil_register_library_map(array(
|
||||||
1 => 'PhabricatorMarkupInterface',
|
1 => 'PhabricatorMarkupInterface',
|
||||||
),
|
),
|
||||||
'PonderCommentEditor' => 'PhabricatorEditor',
|
'PonderCommentEditor' => 'PhabricatorEditor',
|
||||||
'PonderCommentListView' => 'AphrontView',
|
|
||||||
'PonderCommentMail' => 'PonderMail',
|
'PonderCommentMail' => 'PonderMail',
|
||||||
'PonderCommentQuery' => 'PhabricatorQuery',
|
'PonderCommentQuery' => 'PhabricatorQuery',
|
||||||
'PonderController' => 'PhabricatorController',
|
'PonderController' => 'PhabricatorController',
|
||||||
|
@ -4035,7 +4028,6 @@ phutil_register_library_map(array(
|
||||||
5 => 'PhabricatorTokenReceiverInterface',
|
5 => 'PhabricatorTokenReceiverInterface',
|
||||||
),
|
),
|
||||||
'PonderQuestionCommentController' => 'PonderController',
|
'PonderQuestionCommentController' => 'PonderController',
|
||||||
'PonderQuestionDetailView' => 'AphrontView',
|
|
||||||
'PonderQuestionEditController' => 'PonderController',
|
'PonderQuestionEditController' => 'PonderController',
|
||||||
'PonderQuestionEditor' => 'PhabricatorApplicationTransactionEditor',
|
'PonderQuestionEditor' => 'PhabricatorApplicationTransactionEditor',
|
||||||
'PonderQuestionHistoryController' => 'PonderController',
|
'PonderQuestionHistoryController' => 'PonderController',
|
||||||
|
|
|
@ -60,8 +60,7 @@ final class PhabricatorApplicationPonder extends PhabricatorApplication {
|
||||||
'question/preview/' => 'PonderQuestionPreviewController',
|
'question/preview/' => 'PonderQuestionPreviewController',
|
||||||
'question/(?P<status>open|close)/(?P<id>[1-9]\d*)/' =>
|
'question/(?P<status>open|close)/(?P<id>[1-9]\d*)/' =>
|
||||||
'PonderQuestionStatusController',
|
'PonderQuestionStatusController',
|
||||||
'(?P<kind>question)/vote/' => 'PonderVoteSaveController',
|
'vote/' => 'PonderVoteSaveController',
|
||||||
'(?P<kind>answer)/vote/' => 'PonderVoteSaveController'
|
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,6 +17,7 @@ final class PonderQuestionViewController extends PonderController {
|
||||||
->setViewer($user)
|
->setViewer($user)
|
||||||
->withIDs(array($this->questionID))
|
->withIDs(array($this->questionID))
|
||||||
->needAnswers(true)
|
->needAnswers(true)
|
||||||
|
->needViewerVotes(true)
|
||||||
->executeOne();
|
->executeOne();
|
||||||
if (!$question) {
|
if (!$question) {
|
||||||
return new Aphront404Response();
|
return new Aphront404Response();
|
||||||
|
@ -149,11 +150,20 @@ final class PonderQuestionViewController extends PonderController {
|
||||||
|
|
||||||
$view->invokeWillRenderEvent();
|
$view->invokeWillRenderEvent();
|
||||||
|
|
||||||
|
$votable = id(new PonderVotableView())
|
||||||
|
->setPHID($question->getPHID())
|
||||||
|
->setURI($this->getApplicationURI('vote/'))
|
||||||
|
->setCount($question->getVoteCount())
|
||||||
|
->setVote($question->getUserVote());
|
||||||
|
|
||||||
$view->addTextContent(
|
$view->addTextContent(
|
||||||
PhabricatorMarkupEngine::renderOneObject(
|
array(
|
||||||
$question,
|
$votable,
|
||||||
$question->getMarkupField(),
|
PhabricatorMarkupEngine::renderOneObject(
|
||||||
$viewer));
|
$question,
|
||||||
|
$question->getMarkupField(),
|
||||||
|
$viewer),
|
||||||
|
));
|
||||||
|
|
||||||
|
|
||||||
return $view;
|
return $view;
|
||||||
|
@ -314,16 +324,25 @@ final class PonderQuestionViewController extends PonderController {
|
||||||
|
|
||||||
$view->invokeWillRenderEvent();
|
$view->invokeWillRenderEvent();
|
||||||
|
|
||||||
|
$votable = id(new PonderVotableView())
|
||||||
|
->setPHID($answer->getPHID())
|
||||||
|
->setURI($this->getApplicationURI('vote/'))
|
||||||
|
->setCount($answer->getVoteCount())
|
||||||
|
->setVote($answer->getUserVote());
|
||||||
|
|
||||||
$view->addTextContent(
|
$view->addTextContent(
|
||||||
phutil_tag(
|
array(
|
||||||
'div',
|
$votable,
|
||||||
array(
|
phutil_tag(
|
||||||
'class' => 'phabricator-remarkup',
|
'div',
|
||||||
),
|
array(
|
||||||
PhabricatorMarkupEngine::renderOneObject(
|
'class' => 'phabricator-remarkup',
|
||||||
$answer,
|
),
|
||||||
$answer->getMarkupField(),
|
PhabricatorMarkupEngine::renderOneObject(
|
||||||
$viewer)));
|
$answer,
|
||||||
|
$answer->getMarkupField(),
|
||||||
|
$viewer)),
|
||||||
|
));
|
||||||
|
|
||||||
return $view;
|
return $view;
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,17 +2,11 @@
|
||||||
|
|
||||||
final class PonderVoteSaveController extends PonderController {
|
final class PonderVoteSaveController extends PonderController {
|
||||||
|
|
||||||
private $kind;
|
|
||||||
|
|
||||||
public function willProcessRequest(array $data) {
|
|
||||||
$this->kind = $data['kind'];
|
|
||||||
}
|
|
||||||
|
|
||||||
public function processRequest() {
|
public function processRequest() {
|
||||||
$request = $this->getRequest();
|
$request = $this->getRequest();
|
||||||
$user = $request->getUser();
|
$viewer = $request->getUser();
|
||||||
$newvote = $request->getInt("vote");
|
$phid = $request->getStr('phid');
|
||||||
$phid = $request->getStr("phid");
|
$newvote = $request->getInt('vote');
|
||||||
|
|
||||||
if (1 < $newvote || $newvote < -1) {
|
if (1 < $newvote || $newvote < -1) {
|
||||||
return new Aphront400Response();
|
return new Aphront400Response();
|
||||||
|
@ -20,28 +14,20 @@ final class PonderVoteSaveController extends PonderController {
|
||||||
|
|
||||||
$target = null;
|
$target = null;
|
||||||
|
|
||||||
if ($this->kind == "question") {
|
$object = id(new PhabricatorObjectQuery())
|
||||||
$target = id(new PonderQuestionQuery())
|
->setViewer($viewer)
|
||||||
->setViewer($user)
|
->withPHIDs(array($phid))
|
||||||
->withPHIDs(array($phid))
|
->executeOne();
|
||||||
->executeOne();
|
if (!$object) {
|
||||||
} else if ($this->kind == "answer") {
|
|
||||||
$target = id(new PonderAnswerQuery())
|
|
||||||
->setViewer($user)
|
|
||||||
->withPHIDs(array($phid))
|
|
||||||
->executeOne();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!$target) {
|
|
||||||
return new Aphront404Response();
|
return new Aphront404Response();
|
||||||
}
|
}
|
||||||
|
|
||||||
$editor = id(new PonderVoteEditor())
|
$editor = id(new PonderVoteEditor())
|
||||||
->setVotable($target)
|
->setVotable($object)
|
||||||
->setActor($user)
|
->setActor($viewer)
|
||||||
->setVote($newvote)
|
->setVote($newvote)
|
||||||
->saveVote();
|
->saveVote();
|
||||||
|
|
||||||
return id(new AphrontAjaxResponse())->setContent(".");
|
return id(new AphrontAjaxResponse())->setContent(array());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,6 +8,9 @@ final class PonderAnswerQuery
|
||||||
private $authorPHIDs;
|
private $authorPHIDs;
|
||||||
private $questionIDs;
|
private $questionIDs;
|
||||||
|
|
||||||
|
private $needViewerVotes;
|
||||||
|
|
||||||
|
|
||||||
public function withIDs(array $ids) {
|
public function withIDs(array $ids) {
|
||||||
$this->ids = $ids;
|
$this->ids = $ids;
|
||||||
return $this;
|
return $this;
|
||||||
|
@ -28,6 +31,11 @@ final class PonderAnswerQuery
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function needViewerVotes($need_viewer_votes) {
|
||||||
|
$this->needViewerVotes = $need_viewer_votes;
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
private function buildWhereClause($conn_r) {
|
private function buildWhereClause($conn_r) {
|
||||||
$where = array();
|
$where = array();
|
||||||
|
|
||||||
|
@ -78,11 +86,36 @@ final class PonderAnswerQuery
|
||||||
->withIDs(mpull($answers, 'getQuestionID'))
|
->withIDs(mpull($answers, 'getQuestionID'))
|
||||||
->execute();
|
->execute();
|
||||||
|
|
||||||
foreach ($answers as $answer) {
|
foreach ($answers as $key => $answer) {
|
||||||
$question = idx($questions, $answer->getQuestionID());
|
$question = idx($questions, $answer->getQuestionID());
|
||||||
|
if (!$question) {
|
||||||
|
unset($answers[$key]);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
$answer->attachQuestion($question);
|
$answer->attachQuestion($question);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ($this->needViewerVotes) {
|
||||||
|
$viewer_phid = $this->getViewer()->getPHID();
|
||||||
|
|
||||||
|
$etype = PhabricatorEdgeConfig::TYPE_ANSWER_HAS_VOTING_USER;
|
||||||
|
$edges = id(new PhabricatorEdgeQuery())
|
||||||
|
->withSourcePHIDs(mpull($answers, 'getPHID'))
|
||||||
|
->withDestinationPHIDs(array($viewer_phid))
|
||||||
|
->withEdgeTypes(array($etype))
|
||||||
|
->needEdgeData(true)
|
||||||
|
->execute();
|
||||||
|
foreach ($answers as $answer) {
|
||||||
|
$user_edge = idx(
|
||||||
|
$edges[$answer->getPHID()][$etype],
|
||||||
|
$viewer_phid,
|
||||||
|
array());
|
||||||
|
|
||||||
|
$answer->attachUserVote($viewer_phid, idx($user_edge, 'data', 0));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
return $answers;
|
return $answers;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -18,6 +18,7 @@ final class PonderQuestionQuery
|
||||||
const STATUS_CLOSED = 'status-closed';
|
const STATUS_CLOSED = 'status-closed';
|
||||||
|
|
||||||
private $needAnswers;
|
private $needAnswers;
|
||||||
|
private $needViewerVotes;
|
||||||
|
|
||||||
public function withIDs(array $ids) {
|
public function withIDs(array $ids) {
|
||||||
$this->ids = $ids;
|
$this->ids = $ids;
|
||||||
|
@ -49,6 +50,11 @@ final class PonderQuestionQuery
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function needViewerVotes($need_viewer_votes) {
|
||||||
|
$this->needViewerVotes = $need_viewer_votes;
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
public function setOrder($order) {
|
public function setOrder($order) {
|
||||||
$this->order = $order;
|
$this->order = $order;
|
||||||
return $this;
|
return $this;
|
||||||
|
@ -133,10 +139,15 @@ final class PonderQuestionQuery
|
||||||
|
|
||||||
public function willFilterPage(array $questions) {
|
public function willFilterPage(array $questions) {
|
||||||
if ($this->needAnswers) {
|
if ($this->needAnswers) {
|
||||||
$answers = id(new PonderAnswerQuery())
|
$aquery = id(new PonderAnswerQuery())
|
||||||
->setViewer($this->getViewer())
|
->setViewer($this->getViewer())
|
||||||
->withQuestionIDs(mpull($questions, 'getID'))
|
->withQuestionIDs(mpull($questions, 'getID'));
|
||||||
->execute();
|
|
||||||
|
if ($this->needViewerVotes) {
|
||||||
|
$aquery->needViewerVotes($this->needViewerVotes);
|
||||||
|
}
|
||||||
|
|
||||||
|
$answers = $aquery->execute();
|
||||||
$answers = mgroup($answers, 'getQuestionID');
|
$answers = mgroup($answers, 'getQuestionID');
|
||||||
|
|
||||||
foreach ($questions as $question) {
|
foreach ($questions as $question) {
|
||||||
|
@ -144,6 +155,26 @@ final class PonderQuestionQuery
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ($this->needViewerVotes) {
|
||||||
|
$viewer_phid = $this->getViewer()->getPHID();
|
||||||
|
|
||||||
|
$etype = PhabricatorEdgeConfig::TYPE_QUESTION_HAS_VOTING_USER;
|
||||||
|
$edges = id(new PhabricatorEdgeQuery())
|
||||||
|
->withSourcePHIDs(mpull($questions, 'getPHID'))
|
||||||
|
->withDestinationPHIDs(array($viewer_phid))
|
||||||
|
->withEdgeTypes(array($etype))
|
||||||
|
->needEdgeData(true)
|
||||||
|
->execute();
|
||||||
|
foreach ($questions as $question) {
|
||||||
|
$user_edge = idx(
|
||||||
|
$edges[$question->getPHID()][$etype],
|
||||||
|
$viewer_phid,
|
||||||
|
array());
|
||||||
|
|
||||||
|
$question->attachUserVote($viewer_phid, idx($user_edge, 'data', 0));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return $questions;
|
return $questions;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -21,6 +21,8 @@ final class PonderAnswer extends PonderDAO
|
||||||
private $question = self::ATTACHABLE;
|
private $question = self::ATTACHABLE;
|
||||||
private $comments;
|
private $comments;
|
||||||
|
|
||||||
|
private $userVotes = array();
|
||||||
|
|
||||||
// TODO: Get rid of this method.
|
// TODO: Get rid of this method.
|
||||||
public function setQuestion($question) {
|
public function setQuestion($question) {
|
||||||
return $this->attachQuestion($question);
|
return $this->attachQuestion($question);
|
||||||
|
@ -43,6 +45,11 @@ final class PonderAnswer extends PonderDAO
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function attachUserVote($user_phid, $vote) {
|
||||||
|
$this->vote = $vote;
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
public function getUserVote() {
|
public function getUserVote() {
|
||||||
return $this->vote;
|
return $this->vote;
|
||||||
}
|
}
|
||||||
|
|
|
@ -101,6 +101,11 @@ final class PonderQuestion extends PonderDAO
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function attachUserVote($user_phid, $vote) {
|
||||||
|
$this->vote = $vote;
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
public function getUserVote() {
|
public function getUserVote() {
|
||||||
return $this->vote;
|
return $this->vote;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,56 +0,0 @@
|
||||||
<?php
|
|
||||||
|
|
||||||
final class PonderAddCommentView extends AphrontView {
|
|
||||||
|
|
||||||
private $target;
|
|
||||||
private $actionURI;
|
|
||||||
private $questionID;
|
|
||||||
|
|
||||||
public function setTarget($target) {
|
|
||||||
$this->target = $target;
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function setQuestionID($id) {
|
|
||||||
$this->questionID = $id;
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function setActionURI($uri) {
|
|
||||||
$this->actionURI = $uri;
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function render() {
|
|
||||||
require_celerity_resource('ponder-comment-table-css');
|
|
||||||
|
|
||||||
$is_serious = PhabricatorEnv::getEnvConfig('phabricator.serious-business');
|
|
||||||
|
|
||||||
$questionID = $this->questionID;
|
|
||||||
$target = $this->target;
|
|
||||||
|
|
||||||
$form = new AphrontFormView();
|
|
||||||
$form
|
|
||||||
->setUser($this->user)
|
|
||||||
->setAction($this->actionURI)
|
|
||||||
->setNoShading(true)
|
|
||||||
->setWorkflow(true)
|
|
||||||
->addHiddenInput('target', $target)
|
|
||||||
->addHiddenInput('question_id', $questionID)
|
|
||||||
->appendChild(
|
|
||||||
id(new AphrontFormTextAreaControl())
|
|
||||||
->setName('content'))
|
|
||||||
->appendChild(
|
|
||||||
id(new AphrontFormSubmitControl())
|
|
||||||
->setValue($is_serious ?
|
|
||||||
pht('Submit') :
|
|
||||||
pht('Editorialize')));
|
|
||||||
|
|
||||||
$view = id(new AphrontMoreView())
|
|
||||||
->setSome('')
|
|
||||||
->setMore($form->render())
|
|
||||||
->setExpandText(pht('Add Comment'));
|
|
||||||
|
|
||||||
return $view->render();
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,80 +0,0 @@
|
||||||
<?php
|
|
||||||
|
|
||||||
final class PonderAnswerListView extends AphrontView {
|
|
||||||
|
|
||||||
private $question;
|
|
||||||
private $handles;
|
|
||||||
private $answers;
|
|
||||||
|
|
||||||
public function setQuestion($question) {
|
|
||||||
$this->question = $question;
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function setHandles(array $handles) {
|
|
||||||
assert_instances_of($handles, 'PhabricatorObjectHandle');
|
|
||||||
$this->handles = $handles;
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function setAnswers(array $answers) {
|
|
||||||
assert_instances_of($answers, 'PonderAnswer');
|
|
||||||
|
|
||||||
$this->answers = array();
|
|
||||||
|
|
||||||
// group by descreasing score, randomizing
|
|
||||||
// order within groups
|
|
||||||
$by_score = mgroup($answers, 'getVoteCount');
|
|
||||||
$scores = array_keys($by_score);
|
|
||||||
rsort($scores);
|
|
||||||
|
|
||||||
foreach ($scores as $score) {
|
|
||||||
$group = $by_score[$score];
|
|
||||||
shuffle($group);
|
|
||||||
foreach ($group as $cur_answer) {
|
|
||||||
$this->answers[] = $cur_answer;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function render() {
|
|
||||||
require_celerity_resource('ponder-post-css');
|
|
||||||
|
|
||||||
$question = $this->question;
|
|
||||||
$user = $this->user;
|
|
||||||
$handles = $this->handles;
|
|
||||||
|
|
||||||
$panel = id(new AphrontPanelView())
|
|
||||||
->setNoBackground()
|
|
||||||
->setHeader(pht("Responses"));
|
|
||||||
|
|
||||||
foreach ($this->answers as $cur_answer) {
|
|
||||||
$view = new PonderPostBodyView();
|
|
||||||
$view
|
|
||||||
->setQuestion($question)
|
|
||||||
->setTarget($cur_answer)
|
|
||||||
->setAction(PonderLiterals::LITERAL_ANSWERED)
|
|
||||||
->setHandles($handles)
|
|
||||||
->setUser($user);
|
|
||||||
|
|
||||||
$commentview = new PonderCommentListView();
|
|
||||||
$commentview
|
|
||||||
->setUser($user)
|
|
||||||
->setHandles($handles)
|
|
||||||
->setComments($cur_answer->getComments())
|
|
||||||
->setTarget($cur_answer->getPHID())
|
|
||||||
->setQuestionID($question->getID())
|
|
||||||
->setActionURI(new PhutilURI('/ponder/comment/add/'));
|
|
||||||
|
|
||||||
$panel->appendChild($view);
|
|
||||||
$panel->appendChild($commentview);
|
|
||||||
$panel->appendChild(
|
|
||||||
hsprintf('<div style="height: 20px; clear: both"></div>'));
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
return $panel->render();
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,90 +0,0 @@
|
||||||
<?php
|
|
||||||
|
|
||||||
final class PonderCommentListView extends AphrontView {
|
|
||||||
private $handles;
|
|
||||||
private $comments;
|
|
||||||
private $target;
|
|
||||||
private $actionURI;
|
|
||||||
private $questionID;
|
|
||||||
|
|
||||||
public function setHandles(array $handles) {
|
|
||||||
assert_instances_of($handles, 'PhabricatorObjectHandle');
|
|
||||||
$this->handles = $handles;
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function setComments(array $comments) {
|
|
||||||
assert_instances_of($comments, 'PonderComment');
|
|
||||||
$this->comments = $comments;
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function setQuestionID($id) {
|
|
||||||
$this->questionID = $id;
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function setActionURI($uri) {
|
|
||||||
$this->actionURI = $uri;
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function setTarget($target) {
|
|
||||||
$this->target = $target;
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function render() {
|
|
||||||
require_celerity_resource('phabricator-remarkup-css');
|
|
||||||
require_celerity_resource('ponder-comment-table-css');
|
|
||||||
|
|
||||||
$user = $this->user;
|
|
||||||
$handles = $this->handles;
|
|
||||||
$comments = $this->comments;
|
|
||||||
|
|
||||||
$comment_markup = array();
|
|
||||||
|
|
||||||
foreach ($comments as $comment) {
|
|
||||||
$handle = $handles[$comment->getAuthorPHID()];
|
|
||||||
$body = PhabricatorMarkupEngine::renderOneObject(
|
|
||||||
$comment,
|
|
||||||
$comment->getMarkupField(),
|
|
||||||
$this->user);
|
|
||||||
|
|
||||||
$comment_anchor = '';
|
|
||||||
$comment_markup[] = hsprintf(
|
|
||||||
'<tr>'.
|
|
||||||
'<th><a name="comment-%s" /></th>'.
|
|
||||||
'<td>'.
|
|
||||||
'<div class="phabricator-remarkup ponder-comment-markup">'.
|
|
||||||
'%s -%s <span class="ponder-datestamp">%s</span>'.
|
|
||||||
'</div>'.
|
|
||||||
'</td>'.
|
|
||||||
'</tr>',
|
|
||||||
$comment->getID(),
|
|
||||||
$body,
|
|
||||||
$handle->renderLink(),
|
|
||||||
phabricator_datetime($comment->getDateCreated(), $user));
|
|
||||||
}
|
|
||||||
|
|
||||||
$addview = id(new PonderAddCommentView)
|
|
||||||
->setTarget($this->target)
|
|
||||||
->setUser($user)
|
|
||||||
->setQuestionID($this->questionID)
|
|
||||||
->setActionURI($this->actionURI);
|
|
||||||
|
|
||||||
$comment_markup[] = hsprintf(
|
|
||||||
'<tr><th> </th><td>%s</td></tr>',
|
|
||||||
$addview->render());
|
|
||||||
|
|
||||||
$comment_markup = phutil_tag(
|
|
||||||
'table',
|
|
||||||
array(
|
|
||||||
'class' => 'ponder-comments',
|
|
||||||
),
|
|
||||||
$comment_markup);
|
|
||||||
|
|
||||||
return $comment_markup;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
|
@ -97,24 +97,7 @@ final class PonderPostBodyView extends AphrontView {
|
||||||
),
|
),
|
||||||
$content));
|
$content));
|
||||||
|
|
||||||
$outerview = $xaction_view;
|
return $xaction_view;
|
||||||
if (!$this->preview) {
|
|
||||||
$outerview =
|
|
||||||
id(new PonderVotableView())
|
|
||||||
->setPHID($target->getPHID())
|
|
||||||
->setCount($target->getVoteCount())
|
|
||||||
->setVote($target->getUserVote());
|
|
||||||
|
|
||||||
if ($this->target instanceof PonderAnswer) {
|
|
||||||
$outerview->setURI('/ponder/answer/vote/');
|
|
||||||
} else {
|
|
||||||
$outerview->setURI('/ponder/question/vote/');
|
|
||||||
}
|
|
||||||
|
|
||||||
$outerview->appendChild($xaction_view);
|
|
||||||
}
|
|
||||||
|
|
||||||
return $outerview->render();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,50 +0,0 @@
|
||||||
<?php
|
|
||||||
|
|
||||||
final class PonderQuestionDetailView extends AphrontView {
|
|
||||||
|
|
||||||
private $question;
|
|
||||||
private $handles;
|
|
||||||
|
|
||||||
public function setQuestion($question) {
|
|
||||||
$this->question = $question;
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function setHandles($handles) {
|
|
||||||
$this->handles = $handles;
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function render() {
|
|
||||||
|
|
||||||
$question = $this->question;
|
|
||||||
$handles = $this->handles;
|
|
||||||
$user = $this->user;
|
|
||||||
|
|
||||||
$panel = id(new AphrontPanelView())
|
|
||||||
->setNoBackground(true);
|
|
||||||
|
|
||||||
$contentview = new PonderPostBodyView();
|
|
||||||
$contentview
|
|
||||||
->setTarget($question)
|
|
||||||
->setQuestion($question)
|
|
||||||
->setUser($user)
|
|
||||||
->setHandles($handles)
|
|
||||||
->setAction(PonderLiterals::LITERAL_ASKED);
|
|
||||||
|
|
||||||
$commentview = new PonderCommentListView();
|
|
||||||
$commentview
|
|
||||||
->setUser($user)
|
|
||||||
->setHandles($handles)
|
|
||||||
->setComments($question->getComments())
|
|
||||||
->setTarget($question->getPHID())
|
|
||||||
->setQuestionID($question->getID())
|
|
||||||
->setActionURI(new PhutilURI('/ponder/comment/add/'));
|
|
||||||
|
|
||||||
$panel->appendChild($contentview);
|
|
||||||
$panel->appendChild($commentview);
|
|
||||||
|
|
||||||
return $panel->render();
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
|
@ -2,60 +2,42 @@
|
||||||
* @provides ponder-vote-css
|
* @provides ponder-vote-css
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
.ponder-votable {
|
||||||
|
float: right;
|
||||||
|
margin: 4px 0 4px 24px;
|
||||||
|
}
|
||||||
|
|
||||||
.ponder-votebox {
|
.ponder-votebox {
|
||||||
|
border-radius: 4px;
|
||||||
|
background: #f3f3f3;
|
||||||
|
border: 1px solid #d7d7d7;
|
||||||
|
box-shadow: 1px 1px rgba(0, 0, 0, 0.05);
|
||||||
text-align: center;
|
text-align: center;
|
||||||
|
width: 24px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.ponder-votebox a {
|
.ponder-votebox a {
|
||||||
font-size: 20px;
|
font-size: 20px;
|
||||||
line-height: 20px;
|
line-height: 24px;
|
||||||
display: block;
|
display: block;
|
||||||
|
|
||||||
text-decoration: none;
|
text-decoration: none;
|
||||||
color: #a1a5a9;
|
color: #aaaaaa;
|
||||||
font-weight: normal;
|
font-weight: normal;
|
||||||
}
|
}
|
||||||
|
|
||||||
.ponder-votebox a:hover {
|
|
||||||
color: #606060;
|
|
||||||
}
|
|
||||||
|
|
||||||
.ponder-votebox a.ponder-vote-active {
|
.ponder-votebox a.ponder-vote-active {
|
||||||
color: #3b5998;
|
color: {$blue};
|
||||||
}
|
}
|
||||||
|
|
||||||
.ponder-votebox a.ponder-vote-active:hover {
|
.ponder-votebox a:hover {
|
||||||
color: #a1bbe5;
|
color: #ffffff;
|
||||||
|
background: {$blue};
|
||||||
}
|
}
|
||||||
|
|
||||||
.ponder-vote-count {
|
.ponder-vote-count {
|
||||||
color: #888888;
|
color: #333333;
|
||||||
font-size: 14px;
|
font-size: 14px;
|
||||||
line-height: 14px;
|
line-height: 20px;
|
||||||
font-weight: bold;
|
font-weight: bold;
|
||||||
}
|
}
|
||||||
|
|
||||||
.ponder-votebox {
|
|
||||||
float: left;
|
|
||||||
width: 32px;
|
|
||||||
height: 60px;
|
|
||||||
margin-top: 56px;
|
|
||||||
margin-left: 10px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.device-phone .ponder-votebox {
|
|
||||||
margin: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
.device-phone .ponder-votebox-content {
|
|
||||||
margin-left: 35px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.ponder-votable .phabricator-transaction-view {
|
|
||||||
margin: 0;
|
|
||||||
padding: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
.ponder-votable .phabricator-transaction-detail {
|
|
||||||
min-height : 90px;
|
|
||||||
}
|
|
||||||
|
|
|
@ -91,6 +91,7 @@
|
||||||
padding: 12px 18px;
|
padding: 12px 18px;
|
||||||
background: #fdfdfd;
|
background: #fdfdfd;
|
||||||
border-bottom: 1px solid #dbdbdb;
|
border-bottom: 1px solid #dbdbdb;
|
||||||
|
overflow: hidden;
|
||||||
}
|
}
|
||||||
|
|
||||||
.phabricator-property-list-image-content {
|
.phabricator-property-list-image-content {
|
||||||
|
|
Loading…
Reference in a new issue