mirror of
https://github.com/bitwarden/browser.git
synced 2024-11-12 10:14:10 +01:00
9ddec9baf8
* changed hrtime library * changed import style
71 lines
2.0 KiB
TypeScript
71 lines
2.0 KiB
TypeScript
import { LogLevelType } from '../enums/logLevelType';
|
|
|
|
import { LogService as LogServiceAbstraction } from '../abstractions/log.service';
|
|
|
|
import * as hrtime from 'browser-hrtime';
|
|
|
|
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: string) {
|
|
if (!this.isDev) {
|
|
return;
|
|
}
|
|
this.write(LogLevelType.Debug, message);
|
|
}
|
|
|
|
info(message: string) {
|
|
this.write(LogLevelType.Info, message);
|
|
}
|
|
|
|
warning(message: string) {
|
|
this.write(LogLevelType.Warning, message);
|
|
}
|
|
|
|
error(message: string) {
|
|
this.write(LogLevelType.Error, message);
|
|
}
|
|
|
|
write(level: LogLevelType, message: string) {
|
|
if (this.filter != null && this.filter(level)) {
|
|
return;
|
|
}
|
|
|
|
switch (level) {
|
|
case LogLevelType.Debug:
|
|
// tslint:disable-next-line
|
|
console.log(message);
|
|
break;
|
|
case LogLevelType.Info:
|
|
// tslint:disable-next-line
|
|
console.log(message);
|
|
break;
|
|
case LogLevelType.Warning:
|
|
// tslint:disable-next-line
|
|
console.warn(message);
|
|
break;
|
|
case LogLevelType.Error:
|
|
// tslint:disable-next-line
|
|
console.error(message);
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
}
|
|
|
|
time(label: string = 'default') {
|
|
if (!this.timersMap.has(label)) {
|
|
this.timersMap.set(label, hrtime());
|
|
}
|
|
}
|
|
|
|
timeEnd(label: string = 'default'): [number, number] {
|
|
const elapsed = hrtime(this.timersMap.get(label));
|
|
this.timersMap.delete(label);
|
|
this.write(LogLevelType.Info, `${label}: ${elapsed[0] * 1000 + elapsed[1] / 10e6}ms`);
|
|
return elapsed;
|
|
}
|
|
}
|