1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2024-12-23 14:00:56 +01:00

Add a JS component for crossreferences

Summary: When the user clicks a crossreference, jump them to symbol lookup

Test Plan: Clicked some crossref symbols

Reviewers: jungejason, nh, tuomaspelkonen, aran

Reviewed By: nh

CC: aran, nh, epriestley

Differential Revision: 904
This commit is contained in:
epriestley 2011-09-06 11:35:14 -07:00
parent 1e3c10379a
commit 0580772805
4 changed files with 99 additions and 40 deletions

View file

@ -757,6 +757,18 @@ celerity_register_resource_map(array(
), ),
'disk' => '/rsrc/js/application/core/behavior-refresh-csrf.js', 'disk' => '/rsrc/js/application/core/behavior-refresh-csrf.js',
), ),
'javelin-behavior-repository-crossreference' =>
array(
'uri' => '/res/e80365e9/rsrc/js/application/repository/repository-crossreference.js',
'type' => 'js',
'requires' =>
array(
0 => 'javelin-behavior',
1 => 'javelin-dom',
2 => 'javelin-uri',
),
'disk' => '/rsrc/js/application/repository/repository-crossreference.js',
),
'javelin-behavior-workflow' => 'javelin-behavior-workflow' =>
array( array(
'uri' => '/res/079f49c3/rsrc/js/application/core/behavior-workflow.js', 'uri' => '/res/079f49c3/rsrc/js/application/core/behavior-workflow.js',
@ -1380,7 +1392,7 @@ celerity_register_resource_map(array(
), ),
'syntax-highlighting-css' => 'syntax-highlighting-css' =>
array( array(
'uri' => '/res/14bc2ee1/rsrc/css/core/syntax.css', 'uri' => '/res/5669beb6/rsrc/css/core/syntax.css',
'type' => 'css', 'type' => 'css',
'requires' => 'requires' =>
array( array(
@ -1419,6 +1431,30 @@ celerity_register_resource_map(array(
'uri' => '/res/pkg/3dbf4083/javelin.pkg.js', 'uri' => '/res/pkg/3dbf4083/javelin.pkg.js',
'type' => 'js', 'type' => 'js',
), ),
'3e0f4d11' =>
array(
'name' => 'core.pkg.css',
'symbols' =>
array(
0 => 'phabricator-core-css',
1 => 'phabricator-core-buttons-css',
2 => 'phabricator-standard-page-view',
3 => 'aphront-dialog-view-css',
4 => 'aphront-form-view-css',
5 => 'aphront-panel-view-css',
6 => 'aphront-side-nav-view-css',
7 => 'aphront-table-view-css',
8 => 'aphront-crumbs-view-css',
9 => 'aphront-tokenizer-control-css',
10 => 'aphront-typeahead-control-css',
11 => 'aphront-list-filter-view-css',
12 => 'phabricator-directory-css',
13 => 'phabricator-remarkup-css',
14 => 'syntax-highlighting-css',
),
'uri' => '/res/pkg/3e0f4d11/core.pkg.css',
'type' => 'css',
),
'4aa8c13f' => '4aa8c13f' =>
array( array(
'name' => 'typeahead.pkg.js', 'name' => 'typeahead.pkg.js',
@ -1482,42 +1518,18 @@ celerity_register_resource_map(array(
'uri' => '/res/pkg/982ad44b/differential.pkg.js', 'uri' => '/res/pkg/982ad44b/differential.pkg.js',
'type' => 'js', 'type' => 'js',
), ),
'f6422902' =>
array(
'name' => 'core.pkg.css',
'symbols' =>
array(
0 => 'phabricator-core-css',
1 => 'phabricator-core-buttons-css',
2 => 'phabricator-standard-page-view',
3 => 'aphront-dialog-view-css',
4 => 'aphront-form-view-css',
5 => 'aphront-panel-view-css',
6 => 'aphront-side-nav-view-css',
7 => 'aphront-table-view-css',
8 => 'aphront-crumbs-view-css',
9 => 'aphront-tokenizer-control-css',
10 => 'aphront-typeahead-control-css',
11 => 'aphront-list-filter-view-css',
12 => 'phabricator-directory-css',
13 => 'phabricator-remarkup-css',
14 => 'syntax-highlighting-css',
),
'uri' => '/res/pkg/f6422902/core.pkg.css',
'type' => 'css',
),
), ),
'reverse' => 'reverse' =>
array( array(
'aphront-crumbs-view-css' => 'f6422902', 'aphront-crumbs-view-css' => '3e0f4d11',
'aphront-dialog-view-css' => 'f6422902', 'aphront-dialog-view-css' => '3e0f4d11',
'aphront-form-view-css' => 'f6422902', 'aphront-form-view-css' => '3e0f4d11',
'aphront-list-filter-view-css' => 'f6422902', 'aphront-list-filter-view-css' => '3e0f4d11',
'aphront-panel-view-css' => 'f6422902', 'aphront-panel-view-css' => '3e0f4d11',
'aphront-side-nav-view-css' => 'f6422902', 'aphront-side-nav-view-css' => '3e0f4d11',
'aphront-table-view-css' => 'f6422902', 'aphront-table-view-css' => '3e0f4d11',
'aphront-tokenizer-control-css' => 'f6422902', 'aphront-tokenizer-control-css' => '3e0f4d11',
'aphront-typeahead-control-css' => 'f6422902', 'aphront-typeahead-control-css' => '3e0f4d11',
'differential-changeset-view-css' => '7bf96a66', 'differential-changeset-view-css' => '7bf96a66',
'differential-core-view-css' => '7bf96a66', 'differential-core-view-css' => '7bf96a66',
'differential-revision-add-comment-css' => '7bf96a66', 'differential-revision-add-comment-css' => '7bf96a66',
@ -1554,13 +1566,13 @@ celerity_register_resource_map(array(
'javelin-util' => '3dbf4083', 'javelin-util' => '3dbf4083',
'javelin-vector' => '3dbf4083', 'javelin-vector' => '3dbf4083',
'javelin-workflow' => '95c67dcd', 'javelin-workflow' => '95c67dcd',
'phabricator-core-buttons-css' => 'f6422902', 'phabricator-core-buttons-css' => '3e0f4d11',
'phabricator-core-css' => 'f6422902', 'phabricator-core-css' => '3e0f4d11',
'phabricator-directory-css' => 'f6422902', 'phabricator-directory-css' => '3e0f4d11',
'phabricator-keyboard-shortcut' => '95c67dcd', 'phabricator-keyboard-shortcut' => '95c67dcd',
'phabricator-keyboard-shortcut-manager' => '95c67dcd', 'phabricator-keyboard-shortcut-manager' => '95c67dcd',
'phabricator-remarkup-css' => 'f6422902', 'phabricator-remarkup-css' => '3e0f4d11',
'phabricator-standard-page-view' => 'f6422902', 'phabricator-standard-page-view' => '3e0f4d11',
'syntax-highlighting-css' => 'f6422902', 'syntax-highlighting-css' => '3e0f4d11',
), ),
)); ));

View file

@ -136,6 +136,12 @@ class DifferentialChangesetListView extends AphrontView {
)); ));
} }
Javelin::initBehavior(
'repository-crossreference',
array(
'container' => 'differential-review-stage',
));
return return
'<div class="differential-review-stage" id="differential-review-stage">'. '<div class="differential-review-stage" id="differential-review-stage">'.
implode("\n", $output). implode("\n", $output).

View file

@ -14,6 +14,9 @@
padding: 1px 0 3px; padding: 1px 0 3px;
} }
.remarkup-code span {
border-bottom: 1px solid transparent;
}
.remarkup-code .hll { .remarkup-code .hll {
background-color: #ffffcc; background-color: #ffffcc;
@ -126,3 +129,9 @@
.remarkup-code .rbw_b { color: blue; } .remarkup-code .rbw_b { color: blue; }
.remarkup-code .rbw_i { color: indigo; } .remarkup-code .rbw_i { color: indigo; }
.remarkup-code .rbw_v { color: violet; } .remarkup-code .rbw_v { color: violet; }
.repository-crossreference .remarkup-code .nc,
.repository-crossreference .remarkup-code .nf {
cursor: help;
border-bottom: 1px dotted #bbddbb;
}

View file

@ -0,0 +1,32 @@
/**
* @provides javelin-behavior-repository-crossreference
* @requires javelin-behavior
* javelin-dom
* javelin-uri
*/
JX.behavior('repository-crossreference', function(config) {
// NOTE: Pretty much everything in this file is a worst practice. We're
// constrained by the markup generated by the syntax highlighters.
var container = JX.$(config.container);
JX.DOM.alterClass(container, 'repository-crossreference', true);
JX.DOM.listen(
container,
'click',
'tag:span',
function(e) {
var target = e.getTarget();
var map = {nc : 'class', nf : 'function'};
if (JX.DOM.isNode(target, 'span') && (target.className in map)) {
var uri = JX.$U('/diffusion/symbol/' + target.innerHTML + '/');
uri.addQueryParams({
type : map[target.className]
});
window.open(uri);
e.kill();
}
});
});