UNPKG

lib-tools

Version:

The lib-tools helps you simplify the build, bundle, test and npm packaging workflows for Typescript, JavaScript, Angular library projects and assets module projects.

119 lines 16.5 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.Logger = exports.LogLevel = void 0; const colorize_1 = require("./colorize"); // eslint-disable-next-line no-shadow var LogLevel; (function (LogLevel) { LogLevel[LogLevel["None"] = 0] = "None"; LogLevel[LogLevel["Fatal"] = 1] = "Fatal"; LogLevel[LogLevel["Error"] = 2] = "Error"; LogLevel[LogLevel["Warn"] = 4] = "Warn"; LogLevel[LogLevel["Info"] = 8] = "Info"; LogLevel[LogLevel["Debug"] = 16] = "Debug"; })(LogLevel = exports.LogLevel || (exports.LogLevel = {})); class Logger { constructor(loggerOptions) { this._minLogLevel = LogLevel.Info; this.loggerOptions = loggerOptions || {}; if (this.loggerOptions.logLevel != null) { this._minLogLevel = typeof this.loggerOptions.logLevel === 'string' ? this.toLogLevel(this.loggerOptions.logLevel) : this.loggerOptions.logLevel; } } set minLogLevel(minLogLevel) { this._minLogLevel = typeof minLogLevel === 'string' ? this.toLogLevel(minLogLevel) : minLogLevel; } log(level, message, optionalParams) { const logLevel = typeof level === 'string' ? this.toLogLevel(level) : level; if (this._minLogLevel < logLevel || !message) { return; } const prefix = this.getPrefix(logLevel); let logMsg = `${prefix}${message.trimLeft()}`; if (this.loggerOptions.color !== false && logLevel === LogLevel.Warn) { logMsg = colorize_1.colorize(logMsg, 'yellow'); } else if (this.loggerOptions.color !== false && (logLevel === LogLevel.Error || logLevel === LogLevel.Fatal)) { logMsg = colorize_1.colorize(logMsg, 'red'); } if (optionalParams) { if (logLevel === LogLevel.Warn) { console.warn(logMsg, optionalParams); } else { // eslint-disable-next-line no-console console.log(logMsg, optionalParams); } } else { if (logLevel === LogLevel.Warn) { console.warn(logMsg); } else { // eslint-disable-next-line no-console console.log(logMsg); } } } debug(message, optionalParams) { this.log(LogLevel.Debug, message, optionalParams); } info(message, optionalParams) { this.log(LogLevel.Info, message, optionalParams); } warn(message, optionalParams) { this.log(LogLevel.Warn, message, optionalParams); } error(message, optionalParams) { this.log(LogLevel.Error, message, optionalParams); } fatal(message, optionalParams) { this.log(LogLevel.Fatal, message, optionalParams); } toLogLevel(logLevelString) { switch (logLevelString) { case 'debug': return LogLevel.Debug; case 'info': return LogLevel.Info; case 'warn': return LogLevel.Warn; case 'error': return LogLevel.Error; case 'fatal': return LogLevel.Fatal; case 'none': case 'disable': return LogLevel.None; default: return LogLevel.None; } } getPrefix(logLevel) { let prefix = ''; if (this.loggerOptions.name) { prefix += `${this.loggerOptions.name} `; } if (logLevel === LogLevel.Debug && this.loggerOptions.debugPrefix) { prefix += `${this.loggerOptions.debugPrefix} `; } else if (logLevel === LogLevel.Info && this.loggerOptions.infoPrefix) { prefix += `${this.loggerOptions.infoPrefix} `; } else if (logLevel === LogLevel.Warn && this.loggerOptions.warnPrefix) { prefix += `${this.loggerOptions.warnPrefix} `; } else if (logLevel === LogLevel.Error && this.loggerOptions.errorPrefix) { prefix += `${this.loggerOptions.errorPrefix} `; } else if (logLevel === LogLevel.Fatal && (this.loggerOptions.fatalPrefix || this.loggerOptions.errorPrefix)) { prefix += `${this.loggerOptions.fatalPrefix || this.loggerOptions.errorPrefix} `; } return prefix; } } exports.Logger = Logger; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"logger.js","sourceRoot":"./","sources":["utils/logger.ts"],"names":[],"mappings":"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","sourcesContent":["import { colorize } from './colorize';\n\n// eslint-disable-next-line no-shadow\nexport enum LogLevel {\n    None = 0,\n    Fatal = 1,\n    Error = 2,\n    Warn = 4,\n    Info = 8,\n    Debug = 16\n}\n\nexport type LogLevelString = 'debug' | 'info' | 'warn' | 'error' | 'fatal' | 'none' | 'disable';\n\nexport interface LoggerOptions {\n    logLevel?: LogLevel | LogLevelString;\n    name?: string;\n    debugPrefix?: string;\n    infoPrefix?: string;\n    warnPrefix?: string;\n    errorPrefix?: string;\n    fatalPrefix?: string;\n    color?: boolean;\n}\n\nexport interface LoggerBase {\n    log(level: LogLevel | LogLevelString, message: string, optionalParams?: unknown): void;\n    debug(message: string, optionalParams?: unknown): void;\n    info(message: string, optionalParams?: unknown): void;\n    warn(message: string, optionalParams?: unknown): void;\n    error(message: string, optionalParams?: unknown): void;\n    fatal(message: string, optionalParams?: unknown): void;\n}\n\nexport class Logger implements LoggerBase {\n    readonly loggerOptions: LoggerOptions;\n    private _minLogLevel: LogLevel = LogLevel.Info;\n\n    set minLogLevel(minLogLevel: LogLevel | LogLevelString) {\n        this._minLogLevel = typeof minLogLevel === 'string' ? this.toLogLevel(minLogLevel) : minLogLevel;\n    }\n\n    constructor(loggerOptions: LoggerOptions) {\n        this.loggerOptions = loggerOptions || {};\n        if (this.loggerOptions.logLevel != null) {\n            this._minLogLevel =\n                typeof this.loggerOptions.logLevel === 'string'\n                    ? this.toLogLevel(this.loggerOptions.logLevel)\n                    : this.loggerOptions.logLevel;\n        }\n    }\n\n    log(level: LogLevel | LogLevelString, message: string, optionalParams?: unknown): void {\n        const logLevel = typeof level === 'string' ? this.toLogLevel(level) : level;\n\n        if (this._minLogLevel < logLevel || !message) {\n            return;\n        }\n\n        const prefix = this.getPrefix(logLevel);\n\n        let logMsg = `${prefix}${message.trimLeft()}`;\n\n        if (this.loggerOptions.color !== false && logLevel === LogLevel.Warn) {\n            logMsg = colorize(logMsg, 'yellow');\n        } else if (this.loggerOptions.color !== false && (logLevel === LogLevel.Error || logLevel === LogLevel.Fatal)) {\n            logMsg = colorize(logMsg, 'red');\n        }\n\n        if (optionalParams) {\n            if (logLevel === LogLevel.Warn) {\n                console.warn(logMsg, optionalParams);\n            } else {\n                // eslint-disable-next-line no-console\n                console.log(logMsg, optionalParams);\n            }\n        } else {\n            if (logLevel === LogLevel.Warn) {\n                console.warn(logMsg);\n            } else {\n                // eslint-disable-next-line no-console\n                console.log(logMsg);\n            }\n        }\n    }\n\n    debug(message: string, optionalParams?: unknown): void {\n        this.log(LogLevel.Debug, message, optionalParams);\n    }\n\n    info(message: string, optionalParams?: unknown): void {\n        this.log(LogLevel.Info, message, optionalParams);\n    }\n\n    warn(message: string, optionalParams?: unknown): void {\n        this.log(LogLevel.Warn, message, optionalParams);\n    }\n\n    error(message: string, optionalParams?: unknown): void {\n        this.log(LogLevel.Error, message, optionalParams);\n    }\n\n    fatal(message: string, optionalParams?: unknown): void {\n        this.log(LogLevel.Fatal, message, optionalParams);\n    }\n\n    private toLogLevel(logLevelString: LogLevelString): LogLevel {\n        switch (logLevelString) {\n            case 'debug':\n                return LogLevel.Debug;\n            case 'info':\n                return LogLevel.Info;\n            case 'warn':\n                return LogLevel.Warn;\n            case 'error':\n                return LogLevel.Error;\n            case 'fatal':\n                return LogLevel.Fatal;\n            case 'none':\n            case 'disable':\n                return LogLevel.None;\n            default:\n                return LogLevel.None;\n        }\n    }\n\n    private getPrefix(logLevel: LogLevel): string {\n        let prefix = '';\n        if (this.loggerOptions.name) {\n            prefix += `${this.loggerOptions.name} `;\n        }\n\n        if (logLevel === LogLevel.Debug && this.loggerOptions.debugPrefix) {\n            prefix += `${this.loggerOptions.debugPrefix} `;\n        } else if (logLevel === LogLevel.Info && this.loggerOptions.infoPrefix) {\n            prefix += `${this.loggerOptions.infoPrefix} `;\n        } else if (logLevel === LogLevel.Warn && this.loggerOptions.warnPrefix) {\n            prefix += `${this.loggerOptions.warnPrefix} `;\n        } else if (logLevel === LogLevel.Error && this.loggerOptions.errorPrefix) {\n            prefix += `${this.loggerOptions.errorPrefix} `;\n        } else if (logLevel === LogLevel.Fatal && (this.loggerOptions.fatalPrefix || this.loggerOptions.errorPrefix)) {\n            prefix += `${this.loggerOptions.fatalPrefix || this.loggerOptions.errorPrefix} `;\n        }\n\n        return prefix;\n    }\n}\n"]}