Files
feishin/src/logger.ts
T
2023-12-13 18:19:57 -08:00

48 lines
1.2 KiB
TypeScript

import console from 'console';
import dayjs from 'dayjs';
const reset = '\x1b[0m';
const baseLog = (errorType: 'error' | 'info' | 'success' | 'warn') => {
let logString = '';
switch (errorType) {
case 'error':
logString = '\x1b[31m[ERROR] ';
break;
case 'info':
logString = '\x1b[34m[INFO] ';
break;
case 'success':
logString = '\x1b[32m[SUCCESS] ';
break;
case 'warn':
logString = '\x1b[33m[WARNING] ';
break;
default:
logString = '\x1b[34m[INFO] ';
break;
}
return (
text: string,
options?: { context?: Record<string, any>; throwError?: boolean; toast?: boolean },
): null | Error => {
const { throwError } = options || {};
const now = dayjs().toISOString();
console.log(`${logString}${now}${text}${JSON.stringify(options?.context)}${reset}`);
if (!throwError) {
return null;
}
throw new Error(text);
};
};
export const fsLog = {
error: baseLog('error'),
info: baseLog('info'),
success: baseLog('success'),
warn: baseLog('warn'),
};