Update logger

This commit is contained in:
Aya Morisawa
2016-12-29 23:09:21 +09:00
parent dcc32d5581
commit 5b0a227382
3 changed files with 68 additions and 35 deletions

View File

@@ -10,17 +10,44 @@ function toLevelColor(level: LogLevel): chalk.ChalkStyle {
}
}
export function log(message: string): void;
export function log(level: LogLevel, message: string): void;
export function log(level: LogLevel, message: string, domain: string): void;
export function log(x: string | LogLevel, message?: string, domain?: string): void {
const level = typeof message == 'undefined' ? 'Info' : x as LogLevel;
message = typeof message == 'undefined' ? x : message;
if (typeof domain == 'string') {
log(level, `[${domain}] ${message}`);
} else {
export default class Logger {
domain: string;
static log(level: LogLevel, message: string): void {
let color = toLevelColor(level);
let time = (new Date()).toLocaleTimeString('ja-JP');
console.log(`[${time} ${color.bold(level.toUpperCase())}]: ${message}`);
}
static error(message: string): void {
Logger.log('Error', message);
}
static warn(message: string): void {
Logger.log('Warn', message);
}
static info(message: string): void {
Logger.log('Info', message);
}
constructor(domain: string) {
this.domain = domain;
}
log(level: LogLevel, message: string): void {
Logger.log(level, `[${this.domain}] ${message}`);
}
error(message: string): void {
this.log('Error', message);
}
warn(message: string): void {
this.log('Warn', message);
}
info(message: string): void {
this.log('Info', message);
}
}