Files
discordeno/packages/utils/src/logger.ts
Fleny f199bbf71c build(dev-deps): Update biome to v2 (#4246)
* update biome to v2

* Run biome check --write

* Update biome.jsonc

Co-authored-by: Link <lts20050703@gmail.com>

* Fix config error

* Bump biome version

* Update website/yarn.lock

* Update biome to 2.1.3

---------

Co-authored-by: Link <lts20050703@gmail.com>
2025-08-09 12:45:04 -05:00

96 lines
2.1 KiB
TypeScript

import { bgBrightMagenta, black, bold, cyan, gray, italic, red, yellow } from './colors.js'
export enum LogLevels {
Debug,
Info,
Warn,
Error,
Fatal,
}
const prefixes = new Map<LogLevels, string>([
[LogLevels.Debug, 'DEBUG'],
[LogLevels.Info, 'INFO'],
[LogLevels.Warn, 'WARN'],
[LogLevels.Error, 'ERROR'],
[LogLevels.Fatal, 'FATAL'],
])
const noColor: (str: string) => string = (msg) => msg
const colorFunctions = new Map<LogLevels, (str: string) => string>([
[LogLevels.Debug, gray],
[LogLevels.Info, cyan],
[LogLevels.Warn, yellow],
[LogLevels.Error, (str: string) => red(str)],
[LogLevels.Fatal, (str: string) => red(bold(italic(str)))],
])
export function createLogger({ logLevel = LogLevels.Info, name }: { logLevel?: LogLevels; name?: string } = {}) {
function log(level: LogLevels, ...args: any[]) {
if (level < logLevel) return
let color = colorFunctions.get(level)
if (!color) color = noColor
const date = new Date()
const log = [
bgBrightMagenta(black(`[${date.toLocaleDateString()} ${date.toLocaleTimeString()}]`)),
color(prefixes.get(level) ?? 'DEBUG'),
name ? `${name} >` : '>',
...args,
]
switch (level) {
case LogLevels.Debug:
return console.debug(...log)
case LogLevels.Info:
return console.info(...log)
case LogLevels.Warn:
return console.warn(...log)
case LogLevels.Error:
return console.error(...log)
case LogLevels.Fatal:
return console.error(...log)
default:
return console.log(...log)
}
}
function setLevel(level: LogLevels) {
logLevel = level
}
function debug(...args: any[]) {
log(LogLevels.Debug, ...args)
}
function info(...args: any[]) {
log(LogLevels.Info, ...args)
}
function warn(...args: any[]) {
log(LogLevels.Warn, ...args)
}
function error(...args: any[]) {
log(LogLevels.Error, ...args)
}
function fatal(...args: any[]) {
log(LogLevels.Fatal, ...args)
}
return {
log,
setLevel,
debug,
info,
warn,
error,
fatal,
}
}
export const logger = createLogger({ name: 'Discordeno' })
export default logger