@visulima/pail 3.2.2 → 4.0.0-alpha.10
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +188 -0
- package/LICENSE.md +434 -6
- package/README.md +355 -24
- package/dist/error.d.ts +104 -0
- package/dist/error.js +76 -0
- package/dist/index.browser.d.ts +3 -1
- package/dist/index.browser.js +1490 -3
- package/dist/index.server.d.ts +3 -1
- package/dist/index.server.js +2668 -14
- package/dist/interactive/index.js +2 -2
- package/dist/middleware/elysia.d.ts +71 -0
- package/dist/middleware/elysia.js +70 -0
- package/dist/middleware/express.d.ts +86 -0
- package/dist/middleware/express.js +29 -0
- package/dist/middleware/fastify.d.ts +81 -0
- package/dist/middleware/fastify.js +46 -0
- package/dist/middleware/hono.d.ts +85 -0
- package/dist/middleware/hono.js +33 -0
- package/dist/middleware/next/handler.d.ts +36 -0
- package/dist/middleware/next/handler.js +53 -0
- package/dist/middleware/next/middleware.d.ts +59 -0
- package/dist/middleware/next/storage.d.ts +14 -0
- package/dist/middleware/shared/create-middleware-logger.d.ts +82 -0
- package/dist/middleware/shared/headers.d.ts +14 -0
- package/dist/middleware/shared/routes.d.ts +30 -0
- package/dist/middleware/shared/storage.d.ts +29 -0
- package/dist/middleware/sveltekit.d.ts +123 -0
- package/dist/middleware/sveltekit.js +43 -0
- package/dist/object-tree.d.ts +2 -2
- package/dist/object-tree.js +7 -7
- package/dist/packem_shared/{AbstractJsonReporter-intFdT_A.js → AbstractJsonReporter-CjtVgHbU.js} +112 -28
- package/dist/packem_shared/AbstractJsonReporter-DlugSJpY.js +288 -0
- package/dist/packem_shared/{InteractiveManager-CZ85hGNW.js → InteractiveManager-CowYA3Hx.js} +17 -11
- package/dist/packem_shared/{interactive-stream-hook-DG4BtN12.js → InteractiveStreamHook-BypRlYTX.js} +3 -11
- package/dist/packem_shared/{JsonReporter-C0AXk99i.js → JsonReporter-BgPvIyC2.js} +2 -2
- package/dist/packem_shared/{JsonReporter-DcM2LBX9.js → JsonReporter-Dbw82ewj.js} +2 -2
- package/dist/packem_shared/{PrettyReporter-CuLLKr6-.js → PrettyReporter-C2dCzIaf.js} +54 -8
- package/dist/packem_shared/{format-label-Btft2KGP.js → PrettyReporter-gMqa7j_m.js} +372 -78
- package/dist/packem_shared/Spinner-Cokext9b.js +2183 -0
- package/dist/packem_shared/abstract-pretty-reporter-szQO-IgK.js +2635 -0
- package/dist/packem_shared/constants-B1RjD_ps.js +99 -0
- package/dist/packem_shared/{constants-DfDr4MHC.js → constants-omsTHUWB.js} +1 -1
- package/dist/packem_shared/createPailError-B_sgL0nF.js +76 -0
- package/dist/packem_shared/getBarChar-D7JfmdTr.js +459 -0
- package/dist/packem_shared/headers-BxHWM6KI.js +127 -0
- package/dist/packem_shared/{index-DqKWykfa.js → index-BEfVUy9P.js} +174 -64
- package/dist/packem_shared/{index-BomQ3E6J.js → index-Bx3-C0j9.js} +29 -21
- package/dist/packem_shared/pailMiddleware-Ci88geIF.js +24 -0
- package/dist/packem_shared/storage-D0vqz8OX.js +36 -0
- package/dist/packem_shared/{InteractiveStreamHook-DiSubbJ1.js → useLogger-D0rU3lcX.js} +13 -1
- package/dist/packem_shared/{write-console-log-based-on-level-DBmRYXpj.js → write-console-log-based-on-level-ree2lDPw.js} +5 -4
- package/dist/packem_shared/{write-stream-BG8fhcs3.js → write-stream-BuFtjATz.js} +1 -1
- package/dist/pail.browser.d.ts +1 -1
- package/dist/processor/environment-processor.d.ts +124 -0
- package/dist/processor/environment-processor.js +82 -0
- package/dist/processor/message-formatter-processor.d.ts +2 -2
- package/dist/processor/message-formatter-processor.js +654 -6
- package/dist/processor/opentelemetry-processor.js +4 -4
- package/dist/processor/redact-processor.d.ts +1 -1
- package/dist/processor/redact-processor.js +2 -1
- package/dist/processor/sampling-processor.d.ts +111 -0
- package/dist/processor/sampling-processor.js +59 -0
- package/dist/progress-bar.d.ts +10 -1
- package/dist/progress-bar.js +75 -20
- package/dist/reporter/file/json-file-reporter.js +1 -1
- package/dist/reporter/http/abstract-http-reporter.js +23 -26
- package/dist/reporter/http/http-reporter.edge-light.js +134 -53
- package/dist/reporter/json/abstract-json-reporter.d.ts +1 -1
- package/dist/reporter/json/index.browser.js +2 -2
- package/dist/reporter/json/index.js +2 -2
- package/dist/reporter/pretty/index.browser.js +1 -1
- package/dist/reporter/pretty/index.js +1 -1
- package/dist/reporter/simple/simple-reporter.server.js +8 -12
- package/dist/spinner.js +37 -4
- package/dist/types.d.ts +4 -4
- package/dist/wide-event.d.ts +300 -0
- package/dist/wide-event.js +283 -0
- package/package.json +73 -8
- package/dist/packem_shared/PrettyReporter-BFWaYP_J.js +0 -222
- package/dist/packem_shared/abstract-pretty-reporter-DMPDCslJ.js +0 -50
- package/dist/packem_shared/get-longest-label-C9PWeyKq.js +0 -9
- package/dist/packem_shared/pail.browser-CPjQrsyy.js +0 -1427
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@visulima/pail",
|
|
3
|
-
"version": "
|
|
3
|
+
"version": "4.0.0-alpha.10",
|
|
4
4
|
"description": "Highly configurable Logger for Node.js, Edge and Browser.",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"ansi",
|
|
@@ -55,14 +55,14 @@
|
|
|
55
55
|
"warning-logging",
|
|
56
56
|
"winston"
|
|
57
57
|
],
|
|
58
|
-
"homepage": "https://
|
|
58
|
+
"homepage": "https://visulima.com/packages/pail/",
|
|
59
59
|
"bugs": {
|
|
60
60
|
"url": "https://github.com/visulima/visulima/issues"
|
|
61
61
|
},
|
|
62
62
|
"repository": {
|
|
63
63
|
"type": "git",
|
|
64
64
|
"url": "git+https://github.com/visulima/visulima.git",
|
|
65
|
-
"directory": "packages/pail"
|
|
65
|
+
"directory": "packages/error-debugging/pail"
|
|
66
66
|
},
|
|
67
67
|
"funding": [
|
|
68
68
|
{
|
|
@@ -114,6 +114,18 @@
|
|
|
114
114
|
"types": "./dist/processor/opentelemetry-processor.d.ts",
|
|
115
115
|
"default": "./dist/processor/opentelemetry-processor.js"
|
|
116
116
|
},
|
|
117
|
+
"./processor/sampling": {
|
|
118
|
+
"types": "./dist/processor/sampling-processor.d.ts",
|
|
119
|
+
"default": "./dist/processor/sampling-processor.js"
|
|
120
|
+
},
|
|
121
|
+
"./processor/environment": {
|
|
122
|
+
"types": "./dist/processor/environment-processor.d.ts",
|
|
123
|
+
"default": "./dist/processor/environment-processor.js"
|
|
124
|
+
},
|
|
125
|
+
"./error": {
|
|
126
|
+
"types": "./dist/error.d.ts",
|
|
127
|
+
"default": "./dist/error.js"
|
|
128
|
+
},
|
|
117
129
|
"./reporter/file": {
|
|
118
130
|
"types": "./dist/reporter/file/json-file-reporter.d.ts",
|
|
119
131
|
"default": "./dist/reporter/file/json-file-reporter.js"
|
|
@@ -194,6 +206,34 @@
|
|
|
194
206
|
"types": "./dist/object-tree.d.ts",
|
|
195
207
|
"default": "./dist/object-tree.js"
|
|
196
208
|
},
|
|
209
|
+
"./wide-event": {
|
|
210
|
+
"types": "./dist/wide-event.d.ts",
|
|
211
|
+
"default": "./dist/wide-event.js"
|
|
212
|
+
},
|
|
213
|
+
"./middleware/express": {
|
|
214
|
+
"types": "./dist/middleware/express.d.ts",
|
|
215
|
+
"default": "./dist/middleware/express.js"
|
|
216
|
+
},
|
|
217
|
+
"./middleware/fastify": {
|
|
218
|
+
"types": "./dist/middleware/fastify.d.ts",
|
|
219
|
+
"default": "./dist/middleware/fastify.js"
|
|
220
|
+
},
|
|
221
|
+
"./middleware/hono": {
|
|
222
|
+
"types": "./dist/middleware/hono.d.ts",
|
|
223
|
+
"default": "./dist/middleware/hono.js"
|
|
224
|
+
},
|
|
225
|
+
"./middleware/elysia": {
|
|
226
|
+
"types": "./dist/middleware/elysia.d.ts",
|
|
227
|
+
"default": "./dist/middleware/elysia.js"
|
|
228
|
+
},
|
|
229
|
+
"./middleware/sveltekit": {
|
|
230
|
+
"types": "./dist/middleware/sveltekit.d.ts",
|
|
231
|
+
"default": "./dist/middleware/sveltekit.js"
|
|
232
|
+
},
|
|
233
|
+
"./middleware/next": {
|
|
234
|
+
"types": "./dist/middleware/next/handler.d.ts",
|
|
235
|
+
"default": "./dist/middleware/next/handler.js"
|
|
236
|
+
},
|
|
197
237
|
"./package.json": "./package.json"
|
|
198
238
|
},
|
|
199
239
|
"files": [
|
|
@@ -203,26 +243,51 @@
|
|
|
203
243
|
"LICENSE.md"
|
|
204
244
|
],
|
|
205
245
|
"dependencies": {
|
|
206
|
-
"@visulima/colorize": "
|
|
246
|
+
"@visulima/colorize": "2.0.0-alpha.8",
|
|
247
|
+
"type-fest": "5.5.0"
|
|
207
248
|
},
|
|
208
249
|
"peerDependencies": {
|
|
209
|
-
"@opentelemetry/api": "
|
|
210
|
-
"@
|
|
211
|
-
"
|
|
250
|
+
"@opentelemetry/api": "1.9.1",
|
|
251
|
+
"@sveltejs/kit": ">=2.0",
|
|
252
|
+
"@visulima/redact": "3.0.0-alpha.8",
|
|
253
|
+
"elysia": ">=1.0",
|
|
254
|
+
"express": ">=4.0",
|
|
255
|
+
"fastify": ">=4.0",
|
|
256
|
+
"hono": ">=4.0",
|
|
257
|
+
"next": ">=14.0",
|
|
258
|
+
"rotating-file-stream": "3.2.9"
|
|
212
259
|
},
|
|
213
260
|
"peerDependenciesMeta": {
|
|
214
261
|
"@opentelemetry/api": {
|
|
215
262
|
"optional": true
|
|
216
263
|
},
|
|
264
|
+
"@sveltejs/kit": {
|
|
265
|
+
"optional": true
|
|
266
|
+
},
|
|
217
267
|
"@visulima/redact": {
|
|
218
268
|
"optional": true
|
|
219
269
|
},
|
|
270
|
+
"elysia": {
|
|
271
|
+
"optional": true
|
|
272
|
+
},
|
|
273
|
+
"express": {
|
|
274
|
+
"optional": true
|
|
275
|
+
},
|
|
276
|
+
"fastify": {
|
|
277
|
+
"optional": true
|
|
278
|
+
},
|
|
279
|
+
"hono": {
|
|
280
|
+
"optional": true
|
|
281
|
+
},
|
|
282
|
+
"next": {
|
|
283
|
+
"optional": true
|
|
284
|
+
},
|
|
220
285
|
"rotating-file-stream": {
|
|
221
286
|
"optional": true
|
|
222
287
|
}
|
|
223
288
|
},
|
|
224
289
|
"engines": {
|
|
225
|
-
"node": ">=
|
|
290
|
+
"node": ">=22.13 <=25.x"
|
|
226
291
|
},
|
|
227
292
|
"os": [
|
|
228
293
|
"darwin",
|
|
@@ -1,222 +0,0 @@
|
|
|
1
|
-
import { createRequire as __cjs_createRequire } from "node:module";
|
|
2
|
-
|
|
3
|
-
const __cjs_require = __cjs_createRequire(import.meta.url);
|
|
4
|
-
|
|
5
|
-
const __cjs_getProcess = typeof globalThis !== "undefined" && typeof globalThis.process !== "undefined" ? globalThis.process : process;
|
|
6
|
-
|
|
7
|
-
const {
|
|
8
|
-
stdout,
|
|
9
|
-
stderr
|
|
10
|
-
} = __cjs_getProcess;
|
|
11
|
-
import colorize, { red, greenBright, cyan, green, grey, white, bgGrey, underline } from '@visulima/colorize';
|
|
12
|
-
import { d as defaultInspectorConfig, f as formatLabel, i as inspect, r as renderError } from './format-label-Btft2KGP.js';
|
|
13
|
-
import { t as terminalSize, g as getStringWidth, w as wordWrap, W as WrapMode } from './index-DqKWykfa.js';
|
|
14
|
-
import { E as EMPTY_SYMBOL } from './constants-DfDr4MHC.js';
|
|
15
|
-
import { A as AbstractPrettyReporter, g as getLongestBadge } from './abstract-pretty-reporter-DMPDCslJ.js';
|
|
16
|
-
import { g as getLongestLabel } from './get-longest-label-C9PWeyKq.js';
|
|
17
|
-
import { w as writeStream } from './write-stream-BG8fhcs3.js';
|
|
18
|
-
|
|
19
|
-
const pailFileFilter = (line) => !/[\\/]pail[\\/]dist/.test(line);
|
|
20
|
-
class PrettyReporter extends AbstractPrettyReporter {
|
|
21
|
-
#stdout;
|
|
22
|
-
#stderr;
|
|
23
|
-
#interactiveManager;
|
|
24
|
-
#interactive = false;
|
|
25
|
-
#inspectOptions;
|
|
26
|
-
#errorOptions;
|
|
27
|
-
/**
|
|
28
|
-
* Creates a new Server Pretty Reporter instance.
|
|
29
|
-
* @param options Configuration options for styling, error rendering, and object inspection
|
|
30
|
-
*/
|
|
31
|
-
constructor(options = {}) {
|
|
32
|
-
const { error: errorOptions, inspect: inspectOptions, ...rest } = options;
|
|
33
|
-
super({
|
|
34
|
-
uppercase: {
|
|
35
|
-
label: true,
|
|
36
|
-
...rest.uppercase
|
|
37
|
-
},
|
|
38
|
-
...rest
|
|
39
|
-
});
|
|
40
|
-
this.#inspectOptions = { ...defaultInspectorConfig, ...inspectOptions };
|
|
41
|
-
this.#errorOptions = {
|
|
42
|
-
...errorOptions,
|
|
43
|
-
color: {
|
|
44
|
-
fileLine: green,
|
|
45
|
-
hint: cyan,
|
|
46
|
-
marker: red,
|
|
47
|
-
message: red,
|
|
48
|
-
method: greenBright,
|
|
49
|
-
title: red
|
|
50
|
-
}
|
|
51
|
-
};
|
|
52
|
-
this.#stdout = stdout;
|
|
53
|
-
this.#stderr = stderr;
|
|
54
|
-
}
|
|
55
|
-
/**
|
|
56
|
-
* Sets the stdout stream for the reporter.
|
|
57
|
-
* @param stdout_ The writable stream to use for standard output
|
|
58
|
-
*/
|
|
59
|
-
setStdout(stdout_) {
|
|
60
|
-
this.#stdout = stdout_;
|
|
61
|
-
}
|
|
62
|
-
/**
|
|
63
|
-
* Sets the stderr stream for the reporter.
|
|
64
|
-
* @param stderr_ The writable stream to use for error output
|
|
65
|
-
*/
|
|
66
|
-
setStderr(stderr_) {
|
|
67
|
-
this.#stderr = stderr_;
|
|
68
|
-
}
|
|
69
|
-
/**
|
|
70
|
-
* Sets the interactive manager for handling interactive output.
|
|
71
|
-
* @param manager The interactive manager instance, or undefined to disable
|
|
72
|
-
*/
|
|
73
|
-
setInteractiveManager(manager) {
|
|
74
|
-
this.#interactiveManager = manager;
|
|
75
|
-
}
|
|
76
|
-
/**
|
|
77
|
-
* Enables or disables interactive mode.
|
|
78
|
-
* @param interactive Whether to enable interactive terminal features
|
|
79
|
-
*/
|
|
80
|
-
setIsInteractive(interactive) {
|
|
81
|
-
this.#interactive = interactive;
|
|
82
|
-
}
|
|
83
|
-
log(meta) {
|
|
84
|
-
this._log(this._formatMessage(meta), meta.type.level);
|
|
85
|
-
}
|
|
86
|
-
// eslint-disable-next-line sonarjs/cognitive-complexity, no-underscore-dangle
|
|
87
|
-
_formatMessage(data) {
|
|
88
|
-
const { columns } = terminalSize();
|
|
89
|
-
let size = columns;
|
|
90
|
-
if (typeof this.styles.messageLength === "number") {
|
|
91
|
-
size = this.styles.messageLength;
|
|
92
|
-
}
|
|
93
|
-
const { badge, context, date, error, file, groups, label, message, prefix, repeated, scope, suffix, traceError, type } = data;
|
|
94
|
-
const { color } = this.loggerTypes[type.name];
|
|
95
|
-
const colorized = color ? colorize[color] : white;
|
|
96
|
-
const groupSpaces = groups.map(() => " ").join("");
|
|
97
|
-
const items = [];
|
|
98
|
-
if (groups.length > 0) {
|
|
99
|
-
items.push(`${groupSpaces + grey(`[${groups.at(-1)}]`)} `);
|
|
100
|
-
}
|
|
101
|
-
if (date) {
|
|
102
|
-
items.push(`${grey(this.styles.dateFormatter(typeof date === "string" ? new Date(date) : date))} `);
|
|
103
|
-
}
|
|
104
|
-
if (badge) {
|
|
105
|
-
items.push(colorized(badge));
|
|
106
|
-
} else {
|
|
107
|
-
const longestBadge = getLongestBadge(this.loggerTypes);
|
|
108
|
-
if (longestBadge.length > 0) {
|
|
109
|
-
items.push(`${grey(".".repeat(longestBadge.length))} `);
|
|
110
|
-
}
|
|
111
|
-
}
|
|
112
|
-
const longestLabel = getLongestLabel(this.loggerTypes);
|
|
113
|
-
if (label) {
|
|
114
|
-
const longestLabelWidth = getStringWidth(longestLabel);
|
|
115
|
-
const labelWidth = getStringWidth(label);
|
|
116
|
-
items.push(`${colorized(formatLabel(label, this.styles))} `, grey(".".repeat(Math.max(0, longestLabelWidth - labelWidth))));
|
|
117
|
-
} else {
|
|
118
|
-
items.push(grey(".".repeat(longestLabel.length + 2)));
|
|
119
|
-
}
|
|
120
|
-
if (repeated) {
|
|
121
|
-
items.push(`${bgGrey.white(`[${repeated}x]`)} `);
|
|
122
|
-
}
|
|
123
|
-
if (Array.isArray(scope) && scope.length > 0) {
|
|
124
|
-
items.push(` ${grey(`[${scope.join(" > ")}]`)} `);
|
|
125
|
-
}
|
|
126
|
-
if (prefix) {
|
|
127
|
-
items.push(
|
|
128
|
-
`${grey(`${Array.isArray(scope) && scope.length > 0 ? ". " : " "}[${this.styles.underline.prefix ? underline(prefix) : prefix}]`)} `
|
|
129
|
-
);
|
|
130
|
-
}
|
|
131
|
-
const titleSize = getStringWidth(items.join(" "));
|
|
132
|
-
if (file) {
|
|
133
|
-
const fileMessage = file.name + (file.line ? `:${file.line}` : "");
|
|
134
|
-
const fileMessageSize = getStringWidth(fileMessage);
|
|
135
|
-
if (fileMessageSize + titleSize + 2 > size) {
|
|
136
|
-
items.push(grey(` ${fileMessage}`));
|
|
137
|
-
} else {
|
|
138
|
-
const dots = Math.max(0, size - titleSize - fileMessageSize - 2);
|
|
139
|
-
items.push(grey(`${".".repeat(dots)} ${fileMessage}`));
|
|
140
|
-
}
|
|
141
|
-
} else {
|
|
142
|
-
items.push(grey(".".repeat(Math.max(0, size - titleSize - 1))));
|
|
143
|
-
}
|
|
144
|
-
if (items.length > 0) {
|
|
145
|
-
items.push("\n\n");
|
|
146
|
-
}
|
|
147
|
-
if (message !== EMPTY_SYMBOL) {
|
|
148
|
-
const formattedMessage = typeof message === "string" ? message : inspect(message, this.#inspectOptions);
|
|
149
|
-
items.push(
|
|
150
|
-
groupSpaces + wordWrap(formattedMessage, {
|
|
151
|
-
trim: false,
|
|
152
|
-
width: size - 3,
|
|
153
|
-
wrapMode: WrapMode.STRICT_WIDTH
|
|
154
|
-
})
|
|
155
|
-
);
|
|
156
|
-
}
|
|
157
|
-
if (context) {
|
|
158
|
-
let hasError = false;
|
|
159
|
-
items.push(
|
|
160
|
-
...context.map((value) => {
|
|
161
|
-
if (value instanceof Error) {
|
|
162
|
-
hasError = true;
|
|
163
|
-
return `
|
|
164
|
-
|
|
165
|
-
${renderError(value, {
|
|
166
|
-
...this.#errorOptions,
|
|
167
|
-
filterStacktrace: pailFileFilter,
|
|
168
|
-
prefix: groupSpaces
|
|
169
|
-
})}`;
|
|
170
|
-
}
|
|
171
|
-
if (typeof value === "object") {
|
|
172
|
-
return ` ${inspect(value, this.#inspectOptions)}`;
|
|
173
|
-
}
|
|
174
|
-
const newValue = (hasError ? "\n\n" : " ") + value;
|
|
175
|
-
hasError = false;
|
|
176
|
-
return newValue;
|
|
177
|
-
})
|
|
178
|
-
);
|
|
179
|
-
}
|
|
180
|
-
if (error) {
|
|
181
|
-
items.push(
|
|
182
|
-
renderError(error, {
|
|
183
|
-
...this.#errorOptions,
|
|
184
|
-
filterStacktrace: pailFileFilter,
|
|
185
|
-
prefix: groupSpaces
|
|
186
|
-
})
|
|
187
|
-
);
|
|
188
|
-
}
|
|
189
|
-
if (traceError) {
|
|
190
|
-
items.push(
|
|
191
|
-
`
|
|
192
|
-
|
|
193
|
-
${renderError(traceError, {
|
|
194
|
-
...this.#errorOptions,
|
|
195
|
-
filterStacktrace: pailFileFilter,
|
|
196
|
-
hideErrorCauseCodeView: true,
|
|
197
|
-
hideErrorCodeView: true,
|
|
198
|
-
hideErrorErrorsCodeView: true,
|
|
199
|
-
hideMessage: true,
|
|
200
|
-
prefix: groupSpaces
|
|
201
|
-
})}`
|
|
202
|
-
);
|
|
203
|
-
}
|
|
204
|
-
if (suffix) {
|
|
205
|
-
items.push("\n", groupSpaces + grey(this.styles.underline.suffix ? underline(suffix) : suffix));
|
|
206
|
-
}
|
|
207
|
-
return items.join("");
|
|
208
|
-
}
|
|
209
|
-
// eslint-disable-next-line no-underscore-dangle
|
|
210
|
-
_log(message, logLevel) {
|
|
211
|
-
const streamType = ["error", "trace", "warn"].includes(logLevel) ? "stderr" : "stdout";
|
|
212
|
-
const stream = streamType === "stderr" ? this.#stderr : this.#stdout;
|
|
213
|
-
if (this.#interactive && this.#interactiveManager !== void 0 && stream.isTTY) {
|
|
214
|
-
this.#interactiveManager.update(streamType, message.split("\n"), 0);
|
|
215
|
-
} else {
|
|
216
|
-
writeStream(`${message}
|
|
217
|
-
`, stream);
|
|
218
|
-
}
|
|
219
|
-
}
|
|
220
|
-
}
|
|
221
|
-
|
|
222
|
-
export { PrettyReporter };
|
|
@@ -1,50 +0,0 @@
|
|
|
1
|
-
import { L as LOG_TYPES } from './constants-DfDr4MHC.js';
|
|
2
|
-
|
|
3
|
-
const getLongestBadge = (types) => {
|
|
4
|
-
const badges = Object.keys(types).map((x) => types[x].badge ?? "");
|
|
5
|
-
if (badges.length === 0) {
|
|
6
|
-
return "";
|
|
7
|
-
}
|
|
8
|
-
return badges.reduce((x, y) => x.length > y.length ? x : y);
|
|
9
|
-
};
|
|
10
|
-
|
|
11
|
-
const dateFormatter = (date) => [date.getHours(), date.getMinutes(), date.getSeconds()].map((n) => String(n).padStart(2, "0")).join(":");
|
|
12
|
-
class AbstractPrettyReporter {
|
|
13
|
-
/** Styling options for pretty formatting */
|
|
14
|
-
styles;
|
|
15
|
-
/** Logger type configurations for styling */
|
|
16
|
-
loggerTypes;
|
|
17
|
-
/**
|
|
18
|
-
* Creates a new AbstractPrettyReporter instance.
|
|
19
|
-
* @param options Styling options for pretty formatting
|
|
20
|
-
* @protected
|
|
21
|
-
*/
|
|
22
|
-
constructor(options) {
|
|
23
|
-
this.styles = {
|
|
24
|
-
bold: {
|
|
25
|
-
label: false
|
|
26
|
-
},
|
|
27
|
-
dateFormatter,
|
|
28
|
-
underline: {
|
|
29
|
-
label: false,
|
|
30
|
-
message: false,
|
|
31
|
-
prefix: false,
|
|
32
|
-
suffix: false
|
|
33
|
-
},
|
|
34
|
-
uppercase: {
|
|
35
|
-
label: false
|
|
36
|
-
},
|
|
37
|
-
...options
|
|
38
|
-
};
|
|
39
|
-
this.loggerTypes = LOG_TYPES;
|
|
40
|
-
}
|
|
41
|
-
/**
|
|
42
|
-
* Sets the logger types configuration for styling.
|
|
43
|
-
* @param types Logger type configurations with colors and labels
|
|
44
|
-
*/
|
|
45
|
-
setLoggerTypes(types) {
|
|
46
|
-
this.loggerTypes = types;
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
export { AbstractPrettyReporter as A, getLongestBadge as g };
|