-
Notifications
You must be signed in to change notification settings - Fork 670
/
Copy pathlogger.js
64 lines (54 loc) · 1.1 KB
/
logger.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
const lazyPrint = value => {
if (typeof value === 'function') {
return value()
}
return value
}
const logLevels = {
debug: [
['debug', 'debug'],
['verbose', 'debug'],
['info', 'info'],
['error', 'error'],
['warn', 'warn']
],
verbose: [
['verbose', 'debug'],
['info', 'info'],
['error', 'error'],
['warn', 'warn']
],
info: [
['info', 'info'],
['error', 'error'],
['warn', 'warn']
],
warn: [
['warn', 'warn'],
['error', 'error']
],
error: [['error', 'error']],
none: []
}
const print =
fn =>
(message, ...additional) =>
console[fn]({
message: lazyPrint(message),
...(Array.isArray(additional) ? additional.map(lazyPrint) : [])
})
const NO_OP = () => {}
function logger ({ level = 'error' } = {}) {
const levels = logLevels[level]
const logger = {
error: NO_OP,
debug: NO_OP,
info: NO_OP,
verbose: NO_OP,
warn: NO_OP
}
if (!levels) return logger
for (const [level2, consoleMethod] of levels) logger[level2] = print(consoleMethod)
return logger
}
module.exports = logger