2022-09-26 08:01:23 +02:00
|
|
|
const warning = (s: string) => {
|
|
|
|
// Todo remove debug code
|
|
|
|
console.error('Log function was called before initialization', s); // eslint-disable-line
|
|
|
|
};
|
|
|
|
|
|
|
|
export type LogLevel = 'trace' | 'debug' | 'info' | 'warn' | 'error' | 'fatal';
|
|
|
|
|
|
|
|
export const LEVELS: Record<LogLevel, number> = {
|
|
|
|
trace: 0,
|
|
|
|
debug: 1,
|
|
|
|
info: 2,
|
|
|
|
warn: 3,
|
|
|
|
error: 4,
|
|
|
|
fatal: 5,
|
|
|
|
};
|
|
|
|
|
|
|
|
export const log: Record<keyof typeof LEVELS, typeof console.log> = {
|
|
|
|
trace: warning,
|
|
|
|
debug: warning,
|
|
|
|
info: warning,
|
|
|
|
warn: warning,
|
|
|
|
error: warning,
|
|
|
|
fatal: warning,
|
|
|
|
};
|
|
|
|
|
|
|
|
export let setLogLevel: (level: keyof typeof LEVELS | number | string) => void;
|
|
|
|
export let getConfig: () => object;
|
|
|
|
export let sanitizeText: (str: string) => string;
|
|
|
|
// eslint-disable @typescript-eslint/no-explicit-any
|
|
|
|
export let setupGraphViewbox: (
|
|
|
|
graph: any,
|
|
|
|
svgElem: any,
|
|
|
|
padding: any,
|
|
|
|
useMaxWidth: boolean
|
|
|
|
) => void;
|
|
|
|
|
|
|
|
export const injectUtils = (
|
|
|
|
_log: Record<keyof typeof LEVELS, typeof console.log>,
|
|
|
|
_setLogLevel: any,
|
|
|
|
_getConfig: any,
|
|
|
|
_sanitizeText: any,
|
|
|
|
_setupGraphViewbox: any
|
|
|
|
) => {
|
2022-09-26 10:44:18 +02:00
|
|
|
_log.info('Mermaid utils injected');
|
|
|
|
log.trace = _log.trace;
|
2022-09-26 08:01:23 +02:00
|
|
|
log.debug = _log.debug;
|
|
|
|
log.info = _log.info;
|
|
|
|
log.warn = _log.warn;
|
|
|
|
log.error = _log.error;
|
2022-09-26 10:44:18 +02:00
|
|
|
log.fatal = _log.fatal;
|
2022-09-26 08:01:23 +02:00
|
|
|
setLogLevel = _setLogLevel;
|
|
|
|
getConfig = _getConfig;
|
|
|
|
sanitizeText = _sanitizeText;
|
|
|
|
setupGraphViewbox = _setupGraphViewbox;
|
|
|
|
};
|