2011-01-25 11:57:47 -08:00
|
|
|
/**
|
|
|
|
* @provides javelin-behavior-differential-populate
|
Bring Javelin into Phabricator via git submodule, not copy-and-paste
Summary:
Javelin is currently embedded in Phabricator via copy-and-paste of prebuilt
packages. This is not so great.
Pull it in as a submodule instead and make all the Phabriator resources declare
proper dependency trees. Add Javelin linting.
Test Plan:
I tried to run through pretty much all the JS functionality on the site. This is
still a high-risk change, but I did a pretty thorough test
Differential: inline comments, revealing diffs, list tokenizers, comment
preview, editing/deleting comments, add review action.
Maniphest: list tokenizer, comment actions
Herald: rule editing, tokenizers, add/remove rows
Reviewed By: tomo
Reviewers: aran, tomo, mroch, jungejason, tuomaspelkonen
CC: aran, tomo, epriestley
Differential Revision: 223
2011-05-03 15:11:55 -07:00
|
|
|
* @requires javelin-behavior
|
|
|
|
* javelin-dom
|
2012-03-12 20:04:12 -07:00
|
|
|
* javelin-stratcom
|
|
|
|
* phabricator-tooltip
|
2017-05-08 07:58:02 -07:00
|
|
|
* phabricator-diff-changeset-list
|
2017-05-08 09:52:16 -07:00
|
|
|
* phabricator-diff-changeset
|
2017-05-08 07:58:02 -07:00
|
|
|
* @javelin
|
2011-01-25 11:57:47 -08:00
|
|
|
*/
|
|
|
|
|
2017-05-08 07:58:02 -07:00
|
|
|
JX.behavior('differential-populate', function(config, statics) {
|
|
|
|
|
|
|
|
// When we perform a Quicksand navigation, deactivate the changeset lists on
|
|
|
|
// the current page and activate the changeset lists on the new page.
|
|
|
|
var onredraw = function(page_id) {
|
|
|
|
// If the current page is already active, we don't need to do anything.
|
|
|
|
if (statics.pageID === page_id) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
var ii;
|
|
|
|
|
|
|
|
// Put the old lists to sleep.
|
|
|
|
var old_lists = get_lists(statics.pageID);
|
|
|
|
for (ii = 0; ii < old_lists.length; ii++) {
|
|
|
|
old_lists[ii].sleep();
|
|
|
|
}
|
|
|
|
statics.pageID = null;
|
|
|
|
|
|
|
|
// Awaken the new lists, if they exist.
|
|
|
|
if (statics.pages.hasOwnProperty(page_id)) {
|
|
|
|
var new_lists = get_lists(page_id);
|
|
|
|
for (ii = 0; ii < new_lists.length; ii++) {
|
|
|
|
new_lists[ii].wake();
|
|
|
|
}
|
|
|
|
|
|
|
|
statics.pageID = page_id;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
// Get changeset lists on the current page.
|
|
|
|
var get_lists = function(page_id) {
|
|
|
|
if (page_id === null) {
|
|
|
|
return [];
|
|
|
|
}
|
|
|
|
|
|
|
|
return statics.pages[page_id] || [];
|
|
|
|
};
|
|
|
|
|
|
|
|
if (!statics.installed) {
|
|
|
|
statics.installed = true;
|
|
|
|
statics.pages = {};
|
|
|
|
statics.pageID = null;
|
|
|
|
|
|
|
|
JX.Stratcom.listen('quicksand-redraw', null, function(e) {
|
|
|
|
onredraw(e.getData().newResponseID);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2017-05-08 10:20:59 -07:00
|
|
|
var changeset_list = new JX.DiffChangesetList()
|
2017-05-09 12:09:45 -07:00
|
|
|
.setTranslations(JX.phtize(config.pht))
|
2017-05-30 13:23:54 -07:00
|
|
|
.setInlineURI(config.inlineURI);
|
2017-05-08 07:58:02 -07:00
|
|
|
|
|
|
|
// Install and activate the current page.
|
|
|
|
var page_id = JX.Quicksand.getCurrentPageID();
|
|
|
|
statics.pages[page_id] = [changeset_list];
|
|
|
|
onredraw(page_id);
|
|
|
|
|
|
|
|
|
2011-01-25 11:57:47 -08:00
|
|
|
|
Consolidate changeset rendering logic
Summary:
Ref T5179. Currently, all the changeset rendering logic is in the "populate" behavior, and a lot of it comes in via configuration and is hard to get at.
Instead, surface an object which can control it, and which other behaviors can access more easily.
In particular, this allows us to add a "Load/Reload" item to the view options menu, which would previously have been very challenging.
Load/Reload isn't useful on its own, but is a step away from "Show whitespace as...", "Highlight as...", "Show tabtops as...", "View Unified", "View Side-By-Side", etc.
Test Plan:
- Viewed Differential.
- Viewed Diffusion.
- Viewed large changesets, clicked "Load".
- Used "Load" and "Reload" from view options menu.
- Loaded all changes in a large diff, verified "Load" and TOC clicks take precedence over other content loads.
- Played with content stability stuff.
Reviewers: btrahan
Reviewed By: btrahan
Subscribers: epriestley
Maniphest Tasks: T5179
Differential Revision: https://secure.phabricator.com/D9286
2014-05-25 07:13:22 -07:00
|
|
|
for (var ii = 0; ii < config.changesetViewIDs.length; ii++) {
|
|
|
|
var id = config.changesetViewIDs[ii];
|
2017-05-08 11:27:11 -07:00
|
|
|
var node = JX.$(id);
|
|
|
|
var changeset = changeset_list.newChangesetForNode(node);
|
|
|
|
if (changeset.shouldAutoload()) {
|
|
|
|
changeset.setStabilize(true).load();
|
2012-03-12 17:06:55 -07:00
|
|
|
}
|
2011-01-25 11:57:47 -08:00
|
|
|
}
|
|
|
|
|
Consolidate changeset rendering logic
Summary:
Ref T5179. Currently, all the changeset rendering logic is in the "populate" behavior, and a lot of it comes in via configuration and is hard to get at.
Instead, surface an object which can control it, and which other behaviors can access more easily.
In particular, this allows us to add a "Load/Reload" item to the view options menu, which would previously have been very challenging.
Load/Reload isn't useful on its own, but is a step away from "Show whitespace as...", "Highlight as...", "Show tabtops as...", "View Unified", "View Side-By-Side", etc.
Test Plan:
- Viewed Differential.
- Viewed Diffusion.
- Viewed large changesets, clicked "Load".
- Used "Load" and "Reload" from view options menu.
- Loaded all changes in a large diff, verified "Load" and TOC clicks take precedence over other content loads.
- Played with content stability stuff.
Reviewers: btrahan
Reviewed By: btrahan
Subscribers: epriestley
Maniphest Tasks: T5179
Differential Revision: https://secure.phabricator.com/D9286
2014-05-25 07:13:22 -07:00
|
|
|
var highlighted = null;
|
|
|
|
var highlight_class = null;
|
|
|
|
|
2012-03-12 20:04:12 -07:00
|
|
|
JX.Stratcom.listen(
|
|
|
|
['mouseover', 'mouseout'],
|
|
|
|
['differential-changeset', 'tag:td'],
|
|
|
|
function(e) {
|
|
|
|
var t = e.getTarget();
|
|
|
|
|
|
|
|
// NOTE: Using className is not best practice, but the diff UI is perf
|
|
|
|
// sensitive.
|
2012-05-04 17:41:06 -07:00
|
|
|
if (!t.className.match(/cov|copy/)) {
|
2012-03-12 20:04:12 -07:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (e.getType() == 'mouseout') {
|
|
|
|
JX.Tooltip.hide();
|
|
|
|
if (highlighted) {
|
|
|
|
JX.DOM.alterClass(highlighted, highlight_class, false);
|
|
|
|
highlighted = null;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
highlight_class = null;
|
|
|
|
var msg;
|
2012-12-20 18:23:35 -08:00
|
|
|
var align = 'W';
|
2012-05-04 17:41:06 -07:00
|
|
|
var sibling = 'previousSibling';
|
2012-08-06 17:17:38 -07:00
|
|
|
var width = 120;
|
2012-03-12 20:04:12 -07:00
|
|
|
if (t.className.match(/cov-C/)) {
|
|
|
|
msg = 'Covered';
|
|
|
|
highlight_class = 'source-cov-C';
|
|
|
|
} else if (t.className.match(/cov-U/)) {
|
|
|
|
msg = 'Not Covered';
|
|
|
|
highlight_class = 'source-cov-U';
|
|
|
|
} else if (t.className.match(/cov-N/)) {
|
|
|
|
msg = 'Not Executable';
|
|
|
|
highlight_class = 'source-cov-N';
|
2012-05-04 17:41:06 -07:00
|
|
|
} else {
|
|
|
|
var match = /new-copy|new-move/.exec(t.className);
|
|
|
|
if (match) {
|
|
|
|
sibling = 'nextSibling';
|
2012-08-06 17:17:38 -07:00
|
|
|
width = 500;
|
2012-05-04 17:41:06 -07:00
|
|
|
msg = JX.Stratcom.getData(t).msg;
|
|
|
|
highlight_class = match[0];
|
|
|
|
}
|
2012-03-12 20:04:12 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
if (msg) {
|
2012-08-06 17:17:38 -07:00
|
|
|
JX.Tooltip.show(t, width, align, msg);
|
2012-03-12 20:04:12 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
if (highlight_class) {
|
2012-05-04 17:41:06 -07:00
|
|
|
highlighted = t[sibling];
|
2012-03-12 20:04:12 -07:00
|
|
|
JX.DOM.alterClass(highlighted, highlight_class, true);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
2011-01-25 11:57:47 -08:00
|
|
|
});
|