fbredius/storybook

View on GitHub
lib/node-logger/src/index.ts

Summary

Maintainability
A
0 mins
Test Coverage
/* eslint-disable no-console */
import npmLog from 'npmlog';
import prettyTime from 'pretty-hrtime';
import chalk from 'chalk';

export const colors = {
  pink: chalk.hex('F1618C'),
  purple: chalk.hex('B57EE5'),
  orange: chalk.hex('F3AD38'),
  green: chalk.hex('A2E05E'),
  blue: chalk.hex('6DABF5'),
  red: chalk.hex('F16161'),
  gray: chalk.gray,
};

export const logger = {
  info: (message: string): void => npmLog.info('', message),
  plain: (message: string): void => console.log(message),
  line: (count = 1): void => console.log(`${Array(count - 1).fill('\n')}`),
  warn: (message: string): void => npmLog.warn('', message),
  error: (message: string): void => npmLog.error('', message),
  trace: ({ message, time }: { message: string; time: [number, number] }): void =>
    npmLog.info('', `${message} (${colors.purple(prettyTime(time))})`),
  setLevel: (level = 'info'): void => {
    npmLog.level = level;
  },
};

export { npmLog as instance };

const logged = new Set();
export const once = (type: 'info' | 'warn' | 'error') => (message: string) => {
  if (logged.has(message)) return undefined;
  logged.add(message);
  return logger[type](message);
};

once.clear = () => logged.clear();
once.info = once('info');
once.warn = once('warn');
once.error = once('error');