2017-11-06 11:59:14 +01:00
|
|
|
import chalk, { Chalk } from 'chalk';
|
2016-12-29 09:36:03 +01:00
|
|
|
|
|
|
|
export type LogLevel = 'Error' | 'Warn' | 'Info';
|
|
|
|
|
2017-11-06 11:59:14 +01:00
|
|
|
function toLevelColor(level: LogLevel): Chalk {
|
2016-12-29 09:36:03 +01:00
|
|
|
switch (level) {
|
|
|
|
case 'Error': return chalk.red;
|
|
|
|
case 'Warn': return chalk.yellow;
|
|
|
|
case 'Info': return chalk.blue;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-12-29 15:09:21 +01:00
|
|
|
export default class Logger {
|
2017-05-24 13:50:17 +02:00
|
|
|
private domain: string;
|
2016-12-29 15:09:21 +01:00
|
|
|
|
2017-05-24 13:50:17 +02:00
|
|
|
constructor(domain: string) {
|
|
|
|
this.domain = domain;
|
|
|
|
}
|
|
|
|
|
|
|
|
public static log(level: LogLevel, message: string): void {
|
|
|
|
const color = toLevelColor(level);
|
|
|
|
const time = (new Date()).toLocaleTimeString('ja-JP');
|
2018-07-13 16:51:16 +02:00
|
|
|
const coloredMessage = level === 'Info' ? message : color.bold(message);
|
|
|
|
console.log(`[${time} ${color.bold(level.toUpperCase())}]: ${coloredMessage}`);
|
2016-12-29 12:03:34 +01:00
|
|
|
}
|
2016-12-29 15:09:21 +01:00
|
|
|
|
2017-05-24 13:50:17 +02:00
|
|
|
public static error(message: string): void {
|
2016-12-29 15:09:21 +01:00
|
|
|
Logger.log('Error', message);
|
|
|
|
}
|
|
|
|
|
2017-05-24 13:50:17 +02:00
|
|
|
public static warn(message: string): void {
|
2016-12-29 15:09:21 +01:00
|
|
|
Logger.log('Warn', message);
|
|
|
|
}
|
|
|
|
|
2017-05-24 13:50:17 +02:00
|
|
|
public static info(message: string): void {
|
2016-12-29 15:09:21 +01:00
|
|
|
Logger.log('Info', message);
|
|
|
|
}
|
|
|
|
|
2017-05-24 13:50:17 +02:00
|
|
|
public log(level: LogLevel, message: string): void {
|
2016-12-29 15:09:21 +01:00
|
|
|
Logger.log(level, `[${this.domain}] ${message}`);
|
|
|
|
}
|
|
|
|
|
2017-05-24 13:50:17 +02:00
|
|
|
public error(message: string): void {
|
2016-12-29 15:09:21 +01:00
|
|
|
this.log('Error', message);
|
|
|
|
}
|
|
|
|
|
2017-05-24 13:50:17 +02:00
|
|
|
public warn(message: string): void {
|
2016-12-29 15:09:21 +01:00
|
|
|
this.log('Warn', message);
|
|
|
|
}
|
|
|
|
|
2017-05-24 13:50:17 +02:00
|
|
|
public info(message: string): void {
|
2016-12-29 15:09:21 +01:00
|
|
|
this.log('Info', message);
|
|
|
|
}
|
2016-12-29 09:36:03 +01:00
|
|
|
}
|