mirror of
https://github.com/ether/etherpad-lite.git
synced 2025-01-31 19:02:59 +01:00
lint: pluginfw/client_plugins (#4572)
This commit is contained in:
parent
a4e2ea7a8c
commit
6f309ac20a
1 changed files with 22 additions and 26 deletions
|
@ -1,40 +1,36 @@
|
|||
let $, jQuery;
|
||||
$ = jQuery = require('ep_etherpad-lite/static/js/rjquery').$;
|
||||
const _ = require('underscore');
|
||||
'use strict';
|
||||
|
||||
const pluginUtils = require('./shared');
|
||||
const defs = require('./plugin_defs');
|
||||
|
||||
exports.baseURL = '';
|
||||
|
||||
exports.ensure = function (cb) {
|
||||
if (!defs.loaded) exports.update(cb);
|
||||
else cb();
|
||||
};
|
||||
exports.ensure = (cb) => !defs.loaded ? exports.update(cb) : cb();
|
||||
|
||||
exports.update = function (cb) {
|
||||
exports.update = (cb) => {
|
||||
// It appears that this response (see #620) may interrupt the current thread
|
||||
// of execution on Firefox. This schedules the response in the run-loop,
|
||||
// which appears to fix the issue.
|
||||
const callback = function () { setTimeout(cb, 0); };
|
||||
const callback = () => setTimeout(cb, 0);
|
||||
$.ajaxSetup({cache: false});
|
||||
|
||||
jQuery.getJSON(`${exports.baseURL}pluginfw/plugin-definitions.json`).done((data) => {
|
||||
defs.plugins = data.plugins;
|
||||
defs.parts = data.parts;
|
||||
defs.hooks = pluginUtils.extractHooks(defs.parts, 'client_hooks');
|
||||
defs.loaded = true;
|
||||
callback();
|
||||
}).fail((e) => {
|
||||
}).fail((err) => {
|
||||
console.error(`Failed to load plugin-definitions: ${err}`);
|
||||
callback();
|
||||
});
|
||||
};
|
||||
|
||||
function adoptPluginsFromAncestorsOf(frame) {
|
||||
const adoptPluginsFromAncestorsOf = (frame) => {
|
||||
// Bind plugins with parent;
|
||||
let parentRequire = null;
|
||||
try {
|
||||
while (frame = frame.parent) {
|
||||
while ((frame = frame.parent)) {
|
||||
if (typeof (frame.require) !== 'undefined') {
|
||||
parentRequire = frame.require;
|
||||
break;
|
||||
|
@ -42,20 +38,20 @@ function adoptPluginsFromAncestorsOf(frame) {
|
|||
}
|
||||
} catch (error) {
|
||||
// Silence (this can only be a XDomain issue).
|
||||
console.error(error);
|
||||
}
|
||||
if (parentRequire) {
|
||||
const ancestorPluginDefs = parentRequire('ep_etherpad-lite/static/js/pluginfw/plugin_defs');
|
||||
defs.hooks = ancestorPluginDefs.hooks;
|
||||
defs.loaded = ancestorPluginDefs.loaded;
|
||||
defs.parts = ancestorPluginDefs.parts;
|
||||
defs.plugins = ancestorPluginDefs.plugins;
|
||||
const ancestorPlugins = parentRequire('ep_etherpad-lite/static/js/pluginfw/client_plugins');
|
||||
exports.baseURL = ancestorPlugins.baseURL;
|
||||
exports.ensure = ancestorPlugins.ensure;
|
||||
exports.update = ancestorPlugins.update;
|
||||
} else {
|
||||
throw new Error('Parent plugins could not be found.');
|
||||
}
|
||||
}
|
||||
|
||||
if (!parentRequire) throw new Error('Parent plugins could not be found.');
|
||||
|
||||
const ancestorPluginDefs = parentRequire('ep_etherpad-lite/static/js/pluginfw/plugin_defs');
|
||||
defs.hooks = ancestorPluginDefs.hooks;
|
||||
defs.loaded = ancestorPluginDefs.loaded;
|
||||
defs.parts = ancestorPluginDefs.parts;
|
||||
defs.plugins = ancestorPluginDefs.plugins;
|
||||
const ancestorPlugins = parentRequire('ep_etherpad-lite/static/js/pluginfw/client_plugins');
|
||||
exports.baseURL = ancestorPlugins.baseURL;
|
||||
exports.ensure = ancestorPlugins.ensure;
|
||||
exports.update = ancestorPlugins.update;
|
||||
};
|
||||
|
||||
exports.adoptPluginsFromAncestorsOf = adoptPluginsFromAncestorsOf;
|
||||
|
|
Loading…
Reference in a new issue