import moment from 'moment-mini'; /** @typedef {'debug' | 'info' | 'warn' | 'error' | 'fatal'} LogLevel A log level */ /** @type {object} */ export const LEVELS = { debug: 1, info: 2, warn: 3, error: 4, fatal: 5, }; export const log = { debug: () => {}, info: () => {}, warn: () => {}, error: () => {}, fatal: () => {}, }; /** * Sets a log level * * @param {LogLevel} [level="fatal"] The level to set the logging to. Default is `"fatal"` */ export const setLogLevel = function (level = 'fatal') { if (isNaN(level)) { level = level.toLowerCase(); if (LEVELS[level] !== undefined) { level = LEVELS[level]; } } log.trace = () => {}; log.debug = () => {}; log.info = () => {}; log.warn = () => {}; log.error = () => {}; log.fatal = () => {}; if (level <= LEVELS.fatal) { log.fatal = console.error ? console.error.bind(console, format('FATAL'), 'color: orange') : console.log.bind(console, '\x1b[35m', format('FATAL')); } if (level <= LEVELS.error) { log.error = console.error ? console.error.bind(console, format('ERROR'), 'color: orange') : console.log.bind(console, '\x1b[31m', format('ERROR')); } if (level <= LEVELS.warn) { log.warn = console.warn ? console.warn.bind(console, format('WARN'), 'color: orange') : console.log.bind(console, `\x1b[33m`, format('WARN')); } if (level <= LEVELS.info) { log.info = console.info // ? console.info.bind(console, '\x1b[34m', format('INFO'), 'color: blue') ? console.info.bind(console, format('INFO'), 'color: lightblue') : console.log.bind(console, '\x1b[34m', format('INFO')); } if (level <= LEVELS.debug) { log.debug = console.debug ? console.debug.bind(console, format('DEBUG'), 'color: lightgreen') : console.log.bind(console, '\x1b[32m', format('DEBUG')); } }; /** * Returns a format with the timestamp and the log level * * @param {LogLevel} level The level for the log format * @returns {string} The format with the timestamp and log level */ const format = (level) => { const time = moment().format('ss.SSS'); return `%c${time} : ${level} : `; };