1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-04 20:01:00 +01:00

Only table of contents are shown for large diffs by default.

Summary:
Differential used to only show diffs for the first 100 files. Now all
the files are shown in the table of contents and there is a link to
the standalone view for every file. The inline diffs can still be
seen, if user clicks "Show All Files Inline".

Inline comments can also be added in the standalone view, but there is
no form to submit them. The revision page must be reloaded to able to
submit the inline comment.

Test Plan:
Changed the limit to three for testing purposes and checked that a diff of
mine with 5 files had the links to the standalone views. Made sure that
adding a comment in a standalone view worked and that after reloading the
revision page the comment was visible. Changed the limit back to 100 and
made sure that my diff had all the files inline and that the anchor links
were working.

Reviewed By: jungejason
Reviewers: jungejason
CC: epriestley, simpkins, jungejason, tuomaspelkonen
Differential Revision: 147
This commit is contained in:
tuomaspelkonen 2011-04-15 14:25:23 -07:00
parent c223aaa79e
commit ecc32e4d08
6 changed files with 85 additions and 13 deletions

View file

@ -169,6 +169,7 @@ class DifferentialChangesetViewController extends DifferentialController {
$detail = new DifferentialChangesetDetailView(); $detail = new DifferentialChangesetDetailView();
$detail->setChangeset($changeset); $detail->setChangeset($changeset);
$detail->appendChild($output); $detail->appendChild($output);
$detail->setRevisionID($request->getInt('revision_id'));
$output = $output =
'<div class="differential-primary-pane">'. '<div class="differential-primary-pane">'.

View file

@ -99,19 +99,19 @@ class DifferentialRevisionViewController extends DifferentialController {
$warning->setSeverity(AphrontErrorView::SEVERITY_WARNING); $warning->setSeverity(AphrontErrorView::SEVERITY_WARNING);
$warning->setWidth(AphrontErrorView::WIDTH_WIDE); $warning->setWidth(AphrontErrorView::WIDTH_WIDE);
$warning->appendChild( $warning->appendChild(
"<p>This diff is very large and affects {$count} files. Only ". "<p>This diff is very large and affects {$count} files. Use ".
"the first {$limit} files are shown. ". "Table of Contents to open files in a standalone view. ".
"<strong>". "<strong>".
phutil_render_tag( phutil_render_tag(
'a', 'a',
array( array(
'href' => $request_uri->alter('large', 'true'), 'href' => $request_uri->alter('large', 'true'),
), ),
'Show All Files'). 'Show All Files Inline').
"</strong>"); "</strong>");
$warning = $warning->render(); $warning = $warning->render();
$visible_changesets = array_slice($changesets, 0, $limit, true); $visible_changesets = array();
} else { } else {
$warning = null; $warning = null;
$visible_changesets = $changesets; $visible_changesets = $changesets;
@ -176,6 +176,9 @@ class DifferentialRevisionViewController extends DifferentialController {
$toc_view = new DifferentialDiffTableOfContentsView(); $toc_view = new DifferentialDiffTableOfContentsView();
$toc_view->setChangesets($changesets); $toc_view->setChangesets($changesets);
$toc_view->setStandaloneViewLink(empty($visible_changesets));
$toc_view->setVsMap($vs_map);
$toc_view->setRevisionID($revision->getID());
$changeset_view = new DifferentialChangesetListView(); $changeset_view = new DifferentialChangesetListView();
$changeset_view->setChangesets($visible_changesets); $changeset_view->setChangesets($visible_changesets);
@ -205,8 +208,8 @@ class DifferentialRevisionViewController extends DifferentialController {
$revision_detail->render(). $revision_detail->render().
$comment_view->render(). $comment_view->render().
$diff_history->render(). $diff_history->render().
$toc_view->render().
$warning. $warning.
$toc_view->render().
$changeset_view->render(). $changeset_view->render().
$comment_form->render(). $comment_form->render().
'</div>', '</div>',

View file

@ -20,6 +20,7 @@ class DifferentialChangesetDetailView extends AphrontView {
private $changeset; private $changeset;
private $buttons = array(); private $buttons = array();
private $revisionID;
public function setChangeset($changeset) { public function setChangeset($changeset) {
$this->changeset = $changeset; $this->changeset = $changeset;
@ -31,11 +32,20 @@ class DifferentialChangesetDetailView extends AphrontView {
return $this; return $this;
} }
public function setRevisionID($revision_id) {
$this->revisionID = $revision_id;
return $this;
}
public function render() { public function render() {
require_celerity_resource('differential-changeset-view-css'); require_celerity_resource('differential-changeset-view-css');
require_celerity_resource('syntax-highlighting-css'); require_celerity_resource('syntax-highlighting-css');
$edit = false; // TODO if ($this->revisionID) {
$edit = true;
} else {
$edit = false;
}
$changeset = $this->changeset; $changeset = $this->changeset;
$class = 'differential-changeset'; $class = 'differential-changeset';
@ -65,6 +75,13 @@ class DifferentialChangesetDetailView extends AphrontView {
'<div style="clear: both;"></div>'. '<div style="clear: both;"></div>'.
$this->renderChildren()); $this->renderChildren());
if ($edit) {
Javelin::initBehavior(
'differential-edit-inline-comments', array(
'uri' => '/differential/comment/inline/edit/'.$this->revisionID.'/',
));
}
return $output; return $output;
} }

View file

@ -7,6 +7,7 @@
phutil_require_module('phabricator', 'infrastructure/celerity/api'); phutil_require_module('phabricator', 'infrastructure/celerity/api');
phutil_require_module('phabricator', 'infrastructure/javelin/api');
phutil_require_module('phabricator', 'infrastructure/javelin/markup'); phutil_require_module('phabricator', 'infrastructure/javelin/markup');
phutil_require_module('phabricator', 'view/base'); phutil_require_module('phabricator', 'view/base');

View file

@ -19,12 +19,31 @@
final class DifferentialDiffTableOfContentsView extends AphrontView { final class DifferentialDiffTableOfContentsView extends AphrontView {
private $changesets = array(); private $changesets = array();
private $standaloneViewLink = null;
private $renderURI = '/differential/changeset/';
private $revisionID;
public function setChangesets($changesets) { public function setChangesets($changesets) {
$this->changesets = $changesets; $this->changesets = $changesets;
return $this; return $this;
} }
public function setStandaloneViewLink($standalone_view_link) {
$this->standaloneViewLink = $standalone_view_link;
return $this;
}
public function setVsMap(array $vs_map) {
$this->vsMap = $vs_map;
return $this;
}
public function setRevisionID($revision_id) {
$this->revisionID = $revision_id;
return $this;
}
public function render() { public function render() {
require_celerity_resource('differential-core-view-css'); require_celerity_resource('differential-core-view-css');
@ -62,12 +81,40 @@ final class DifferentialDiffTableOfContentsView extends AphrontView {
} }
} }
} else { } else {
if ($this->standaloneViewLink) {
$id = $changeset->getID();
if ($id) {
$vs_id = idx($this->vsMap, $id);
} else {
$vs_id = null;
}
$ref = $changeset->getRenderingReference();
$detail_uri = new PhutilURI($this->renderURI);
$detail_uri->setQueryParams(
array(
'id' => $ref,
'vs' => $vs_id,
'whitespace' => 'TODO',
'revision_id' => $this->revisionID,
));
$link = phutil_render_tag(
'a',
array(
'href' => $detail_uri,
'target' => '_blank',
),
phutil_escape_html($display_file));
} else {
$link = phutil_render_tag( $link = phutil_render_tag(
'a', 'a',
array( array(
'href' => '#'.$changeset->getAnchorName(), 'href' => '#'.$changeset->getAnchorName(),
), ),
phutil_escape_html($display_file)); phutil_escape_html($display_file));
}
if ($type == DifferentialChangeType::TYPE_MOVE_HERE) { if ($type == DifferentialChangeType::TYPE_MOVE_HERE) {
$meta = 'Moved from '.phutil_escape_html($changeset->getOldFile()); $meta = 'Moved from '.phutil_escape_html($changeset->getOldFile());
} else if ($type == DifferentialChangeType::TYPE_COPY_HERE) { } else if ($type == DifferentialChangeType::TYPE_COPY_HERE) {
@ -99,7 +146,8 @@ final class DifferentialDiffTableOfContentsView extends AphrontView {
$rows[] = $rows[] =
'<tr>'. '<tr>'.
'<td class="differential-toc-char" title='.$chartitle.'>'.$char.'</td>'. '<td class="differential-toc-char" title='.$chartitle.'>'.$char.
'</td>'.
'<td class="differential-toc-prop">'.$pchar.'</td>'. '<td class="differential-toc-prop">'.$pchar.'</td>'.
'<td class="differential-toc-ftype">'.$desc.'</td>'. '<td class="differential-toc-ftype">'.$desc.'</td>'.
'<td class="differential-toc-file">'.$link.$lines.'</td>'. '<td class="differential-toc-file">'.$link.$lines.'</td>'.

View file

@ -11,6 +11,8 @@ phutil_require_module('phabricator', 'infrastructure/celerity/api');
phutil_require_module('phabricator', 'view/base'); phutil_require_module('phabricator', 'view/base');
phutil_require_module('phutil', 'markup'); phutil_require_module('phutil', 'markup');
phutil_require_module('phutil', 'parser/uri');
phutil_require_module('phutil', 'utils');
phutil_require_source('DifferentialDiffTableOfContentsView.php'); phutil_require_source('DifferentialDiffTableOfContentsView.php');