mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-09 06:11:01 +01:00
5883b4f50c
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
120 lines
3 KiB
PHP
120 lines
3 KiB
PHP
<?php
|
|
|
|
/*
|
|
* Copyright 2012 Facebook, Inc.
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
final class PonderCommentListView extends AphrontView {
|
|
private $user;
|
|
private $handles;
|
|
private $comments;
|
|
private $target;
|
|
private $actionURI;
|
|
private $questionID;
|
|
|
|
public function setUser(PhabricatorUser $user) {
|
|
$this->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 = '<a name="comment-' . $comment->getID() . '" />';
|
|
$comment_markup[] =
|
|
'<tr>'.
|
|
'<th>'.
|
|
$comment_anchor.
|
|
'</th>'.
|
|
'<td>'.
|
|
'<div class="phabricator-remarkup ponder-comment-markup">'.
|
|
$body.
|
|
' —'.
|
|
$handle->renderLink().
|
|
' '.
|
|
'<span class="ponder-datestamp">'.
|
|
phabricator_datetime($comment->getDateCreated(), $user).
|
|
'</span>'.
|
|
'</div>'.
|
|
'</td>'.
|
|
'</tr>';
|
|
}
|
|
|
|
$addview = id(new PonderAddCommentView)
|
|
->setTarget($this->target)
|
|
->setUser($user)
|
|
->setQuestionID($this->questionID)
|
|
->setActionURI($this->actionURI);
|
|
|
|
$comment_markup[] =
|
|
'<tr>'.
|
|
'<th> </th>'.
|
|
'<td>'.$addview->render().'</td>'.
|
|
'</tr>';
|
|
|
|
$comment_markup = phutil_render_tag(
|
|
'table',
|
|
array(
|
|
'class' => 'ponder-comments',
|
|
),
|
|
implode("\n", $comment_markup)
|
|
);
|
|
|
|
|
|
return $comment_markup;
|
|
}
|
|
|
|
}
|