UNPKG

5.13 kBJavaScriptView Raw
1"use strict";
2var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3 if (k2 === undefined) k2 = k;
4 Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
5}) : (function(o, m, k, k2) {
6 if (k2 === undefined) k2 = k;
7 o[k2] = m[k];
8}));
9var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
10 Object.defineProperty(o, "default", { enumerable: true, value: v });
11}) : function(o, v) {
12 o["default"] = v;
13});
14var __importStar = (this && this.__importStar) || function (mod) {
15 if (mod && mod.__esModule) return mod;
16 var result = {};
17 if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
18 __setModuleDefault(result, mod);
19 return result;
20};
21var __importDefault = (this && this.__importDefault) || function (mod) {
22 return (mod && mod.__esModule) ? mod : { "default": mod };
23};
24Object.defineProperty(exports, "__esModule", { value: true });
25const fs = __importStar(require("fs"));
26const react_1 = __importDefault(require("react"));
27const stack_utils_1 = __importDefault(require("stack-utils"));
28const code_excerpt_1 = __importDefault(require("code-excerpt"));
29const Box_1 = __importDefault(require("./Box"));
30const Text_1 = __importDefault(require("./Text"));
31const stackUtils = new stack_utils_1.default({
32 cwd: process.cwd(),
33 internals: stack_utils_1.default.nodeInternals()
34});
35const ErrorOverview = ({ error }) => {
36 const stack = error.stack ? error.stack.split('\n').slice(1) : undefined;
37 const origin = stack ? stackUtils.parseLine(stack[0]) : undefined;
38 let excerpt;
39 let lineWidth = 0;
40 if ((origin === null || origin === void 0 ? void 0 : origin.file) && (origin === null || origin === void 0 ? void 0 : origin.line) && fs.existsSync(origin.file)) {
41 const sourceCode = fs.readFileSync(origin.file, 'utf8');
42 excerpt = code_excerpt_1.default(sourceCode, origin.line);
43 if (excerpt) {
44 for (const { line } of excerpt) {
45 lineWidth = Math.max(lineWidth, String(line).length);
46 }
47 }
48 }
49 return (react_1.default.createElement(Box_1.default, { flexDirection: "column", padding: 1 },
50 react_1.default.createElement(Box_1.default, null,
51 react_1.default.createElement(Text_1.default, { backgroundColor: "red", color: "white" },
52 ' ',
53 "ERROR",
54 ' '),
55 react_1.default.createElement(Text_1.default, null,
56 " ",
57 error.message)),
58 origin && (react_1.default.createElement(Box_1.default, { marginTop: 1 },
59 react_1.default.createElement(Text_1.default, { dimColor: true },
60 origin.file,
61 ":",
62 origin.line,
63 ":",
64 origin.column))),
65 origin && excerpt && (react_1.default.createElement(Box_1.default, { marginTop: 1, flexDirection: "column" }, excerpt.map(({ line, value }) => (react_1.default.createElement(Box_1.default, { key: line },
66 react_1.default.createElement(Box_1.default, { width: lineWidth + 1 },
67 react_1.default.createElement(Text_1.default, { dimColor: line !== origin.line, backgroundColor: line === origin.line ? 'red' : undefined, color: line === origin.line ? 'white' : undefined },
68 String(line).padStart(lineWidth, ' '),
69 ":")),
70 react_1.default.createElement(Text_1.default, { key: line, backgroundColor: line === origin.line ? 'red' : undefined, color: line === origin.line ? 'white' : undefined }, ' ' + value)))))),
71 error.stack && (react_1.default.createElement(Box_1.default, { marginTop: 1, flexDirection: "column" }, error.stack
72 .split('\n')
73 .slice(1)
74 .map(line => {
75 const parsedLine = stackUtils.parseLine(line);
76 // If the line from the stack cannot be parsed, we print out the unparsed line.
77 if (!parsedLine) {
78 return (react_1.default.createElement(Box_1.default, { key: line },
79 react_1.default.createElement(Text_1.default, { dimColor: true }, "- "),
80 react_1.default.createElement(Text_1.default, { dimColor: true, bold: true }, line)));
81 }
82 return (react_1.default.createElement(Box_1.default, { key: line },
83 react_1.default.createElement(Text_1.default, { dimColor: true }, "- "),
84 react_1.default.createElement(Text_1.default, { dimColor: true, bold: true }, parsedLine.function),
85 react_1.default.createElement(Text_1.default, { dimColor: true, color: "gray" },
86 ' ',
87 "(",
88 parsedLine.file,
89 ":",
90 parsedLine.line,
91 ":",
92 parsedLine.column,
93 ")")));
94 })))));
95};
96exports.default = ErrorOverview;
97//# sourceMappingURL=ErrorOverview.js.map
\No newline at end of file