-
-
Notifications
You must be signed in to change notification settings - Fork 65
/
logging.node.js
164 lines (147 loc) · 3.81 KB
/
logging.node.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
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
/**
* Isomorphic logging module with support for colors!
*
* @module logging
*/
import * as env from './environment.js'
import * as common from './logging.common.js'
export { BOLD, UNBOLD, BLUE, GREY, GREEN, RED, PURPLE, ORANGE, UNCOLOR } from './logging.common.js'
const _nodeStyleMap = {
[common.BOLD]: '\u001b[1m',
[common.UNBOLD]: '\u001b[2m',
[common.BLUE]: '\x1b[34m',
[common.GREEN]: '\x1b[32m',
[common.GREY]: '\u001b[37m',
[common.RED]: '\x1b[31m',
[common.PURPLE]: '\x1b[35m',
[common.ORANGE]: '\x1b[38;5;208m',
[common.UNCOLOR]: '\x1b[0m'
}
/* c8 ignore start */
/**
* @param {Array<string|undefined|Symbol|Object|number|function():Array<any>>} args
* @return {Array<string|object|number|undefined>}
*/
const computeNodeLoggingArgs = (args) => {
if (args.length === 1 && args[0]?.constructor === Function) {
args = /** @type {Array<string|Symbol|Object|number>} */ (/** @type {[function]} */ (args)[0]())
}
const strBuilder = []
const logArgs = []
// try with formatting until we find something unsupported
let i = 0
for (; i < args.length; i++) {
const arg = args[i]
// @ts-ignore
const style = _nodeStyleMap[arg]
if (style !== undefined) {
strBuilder.push(style)
} else {
if (arg === undefined) {
break
} else if (arg.constructor === String || arg.constructor === Number) {
strBuilder.push(arg)
} else {
break
}
}
}
if (i > 0) {
// create logArgs with what we have so far
strBuilder.push('\x1b[0m')
logArgs.push(strBuilder.join(''))
}
// append the rest
for (; i < args.length; i++) {
const arg = args[i]
if (!(arg instanceof Symbol)) {
logArgs.push(arg)
}
}
return logArgs
}
/* c8 ignore stop */
/* c8 ignore start */
const computeLoggingArgs = env.supportsColor
? computeNodeLoggingArgs
: common.computeNoColorLoggingArgs
/* c8 ignore stop */
/**
* @param {Array<string|Symbol|Object|number|undefined>} args
*/
export const print = (...args) => {
console.log(...computeLoggingArgs(args))
}
/* c8 ignore start */
/**
* @param {Array<string|Symbol|Object|number>} args
*/
export const warn = (...args) => {
console.warn(...computeLoggingArgs(args))
}
/* c8 ignore stop */
/**
* @param {Error} err
*/
/* c8 ignore start */
export const printError = (err) => {
console.error(err)
}
/* c8 ignore stop */
/**
* @param {string} _url image location
* @param {number} _height height of the image in pixel
*/
/* c8 ignore start */
export const printImg = (_url, _height) => {
// console.log('%c ', `font-size: ${height}x; background: url(${url}) no-repeat;`)
}
/* c8 ignore stop */
/**
* @param {string} base64
* @param {number} height
*/
/* c8 ignore next 2 */
export const printImgBase64 = (base64, height) =>
printImg(`data:image/gif;base64,${base64}`, height)
/**
* @param {Array<string|Symbol|Object|number>} args
*/
/* c8 ignore next 3 */
export const group = (...args) => {
console.group(...computeLoggingArgs(args))
}
/**
* @param {Array<string|Symbol|Object|number>} args
*/
/* c8 ignore next 3 */
export const groupCollapsed = (...args) => {
console.groupCollapsed(...computeLoggingArgs(args))
}
/* c8 ignore next 3 */
export const groupEnd = () => {
console.groupEnd()
}
/**
* @param {function():Node} _createNode
*/
/* c8 ignore next 2 */
export const printDom = (_createNode) => {}
/**
* @param {HTMLCanvasElement} canvas
* @param {number} height
*/
/* c8 ignore next 2 */
export const printCanvas = (canvas, height) =>
printImg(canvas.toDataURL(), height)
/**
* @param {Element} _dom
*/
/* c8 ignore next */
export const createVConsole = (_dom) => {}
/**
* @param {string} moduleName
* @return {function(...any):void}
*/
/* c8 ignore next */
export const createModuleLogger = (moduleName) => common.createModuleLogger(print, moduleName)