1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-15 17:21:10 +01:00

Improve inline comment previews

Summary:
  - When an inline comment preview corresponds to an inline comment on the page, link to it. Just punt in the tough case where the inline is on some other page.
  - In "haunted" mode, "z" now toggles through three modes: normal, comment area only, and comment + previews.

Test Plan:
  - Viewed visible and not-visible inline comment previews, clicked "View" links.
  - Tapped "z" a bunch to toggle haunt modes.

Reviewers: btrahan

Reviewed By: btrahan

CC: aran, epriestley

Maniphest Tasks: T517, T214

Differential Revision: https://secure.phabricator.com/D2041
This commit is contained in:
epriestley 2012-03-28 10:11:41 -07:00
parent 99b03ffd47
commit 29d8fc04e5
4 changed files with 69 additions and 21 deletions

View file

@ -136,6 +136,8 @@ final class DifferentialInlineCommentView extends AphrontView {
} }
} }
$anchor_name = 'inline-'.$inline->getID();
if ($this->editable && !$this->preview) { if ($this->editable && !$this->preview) {
$links[] = javelin_render_tag( $links[] = javelin_render_tag(
'a', 'a',
@ -153,6 +155,16 @@ final class DifferentialInlineCommentView extends AphrontView {
'sigil' => 'differential-inline-delete', 'sigil' => 'differential-inline-delete',
), ),
'Delete'); 'Delete');
} else if ($this->preview) {
$links[] = javelin_render_tag(
'a',
array(
'meta' => array(
'anchor' => $anchor_name,
),
'sigil' => 'differential-inline-preview-jump',
),
'Not Visible');
} }
if ($links) { if ($links) {
@ -178,8 +190,9 @@ final class DifferentialInlineCommentView extends AphrontView {
} }
} }
$anchor_name = 'inline-'.$inline->getID(); if ($this->preview) {
$anchor = null;
} else {
$anchor = phutil_render_tag( $anchor = phutil_render_tag(
'a', 'a',
array( array(
@ -188,6 +201,7 @@ final class DifferentialInlineCommentView extends AphrontView {
'class' => 'differential-inline-comment-anchor', 'class' => 'differential-inline-comment-anchor',
), ),
''); '');
}
$classes = array( $classes = array(
'differential-inline-comment', 'differential-inline-comment',

View file

@ -10,8 +10,14 @@
max-width: 1162px; max-width: 1162px;
} }
/* Spooky haunted panel which floats on the bottom of the screen. */ /* Spooky haunted panel which floats on the bottom of the screen.
.differential-haunted-panel .differential-add-comment-panel { Haunt modes are:
- Mode 1: Just the comment box.
- Mode 2: Comment box, comment preview, and inline comment previews.
*/
.differential-haunt-mode-1 .differential-add-comment-panel,
.differential-haunt-mode-2 .differential-add-comment-panel {
position: fixed; position: fixed;
width: 100%; width: 100%;
bottom: 0; bottom: 0;
@ -28,15 +34,20 @@
} }
.differential-haunted-panel .differential-add-comment-panel h1 { .differential-haunt-mode-2 .differential-add-comment-panel {
max-height: 75%;
}
.differential-haunt-mode-1 .differential-add-comment-panel h1,
.differential-haunt-mode-2 .differential-add-comment-panel h1 {
display: none; display: none;
} }
.differential-haunted-panel .aphront-panel-preview { .differential-haunt-mode-1 .aphront-panel-preview {
display: none; display: none;
} }
.differential-haunted-panel { .differential-haunt-mode-1 {
padding-bottom: 250px; padding-bottom: 250px;
} }

View file

@ -47,7 +47,27 @@ JX.behavior('differential-feedback-preview', function(config) {
function refreshInlinePreview() { function refreshInlinePreview() {
new JX.Request(config.inlineuri, function(r) { new JX.Request(config.inlineuri, function(r) {
JX.DOM.setContent(JX.$(config.inline), JX.$H(r)); var inline = JX.$(config.inline);
JX.DOM.setContent(inline, JX.$H(r));
// Go through the previews and activate any "View" links where the
// actual comment appears in the document.
var links = JX.DOM.scry(
inline,
'a',
'differential-inline-preview-jump');
for (var ii = 0; ii < links.length; ii++) {
var data = JX.Stratcom.getData(links[ii]);
try {
JX.$(data.anchor);
links[ii].href = '#' + data.anchor;
JX.DOM.setContent(links[ii], 'View');
} catch (ignored) {
// This inline comment isn't visible, e.g. on some other diff.
}
}
}) })
.setTimeout(5000) .setTimeout(5000)
.send(); .send();

View file

@ -150,11 +150,14 @@ JX.behavior('differential-keyboard-navigation', function(config) {
changesets = null; changesets = null;
}); });
var is_haunted = false; var haunt_mode = 0;
function haunt() { function haunt() {
is_haunted = !is_haunted; haunt_mode = (haunt_mode + 1) % 3;
var haunt = JX.$(config.haunt)
JX.DOM.alterClass(haunt, 'differential-haunted-panel', is_haunted); var el = JX.$(config.haunt);
for (var ii = 1; ii <= 2; ii++) {
JX.DOM.alterClass(el, 'differential-haunt-mode-'+ii, (haunt_mode == ii));
}
} }
new JX.KeyboardShortcut('j', 'Jump to next change.') new JX.KeyboardShortcut('j', 'Jump to next change.')
@ -221,7 +224,7 @@ JX.behavior('differential-keyboard-navigation', function(config) {
.register(); .register();
if (config.haunt) { if (config.haunt) {
new JX.KeyboardShortcut('z', 'Haunt / unhaunt comment panel.') new JX.KeyboardShortcut('z', 'Cycle comment panel haunting modes.')
.setHandler(haunt) .setHandler(haunt)
.register(); .register();
} }