Files
Trilium/apps/client/src/services/glob.ts

102 lines
3.2 KiB
TypeScript
Raw Normal View History

import utils from "./utils.js";
2022-12-01 13:07:23 +01:00
import appContext from "../components/app_context.js";
import server from "./server.js";
import ws from "./ws.js";
2021-04-16 23:01:56 +02:00
import froca from "./froca.js";
2023-06-29 12:19:01 +02:00
import linkService from "./link.js";
2020-04-12 14:22:51 +02:00
function setupGlobs() {
window.glob.isDesktop = utils.isDesktop;
window.glob.isMobile = utils.isMobile;
2025-01-09 18:07:02 +02:00
window.glob.getComponentByEl = (el) => appContext.getComponentByEl(el);
2020-04-12 14:22:51 +02:00
window.glob.getHeaders = server.getHeaders;
2025-01-09 18:07:02 +02:00
window.glob.getReferenceLinkTitle = (href) => linkService.getReferenceLinkTitle(href);
window.glob.getReferenceLinkTitleSync = (href) => linkService.getReferenceLinkTitleSync(href);
2020-04-12 14:22:51 +02:00
// required for ESLint plugin and CKEditor
2023-06-06 12:31:38 +02:00
window.glob.getActiveContextNote = () => appContext.tabManager.getActiveContextNote();
2020-04-12 14:22:51 +02:00
window.glob.appContext = appContext; // for debugging
2021-04-16 22:57:37 +02:00
window.glob.froca = froca;
2021-04-17 20:52:46 +02:00
window.glob.treeCache = froca; // compatibility for CKEditor builds for a while
2020-04-12 14:22:51 +02:00
window.onerror = function (msg, url, lineNo, columnNo, error) {
2024-12-21 17:47:09 +02:00
const string = String(msg).toLowerCase();
2020-04-12 14:22:51 +02:00
let errorObjectString = "";
try {
errorObjectString = JSON.stringify(error);
} catch (e: any) {
errorObjectString = e.toString();
}
2020-04-12 14:22:51 +02:00
let message = "Uncaught error: ";
if (string.includes("script error")) {
2025-01-09 18:07:02 +02:00
message += "No details available";
2020-04-12 14:22:51 +02:00
} else {
message += [`Message: ${msg}`, `URL: ${url}`, `Line: ${lineNo}`, `Column: ${columnNo}`, `Error object: ${errorObjectString}`, `Stack: ${error && error.stack}`].join(", ");
2020-04-12 14:22:51 +02:00
}
ws.logError(message);
return false;
};
2024-10-25 19:57:40 +03:00
window.addEventListener("unhandledrejection", (e) => {
const string = e?.reason?.message?.toLowerCase();
2024-10-25 19:57:40 +03:00
let message = "Uncaught error: ";
let errorObjectString;
try {
errorObjectString = JSON.stringify(e.reason)
} catch (error: any) {
errorObjectString = error.toString();
}
2024-10-25 19:57:40 +03:00
if (string?.includes("script error")) {
2025-01-09 18:07:02 +02:00
message += "No details available";
2024-10-25 19:57:40 +03:00
} else {
message += [
`Message: ${e.reason.message}`,
`Line: ${e.reason.lineNumber}`,
`Column: ${e.reason.columnNumber}`,
`Error object: ${errorObjectString}`,
2024-10-25 19:57:40 +03:00
`Stack: ${e.reason && e.reason.stack}`
2025-01-09 18:07:02 +02:00
].join(", ");
2024-10-25 19:57:40 +03:00
}
ws.logError(message);
return false;
});
2020-04-12 14:22:51 +02:00
for (const appCssNoteId of glob.appCssNoteIds || []) {
requireCss(`api/notes/download/${appCssNoteId}`, false);
}
utils.initHelpButtons($(window));
2020-04-12 14:22:51 +02:00
$("body").on("click", "a.external", function () {
2025-01-09 18:07:02 +02:00
window.open($(this).attr("href"), "_blank");
return false;
2020-04-12 14:22:51 +02:00
});
}
async function requireCss(url: string, prependAssetPath = true) {
const cssLinks = Array.from(document.querySelectorAll("link")).map((el) => el.href);
if (!cssLinks.some((l) => l.endsWith(url))) {
if (prependAssetPath) {
url = `${window.glob.assetPath}/${url}`;
}
$("head").append($('<link rel="stylesheet" type="text/css" />').attr("href", url));
}
}
2020-04-12 14:22:51 +02:00
export default {
setupGlobs
2025-01-09 18:07:02 +02:00
};