Files
discordeno/packages/utils/src/logger.ts
dependabot[bot] e31c4d0a8a build(deps-dev): bump eslint-config-standard-with-typescript from 40.0.0 to 42.0.0 (#3297)
* build(deps-dev): bump eslint-config-standard-with-typescript

Bumps [eslint-config-standard-with-typescript](https://github.com/standard/eslint-config-standard-with-typescript) from 40.0.0 to 42.0.0.
- [Release notes](https://github.com/standard/eslint-config-standard-with-typescript/releases)
- [Changelog](https://github.com/standard/eslint-config-standard-with-typescript/blob/master/CHANGELOG.md)
- [Commits](https://github.com/standard/eslint-config-standard-with-typescript/compare/v40.0.0...v42.0.0)

---
updated-dependencies:
- dependency-name: eslint-config-standard-with-typescript
  dependency-type: direct:development
  update-type: version-update:semver-major
...

Signed-off-by: dependabot[bot] <support@github.com>

* Disable @typescript-eslint/no-unsafe-argument for the logger

* Fix eslint errors

---------

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
Co-authored-by: Fleny <Fleny113@outlook.com>
2023-12-11 22:04:40 +00:00

122 lines
2.8 KiB
TypeScript

/* eslint-disable @typescript-eslint/no-confusing-void-expression */
/* eslint-disable @typescript-eslint/explicit-function-return-type */
/* eslint-disable @typescript-eslint/no-unsafe-argument */
import { bgBrightMagenta, black, bold, cyan, gray, italic, red, yellow } from './colors.js'
export enum LogLevels {
Debug,
Info,
Warn,
Error,
Fatal,
}
export enum LogDepth {
Minimal,
Full,
}
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
} = {}) {
let depth = LogDepth.Minimal
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 setDepth(level: LogDepth) {
depth = level
}
function debug(...args: any[]) {
if (LogDepth.Minimal === depth) log(LogLevels.Debug, args[0])
else log(LogLevels.Debug, ...args)
}
function info(...args: any[]) {
if (LogDepth.Minimal === depth) log(LogLevels.Info, args[0])
else log(LogLevels.Info, ...args)
}
function warn(...args: any[]) {
if (LogDepth.Minimal === depth) log(LogLevels.Warn, args[0])
else log(LogLevels.Warn, ...args)
}
function error(...args: any[]) {
if (LogDepth.Minimal === depth) log(LogLevels.Error, args[0])
else log(LogLevels.Error, ...args)
}
function fatal(...args: any[]) {
if (LogDepth.Minimal === depth) log(LogLevels.Fatal, args[0])
else log(LogLevels.Fatal, ...args)
}
return {
log,
setDepth,
setLevel,
debug,
info,
warn,
error,
fatal,
}
}
export const logger = createLogger({ name: 'Discordeno' })
export default logger