From 5883b4f50c35b8f8b7346731f9b27c3b89fe9381 Mon Sep 17 00:00:00 2001 From: Pieter Hooimeijer Date: Tue, 11 Sep 2012 12:13:20 -0700 Subject: [PATCH] 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 --- resources/sql/patches/ponder-comments.sql | 11 ++ src/__celerity_resource_map__.php | 15 ++- src/__phutil_library_map__.php | 18 ++- .../PhabricatorApplicationPonder.php | 1 + .../PonderAnswerPreviewController.php | 2 +- .../PonderCommentSaveController.php | 58 +++++++++ .../PonderQuestionPreviewController.php | 2 +- .../PonderQuestionViewController.php | 14 +- .../ponder/query/PonderCommentQuery.php | 81 ++++++++++++ .../ponder/storage/PonderAnswer.php | 10 ++ .../ponder/storage/PonderComment.php | 57 +++++++++ .../ponder/storage/PonderQuestion.php | 23 ++++ .../ponder/view/PonderAddCommentView.php | 70 ++++++++++ .../ponder/view/PonderAnswerListView.php | 14 +- .../ponder/view/PonderCommentListView.php | 120 ++++++++++++++++++ ...entBodyView.php => PonderPostBodyView.php} | 2 +- .../ponder/view/PonderQuestionDetailView.php | 12 +- .../ponder/view/PonderVotableView.php | 1 - .../patch/PhabricatorBuiltinPatchList.php | 4 + .../rsrc/css/application/ponder/comments.css | 104 +++++++++++++++ webroot/rsrc/css/application/ponder/core.css | 11 +- webroot/rsrc/css/application/ponder/post.css | 15 ++- webroot/rsrc/css/application/ponder/vote.css | 7 +- 23 files changed, 631 insertions(+), 21 deletions(-) create mode 100644 resources/sql/patches/ponder-comments.sql create mode 100644 src/applications/ponder/controller/PonderCommentSaveController.php create mode 100644 src/applications/ponder/query/PonderCommentQuery.php create mode 100644 src/applications/ponder/storage/PonderComment.php create mode 100644 src/applications/ponder/view/PonderAddCommentView.php create mode 100644 src/applications/ponder/view/PonderCommentListView.php rename src/applications/ponder/view/{PonderCommentBodyView.php => PonderPostBodyView.php} (98%) create mode 100644 webroot/rsrc/css/application/ponder/comments.css diff --git a/resources/sql/patches/ponder-comments.sql b/resources/sql/patches/ponder-comments.sql new file mode 100644 index 0000000000..1f21bfc3e6 --- /dev/null +++ b/resources/sql/patches/ponder-comments.sql @@ -0,0 +1,11 @@ +CREATE TABLE `{$NAMESPACE}_ponder`.`ponder_comment` ( + `id` int(10) unsigned NOT NULL AUTO_INCREMENT, + `authorPHID` varchar(64) CHARACTER SET utf8 COLLATE utf8_bin NOT NULL, + `targetPHID` varchar(64) CHARACTER SET utf8 COLLATE utf8_bin NOT NULL, + `content` longtext CHARACTER SET utf8 NOT NULL, + `dateCreated` int(10) unsigned NOT NULL, + `dateModified` int(10) unsigned NOT NULL, + PRIMARY KEY (`id`), + KEY `authorPHID` (`authorPHID`), + KEY `targetPHID` (`targetPHID`) +) ENGINE=InnoDB DEFAULT CHARSET=utf8; \ No newline at end of file diff --git a/src/__celerity_resource_map__.php b/src/__celerity_resource_map__.php index 72368d272c..f855f10dda 100644 --- a/src/__celerity_resource_map__.php +++ b/src/__celerity_resource_map__.php @@ -2851,9 +2851,18 @@ celerity_register_resource_map(array( ), 'disk' => '/rsrc/css/application/phriction/phriction-document-css.css', ), + 'ponder-comment-table-css' => + array( + 'uri' => '/res/a1bb9056/rsrc/css/application/ponder/comments.css', + 'type' => 'css', + 'requires' => + array( + ), + 'disk' => '/rsrc/css/application/ponder/comments.css', + ), 'ponder-core-view-css' => array( - 'uri' => '/res/4a6e2fc7/rsrc/css/application/ponder/core.css', + 'uri' => '/res/3a2d5e18/rsrc/css/application/ponder/core.css', 'type' => 'css', 'requires' => array( @@ -2871,7 +2880,7 @@ celerity_register_resource_map(array( ), 'ponder-post-css' => array( - 'uri' => '/res/32c960df/rsrc/css/application/ponder/post.css', + 'uri' => '/res/013b9e2c/rsrc/css/application/ponder/post.css', 'type' => 'css', 'requires' => array( @@ -2880,7 +2889,7 @@ celerity_register_resource_map(array( ), 'ponder-vote-css' => array( - 'uri' => '/res/923bcf97/rsrc/css/application/ponder/vote.css', + 'uri' => '/res/d4dff9ba/rsrc/css/application/ponder/vote.css', 'type' => 'css', 'requires' => array( diff --git a/src/__phutil_library_map__.php b/src/__phutil_library_map__.php index a6e06216fd..2f0449d89e 100644 --- a/src/__phutil_library_map__.php +++ b/src/__phutil_library_map__.php @@ -1164,6 +1164,7 @@ phutil_register_library_map(array( 'PhrictionHistoryController' => 'applications/phriction/controller/PhrictionHistoryController.php', 'PhrictionListController' => 'applications/phriction/controller/PhrictionListController.php', 'PonderAddAnswerView' => 'applications/ponder/view/PonderAddAnswerView.php', + 'PonderAddCommentView' => 'applications/ponder/view/PonderAddCommentView.php', 'PonderAnswer' => 'applications/ponder/storage/PonderAnswer.php', 'PonderAnswerEditor' => 'applications/ponder/editor/PonderAnswerEditor.php', 'PonderAnswerListView' => 'applications/ponder/view/PonderAnswerListView.php', @@ -1172,11 +1173,15 @@ phutil_register_library_map(array( 'PonderAnswerSaveController' => 'applications/ponder/controller/PonderAnswerSaveController.php', 'PonderAnswerSummaryView' => 'applications/ponder/view/PonderAnswerSummaryView.php', 'PonderAnswerViewController' => 'applications/ponder/controller/PonderAnswerViewController.php', - 'PonderCommentBodyView' => 'applications/ponder/view/PonderCommentBodyView.php', + 'PonderComment' => 'applications/ponder/storage/PonderComment.php', + 'PonderCommentListView' => 'applications/ponder/view/PonderCommentListView.php', + 'PonderCommentQuery' => 'applications/ponder/query/PonderCommentQuery.php', + 'PonderCommentSaveController' => 'applications/ponder/controller/PonderCommentSaveController.php', 'PonderConstants' => 'applications/ponder/PonderConstants.php', 'PonderController' => 'applications/ponder/controller/PonderController.php', 'PonderDAO' => 'applications/ponder/storage/PonderDAO.php', 'PonderFeedController' => 'applications/ponder/controller/PonderFeedController.php', + 'PonderPostBodyView' => 'applications/ponder/view/PonderPostBodyView.php', 'PonderQuestion' => 'applications/ponder/storage/PonderQuestion.php', 'PonderQuestionAskController' => 'applications/ponder/controller/PonderQuestionAskController.php', 'PonderQuestionDetailView' => 'applications/ponder/view/PonderQuestionDetailView.php', @@ -2248,6 +2253,7 @@ phutil_register_library_map(array( 'PhrictionHistoryController' => 'PhrictionController', 'PhrictionListController' => 'PhrictionController', 'PonderAddAnswerView' => 'AphrontView', + 'PonderAddCommentView' => 'AphrontView', 'PonderAnswer' => array( 0 => 'PonderDAO', @@ -2260,10 +2266,18 @@ phutil_register_library_map(array( 'PonderAnswerSaveController' => 'PonderController', 'PonderAnswerSummaryView' => 'AphrontView', 'PonderAnswerViewController' => 'PonderController', - 'PonderCommentBodyView' => 'AphrontView', + 'PonderComment' => + array( + 0 => 'PonderDAO', + 1 => 'PhabricatorMarkupInterface', + ), + 'PonderCommentListView' => 'AphrontView', + 'PonderCommentQuery' => 'PhabricatorQuery', + 'PonderCommentSaveController' => 'PonderController', 'PonderController' => 'PhabricatorController', 'PonderDAO' => 'PhabricatorLiskDAO', 'PonderFeedController' => 'PonderController', + 'PonderPostBodyView' => 'AphrontView', 'PonderQuestion' => array( 0 => 'PonderDAO', diff --git a/src/applications/ponder/application/PhabricatorApplicationPonder.php b/src/applications/ponder/application/PhabricatorApplicationPonder.php index f85a9d2495..843ce14feb 100644 --- a/src/applications/ponder/application/PhabricatorApplicationPonder.php +++ b/src/applications/ponder/application/PhabricatorApplicationPonder.php @@ -53,6 +53,7 @@ final class PhabricatorApplicationPonder extends PhabricatorApplication { 'answer/preview/' => 'PonderAnswerPreviewController', 'question/ask/' => 'PonderQuestionAskController', 'question/preview/' => 'PonderQuestionPreviewController', + 'comment/add/' => 'PonderCommentSaveController', '(?Pquestion)/vote/' => 'PonderVoteSaveController', '(?Panswer)/vote/' => 'PonderVoteSaveController' )); diff --git a/src/applications/ponder/controller/PonderAnswerPreviewController.php b/src/applications/ponder/controller/PonderAnswerPreviewController.php index 9b4d3b7d92..6fc829c179 100644 --- a/src/applications/ponder/controller/PonderAnswerPreviewController.php +++ b/src/applications/ponder/controller/PonderAnswerPreviewController.php @@ -38,7 +38,7 @@ final class PonderAnswerPreviewController $answer->setContent($request->getStr('content')); $answer->setAuthorPHID($author_phid); - $view = new PonderCommentBodyView(); + $view = new PonderPostBodyView(); $view ->setQuestion($question) ->setTarget($answer) diff --git a/src/applications/ponder/controller/PonderCommentSaveController.php b/src/applications/ponder/controller/PonderCommentSaveController.php new file mode 100644 index 0000000000..2a81e2b48e --- /dev/null +++ b/src/applications/ponder/controller/PonderCommentSaveController.php @@ -0,0 +1,58 @@ +getRequest(); + if (!$request->isFormPost()) { + return new Aphront400Response(); + } + + $user = $request->getUser(); + $question_id = $request->getInt('question_id'); + $question = PonderQuestionQuery::loadSingle($user, $question_id); + + if (!$question) { + return new Aphront404Response(); + } + + $target = $request->getStr('target'); + $objects = id(new PhabricatorObjectHandleData(array($target))) + ->loadHandles(); + if (!$objects) { + return new Aphront404Response(); + } + $content = $request->getStr('content'); + + $res = new PonderComment(); + $res + ->setContent($content) + ->setAuthorPHID($user->getPHID()) + ->setTargetPHID($target) + ->save(); + + PhabricatorSearchPonderIndexer::indexQuestion($question); + + return id(new AphrontRedirectResponse()) + ->setURI( + id(new PhutilURI('/Q'. $question->getID())) + ->setFragment('comment-' . $res->getID())); + } + +} diff --git a/src/applications/ponder/controller/PonderQuestionPreviewController.php b/src/applications/ponder/controller/PonderQuestionPreviewController.php index 4725dabec3..64b64b7500 100644 --- a/src/applications/ponder/controller/PonderQuestionPreviewController.php +++ b/src/applications/ponder/controller/PonderQuestionPreviewController.php @@ -35,7 +35,7 @@ final class PonderQuestionPreviewController $question->setContent($request->getStr('content')); $question->setAuthorPHID($author_phid); - $view = new PonderCommentBodyView(); + $view = new PonderPostBodyView(); $view ->setQuestion($question) ->setTarget($question) diff --git a/src/applications/ponder/controller/PonderQuestionViewController.php b/src/applications/ponder/controller/PonderQuestionViewController.php index 5e3ef265a3..b15ac7d027 100644 --- a/src/applications/ponder/controller/PonderQuestionViewController.php +++ b/src/applications/ponder/controller/PonderQuestionViewController.php @@ -34,11 +34,21 @@ final class PonderQuestionViewController extends PonderController { return new Aphront404Response(); } $question->attachRelated($user->getPHID()); - $answers = $question->getAnswers(); - $object_phids = array($user->getPHID(), $question->getAuthorPHID()); + + $answers = $question->getAnswers(); + $comments = $question->getComments(); + foreach ($comments as $comment) { + $object_phids[] = $comment->getAuthorPHID(); + } + foreach ($answers as $answer) { $object_phids[] = $answer->getAuthorPHID(); + + $comments = $answer->getComments(); + foreach ($comments as $comment) { + $object_phids[] = $comment->getAuthorPHID(); + } } $handles = $this->loadViewerHandles($object_phids); diff --git a/src/applications/ponder/query/PonderCommentQuery.php b/src/applications/ponder/query/PonderCommentQuery.php new file mode 100644 index 0000000000..2982160614 --- /dev/null +++ b/src/applications/ponder/query/PonderCommentQuery.php @@ -0,0 +1,81 @@ +ids = $qids; + return $this; + } + + public function withTargetPHIDs($phids) { + $this->targetPHIDs = $phids; + return $this; + } + + public function withAuthorPHID($phid) { + $this->authorPHID = $phid; + return $this; + } + + private function buildWhereClause($conn_r) { + $where = array(); + if ($this->ids) { + $where[] = qsprintf($conn_r, 'id in (%Ls)', $this->ids); + } + if ($this->authorPHID) { + $where[] = qsprintf($conn_r, 'authorPHID = %s', $this->authorPHID); + } + if ($this->targetPHIDs) { + $where[] = qsprintf($conn_r, 'targetPHID in (%Ls)', $this->targetPHIDs); + } + + return $this->formatWhereClause($where); + } + + private function buildOrderByClause($conn_r) { + return 'ORDER BY id'; + } + + public function execute() { + $comment = new PonderComment(); + $conn_r = $comment->establishConnection('r'); + + $select = qsprintf( + $conn_r, + 'SELECT r.* FROM %T r', + $comment->getTableName()); + + $where = $this->buildWhereClause($conn_r); + $order_by = $this->buildOrderByClause($conn_r); + + return $comment->loadAllFromArray( + queryfx_all( + $conn_r, + '%Q %Q %Q', + $select, + $where, + $order_by)); + } + + +} diff --git a/src/applications/ponder/storage/PonderAnswer.php b/src/applications/ponder/storage/PonderAnswer.php index 26fc26ac02..cb9831a950 100644 --- a/src/applications/ponder/storage/PonderAnswer.php +++ b/src/applications/ponder/storage/PonderAnswer.php @@ -31,6 +31,7 @@ final class PonderAnswer extends PonderDAO protected $voteCount; private $vote; private $question = null; + private $comments; public function setQuestion($question) { $this->question = $question; @@ -53,6 +54,15 @@ final class PonderAnswer extends PonderDAO return $this->vote; } + public function setComments($comments) { + $this->comments = $comments; + return $this; + } + + public function getComments() { + return $this->comments; + } + public function getConfiguration() { return array( self::CONFIG_AUX_PHID => true, diff --git a/src/applications/ponder/storage/PonderComment.php b/src/applications/ponder/storage/PonderComment.php new file mode 100644 index 0000000000..13250c625f --- /dev/null +++ b/src/applications/ponder/storage/PonderComment.php @@ -0,0 +1,57 @@ +getMarkupText($field)); + $id = $this->getID(); + return "ponder:c{$id}:{$field}:{$hash}"; + } + + public function getMarkupText($field) { + return $this->getContent(); + } + + public function newMarkupEngine($field) { + return PhabricatorMarkupEngine::newPonderMarkupEngine(); + } + + public function didMarkupText( + $field, + $output, + PhutilMarkupEngine $engine) { + return $output; + } + + public function shouldUseMarkupCache($field) { + return (bool)$this->getID(); + } + + public function getMarkupField() { + return self::MARKUP_FIELD_CONTENT; + } +} + diff --git a/src/applications/ponder/storage/PonderQuestion.php b/src/applications/ponder/storage/PonderQuestion.php index 192df6d6c8..75661db481 100644 --- a/src/applications/ponder/storage/PonderQuestion.php +++ b/src/applications/ponder/storage/PonderQuestion.php @@ -34,6 +34,7 @@ final class PonderQuestion extends PonderDAO private $answers; private $vote; + private $comments; public function getConfiguration() { return array( @@ -76,10 +77,23 @@ final class PonderQuestion extends PonderDAO $edges[$user_phid][PhabricatorEdgeConfig::TYPE_VOTING_USER_HAS_ANSWER]; $edges = null; + if ($qa_phids) { + $comments = id(new PonderCommentQuery()) + ->withTargetPHIDs($qa_phids) + ->execute(); + + $comments = mgroup($comments, 'getTargetPHID'); + } + else { + $comments = array(); + } + $this->setUserVote(idx($question_edge, $this->getPHID())); + $this->setComments(idx($comments, $this->getPHID(), array())); foreach ($this->answers as $answer) { $answer->setQuestion($this); $answer->setUserVote(idx($answer_edges, $answer->getPHID())); + $answer->setComments(idx($comments, $answer->getPHID(), array())); } } @@ -95,6 +109,15 @@ final class PonderQuestion extends PonderDAO return $this->vote; } + public function setComments($comments) { + $this->comments = $comments; + return $this; + } + + public function getComments() { + return $this->comments; + } + public function getAnswers() { return $this->answers; } diff --git a/src/applications/ponder/view/PonderAddCommentView.php b/src/applications/ponder/view/PonderAddCommentView.php new file mode 100644 index 0000000000..f4ed0248f3 --- /dev/null +++ b/src/applications/ponder/view/PonderAddCommentView.php @@ -0,0 +1,70 @@ +target = $target; + return $this; + } + + public function setUser(PhabricatorUser $user) { + $this->user = $user; + 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) + ->addHiddenInput('target', $target) + ->addHiddenInput('question_id', $questionID) + ->appendChild( + id(new AphrontFormTextAreaControl()) + ->setName('content') + ->setEnableDragAndDropFileUploads(false)) + ->appendChild( + id(new AphrontFormSubmitControl()) + ->setValue($is_serious ? 'Submit' : 'Editorialize')); + + return $form->render(); + } +} diff --git a/src/applications/ponder/view/PonderAnswerListView.php b/src/applications/ponder/view/PonderAnswerListView.php index dd4034be23..3e0adbb862 100644 --- a/src/applications/ponder/view/PonderAnswerListView.php +++ b/src/applications/ponder/view/PonderAnswerListView.php @@ -73,7 +73,7 @@ final class PonderAnswerListView extends AphrontView { ->setHeader("Responses:"); foreach ($this->answers as $cur_answer) { - $view = new PonderCommentBodyView(); + $view = new PonderPostBodyView(); $view ->setQuestion($question) ->setTarget($cur_answer) @@ -81,7 +81,19 @@ final class PonderAnswerListView extends AphrontView { ->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('
'); + } return $panel->render(); diff --git a/src/applications/ponder/view/PonderCommentListView.php b/src/applications/ponder/view/PonderCommentListView.php new file mode 100644 index 0000000000..3100339bdb --- /dev/null +++ b/src/applications/ponder/view/PonderCommentListView.php @@ -0,0 +1,120 @@ +user = $user; + return $this; + } + + 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[] = + ''. + ''. + $comment_anchor. + ''. + ''. + '
'. + $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[] = + ''. + ' '. + ''.$addview->render().''. + ''; + + $comment_markup = phutil_render_tag( + 'table', + array( + 'class' => 'ponder-comments', + ), + implode("\n", $comment_markup) + ); + + + return $comment_markup; + } + +} diff --git a/src/applications/ponder/view/PonderCommentBodyView.php b/src/applications/ponder/view/PonderPostBodyView.php similarity index 98% rename from src/applications/ponder/view/PonderCommentBodyView.php rename to src/applications/ponder/view/PonderPostBodyView.php index b35407414f..7d1c3b77f4 100644 --- a/src/applications/ponder/view/PonderCommentBodyView.php +++ b/src/applications/ponder/view/PonderPostBodyView.php @@ -16,7 +16,7 @@ * limitations under the License. */ -final class PonderCommentBodyView extends AphrontView { +final class PonderPostBodyView extends AphrontView { private $target; private $question; diff --git a/src/applications/ponder/view/PonderQuestionDetailView.php b/src/applications/ponder/view/PonderQuestionDetailView.php index 7e9f56dcc5..f23c628b10 100644 --- a/src/applications/ponder/view/PonderQuestionDetailView.php +++ b/src/applications/ponder/view/PonderQuestionDetailView.php @@ -48,7 +48,7 @@ final class PonderQuestionDetailView extends AphrontView { ->addClass("ponder-panel") ->setHeader($this->renderObjectLink().' '.$question->getTitle()); - $contentview = new PonderCommentBodyView(); + $contentview = new PonderPostBodyView(); $contentview ->setTarget($question) ->setQuestion($question) @@ -56,7 +56,17 @@ final class PonderQuestionDetailView extends AphrontView { ->setHandles($handles) ->setAction(PonderConstants::ASKED_LITERAL); + $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(); } diff --git a/src/applications/ponder/view/PonderVotableView.php b/src/applications/ponder/view/PonderVotableView.php index 72c02f604f..d4fb401b5c 100644 --- a/src/applications/ponder/view/PonderVotableView.php +++ b/src/applications/ponder/view/PonderVotableView.php @@ -61,7 +61,6 @@ final class PonderVotableView extends AphrontView { '
'. $this->renderChildren(). - '
'. ''; return $content; diff --git a/src/infrastructure/storage/patch/PhabricatorBuiltinPatchList.php b/src/infrastructure/storage/patch/PhabricatorBuiltinPatchList.php index 0d10dd2e36..2990f95b5c 100644 --- a/src/infrastructure/storage/patch/PhabricatorBuiltinPatchList.php +++ b/src/infrastructure/storage/patch/PhabricatorBuiltinPatchList.php @@ -972,6 +972,10 @@ final class PhabricatorBuiltinPatchList extends PhabricatorSQLPatchList { 'type' => 'sql', 'name' => $this->getPatchPath('edgetype.sql'), ), + 'ponder-comments.sql' => array( + 'type' => 'sql', + 'name' => $this->getPatchPath('ponder-comments.sql'), + ), ); } diff --git a/webroot/rsrc/css/application/ponder/comments.css b/webroot/rsrc/css/application/ponder/comments.css new file mode 100644 index 0000000000..389347af2e --- /dev/null +++ b/webroot/rsrc/css/application/ponder/comments.css @@ -0,0 +1,104 @@ +/** + * @provides ponder-comment-table-css + */ + + +.ponder-comments { + width: 600px; + margin : 0; + margin-left : 120px; +} + +.ponder-comments th { + width : 0px; + height : 0px; +} + +.ponder-comments td { + vertical-align: top; + padding: 6px 2px; + border-bottom: 1px dotted #d0d0d0; + background : #FFF; +} + +.ponder-datestamp { + font-size: 9px; + font-family: "Verdana"; + color: #666666; +} + +.ponder-label { + display: block; + width: 100%; + font-size: 14px; + font-weight: bold; + color: #222222; + text-align: left; + margin: 0px 0px 6px; + padding: 6px 4px; + background: #cccccc; + border-bottom: 1px solid #aaaaaa; + cursor: pointer; +} + +td .aphront-form-control { + padding : 0; +} + +td .aphront-form-control-submit { + float : right; + margin : 0; + padding : 0; +} + +.aphront-form-control-submit button { + margin : 0; +} + + +td .aphront-form-input { + margin : 0; + width : 100%; +} + +td .aphront-form-control textarea { + height : 40px; + width : 560px; + padding : 0; + margin : 0; + background : #EEE; + border : 1px solid #CCC; +} + +div.ponder-comment-markup { + padding-left : 5px; +} + + +.ponder-comment-markup p { + margin : 0; +} + +.ponder-comment-markup h2 { + margin : 0; + font-size : inherit; + font-weight : normal; +} + +.ponder-comment-markup h3 { + margin : 0; + font-size : inherit; + font-weight : normal; +} + +.ponder-comment-markup h4 { + margin : 0; + font-size : inherit; + font-weight : normal; +} + +.ponder-comment-markup h5 { + margin : 0; + font-size : inherit; + font-weight : normal; +} diff --git a/webroot/rsrc/css/application/ponder/core.css b/webroot/rsrc/css/application/ponder/core.css index 327f20c83b..3334c7c929 100644 --- a/webroot/rsrc/css/application/ponder/core.css +++ b/webroot/rsrc/css/application/ponder/core.css @@ -10,13 +10,18 @@ .ponder-panel { max-width: 800px; - font-family : antiqua, verdana, arial; + padding-left : 30px; + border : none; + background : white; } .ponder-panel h1 { - padding-bottom: 8px; - margin-bottom: 8px; + margin-left : -30px; + margin-right : -50px; + margin-bottom: 0px; + padding-bottom : 4px; font-size : 1.5em; + border-bottom : 1px solid #AAA; } .ponder-panel .aphront-form-view { diff --git a/webroot/rsrc/css/application/ponder/post.css b/webroot/rsrc/css/application/ponder/post.css index 30155ec4b8..4be6f5f5e1 100644 --- a/webroot/rsrc/css/application/ponder/post.css +++ b/webroot/rsrc/css/application/ponder/post.css @@ -20,15 +20,24 @@ width: 81ch; } +.ponder-question { + background : white; +} + .phabricator-transaction-view .ponder-question { - border-color: #777; + background : white; } .phabricator-transaction-detail .ponder-question { - border-color: #777; + border : none; } .phabricator-transaction-view .ponder-answer { -/* border-color: #203791; */ + background : white; + margin-bottom : 0; +} + +.phabricator-transaction-content { + background : white; } diff --git a/webroot/rsrc/css/application/ponder/vote.css b/webroot/rsrc/css/application/ponder/vote.css index 6d09e24d42..9e6e0e428d 100644 --- a/webroot/rsrc/css/application/ponder/vote.css +++ b/webroot/rsrc/css/application/ponder/vote.css @@ -2,8 +2,11 @@ * @provides ponder-vote-css */ -.ponder-votable { - min-height : 120px; + + +.ponder-votable .phabricator-transaction-view { + margin : 0; + padding : 0; } .ponder-votable .phabricator-transaction-detail {