|
|
|
@ -113,7 +113,18 @@ let contentPolicy = {
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
let docObserver = {
|
|
|
|
|
contentBaseURI: 'chrome://' + appName + '/content/js/',
|
|
|
|
|
contentBaseURI: 'chrome://' + appName + '/content/',
|
|
|
|
|
injectScript: function(script, evalCode) {
|
|
|
|
|
if (evalCode) {
|
|
|
|
|
Components.utils.evalInSandbox(script, this);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Services.scriptloader.loadSubScript(
|
|
|
|
|
docObserver.contentBaseURI + script,
|
|
|
|
|
this
|
|
|
|
|
);
|
|
|
|
|
},
|
|
|
|
|
initContext: function(win, sandbox) {
|
|
|
|
|
let messager = getMessager(win);
|
|
|
|
|
|
|
|
|
@ -125,6 +136,12 @@ let docObserver = {
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
win.self = win;
|
|
|
|
|
|
|
|
|
|
Components.utils.exportFunction(
|
|
|
|
|
this.injectScript,
|
|
|
|
|
win,
|
|
|
|
|
{defineAs: 'injectScript'}
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
win.sendAsyncMessage = messager.sendAsyncMessage;
|
|
|
|
@ -158,12 +175,12 @@ let docObserver = {
|
|
|
|
|
let lss = Services.scriptloader.loadSubScript;
|
|
|
|
|
win = this.initContext(win, true);
|
|
|
|
|
|
|
|
|
|
lss(this.contentBaseURI + 'vapi-client.js', win);
|
|
|
|
|
lss(this.contentBaseURI + 'contentscript-start.js', win);
|
|
|
|
|
lss(this.contentBaseURI + 'js/vapi-client.js', win);
|
|
|
|
|
lss(this.contentBaseURI + 'js/contentscript-start.js', win);
|
|
|
|
|
|
|
|
|
|
let docReady = function(e) {
|
|
|
|
|
this.removeEventListener(e.type, docReady, true);
|
|
|
|
|
lss(docObserver.contentBaseURI + 'contentscript-end.js', win);
|
|
|
|
|
lss(docObserver.contentBaseURI + 'js/contentscript-end.js', win);
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
doc.addEventListener('DOMContentLoaded', docReady, true);
|
|
|
|
|