@xyo-network/react-error 2.40.1 → 2.40.3
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/dist/cjs/components/XyoErrorBoundary/ThrownErrorBoundary.d.ts +3 -1
- package/dist/cjs/components/XyoErrorBoundary/ThrownErrorBoundary.d.ts.map +1 -1
- package/dist/cjs/components/XyoErrorBoundary/ThrownErrorBoundary.js +9 -3
- package/dist/cjs/components/XyoErrorBoundary/ThrownErrorBoundary.js.map +1 -1
- package/dist/cjs/components/XyoErrorRender/ErrorAlert.d.ts +1 -0
- package/dist/cjs/components/XyoErrorRender/ErrorAlert.d.ts.map +1 -1
- package/dist/cjs/components/XyoErrorRender/ErrorAlert.js +2 -2
- package/dist/cjs/components/XyoErrorRender/ErrorAlert.js.map +1 -1
- package/dist/cjs/components/XyoErrorRender/Props.d.ts +1 -0
- package/dist/cjs/components/XyoErrorRender/Props.d.ts.map +1 -1
- package/dist/cjs/components/XyoErrorRender/Render.d.ts.map +1 -1
- package/dist/cjs/components/XyoErrorRender/Render.js +2 -2
- package/dist/cjs/components/XyoErrorRender/Render.js.map +1 -1
- package/dist/docs.json +719 -565
- package/dist/esm/components/XyoErrorBoundary/ThrownErrorBoundary.d.ts +3 -1
- package/dist/esm/components/XyoErrorBoundary/ThrownErrorBoundary.d.ts.map +1 -1
- package/dist/esm/components/XyoErrorBoundary/ThrownErrorBoundary.js +9 -3
- package/dist/esm/components/XyoErrorBoundary/ThrownErrorBoundary.js.map +1 -1
- package/dist/esm/components/XyoErrorRender/ErrorAlert.d.ts +1 -0
- package/dist/esm/components/XyoErrorRender/ErrorAlert.d.ts.map +1 -1
- package/dist/esm/components/XyoErrorRender/ErrorAlert.js +2 -2
- package/dist/esm/components/XyoErrorRender/ErrorAlert.js.map +1 -1
- package/dist/esm/components/XyoErrorRender/Props.d.ts +1 -0
- package/dist/esm/components/XyoErrorRender/Props.d.ts.map +1 -1
- package/dist/esm/components/XyoErrorRender/Render.d.ts.map +1 -1
- package/dist/esm/components/XyoErrorRender/Render.js +2 -2
- package/dist/esm/components/XyoErrorRender/Render.js.map +1 -1
- package/package.json +1 -1
- package/src/components/XyoErrorBoundary/ThrownErrorBoundary.stories.tsx +1 -1
- package/src/components/XyoErrorBoundary/ThrownErrorBoundary.tsx +12 -4
- package/src/components/XyoErrorRender/ErrorAlert.tsx +7 -1
- package/src/components/XyoErrorRender/Props.ts +1 -0
- package/src/components/XyoErrorRender/Render.tsx +9 -2
|
@@ -7,7 +7,8 @@ export interface XyoErrorBoundaryProps {
|
|
|
7
7
|
children: ReactNode;
|
|
8
8
|
rollbar?: Rollbar;
|
|
9
9
|
basePageProps?: BasePageProps;
|
|
10
|
-
errorComponent?: (e:
|
|
10
|
+
errorComponent?: (e: XyoError, boundaryName?: string) => ReactNode;
|
|
11
|
+
boundaryName?: string;
|
|
11
12
|
}
|
|
12
13
|
export interface XyoErrorBoundaryState {
|
|
13
14
|
xyoError?: XyoError;
|
|
@@ -15,6 +16,7 @@ export interface XyoErrorBoundaryState {
|
|
|
15
16
|
export declare class XyoThrownErrorBoundary extends Component<XyoErrorBoundaryProps, XyoErrorBoundaryState> {
|
|
16
17
|
state: XyoErrorBoundaryState;
|
|
17
18
|
static normalizeError(error: Error | XyoError): XyoError;
|
|
19
|
+
static getDerivedStateFromError(error: Error): XyoErrorBoundaryState;
|
|
18
20
|
componentDidCatch(error: Error, errorInfo: ErrorInfo): void;
|
|
19
21
|
render(): string | number | boolean | import("react").ReactFragment | JSX.Element | null | undefined;
|
|
20
22
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ThrownErrorBoundary.d.ts","sourceRoot":"","sources":["../../../../src/components/XyoErrorBoundary/ThrownErrorBoundary.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAA;AACpD,OAAO,EAAE,QAAQ,EAAkB,MAAM,qBAAqB,CAAA;AAC9D,OAAO,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,OAAO,CAAA;AACvD,OAAO,OAAO,MAAM,SAAS,CAAA;AAI7B,MAAM,WAAW,qBAAqB;IACpC,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB,QAAQ,EAAE,SAAS,CAAA;IACnB,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB,aAAa,CAAC,EAAE,aAAa,CAAA;IAC7B,cAAc,CAAC,EAAE,CAAC,CAAC,EAAE,
|
|
1
|
+
{"version":3,"file":"ThrownErrorBoundary.d.ts","sourceRoot":"","sources":["../../../../src/components/XyoErrorBoundary/ThrownErrorBoundary.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAA;AACpD,OAAO,EAAE,QAAQ,EAAkB,MAAM,qBAAqB,CAAA;AAC9D,OAAO,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,OAAO,CAAA;AACvD,OAAO,OAAO,MAAM,SAAS,CAAA;AAI7B,MAAM,WAAW,qBAAqB;IACpC,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB,QAAQ,EAAE,SAAS,CAAA;IACnB,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB,aAAa,CAAC,EAAE,aAAa,CAAA;IAC7B,cAAc,CAAC,EAAE,CAAC,CAAC,EAAE,QAAQ,EAAE,YAAY,CAAC,EAAE,MAAM,KAAK,SAAS,CAAA;IAClE,YAAY,CAAC,EAAE,MAAM,CAAA;CACtB;AAED,MAAM,WAAW,qBAAqB;IACpC,QAAQ,CAAC,EAAE,QAAQ,CAAA;CACpB;AAED,qBAAa,sBAAuB,SAAQ,SAAS,CAAC,qBAAqB,EAAE,qBAAqB,CAAC;IAC1F,KAAK,EAAE,qBAAqB,CAElC;WAEa,cAAc,CAAC,KAAK,EAAE,KAAK,GAAG,QAAQ,GAAG,QAAQ;IAI/D,MAAM,CAAC,wBAAwB,CAAC,KAAK,EAAE,KAAK;IAIrC,iBAAiB,CAAC,KAAK,EAAE,KAAK,EAAE,SAAS,EAAE,SAAS;IAYpD,MAAM;CAYd"}
|
|
@@ -15,9 +15,12 @@ class XyoThrownErrorBoundary extends react_1.Component {
|
|
|
15
15
|
static normalizeError(error) {
|
|
16
16
|
return (error.schema === module_1.XyoErrorSchema ? error : { message: error.message, schema: module_1.XyoErrorSchema, sources: [] });
|
|
17
17
|
}
|
|
18
|
+
static getDerivedStateFromError(error) {
|
|
19
|
+
return { hasError: true, xyoError: XyoThrownErrorBoundary.normalizeError(error) };
|
|
20
|
+
}
|
|
18
21
|
componentDidCatch(error, errorInfo) {
|
|
19
22
|
const { rethrow, rollbar } = this.props;
|
|
20
|
-
const xyoError =
|
|
23
|
+
const { xyoError } = this.state;
|
|
21
24
|
rollbar === null || rollbar === void 0 ? void 0 : rollbar.error(error);
|
|
22
25
|
console.error('XyoError:', xyoError, errorInfo);
|
|
23
26
|
if (rethrow) {
|
|
@@ -26,9 +29,12 @@ class XyoThrownErrorBoundary extends react_1.Component {
|
|
|
26
29
|
}
|
|
27
30
|
render() {
|
|
28
31
|
const { xyoError } = this.state;
|
|
29
|
-
const { children } = this.props;
|
|
32
|
+
const { children, boundaryName, errorComponent } = this.props;
|
|
30
33
|
if (xyoError) {
|
|
31
|
-
|
|
34
|
+
if (errorComponent) {
|
|
35
|
+
return errorComponent(xyoError);
|
|
36
|
+
}
|
|
37
|
+
return (0, jsx_runtime_1.jsx)(XyoErrorRender_1.XyoErrorRender, { xyoError: xyoError, errorContext: `${boundaryName} Boundary` });
|
|
32
38
|
}
|
|
33
39
|
return children;
|
|
34
40
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ThrownErrorBoundary.js","sourceRoot":"","sources":["../../../../src/components/XyoErrorBoundary/ThrownErrorBoundary.tsx"],"names":[],"mappings":";;;;AACA,gDAA8D;AAC9D,iCAAuD;AAGvD,sDAAkD;
|
|
1
|
+
{"version":3,"file":"ThrownErrorBoundary.js","sourceRoot":"","sources":["../../../../src/components/XyoErrorBoundary/ThrownErrorBoundary.tsx"],"names":[],"mappings":";;;;AACA,gDAA8D;AAC9D,iCAAuD;AAGvD,sDAAkD;AAelD,MAAa,sBAAuB,SAAQ,iBAAuD;IAAnG;;QACS,UAAK,GAA0B;YACpC,QAAQ,EAAE,SAAS;SACpB,CAAA;IAkCH,CAAC;IAhCQ,MAAM,CAAC,cAAc,CAAC,KAAuB;QAClD,OAAO,CAAE,KAAkB,CAAC,MAAM,KAAK,uBAAc,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,uBAAc,EAAE,OAAO,EAAE,EAAE,EAAE,CAAa,CAAA;IAC9I,CAAC;IAED,MAAM,CAAC,wBAAwB,CAAC,KAAY;QAC1C,OAAO,EAAE,QAAQ,EAAE,IAAI,EAAE,QAAQ,EAAE,sBAAsB,CAAC,cAAc,CAAC,KAAK,CAAC,EAA2B,CAAA;IAC5G,CAAC;IAEM,iBAAiB,CAAC,KAAY,EAAE,SAAoB;QACzD,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC,KAAK,CAAA;QACvC,MAAM,EAAE,QAAQ,EAAE,GAAG,IAAI,CAAC,KAAK,CAAA;QAE/B,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,KAAK,CAAC,KAAK,CAAC,CAAA;QAErB,OAAO,CAAC,KAAK,CAAC,WAAW,EAAE,QAAQ,EAAE,SAAS,CAAC,CAAA;QAC/C,IAAI,OAAO,EAAE;YACX,MAAM,KAAK,CAAA;SACZ;IACH,CAAC;IAEM,MAAM;QACX,MAAM,EAAE,QAAQ,EAAE,GAAG,IAAI,CAAC,KAAK,CAAA;QAC/B,MAAM,EAAE,QAAQ,EAAE,YAAY,EAAE,cAAc,EAAE,GAAG,IAAI,CAAC,KAAK,CAAA;QAC7D,IAAI,QAAQ,EAAE;YACZ,IAAI,cAAc,EAAE;gBAClB,OAAO,cAAc,CAAC,QAAQ,CAAC,CAAA;aAChC;YACD,OAAO,uBAAC,+BAAc,IAAC,QAAQ,EAAE,QAAQ,EAAE,YAAY,EAAE,GAAG,YAAY,WAAW,GAAI,CAAA;SACxF;QAED,OAAO,QAAQ,CAAA;IACjB,CAAC;CACF;AArCD,wDAqCC"}
|
|
@@ -3,6 +3,7 @@ import { AlertProps } from '@mui/material';
|
|
|
3
3
|
import { XyoError } from '@xyo-network/module';
|
|
4
4
|
export interface XyoErrorAlertProps extends AlertProps {
|
|
5
5
|
error?: XyoError;
|
|
6
|
+
errorContext?: string;
|
|
6
7
|
}
|
|
7
8
|
export declare const XyoErrorAlert: React.FC<XyoErrorAlertProps>;
|
|
8
9
|
//# sourceMappingURL=ErrorAlert.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ErrorAlert.d.ts","sourceRoot":"","sources":["../../../../src/components/XyoErrorRender/ErrorAlert.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAS,UAAU,EAA0B,MAAM,eAAe,CAAA;AACzE,OAAO,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAA;AAE9C,MAAM,WAAW,kBAAmB,SAAQ,UAAU;IACpD,KAAK,CAAC,EAAE,QAAQ,CAAA;
|
|
1
|
+
{"version":3,"file":"ErrorAlert.d.ts","sourceRoot":"","sources":["../../../../src/components/XyoErrorRender/ErrorAlert.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAS,UAAU,EAA0B,MAAM,eAAe,CAAA;AACzE,OAAO,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAA;AAE9C,MAAM,WAAW,kBAAmB,SAAQ,UAAU;IACpD,KAAK,CAAC,EAAE,QAAQ,CAAA;IAChB,YAAY,CAAC,EAAE,MAAM,CAAA;CACtB;AAED,eAAO,MAAM,aAAa,EAAE,KAAK,CAAC,EAAE,CAAC,kBAAkB,CAetD,CAAA"}
|
|
@@ -5,8 +5,8 @@ const tslib_1 = require("tslib");
|
|
|
5
5
|
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
6
6
|
const material_1 = require("@mui/material");
|
|
7
7
|
const XyoErrorAlert = (_a) => {
|
|
8
|
-
var { error } = _a, props = tslib_1.__rest(_a, ["error"]);
|
|
9
|
-
return ((0, jsx_runtime_1.jsxs)(material_1.Alert, Object.assign({ severity: "error" }, props, { children: [(0, jsx_runtime_1.jsx)(material_1.AlertTitle, { children: "Whoops! Something went wrong" }), (0, jsx_runtime_1.jsx)(material_1.Typography, Object.assign({ variant: "caption", mr: 0.5, fontWeight: "bold" }, { children: "Error:" })), (0, jsx_runtime_1.jsx)(material_1.Typography, Object.assign({ variant: "caption" }, { children: error === null || error === void 0 ? void 0 : error.message }))] })));
|
|
8
|
+
var { error, errorContext } = _a, props = tslib_1.__rest(_a, ["error", "errorContext"]);
|
|
9
|
+
return ((0, jsx_runtime_1.jsxs)(material_1.Alert, Object.assign({ severity: "error" }, props, { children: [(0, jsx_runtime_1.jsx)(material_1.AlertTitle, { children: "Whoops! Something went wrong" }), errorContext ? ((0, jsx_runtime_1.jsx)(material_1.Typography, Object.assign({ variant: "caption", my: 0.5, lineHeight: "1", display: "block" }, { children: errorContext }))) : null, (0, jsx_runtime_1.jsx)(material_1.Typography, Object.assign({ variant: "caption", mr: 0.5, fontWeight: "bold" }, { children: "Error:" })), (0, jsx_runtime_1.jsx)(material_1.Typography, Object.assign({ variant: "caption" }, { children: error === null || error === void 0 ? void 0 : error.message }))] })));
|
|
10
10
|
};
|
|
11
11
|
exports.XyoErrorAlert = XyoErrorAlert;
|
|
12
12
|
//# sourceMappingURL=ErrorAlert.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ErrorAlert.js","sourceRoot":"","sources":["../../../../src/components/XyoErrorRender/ErrorAlert.tsx"],"names":[],"mappings":";;;;;AAAA,4CAAyE;
|
|
1
|
+
{"version":3,"file":"ErrorAlert.js","sourceRoot":"","sources":["../../../../src/components/XyoErrorRender/ErrorAlert.tsx"],"names":[],"mappings":";;;;;AAAA,4CAAyE;AAQlE,MAAM,aAAa,GAAiC,CAAC,EAAiC,EAAE,EAAE;QAArC,EAAE,KAAK,EAAE,YAAY,OAAY,EAAP,KAAK,sBAA/B,yBAAiC,CAAF;IACzF,OAAO,CACL,wBAAC,gBAAK,kBAAC,QAAQ,EAAC,OAAO,IAAK,KAAK,eAC/B,uBAAC,qBAAU,+CAA0C,EACpD,YAAY,CAAC,CAAC,CAAC,CACd,uBAAC,qBAAU,kBAAC,OAAO,EAAC,SAAS,EAAC,EAAE,EAAE,GAAG,EAAE,UAAU,EAAC,GAAG,EAAC,OAAO,EAAC,OAAO,gBAClE,YAAY,IACF,CACd,CAAC,CAAC,CAAC,IAAI,EACR,uBAAC,qBAAU,kBAAC,OAAO,EAAC,SAAS,EAAC,EAAE,EAAE,GAAG,EAAE,UAAU,EAAC,MAAM,4BAE3C,EACb,uBAAC,qBAAU,kBAAC,OAAO,EAAC,SAAS,gBAAE,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,OAAO,IAAc,KACrD,CACT,CAAA;AACH,CAAC,CAAA;AAfY,QAAA,aAAa,iBAezB"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Props.d.ts","sourceRoot":"","sources":["../../../../src/components/XyoErrorRender/Props.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAA;AACpD,OAAO,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAA;AAC9C,OAAO,EAAE,SAAS,EAAE,MAAM,OAAO,CAAA;AAEjC,MAAM,WAAW,mBAAoB,SAAQ,YAAY;IACvD,QAAQ,CAAC,EAAE,QAAQ,CAAA;IACnB,WAAW,CAAC,EAAE,SAAS,CAAA;IACvB,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,cAAc,CAAC,EAAE,OAAO,CAAA;
|
|
1
|
+
{"version":3,"file":"Props.d.ts","sourceRoot":"","sources":["../../../../src/components/XyoErrorRender/Props.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAA;AACpD,OAAO,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAA;AAC9C,OAAO,EAAE,SAAS,EAAE,MAAM,OAAO,CAAA;AAEjC,MAAM,WAAW,mBAAoB,SAAQ,YAAY;IACvD,QAAQ,CAAC,EAAE,QAAQ,CAAA;IACnB,WAAW,CAAC,EAAE,SAAS,CAAA;IACvB,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,cAAc,CAAC,EAAE,OAAO,CAAA;IACxB,YAAY,CAAC,EAAE,MAAM,CAAA;CACtB"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Render.d.ts","sourceRoot":"","sources":["../../../../src/components/XyoErrorRender/Render.tsx"],"names":[],"mappings":";AAKA,OAAO,EAAE,mBAAmB,EAAE,MAAM,SAAS,CAAA;AAE7C,eAAO,MAAM,cAAc,EAAE,KAAK,CAAC,EAAE,CAAC,mBAAmB,
|
|
1
|
+
{"version":3,"file":"Render.d.ts","sourceRoot":"","sources":["../../../../src/components/XyoErrorRender/Render.tsx"],"names":[],"mappings":";AAKA,OAAO,EAAE,mBAAmB,EAAE,MAAM,SAAS,CAAA;AAE7C,eAAO,MAAM,cAAc,EAAE,KAAK,CAAC,EAAE,CAAC,mBAAmB,CAiCxD,CAAA"}
|
|
@@ -9,7 +9,7 @@ const react_router_dom_1 = require("react-router-dom");
|
|
|
9
9
|
const ErrorAlert_1 = require("./ErrorAlert");
|
|
10
10
|
const XyoErrorRender = (_a) => {
|
|
11
11
|
var _b;
|
|
12
|
-
var { xyoError, noErrorDisplay = false, customError = null, children } = _a, props = tslib_1.__rest(_a, ["xyoError", "noErrorDisplay", "customError", "children"]);
|
|
12
|
+
var { xyoError, noErrorDisplay = false, customError = null, children, errorContext } = _a, props = tslib_1.__rest(_a, ["xyoError", "noErrorDisplay", "customError", "children", "errorContext"]);
|
|
13
13
|
const location = (0, react_router_dom_1.useLocation)();
|
|
14
14
|
(0, react_1.useEffect)(() => {
|
|
15
15
|
// ensure we end up at the same place we are now after logging in
|
|
@@ -20,7 +20,7 @@ const XyoErrorRender = (_a) => {
|
|
|
20
20
|
};
|
|
21
21
|
}, [location]);
|
|
22
22
|
if (xyoError) {
|
|
23
|
-
return ((0, jsx_runtime_1.jsx)(react_flexbox_1.FlexCol, Object.assign({ alignItems: "stretch" }, props, { children: noErrorDisplay ? (customError) : ((0, jsx_runtime_1.jsx)(react_flexbox_1.FlexCol, Object.assign({ alignItems: "center" }, props, { children: (0, jsx_runtime_1.jsx)(ErrorAlert_1.XyoErrorAlert, { error: xyoError }) }))) })));
|
|
23
|
+
return ((0, jsx_runtime_1.jsx)(react_flexbox_1.FlexCol, Object.assign({ alignItems: "stretch" }, props, { children: noErrorDisplay ? (customError) : ((0, jsx_runtime_1.jsx)(react_flexbox_1.FlexCol, Object.assign({ alignItems: "center" }, props, { children: (0, jsx_runtime_1.jsx)(ErrorAlert_1.XyoErrorAlert, { error: xyoError, errorContext: errorContext }) }))) })));
|
|
24
24
|
}
|
|
25
25
|
else {
|
|
26
26
|
return (_b = (0, jsx_runtime_1.jsx)(jsx_runtime_1.Fragment, { children: children })) !== null && _b !== void 0 ? _b : null;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Render.js","sourceRoot":"","sources":["../../../../src/components/XyoErrorRender/Render.tsx"],"names":[],"mappings":";;;;;AAAA,yDAA+C;AAC/C,iCAAiC;AACjC,uDAA8C;AAE9C,6CAA4C;AAGrC,MAAM,cAAc,GAAkC,CAAC,
|
|
1
|
+
{"version":3,"file":"Render.js","sourceRoot":"","sources":["../../../../src/components/XyoErrorRender/Render.tsx"],"names":[],"mappings":";;;;;AAAA,yDAA+C;AAC/C,iCAAiC;AACjC,uDAA8C;AAE9C,6CAA4C;AAGrC,MAAM,cAAc,GAAkC,CAAC,EAO7D,EAAE,EAAE;;QAPyD,EAC5D,QAAQ,EACR,cAAc,GAAG,KAAK,EACtB,WAAW,GAAG,IAAI,EAClB,QAAQ,EACR,YAAY,OAEb,EADI,KAAK,sBANoD,yEAO7D,CADS;IAER,MAAM,QAAQ,GAAG,IAAA,8BAAW,GAAE,CAAA;IAC9B,IAAA,iBAAS,EAAC,GAAG,EAAE;QACb,iEAAiE;QACjE,QAAQ,CAAC,KAAK,GAAG;YACf,IAAI,EAAE;gBACJ,QAAQ,EAAE,MAAM,CAAC,QAAQ,CAAC,QAAQ;aACnC;SACF,CAAA;IACH,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAA;IAEd,IAAI,QAAQ,EAAE;QACZ,OAAO,CACL,uBAAC,uBAAO,kBAAC,UAAU,EAAC,SAAS,IAAK,KAAK,cACpC,cAAc,CAAC,CAAC,CAAC,CAChB,WAAW,CACZ,CAAC,CAAC,CAAC,CACF,uBAAC,uBAAO,kBAAC,UAAU,EAAC,QAAQ,IAAK,KAAK,cACpC,uBAAC,0BAAa,IAAC,KAAK,EAAE,QAAQ,EAAE,YAAY,EAAE,YAAY,GAAI,IACtD,CACX,IACO,CACX,CAAA;KACF;SAAM;QACL,OAAO,MAAA,2DAAG,QAAQ,GAAI,mCAAI,IAAI,CAAA;KAC/B;AACH,CAAC,CAAA;AAjCY,QAAA,cAAc,kBAiC1B"}
|