Notes/src/public/app/services/library_loader.js

133 lines
3.3 KiB
JavaScript
Raw Normal View History

2018-03-27 22:42:46 -04:00
const CKEDITOR = {"js": ["libraries/ckeditor/ckeditor.js"]};
const CODE_MIRROR = {
js: [
"libraries/codemirror/codemirror.js",
2022-01-07 19:33:59 +01:00
"libraries/codemirror/addon/display/placeholder.js",
2018-03-27 22:42:46 -04:00
"libraries/codemirror/addon/edit/matchbrackets.js",
"libraries/codemirror/addon/edit/matchtags.js",
2022-01-07 19:33:59 +01:00
"libraries/codemirror/addon/fold/xml-fold.js",
"libraries/codemirror/addon/lint/lint.js",
"libraries/codemirror/addon/lint/eslint.js",
"libraries/codemirror/addon/mode/loadmode.js",
"libraries/codemirror/addon/mode/simple.js",
2018-03-27 22:42:46 -04:00
"libraries/codemirror/addon/search/match-highlighter.js",
"libraries/codemirror/mode/meta.js",
2022-01-07 19:33:59 +01:00
"libraries/codemirror/keymap/vim.js"
2018-03-27 22:42:46 -04:00
],
css: [
"libraries/codemirror/codemirror.css",
"libraries/codemirror/addon/lint/lint.css"
]
};
const ESLINT = {js: ["libraries/eslint.js"]};
2018-09-02 23:02:01 +02:00
const COMMONMARK = {js: ["libraries/commonmark.min.js"]};
2018-10-18 11:46:07 +02:00
const RELATION_MAP = {
js: [
"libraries/jsplumb.js",
"libraries/panzoom.js"
],
css: [
"stylesheets/relation_map.css"
2018-10-18 11:46:07 +02:00
]
};
2019-06-29 22:57:47 +02:00
const PRINT_THIS = {js: ["libraries/printThis.js"]};
2019-09-08 16:06:42 +02:00
const CALENDAR_WIDGET = {css: ["stylesheets/calendar.css"]};
2020-09-21 22:57:22 +02:00
const KATEX = {
js: [ "libraries/katex/katex.min.js", "libraries/katex/mhchem.min.js", "libraries/katex/auto-render.min.js" ],
2020-09-21 22:57:22 +02:00
css: [ "libraries/katex/katex.min.css" ]
};
const WHEEL_ZOOM = {
js: [ "libraries/wheel-zoom.min.js"]
};
const FORCE_GRAPH = {
js: [ "libraries/force-graph.min.js"]
};
const MERMAID = {
js: [ "libraries/mermaid.min.js" ]
}
const EXCALIDRAW = {
js: [
"node_modules/react/umd/react.production.min.js", //v17.0.2
"node_modules/react-dom/umd/react-dom.production.min.js", //v17.0.2
"node_modules/@excalidraw/excalidraw/dist/excalidraw.production.min.js", //v.0.11.0
],
// css: [
// "stylesheets/somestyle.css"
// ]
};
2022-04-09 15:51:37 +02:00
const EXCALIDRAW_UTILS = {
/**
* FIXME: excalidraw-utils does not render pen-background. maybe own built required?
*/
2022-04-09 15:51:37 +02:00
js: [
"node_modules/@excalidraw/utils/dist/excalidraw-utils.min.js", //v0.1.2
2022-04-09 15:51:37 +02:00
]
};
2018-03-27 22:42:46 -04:00
async function requireLibrary(library) {
if (library.css) {
2020-02-17 19:42:52 +01:00
library.css.map(cssUrl => requireCss(cssUrl));
2018-03-27 22:42:46 -04:00
}
if (library.js) {
for (const scriptUrl of library.js) {
await requireScript(scriptUrl);
}
}
}
2018-04-07 15:56:46 -04:00
// we save the promises in case of the same script being required concurrently multiple times
const loadedScriptPromises = {};
2018-03-27 22:42:46 -04:00
async function requireScript(url) {
2018-04-07 15:56:46 -04:00
if (!loadedScriptPromises[url]) {
loadedScriptPromises[url] = $.ajax({
2018-03-27 22:42:46 -04:00
url: url,
dataType: "script",
cache: true
2018-04-07 15:56:46 -04:00
});
2018-03-27 22:42:46 -04:00
}
2018-04-07 15:56:46 -04:00
await loadedScriptPromises[url];
2018-03-27 22:42:46 -04:00
}
2020-02-17 19:42:52 +01:00
async function requireCss(url) {
const cssLinks = Array
.from(document.querySelectorAll('link'))
.map(el => el.href);
if (!cssLinks.some(l => l.endsWith(url))) {
$('head').append($('<link rel="stylesheet" type="text/css" />').attr('href', url));
}
}
2018-03-27 22:42:46 -04:00
export default {
2020-02-17 19:42:52 +01:00
requireCss,
2018-03-27 22:42:46 -04:00
requireLibrary,
CKEDITOR,
CODE_MIRROR,
2018-09-02 23:02:01 +02:00
ESLINT,
2018-10-18 11:46:07 +02:00
COMMONMARK,
2019-06-03 22:55:59 +02:00
RELATION_MAP,
2019-08-20 23:30:19 +02:00
PRINT_THIS,
2020-09-21 22:57:22 +02:00
CALENDAR_WIDGET,
KATEX,
WHEEL_ZOOM,
FORCE_GRAPH,
MERMAID,
2022-04-09 15:51:37 +02:00
EXCALIDRAW,
EXCALIDRAW_UTILS
2020-07-04 10:18:01 +02:00
}