mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-02 19:01:03 +01:00
AddCommentView
This commit is contained in:
parent
c55b1ed9bb
commit
5f32fb3283
7 changed files with 162 additions and 76 deletions
|
@ -65,6 +65,7 @@ phutil_register_library_map(array(
|
||||||
'ConduitAPI_user_find_Method' => 'applications/conduit/method/user/find',
|
'ConduitAPI_user_find_Method' => 'applications/conduit/method/user/find',
|
||||||
'ConduitException' => 'applications/conduit/protocol/exception',
|
'ConduitException' => 'applications/conduit/protocol/exception',
|
||||||
'DifferentialAction' => 'applications/differential/constants/action',
|
'DifferentialAction' => 'applications/differential/constants/action',
|
||||||
|
'DifferentialAddCommentView' => 'applications/differential/view/addcomment',
|
||||||
'DifferentialCCWelcomeMail' => 'applications/differential/mail/ccwelcome',
|
'DifferentialCCWelcomeMail' => 'applications/differential/mail/ccwelcome',
|
||||||
'DifferentialChangeType' => 'applications/differential/constants/changetype',
|
'DifferentialChangeType' => 'applications/differential/constants/changetype',
|
||||||
'DifferentialChangeset' => 'applications/differential/storage/changeset',
|
'DifferentialChangeset' => 'applications/differential/storage/changeset',
|
||||||
|
@ -224,6 +225,7 @@ phutil_register_library_map(array(
|
||||||
'ConduitAPI_differential_setdiffproperty_Method' => 'ConduitAPIMethod',
|
'ConduitAPI_differential_setdiffproperty_Method' => 'ConduitAPIMethod',
|
||||||
'ConduitAPI_file_upload_Method' => 'ConduitAPIMethod',
|
'ConduitAPI_file_upload_Method' => 'ConduitAPIMethod',
|
||||||
'ConduitAPI_user_find_Method' => 'ConduitAPIMethod',
|
'ConduitAPI_user_find_Method' => 'ConduitAPIMethod',
|
||||||
|
'DifferentialAddCommentView' => 'AphrontView',
|
||||||
'DifferentialCCWelcomeMail' => 'DifferentialReviewRequestMail',
|
'DifferentialCCWelcomeMail' => 'DifferentialReviewRequestMail',
|
||||||
'DifferentialChangeset' => 'DifferentialDAO',
|
'DifferentialChangeset' => 'DifferentialDAO',
|
||||||
'DifferentialChangesetDetailView' => 'AphrontView',
|
'DifferentialChangesetDetailView' => 'AphrontView',
|
||||||
|
|
|
@ -32,7 +32,7 @@ final class DifferentialAction {
|
||||||
const ACTION_CREATE = 'create';
|
const ACTION_CREATE = 'create';
|
||||||
const ACTION_ADDREVIEWERS = 'add_reviewers';
|
const ACTION_ADDREVIEWERS = 'add_reviewers';
|
||||||
|
|
||||||
public static function getActionVerb($action) {
|
public static function getActionPastTenseVerb($action) {
|
||||||
static $verbs = array(
|
static $verbs = array(
|
||||||
self::ACTION_COMMENT => 'commented on',
|
self::ACTION_COMMENT => 'commented on',
|
||||||
self::ACTION_ACCEPT => 'accepted',
|
self::ACTION_ACCEPT => 'accepted',
|
||||||
|
@ -56,4 +56,23 @@ final class DifferentialAction {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static function getActionVerb($action) {
|
||||||
|
static $verbs = array(
|
||||||
|
self::ACTION_COMMENT => 'Comment',
|
||||||
|
self::ACTION_ACCEPT => "Accept Revision \xE2\x9C\x94",
|
||||||
|
self::ACTION_REJECT => "Request Changes \xE2\x9C\x98",
|
||||||
|
self::ACTION_ABANDON => 'Abandon Revision',
|
||||||
|
self::ACTION_REQUEST => 'Request Review',
|
||||||
|
self::ACTION_RECLAIM => 'Reclaim Revision',
|
||||||
|
self::ACTION_RESIGN => 'Resign as Reviewer',
|
||||||
|
self::ACTION_ADDREVIEWERS => 'Add Reviewers',
|
||||||
|
);
|
||||||
|
|
||||||
|
if (!empty($verbs[$action])) {
|
||||||
|
return $verbs[$action];
|
||||||
|
} else {
|
||||||
|
return 'brazenly '.$action;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -80,6 +80,10 @@ class DifferentialRevisionViewController extends DifferentialController {
|
||||||
$changeset_view = new DifferentialChangesetListView();
|
$changeset_view = new DifferentialChangesetListView();
|
||||||
$changeset_view->setChangesets($changesets);
|
$changeset_view->setChangesets($changesets);
|
||||||
|
|
||||||
|
$comment_form = new DifferentialAddCommentView();
|
||||||
|
$comment_form->setRevision($revision);
|
||||||
|
$comment_form->setActions($this->getRevisionCommentActions($revision));
|
||||||
|
|
||||||
return $this->buildStandardPageResponse(
|
return $this->buildStandardPageResponse(
|
||||||
'<div class="differential-primary-pane">'.
|
'<div class="differential-primary-pane">'.
|
||||||
$revision_detail->render().
|
$revision_detail->render().
|
||||||
|
@ -87,6 +91,7 @@ class DifferentialRevisionViewController extends DifferentialController {
|
||||||
$diff_history->render().
|
$diff_history->render().
|
||||||
$toc_view->render().
|
$toc_view->render().
|
||||||
$changeset_view->render().
|
$changeset_view->render().
|
||||||
|
$comment_form->render().
|
||||||
'</div>',
|
'</div>',
|
||||||
array(
|
array(
|
||||||
'title' => $revision->getTitle(),
|
'title' => $revision->getTitle(),
|
||||||
|
@ -210,10 +215,60 @@ class DifferentialRevisionViewController extends DifferentialController {
|
||||||
return implode(', ', mpull($list, 'renderLink'));
|
return implode(', ', mpull($list, 'renderLink'));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private function getRevisionCommentActions(DifferentialRevision $revision) {
|
||||||
|
|
||||||
|
$actions = array(
|
||||||
|
DifferentialAction::ACTION_COMMENT => true,
|
||||||
|
);
|
||||||
|
|
||||||
|
$viewer_phid = $this->getRequest()->getUser()->getPHID();
|
||||||
|
$viewer_is_owner = ($viewer_phid == $revision->getAuthorPHID());
|
||||||
|
|
||||||
|
if ($viewer_is_owner) {
|
||||||
|
switch ($revision->getStatus()) {
|
||||||
|
case DifferentialRevisionStatus::NEEDS_REVIEW:
|
||||||
|
$actions[DifferentialAction::ACTION_ABANDON] = true;
|
||||||
|
break;
|
||||||
|
case DifferentialRevisionStatus::NEEDS_REVISION:
|
||||||
|
case DifferentialRevisionStatus::ACCEPTED:
|
||||||
|
$actions[DifferentialAction::ACTION_ABANDON] = true;
|
||||||
|
$actions[DifferentialAction::ACTION_REQUEST] = true;
|
||||||
|
break;
|
||||||
|
case DifferentialRevisionStatus::COMMITTED:
|
||||||
|
break;
|
||||||
|
case DifferentialRevisionStatus::ABANDONED:
|
||||||
|
$actions[DifferentialAction::ACTION_RECLAIM] = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
switch ($revision->getStatus()) {
|
||||||
|
case DifferentialRevisionStatus::NEEDS_REVIEW:
|
||||||
|
$actions[DifferentialAction::ACTION_ACCEPT] = true;
|
||||||
|
$actions[DifferentialAction::ACTION_REJECT] = true;
|
||||||
|
break;
|
||||||
|
case DifferentialRevisionStatus::NEEDS_REVISION:
|
||||||
|
$actions[DifferentialAction::ACTION_ACCEPT] = true;
|
||||||
|
break;
|
||||||
|
case DifferentialRevisionStatus::ACCEPTED:
|
||||||
|
$actions[DifferentialAction::ACTION_REJECT] = true;
|
||||||
|
break;
|
||||||
|
case DifferentialRevisionStatus::COMMITTED:
|
||||||
|
case DifferentialRevisionStatus::ABANDONED:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$actions[DifferentialAction::ACTION_ADDREVIEWERS] = true;
|
||||||
|
|
||||||
|
return array_keys($actions);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
/*
|
/*
|
||||||
|
|
||||||
|
|
||||||
|
protected function getRevisionActions(DifferentialRevision $revision) {
|
||||||
|
|
||||||
$viewer_id = $this->getRequest()->getViewerContext()->getUserID();
|
$viewer_id = $this->getRequest()->getViewerContext()->getUserID();
|
||||||
$viewer_is_owner = ($viewer_id == $revision->getOwnerID());
|
$viewer_is_owner = ($viewer_id == $revision->getOwnerID());
|
||||||
$viewer_is_reviewer =
|
$viewer_is_reviewer =
|
||||||
|
@ -1334,81 +1389,7 @@ class DifferentialRevisionViewController extends DifferentialController {
|
||||||
return $inline_comments;
|
return $inline_comments;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected function getRevisionActions(DifferentialRevision $revision) {
|
|
||||||
$actions = array(
|
|
||||||
'none' => true,
|
|
||||||
);
|
|
||||||
|
|
||||||
$viewer = $this->getRequest()->getViewerContext();
|
|
||||||
|
|
||||||
$viewer_is_owner = ($viewer->getUserID() == $revision->getOwnerID());
|
|
||||||
if ($viewer_is_owner) {
|
|
||||||
switch ($revision->getStatus()) {
|
|
||||||
case DifferentialConstants::NEEDS_REVIEW:
|
|
||||||
$actions['abandon'] = true;
|
|
||||||
break;
|
|
||||||
case DifferentialConstants::NEEDS_REVISION:
|
|
||||||
$actions['abandon'] = true;
|
|
||||||
$actions['request_review'] = true;
|
|
||||||
break;
|
|
||||||
case DifferentialConstants::ACCEPTED:
|
|
||||||
$actions['abandon'] = true;
|
|
||||||
$actions['request_review'] = true;
|
|
||||||
break;
|
|
||||||
case DifferentialConstants::COMMITTED:
|
|
||||||
break;
|
|
||||||
case DifferentialConstants::ABANDONED:
|
|
||||||
$actions['reclaim'] = true;
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
throw new Exception('Unknown DifferentialRevision status.');
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
switch ($revision->getStatus()) {
|
|
||||||
case DifferentialConstants::NEEDS_REVIEW:
|
|
||||||
$actions['accept'] = true;
|
|
||||||
$actions['reject'] = true;
|
|
||||||
break;
|
|
||||||
case DifferentialConstants::NEEDS_REVISION:
|
|
||||||
$actions['accept'] = true;
|
|
||||||
break;
|
|
||||||
case DifferentialConstants::ACCEPTED:
|
|
||||||
$actions['reject'] = true;
|
|
||||||
break;
|
|
||||||
case DifferentialConstants::COMMITTED:
|
|
||||||
break;
|
|
||||||
case DifferentialConstants::ABANDONED:
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
throw new Exception('Unknown DifferentialRevision status.');
|
|
||||||
}
|
|
||||||
|
|
||||||
if (in_array($viewer->getUserID(), $revision->getReviewers())) {
|
|
||||||
$actions['resign'] = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Put add reviewers at the bottom since it's rare relative to other
|
|
||||||
// actions, notably accept and reject
|
|
||||||
$actions['add_reviewers'] = true;
|
|
||||||
|
|
||||||
static $action_names = array(
|
|
||||||
'none' => 'Comment',
|
|
||||||
'abandon' => 'Abandon Revision',
|
|
||||||
'request_review' => 'Request Review',
|
|
||||||
'reclaim' => 'Reclaim Revision',
|
|
||||||
'accept' => "Accept Revision \xE2\x9C\x94",
|
|
||||||
'reject' => "Request Changes \xE2\x9C\x98",
|
|
||||||
'resign' => "Resign as Reviewer",
|
|
||||||
'add_reviewers' => "Add Reviewers",
|
|
||||||
);
|
|
||||||
|
|
||||||
foreach ($actions as $key => $value) {
|
|
||||||
$actions[$key] = $action_names[$key];
|
|
||||||
}
|
|
||||||
|
|
||||||
return $actions;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected function getRevisionStatusDisplay(DifferentialRevision $revision) {
|
protected function getRevisionStatusDisplay(DifferentialRevision $revision) {
|
||||||
$viewer_id = $this->getRequest()->getViewerContext()->getUserID();
|
$viewer_id = $this->getRequest()->getViewerContext()->getUserID();
|
||||||
|
|
|
@ -12,6 +12,7 @@ phutil_require_module('phabricator', 'applications/differential/constants/revisi
|
||||||
phutil_require_module('phabricator', 'applications/differential/controller/base');
|
phutil_require_module('phabricator', 'applications/differential/controller/base');
|
||||||
phutil_require_module('phabricator', 'applications/differential/storage/comment');
|
phutil_require_module('phabricator', 'applications/differential/storage/comment');
|
||||||
phutil_require_module('phabricator', 'applications/differential/storage/revision');
|
phutil_require_module('phabricator', 'applications/differential/storage/revision');
|
||||||
|
phutil_require_module('phabricator', 'applications/differential/view/addcomment');
|
||||||
phutil_require_module('phabricator', 'applications/differential/view/changesetlistview');
|
phutil_require_module('phabricator', 'applications/differential/view/changesetlistview');
|
||||||
phutil_require_module('phabricator', 'applications/differential/view/difftableofcontents');
|
phutil_require_module('phabricator', 'applications/differential/view/difftableofcontents');
|
||||||
phutil_require_module('phabricator', 'applications/differential/view/revisioncommentlist');
|
phutil_require_module('phabricator', 'applications/differential/view/revisioncommentlist');
|
||||||
|
|
|
@ -0,0 +1,66 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Copyright 2011 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 DifferentialAddCommentView extends AphrontView {
|
||||||
|
|
||||||
|
private $revision;
|
||||||
|
private $actions;
|
||||||
|
private $actionURI;
|
||||||
|
|
||||||
|
public function setRevision($revision) {
|
||||||
|
$this->revision = $revision;
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function setActions(array $actions) {
|
||||||
|
$this->actions = $actions;
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function setActionURI($uri) {
|
||||||
|
$this->actionURI = $uri;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function render() {
|
||||||
|
|
||||||
|
$actions = array();
|
||||||
|
foreach ($this->actions as $action) {
|
||||||
|
$actions[$action] = DifferentialAction::getActionVerb($action);
|
||||||
|
}
|
||||||
|
|
||||||
|
$form = new AphrontFormView();
|
||||||
|
$form
|
||||||
|
->setAction($this->actionURI)
|
||||||
|
->appendChild(
|
||||||
|
id(new AphrontFormSelectControl())
|
||||||
|
->setLabel('Action')
|
||||||
|
->setOptions($actions))
|
||||||
|
->appendChild(
|
||||||
|
id(new AphrontFormTextAreaControl())
|
||||||
|
->setLabel('Comment'))
|
||||||
|
->appendChild(
|
||||||
|
id(new AphrontFormSubmitControl())
|
||||||
|
->setValue('Comment'));
|
||||||
|
|
||||||
|
return
|
||||||
|
'<div class="differential-panel">'.
|
||||||
|
'<h1>Add Comment</h1>'.
|
||||||
|
$form->render().
|
||||||
|
'</div>';
|
||||||
|
}
|
||||||
|
}
|
17
src/applications/differential/view/addcomment/__init__.php
Normal file
17
src/applications/differential/view/addcomment/__init__.php
Normal file
|
@ -0,0 +1,17 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* This file is automatically generated. Lint this module to rebuild it.
|
||||||
|
* @generated
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
phutil_require_module('phabricator', 'applications/differential/constants/action');
|
||||||
|
phutil_require_module('phabricator', 'view/base');
|
||||||
|
phutil_require_module('phabricator', 'view/form/base');
|
||||||
|
phutil_require_module('phabricator', 'view/form/control/submit');
|
||||||
|
|
||||||
|
phutil_require_module('phutil', 'utils');
|
||||||
|
|
||||||
|
|
||||||
|
phutil_require_source('DifferentialAddCommentView.php');
|
|
@ -46,7 +46,7 @@ final class DifferentialRevisionCommentView extends AphrontView {
|
||||||
$author = $comment->getAuthorPHID();
|
$author = $comment->getAuthorPHID();
|
||||||
$author = $this->handles[$author]->renderLink();
|
$author = $this->handles[$author]->renderLink();
|
||||||
|
|
||||||
$verb = DifferentialAction::getActionVerb($comment->getAction());
|
$verb = DifferentialAction::getActionPastTenseVerb($comment->getAction());
|
||||||
$verb = phutil_escape_html($verb);
|
$verb = phutil_escape_html($verb);
|
||||||
|
|
||||||
$content = $comment->getContent();
|
$content = $comment->getContent();
|
||||||
|
|
Loading…
Reference in a new issue