58 lines
1.6 KiB
TypeScript
58 lines
1.6 KiB
TypeScript
import { LogService as LogServiceAbstraction } from "../abstractions/log.service";
|
|
import { LogLevelType } from "../enums/log-level-type.enum";
|
|
|
|
export class ConsoleLogService implements LogServiceAbstraction {
|
|
protected timersMap: Map<string, [number, number]> = new Map();
|
|
|
|
constructor(
|
|
protected isDev: boolean,
|
|
protected filter: (level: LogLevelType) => boolean = null,
|
|
) {}
|
|
|
|
debug(message?: any, ...optionalParams: any[]) {
|
|
if (!this.isDev) {
|
|
return;
|
|
}
|
|
this.write(LogLevelType.Debug, message, ...optionalParams);
|
|
}
|
|
|
|
info(message?: any, ...optionalParams: any[]) {
|
|
this.write(LogLevelType.Info, message, ...optionalParams);
|
|
}
|
|
|
|
warning(message?: any, ...optionalParams: any[]) {
|
|
this.write(LogLevelType.Warning, message, ...optionalParams);
|
|
}
|
|
|
|
error(message?: any, ...optionalParams: any[]) {
|
|
this.write(LogLevelType.Error, message, ...optionalParams);
|
|
}
|
|
|
|
write(level: LogLevelType, message?: any, ...optionalParams: any[]) {
|
|
if (this.filter != null && this.filter(level)) {
|
|
return;
|
|
}
|
|
|
|
switch (level) {
|
|
case LogLevelType.Debug:
|
|
// eslint-disable-next-line
|
|
console.log(message, ...optionalParams);
|
|
break;
|
|
case LogLevelType.Info:
|
|
// eslint-disable-next-line
|
|
console.log(message, ...optionalParams);
|
|
break;
|
|
case LogLevelType.Warning:
|
|
// eslint-disable-next-line
|
|
console.warn(message, ...optionalParams);
|
|
break;
|
|
case LogLevelType.Error:
|
|
// eslint-disable-next-line
|
|
console.error(message, ...optionalParams);
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
}
|
|
}
|