Skip to content

pretty

typescript
declare function pretty<Level extends string = string>(
  params?: PrettyTargetParams<Level>
): Target<Level>;

pretty.defaultColors = {
  /* ... */
};
pretty.defaultBadges = {
  /* ... */
};
declare function pretty<Level extends string = string>(
  params?: PrettyTargetParams<Level>
): Target<Level>;

pretty.defaultColors = {
  /* ... */
};
pretty.defaultBadges = {
  /* ... */
};

PrettyTargetParams

typescript
interface PrettyTargetParams<Level extends string> {
  /**
   * Default handler for log messages without errors.
   * @default console.log
   */
  log?(...args: unknown[]): void;

  /**
   * Default handler for log messages with errors (e.g. `logger.error(new Error(), 'message')`).
   * @default console.error
   */
  logError?(...args: unknown[]): void;
  /**
   * Custom implementation of colors from `@neodx/colors` or other libraries with same contracts.
   * @example
   * createColors(false, false) // disable colors completely
   */
  colors?: Colors;
  /**
   * Display milliseconds in log message (e.g. `12:34:56.789`).
   * Works only if `displayTime` is `true`.
   * @default false
   */
  displayMs?: boolean;
  /**
   * Display time in a log message
   * @default true
   */
  displayTime?: boolean;
  /**
   * Display log level in log message.
   * @default true
   */
  displayLevel?: boolean;
  /**
   * Pretty errors configuration (true - enable default, false - disable, object - custom options).
   * @default true
   */
  prettyErrors?: boolean | Partial<PrintPrettyErrorOptions>;
  /**
   * Map with colorr names for each log level.
   * @example
   * { ...pretty.defaultColors, fatal: 'redBright' }
   */
  levelColors?: Partial<Record<Level, ColorName>> | null;
  /**
   * Map with badges for each log level.
   * @example
   * { ...pretty.defaultBadges, fatal: '💀' }
   */
  levelBadges?: Partial<Record<Level, string>> | null;
}
interface PrettyTargetParams<Level extends string> {
  /**
   * Default handler for log messages without errors.
   * @default console.log
   */
  log?(...args: unknown[]): void;

  /**
   * Default handler for log messages with errors (e.g. `logger.error(new Error(), 'message')`).
   * @default console.error
   */
  logError?(...args: unknown[]): void;
  /**
   * Custom implementation of colors from `@neodx/colors` or other libraries with same contracts.
   * @example
   * createColors(false, false) // disable colors completely
   */
  colors?: Colors;
  /**
   * Display milliseconds in log message (e.g. `12:34:56.789`).
   * Works only if `displayTime` is `true`.
   * @default false
   */
  displayMs?: boolean;
  /**
   * Display time in a log message
   * @default true
   */
  displayTime?: boolean;
  /**
   * Display log level in log message.
   * @default true
   */
  displayLevel?: boolean;
  /**
   * Pretty errors configuration (true - enable default, false - disable, object - custom options).
   * @default true
   */
  prettyErrors?: boolean | Partial<PrintPrettyErrorOptions>;
  /**
   * Map with colorr names for each log level.
   * @example
   * { ...pretty.defaultColors, fatal: 'redBright' }
   */
  levelColors?: Partial<Record<Level, ColorName>> | null;
  /**
   * Map with badges for each log level.
   * @example
   * { ...pretty.defaultBadges, fatal: '💀' }
   */
  levelBadges?: Partial<Record<Level, string>> | null;
}

Default colors and badges

typescript
const defaultLevelBadges = {
  info: '◌',
  done: '✔',
  warn: '⚠',
  error: '✘',
  debug: '⚙'
};

const defaultLevelColors = {
  info: 'cyanBright',
  warn: 'yellowBright',
  done: 'greenBright',
  debug: 'blueBright',
  error: 'red',
  verbose: 'bold'
};
const defaultLevelBadges = {
  info: '◌',
  done: '✔',
  warn: '⚠',
  error: '✘',
  debug: '⚙'
};

const defaultLevelColors = {
  info: 'cyanBright',
  warn: 'yellowBright',
  done: 'greenBright',
  debug: 'blueBright',
  error: 'red',
  verbose: 'bold'
};

Released under the MIT License.