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

Support symbol linking in Remarkup code blocks

Summary:
Trigger the crossreference behavior on code blocks. Limited to
Differential, where we know what the project is, but includes regular
comments, inline comments, and previews of both.

(Hopefully event handlers on deleted elements also get deleted, so we
don't leak memory? Also, caching is a problem, and I didn't find a way
to mark existing cache entries as stale, like
`DifferentialChangesetParser::CACHE_VERSION`...)

Test Plan:
Load Differential revision, make lots of comments, click on
things.

Reviewers: epriestley

Reviewed By: epriestley

CC: aran, Korvin

Maniphest Tasks: T1602

Differential Revision: https://secure.phabricator.com/D3283
This commit is contained in:
Alan Huang 2012-08-14 14:03:26 -07:00
parent 0f076779b2
commit 1855ed4bee
5 changed files with 119 additions and 67 deletions

View file

@ -1306,7 +1306,7 @@ celerity_register_resource_map(array(
), ),
'javelin-behavior-differential-feedback-preview' => 'javelin-behavior-differential-feedback-preview' =>
array( array(
'uri' => '/res/f27f3f49/rsrc/js/application/differential/behavior-comment-preview.js', 'uri' => '/res/d6c8a84c/rsrc/js/application/differential/behavior-comment-preview.js',
'type' => 'js', 'type' => 'js',
'requires' => 'requires' =>
array( array(
@ -1860,7 +1860,7 @@ celerity_register_resource_map(array(
), ),
'javelin-behavior-repository-crossreference' => 'javelin-behavior-repository-crossreference' =>
array( array(
'uri' => '/res/b24ebee5/rsrc/js/application/repository/repository-crossreference.js', 'uri' => '/res/d3ff7611/rsrc/js/application/repository/repository-crossreference.js',
'type' => 'js', 'type' => 'js',
'requires' => 'requires' =>
array( array(
@ -3119,7 +3119,7 @@ celerity_register_resource_map(array(
'uri' => '/res/pkg/19ebcc79/differential.pkg.css', 'uri' => '/res/pkg/19ebcc79/differential.pkg.css',
'type' => 'css', 'type' => 'css',
), ),
29296904 => '5b33c790' =>
array( array(
'name' => 'differential.pkg.js', 'name' => 'differential.pkg.js',
'symbols' => 'symbols' =>
@ -3143,7 +3143,7 @@ celerity_register_resource_map(array(
16 => 'javelin-behavior-differential-dropdown-menus', 16 => 'javelin-behavior-differential-dropdown-menus',
17 => 'javelin-behavior-buoyant', 17 => 'javelin-behavior-buoyant',
), ),
'uri' => '/res/pkg/29296904/differential.pkg.js', 'uri' => '/res/pkg/5b33c790/differential.pkg.js',
'type' => 'js', 'type' => 'js',
), ),
'c8ce2d88' => 'c8ce2d88' =>
@ -3251,7 +3251,7 @@ celerity_register_resource_map(array(
'aphront-typeahead-control-css' => 'edf6b149', 'aphront-typeahead-control-css' => 'edf6b149',
'differential-changeset-view-css' => '19ebcc79', 'differential-changeset-view-css' => '19ebcc79',
'differential-core-view-css' => '19ebcc79', 'differential-core-view-css' => '19ebcc79',
'differential-inline-comment-editor' => '29296904', 'differential-inline-comment-editor' => '5b33c790',
'differential-local-commits-view-css' => '19ebcc79', 'differential-local-commits-view-css' => '19ebcc79',
'differential-results-table-css' => '19ebcc79', 'differential-results-table-css' => '19ebcc79',
'differential-revision-add-comment-css' => '19ebcc79', 'differential-revision-add-comment-css' => '19ebcc79',
@ -3264,21 +3264,21 @@ celerity_register_resource_map(array(
'inline-comment-summary-css' => '19ebcc79', 'inline-comment-summary-css' => '19ebcc79',
'javelin-behavior' => '6fb20113', 'javelin-behavior' => '6fb20113',
'javelin-behavior-aphront-basic-tokenizer' => '97f65640', 'javelin-behavior-aphront-basic-tokenizer' => '97f65640',
'javelin-behavior-aphront-drag-and-drop' => '29296904', 'javelin-behavior-aphront-drag-and-drop' => '5b33c790',
'javelin-behavior-aphront-drag-and-drop-textarea' => '29296904', 'javelin-behavior-aphront-drag-and-drop-textarea' => '5b33c790',
'javelin-behavior-aphront-form-disable-on-submit' => '971b021e', 'javelin-behavior-aphront-form-disable-on-submit' => '971b021e',
'javelin-behavior-audit-preview' => '5e68be89', 'javelin-behavior-audit-preview' => '5e68be89',
'javelin-behavior-buoyant' => '29296904', 'javelin-behavior-buoyant' => '5b33c790',
'javelin-behavior-differential-accept-with-errors' => '29296904', 'javelin-behavior-differential-accept-with-errors' => '5b33c790',
'javelin-behavior-differential-add-reviewers-and-ccs' => '29296904', 'javelin-behavior-differential-add-reviewers-and-ccs' => '5b33c790',
'javelin-behavior-differential-comment-jump' => '29296904', 'javelin-behavior-differential-comment-jump' => '5b33c790',
'javelin-behavior-differential-diff-radios' => '29296904', 'javelin-behavior-differential-diff-radios' => '5b33c790',
'javelin-behavior-differential-dropdown-menus' => '29296904', 'javelin-behavior-differential-dropdown-menus' => '5b33c790',
'javelin-behavior-differential-edit-inline-comments' => '29296904', 'javelin-behavior-differential-edit-inline-comments' => '5b33c790',
'javelin-behavior-differential-feedback-preview' => '29296904', 'javelin-behavior-differential-feedback-preview' => '5b33c790',
'javelin-behavior-differential-keyboard-navigation' => '29296904', 'javelin-behavior-differential-keyboard-navigation' => '5b33c790',
'javelin-behavior-differential-populate' => '29296904', 'javelin-behavior-differential-populate' => '5b33c790',
'javelin-behavior-differential-show-more' => '29296904', 'javelin-behavior-differential-show-more' => '5b33c790',
'javelin-behavior-diffusion-commit-graph' => '5e68be89', 'javelin-behavior-diffusion-commit-graph' => '5e68be89',
'javelin-behavior-diffusion-pull-lastmodified' => '5e68be89', 'javelin-behavior-diffusion-pull-lastmodified' => '5e68be89',
'javelin-behavior-maniphest-batch-selector' => '7707de41', 'javelin-behavior-maniphest-batch-selector' => '7707de41',
@ -3288,12 +3288,12 @@ celerity_register_resource_map(array(
'javelin-behavior-maniphest-transaction-preview' => '7707de41', 'javelin-behavior-maniphest-transaction-preview' => '7707de41',
'javelin-behavior-phabricator-autofocus' => '971b021e', 'javelin-behavior-phabricator-autofocus' => '971b021e',
'javelin-behavior-phabricator-keyboard-shortcuts' => '971b021e', 'javelin-behavior-phabricator-keyboard-shortcuts' => '971b021e',
'javelin-behavior-phabricator-object-selector' => '29296904', 'javelin-behavior-phabricator-object-selector' => '5b33c790',
'javelin-behavior-phabricator-oncopy' => '971b021e', 'javelin-behavior-phabricator-oncopy' => '971b021e',
'javelin-behavior-phabricator-tooltips' => '971b021e', 'javelin-behavior-phabricator-tooltips' => '971b021e',
'javelin-behavior-phabricator-watch-anchor' => '971b021e', 'javelin-behavior-phabricator-watch-anchor' => '971b021e',
'javelin-behavior-refresh-csrf' => '971b021e', 'javelin-behavior-refresh-csrf' => '971b021e',
'javelin-behavior-repository-crossreference' => '29296904', 'javelin-behavior-repository-crossreference' => '5b33c790',
'javelin-behavior-workflow' => '971b021e', 'javelin-behavior-workflow' => '971b021e',
'javelin-dom' => '6fb20113', 'javelin-dom' => '6fb20113',
'javelin-event' => '6fb20113', 'javelin-event' => '6fb20113',
@ -3319,7 +3319,7 @@ celerity_register_resource_map(array(
'phabricator-core-buttons-css' => 'edf6b149', 'phabricator-core-buttons-css' => 'edf6b149',
'phabricator-core-css' => 'edf6b149', 'phabricator-core-css' => 'edf6b149',
'phabricator-directory-css' => 'edf6b149', 'phabricator-directory-css' => 'edf6b149',
'phabricator-drag-and-drop-file-upload' => '29296904', 'phabricator-drag-and-drop-file-upload' => '5b33c790',
'phabricator-dropdown-menu' => '971b021e', 'phabricator-dropdown-menu' => '971b021e',
'phabricator-flag-css' => 'edf6b149', 'phabricator-flag-css' => 'edf6b149',
'phabricator-jump-nav' => 'edf6b149', 'phabricator-jump-nav' => 'edf6b149',
@ -3331,7 +3331,7 @@ celerity_register_resource_map(array(
'phabricator-prefab' => '971b021e', 'phabricator-prefab' => '971b021e',
'phabricator-project-tag-css' => '7839ae2d', 'phabricator-project-tag-css' => '7839ae2d',
'phabricator-remarkup-css' => 'edf6b149', 'phabricator-remarkup-css' => 'edf6b149',
'phabricator-shaped-request' => '29296904', 'phabricator-shaped-request' => '5b33c790',
'phabricator-standard-page-view' => 'edf6b149', 'phabricator-standard-page-view' => 'edf6b149',
'phabricator-tooltip' => '971b021e', 'phabricator-tooltip' => '971b021e',
'phabricator-transaction-view-css' => 'edf6b149', 'phabricator-transaction-view-css' => 'edf6b149',

View file

@ -256,11 +256,12 @@ final class DifferentialRevisionViewController extends DifferentialController {
DifferentialChangesetParser::WHITESPACE_IGNORE_ALL); DifferentialChangesetParser::WHITESPACE_IGNORE_ALL);
if ($arc_project) { if ($arc_project) {
$symbol_indexes = $this->buildSymbolIndexes( list($symbol_indexes, $project_phids) = $this->buildSymbolIndexes(
$arc_project, $arc_project,
$visible_changesets); $visible_changesets);
} else { } else {
$symbol_indexes = array(); $symbol_indexes = array();
$project_phids = null;
} }
$revision_detail->setActions($actions); $revision_detail->setActions($actions);
@ -275,6 +276,15 @@ final class DifferentialRevisionViewController extends DifferentialController {
$comment_view->setTargetDiff($target); $comment_view->setTargetDiff($target);
$comment_view->setVersusDiffID($diff_vs); $comment_view->setVersusDiffID($diff_vs);
if ($arc_project) {
Javelin::initBehavior(
'repository-crossreference',
array(
'section' => $comment_view->getID(),
'projects' => $project_phids,
));
}
$changeset_view = new DifferentialChangesetListView(); $changeset_view = new DifferentialChangesetListView();
$changeset_view->setChangesets($changesets); $changeset_view->setChangesets($changesets);
$changeset_view->setVisibleChangesets($visible_changesets); $changeset_view->setVisibleChangesets($visible_changesets);
@ -777,7 +787,7 @@ final class DifferentialRevisionViewController extends DifferentialController {
$langs = $arc_project->getSymbolIndexLanguages(); $langs = $arc_project->getSymbolIndexLanguages();
if (!$langs) { if (!$langs) {
return array(); return array(array(), array());
} }
$symbol_indexes = array(); $symbol_indexes = array();
@ -797,7 +807,7 @@ final class DifferentialRevisionViewController extends DifferentialController {
} }
} }
return $symbol_indexes; return array($symbol_indexes, $project_phids);
} }
private function loadOtherRevisions( private function loadOtherRevisions(

View file

@ -25,6 +25,7 @@ final class DifferentialRevisionCommentListView extends AphrontView {
private $user; private $user;
private $target; private $target;
private $versusDiffID; private $versusDiffID;
private $id;
public function setComments(array $comments) { public function setComments(array $comments) {
assert_instances_of($comments, 'DifferentialComment'); assert_instances_of($comments, 'DifferentialComment');
@ -65,6 +66,13 @@ final class DifferentialRevisionCommentListView extends AphrontView {
return $this; return $this;
} }
public function getID() {
if (!$this->id) {
$this->id = celerity_generate_unique_node_id();
}
return $this->id;
}
public function render() { public function render() {
require_celerity_resource('differential-revision-comment-list-css'); require_celerity_resource('differential-revision-comment-list-css');
@ -179,11 +187,14 @@ final class DifferentialRevisionCommentListView extends AphrontView {
$hidden = null; $hidden = null;
} }
return return javelin_render_tag(
'<div class="differential-comment-list">'. 'div',
array(
'class' => 'differential-comment-list',
'id' => $this->getID(),
),
implode("\n", $header). implode("\n", $header).
$hidden. $hidden.
implode("\n", $visible). implode("\n", $visible));
'</div>';
} }
} }

View file

@ -19,7 +19,11 @@ JX.behavior('differential-feedback-preview', function(config) {
} }
var callback = function(r) { var callback = function(r) {
JX.DOM.setContent(JX.$(config.preview), JX.$H(r)); var preview = JX.$(config.preview);
JX.DOM.setContent(preview, JX.$H(r));
JX.Stratcom.invoke('differential-preview-update', null, {
container: preview
});
}; };
var getdata = function() { var getdata = function() {
@ -50,6 +54,9 @@ JX.behavior('differential-feedback-preview', function(config) {
var inline = JX.$(config.inline); var inline = JX.$(config.inline);
JX.DOM.setContent(inline, JX.$H(r)); JX.DOM.setContent(inline, JX.$H(r));
JX.Stratcom.invoke('differential-preview-update', null, {
container: inline
});
// Go through the previews and activate any "View" links where the // Go through the previews and activate any "View" links where the
// actual comment appears in the document. // actual comment appears in the document.

View file

@ -10,10 +10,10 @@ JX.behavior('repository-crossreference', function(config) {
// NOTE: Pretty much everything in this file is a worst practice. We're // NOTE: Pretty much everything in this file is a worst practice. We're
// constrained by the markup generated by the syntax highlighters. // constrained by the markup generated by the syntax highlighters.
var container = JX.$(config.container); function link(element, lang) {
JX.DOM.alterClass(container, 'repository-crossreference', true); JX.DOM.alterClass(element, 'repository-crossreference', true);
JX.DOM.listen( JX.DOM.listen(
container, element,
'click', 'click',
'tag:span', 'tag:span',
function(e) { function(e) {
@ -26,7 +26,7 @@ JX.behavior('repository-crossreference', function(config) {
if (JX.DOM.isNode(target, 'span') && (target.className in map)) { if (JX.DOM.isNode(target, 'span') && (target.className in map)) {
var symbol = target.textContent || target.innerText; var symbol = target.textContent || target.innerText;
var query = { var query = {
lang : config.lang, lang : lang,
projects : config.projects.join(','), projects : config.projects.join(','),
jump : true jump : true
}; };
@ -48,5 +48,29 @@ JX.behavior('repository-crossreference', function(config) {
target = target.parentNode; target = target.parentNode;
} }
}); });
}
function linkAll(section) {
var blocks = section.getElementsByClassName('remarkup-code-block');
for (var i = 0; i < blocks.length; ++i) {
if (blocks[i].hasAttribute('data-code-lang')) {
var lang = blocks[i].getAttribute('data-code-lang');
link(blocks[i], lang);
}
}
}
if (config.container) {
link(JX.$(config.container), config.lang);
} else if (config.section) {
linkAll(JX.$(config.section));
}
JX.Stratcom.listen(
'differential-preview-update',
null,
function(e) {
linkAll(e.getData().container);
});
}); });