2023-07-27 16:05:56 +01:00
|
|
|
import Logger from '@joplin/utils/Logger';
|
2021-11-15 17:19:51 +00:00
|
|
|
|
|
|
|
const logger = Logger.create('loadScript');
|
|
|
|
|
|
|
|
export interface Script {
|
|
|
|
id: string;
|
|
|
|
src: string;
|
|
|
|
attrs?: Record<string, any>;
|
|
|
|
}
|
|
|
|
|
|
|
|
export const loadScript = async (script: Script) => {
|
|
|
|
return new Promise((resolve) => {
|
2023-02-16 10:55:24 +00:00
|
|
|
// eslint-disable-next-line no-console
|
2021-12-23 12:04:09 +01:00
|
|
|
console.info('Loading script:', script);
|
|
|
|
|
2021-11-15 17:19:51 +00:00
|
|
|
let element: any = document.getElementById(script.id);
|
|
|
|
|
|
|
|
if (element) {
|
|
|
|
if (element.href === script.src || element.src === script.src) {
|
|
|
|
logger.info(`Trying to load a script that has already been loaded: ${JSON.stringify(script)} - skipping it`);
|
|
|
|
resolve(null);
|
|
|
|
} else {
|
|
|
|
logger.info(`Source of script has changed - reloading it: ${JSON.stringify(script)}`);
|
|
|
|
element.parentNode.removeChild(element);
|
|
|
|
element = null;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (script.src.indexOf('.css') >= 0) {
|
|
|
|
element = document.createElement('link');
|
|
|
|
element.rel = 'stylesheet';
|
|
|
|
element.href = script.src;
|
|
|
|
} else {
|
|
|
|
element = document.createElement('script');
|
|
|
|
element.src = script.src;
|
|
|
|
if (script.attrs) {
|
|
|
|
for (const attr in script.attrs) {
|
|
|
|
element[attr] = script.attrs[attr];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
element.id = script.id;
|
|
|
|
|
|
|
|
element.onload = () => {
|
|
|
|
resolve(null);
|
|
|
|
};
|
|
|
|
|
|
|
|
document.getElementsByTagName('head')[0].appendChild(element);
|
|
|
|
});
|
|
|
|
};
|