@pie-lib/charting 6.2.0-next.0 → 6.2.0-next.2
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/lib/__tests__/actions-button.test.js +332 -0
- package/lib/__tests__/axes.test.js +746 -0
- package/lib/__tests__/chart-setup.test.js +796 -0
- package/lib/__tests__/chart-type.test.js +25 -0
- package/lib/__tests__/chart.test.js +103 -0
- package/lib/__tests__/grid.test.js +39 -0
- package/lib/__tests__/key-legend.test.js +235 -0
- package/lib/__tests__/mark-label.test.js +46 -0
- package/lib/__tests__/tool-menu.test.js +627 -0
- package/lib/__tests__/utils.js +56 -0
- package/lib/__tests__/utils.test.js +186 -0
- package/lib/actions-button.js +1 -1
- package/lib/axes.js +1 -1
- package/lib/bars/__tests__/bar.test.js +53 -0
- package/lib/bars/__tests__/histogram.test.js +53 -0
- package/lib/bars/__tests__/utils.js +50 -0
- package/lib/bars/bar.js +1 -1
- package/lib/bars/common/__tests__/bars.test.js +76 -0
- package/lib/bars/common/__tests__/utils.js +50 -0
- package/lib/bars/common/bars.js +1 -1
- package/lib/bars/common/correct-check-icon.js +1 -1
- package/lib/bars/histogram.js +1 -1
- package/lib/chart-setup.js +1 -1
- package/lib/chart-type.js +1 -1
- package/lib/chart-types.js +1 -1
- package/lib/chart.js +1 -1
- package/lib/common/__tests__/correctness-indicators.test.js +887 -0
- package/lib/common/__tests__/drag-handle.test.js +73 -0
- package/lib/common/__tests__/utils.js +50 -0
- package/lib/common/correctness-indicators.js +1 -1
- package/lib/common/drag-handle.js +1 -1
- package/lib/common/drag-icon.js +1 -1
- package/lib/common/styles.js +1 -1
- package/lib/grid.js +1 -1
- package/lib/index.js +1 -1
- package/lib/key-legend.js +1 -1
- package/lib/line/__tests__/line-cross.test.js +617 -0
- package/lib/line/__tests__/line-dot.test.js +47 -0
- package/lib/line/__tests__/utils.js +56 -0
- package/lib/line/common/__tests__/drag-handle.test.js +73 -0
- package/lib/line/common/__tests__/line.test.js +92 -0
- package/lib/line/common/__tests__/utils.js +50 -0
- package/lib/line/common/drag-handle.js +1 -1
- package/lib/line/common/line.js +1 -1
- package/lib/line/line-cross.js +1 -1
- package/lib/line/line-dot.js +1 -1
- package/lib/mark-label.js +1 -1
- package/lib/plot/__tests__/dot.test.js +513 -0
- package/lib/plot/__tests__/line.test.js +566 -0
- package/lib/plot/__tests__/utils.js +50 -0
- package/lib/plot/common/__tests__/plot.test.js +79 -0
- package/lib/plot/common/__tests__/utils.js +50 -0
- package/lib/plot/common/plot.js +1 -1
- package/lib/plot/dot.js +1 -1
- package/lib/plot/line.js +1 -1
- package/lib/tool-menu.js +1 -1
- package/lib/utils.js +1 -1
- package/package.json +8 -11
- package/LICENSE.md +0 -5
|
@@ -0,0 +1,746 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
5
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
6
|
+
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
|
|
7
|
+
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
|
|
8
|
+
var _react = _interopRequireDefault(require("react"));
|
|
9
|
+
var _testUtils = require("@pie-lib/test-utils");
|
|
10
|
+
var _styles = require("@mui/material/styles");
|
|
11
|
+
var _axes = _interopRequireWildcard(require("../axes"));
|
|
12
|
+
var _utils = require("./utils");
|
|
13
|
+
var _excluded = ["children"],
|
|
14
|
+
_excluded2 = ["children", "tickValues"];
|
|
15
|
+
function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function _interopRequireWildcard(e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, "default": e }; if (null === e || "object" != _typeof(e) && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (var _t in e) "default" !== _t && {}.hasOwnProperty.call(e, _t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, _t)) && (i.get || i.set) ? o(f, _t, i) : f[_t] = e[_t]); return f; })(e, t); }
|
|
16
|
+
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
17
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
18
|
+
jest.mock('@visx/axis', function () {
|
|
19
|
+
return {
|
|
20
|
+
AxisLeft: function AxisLeft(_ref) {
|
|
21
|
+
var children = _ref.children,
|
|
22
|
+
props = (0, _objectWithoutProperties2["default"])(_ref, _excluded);
|
|
23
|
+
return /*#__PURE__*/_react["default"].createElement("g", (0, _extends2["default"])({
|
|
24
|
+
"data-testid": "axis-left"
|
|
25
|
+
}, props), typeof children === 'function' ? children({
|
|
26
|
+
formattedValue: '5'
|
|
27
|
+
}) : children);
|
|
28
|
+
},
|
|
29
|
+
AxisBottom: function AxisBottom(_ref2) {
|
|
30
|
+
var children = _ref2.children,
|
|
31
|
+
tickValues = _ref2.tickValues,
|
|
32
|
+
props = (0, _objectWithoutProperties2["default"])(_ref2, _excluded2);
|
|
33
|
+
return /*#__PURE__*/_react["default"].createElement("g", (0, _extends2["default"])({
|
|
34
|
+
"data-testid": "axis-bottom"
|
|
35
|
+
}, props), typeof children === 'function' ? (tickValues || ['0-A', '1-B', '2-C']).map(function (v, i) {
|
|
36
|
+
return children({
|
|
37
|
+
formattedValue: v,
|
|
38
|
+
index: i
|
|
39
|
+
});
|
|
40
|
+
}) : children);
|
|
41
|
+
}
|
|
42
|
+
};
|
|
43
|
+
});
|
|
44
|
+
jest.mock('../mark-label', function () {
|
|
45
|
+
return function MarkLabel(_ref3) {
|
|
46
|
+
var mark = _ref3.mark,
|
|
47
|
+
disabled = _ref3.disabled,
|
|
48
|
+
_onChange = _ref3.onChange,
|
|
49
|
+
error = _ref3.error,
|
|
50
|
+
autoFocus = _ref3.autoFocus,
|
|
51
|
+
inputRef = _ref3.inputRef,
|
|
52
|
+
correctnessIndicator = _ref3.correctnessIndicator;
|
|
53
|
+
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
54
|
+
"data-testid": "mark-label"
|
|
55
|
+
}, /*#__PURE__*/_react["default"].createElement("input", {
|
|
56
|
+
"data-testid": "mark-label-input",
|
|
57
|
+
ref: inputRef,
|
|
58
|
+
value: (mark === null || mark === void 0 ? void 0 : mark.label) || '',
|
|
59
|
+
disabled: disabled,
|
|
60
|
+
onChange: function onChange(e) {
|
|
61
|
+
return _onChange && _onChange(e.target.value);
|
|
62
|
+
},
|
|
63
|
+
autoFocus: autoFocus
|
|
64
|
+
}), error && /*#__PURE__*/_react["default"].createElement("span", {
|
|
65
|
+
"data-testid": "mark-label-error"
|
|
66
|
+
}, error), correctnessIndicator);
|
|
67
|
+
};
|
|
68
|
+
});
|
|
69
|
+
jest.mock('@pie-lib/config-ui', function () {
|
|
70
|
+
return {
|
|
71
|
+
AlertDialog: function AlertDialog(_ref4) {
|
|
72
|
+
var open = _ref4.open,
|
|
73
|
+
title = _ref4.title,
|
|
74
|
+
text = _ref4.text,
|
|
75
|
+
onClose = _ref4.onClose,
|
|
76
|
+
onConfirm = _ref4.onConfirm;
|
|
77
|
+
return open ? /*#__PURE__*/_react["default"].createElement("div", {
|
|
78
|
+
"data-testid": "alert-dialog"
|
|
79
|
+
}, /*#__PURE__*/_react["default"].createElement("h2", null, title), /*#__PURE__*/_react["default"].createElement("p", null, text), /*#__PURE__*/_react["default"].createElement("button", {
|
|
80
|
+
"data-testid": "alert-cancel",
|
|
81
|
+
onClick: onClose
|
|
82
|
+
}, "Cancel"), /*#__PURE__*/_react["default"].createElement("button", {
|
|
83
|
+
"data-testid": "alert-confirm",
|
|
84
|
+
onClick: onConfirm
|
|
85
|
+
}, "Confirm")) : null;
|
|
86
|
+
}
|
|
87
|
+
};
|
|
88
|
+
});
|
|
89
|
+
jest.mock('../common/correctness-indicators', function () {
|
|
90
|
+
return {
|
|
91
|
+
TickCorrectnessIndicator: function TickCorrectnessIndicator(_ref5) {
|
|
92
|
+
var correctness = _ref5.correctness,
|
|
93
|
+
interactive = _ref5.interactive;
|
|
94
|
+
return correctness && interactive ? /*#__PURE__*/_react["default"].createElement("div", {
|
|
95
|
+
"data-testid": "tick-correctness-indicator"
|
|
96
|
+
}, correctness.value === 'correct' ? '✓' : '✗') : null;
|
|
97
|
+
}
|
|
98
|
+
};
|
|
99
|
+
});
|
|
100
|
+
jest.mock('@pie-lib/math-rendering', function () {
|
|
101
|
+
return {
|
|
102
|
+
renderMath: jest.fn(function (text) {
|
|
103
|
+
return text;
|
|
104
|
+
})
|
|
105
|
+
};
|
|
106
|
+
});
|
|
107
|
+
var theme = (0, _styles.createTheme)();
|
|
108
|
+
describe('ChartAxes', function () {
|
|
109
|
+
var renderComponent = function renderComponent(extras) {
|
|
110
|
+
var defaults = {
|
|
111
|
+
classes: {},
|
|
112
|
+
className: 'className',
|
|
113
|
+
graphProps: (0, _utils.graphProps)(),
|
|
114
|
+
xBand: (0, _utils.createBandScale)(['a', 'b', 'c'], [0, 400]),
|
|
115
|
+
categories: []
|
|
116
|
+
};
|
|
117
|
+
var props = _objectSpread(_objectSpread({}, defaults), extras);
|
|
118
|
+
return (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_styles.ThemeProvider, {
|
|
119
|
+
theme: theme
|
|
120
|
+
}, /*#__PURE__*/_react["default"].createElement("svg", null, /*#__PURE__*/_react["default"].createElement(_axes["default"], props))));
|
|
121
|
+
};
|
|
122
|
+
describe('rendering', function () {
|
|
123
|
+
it('renders axes container', function () {
|
|
124
|
+
var _renderComponent = renderComponent(),
|
|
125
|
+
container = _renderComponent.container;
|
|
126
|
+
expect(container.firstChild).toBeInTheDocument();
|
|
127
|
+
});
|
|
128
|
+
it('renders SVG with axes group', function () {
|
|
129
|
+
var _renderComponent2 = renderComponent(),
|
|
130
|
+
container = _renderComponent2.container;
|
|
131
|
+
var svg = container.querySelector('svg');
|
|
132
|
+
expect(svg).toBeInTheDocument();
|
|
133
|
+
var axesGroup = container.querySelector('g');
|
|
134
|
+
expect(axesGroup).toBeInTheDocument();
|
|
135
|
+
});
|
|
136
|
+
it('renders axes elements', function () {
|
|
137
|
+
var _renderComponent3 = renderComponent(),
|
|
138
|
+
container = _renderComponent3.container;
|
|
139
|
+
var groups = container.querySelectorAll('g');
|
|
140
|
+
expect(groups.length).toBeGreaterThan(0);
|
|
141
|
+
});
|
|
142
|
+
});
|
|
143
|
+
describe('edge cases', function () {
|
|
144
|
+
it('handles missing xBand', function () {
|
|
145
|
+
var _renderComponent4 = renderComponent({
|
|
146
|
+
xBand: undefined
|
|
147
|
+
}),
|
|
148
|
+
container = _renderComponent4.container;
|
|
149
|
+
expect(container).toBeInTheDocument();
|
|
150
|
+
});
|
|
151
|
+
it('handles empty categories', function () {
|
|
152
|
+
var _renderComponent5 = renderComponent({
|
|
153
|
+
categories: []
|
|
154
|
+
}),
|
|
155
|
+
container = _renderComponent5.container;
|
|
156
|
+
expect(container).toBeInTheDocument();
|
|
157
|
+
});
|
|
158
|
+
it('handles null categories', function () {
|
|
159
|
+
var _renderComponent6 = renderComponent({
|
|
160
|
+
categories: null
|
|
161
|
+
}),
|
|
162
|
+
container = _renderComponent6.container;
|
|
163
|
+
expect(container).toBeInTheDocument();
|
|
164
|
+
});
|
|
165
|
+
});
|
|
166
|
+
});
|
|
167
|
+
describe('RawChartAxes', function () {
|
|
168
|
+
var renderComponent = function renderComponent(extras) {
|
|
169
|
+
var defaults = {
|
|
170
|
+
classes: {},
|
|
171
|
+
className: 'className',
|
|
172
|
+
graphProps: (0, _utils.graphProps)(),
|
|
173
|
+
xBand: (0, _utils.createBandScale)(['a', 'b', 'c'], [0, 400]),
|
|
174
|
+
categories: []
|
|
175
|
+
};
|
|
176
|
+
var props = _objectSpread(_objectSpread({}, defaults), extras);
|
|
177
|
+
return (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_styles.ThemeProvider, {
|
|
178
|
+
theme: theme
|
|
179
|
+
}, /*#__PURE__*/_react["default"].createElement("svg", null, /*#__PURE__*/_react["default"].createElement(_axes.RawChartAxes, props))));
|
|
180
|
+
};
|
|
181
|
+
describe('rendering', function () {
|
|
182
|
+
it('renders raw axes container', function () {
|
|
183
|
+
var _renderComponent7 = renderComponent(),
|
|
184
|
+
container = _renderComponent7.container;
|
|
185
|
+
expect(container.firstChild).toBeInTheDocument();
|
|
186
|
+
});
|
|
187
|
+
it('renders SVG with axes group', function () {
|
|
188
|
+
var _renderComponent8 = renderComponent(),
|
|
189
|
+
container = _renderComponent8.container;
|
|
190
|
+
var svg = container.querySelector('svg');
|
|
191
|
+
expect(svg).toBeInTheDocument();
|
|
192
|
+
var axesGroup = container.querySelector('g');
|
|
193
|
+
expect(axesGroup).toBeInTheDocument();
|
|
194
|
+
});
|
|
195
|
+
it('renders both axes when leftAxis is true', function () {
|
|
196
|
+
var _renderComponent9 = renderComponent({
|
|
197
|
+
leftAxis: true
|
|
198
|
+
}),
|
|
199
|
+
getByTestId = _renderComponent9.getByTestId;
|
|
200
|
+
expect(getByTestId('axis-left')).toBeInTheDocument();
|
|
201
|
+
expect(getByTestId('axis-bottom')).toBeInTheDocument();
|
|
202
|
+
});
|
|
203
|
+
it('renders only bottom axis when leftAxis is false', function () {
|
|
204
|
+
var _renderComponent0 = renderComponent({
|
|
205
|
+
leftAxis: false
|
|
206
|
+
}),
|
|
207
|
+
queryByTestId = _renderComponent0.queryByTestId,
|
|
208
|
+
getByTestId = _renderComponent0.getByTestId;
|
|
209
|
+
expect(queryByTestId('axis-left')).not.toBeInTheDocument();
|
|
210
|
+
expect(getByTestId('axis-bottom')).toBeInTheDocument();
|
|
211
|
+
});
|
|
212
|
+
});
|
|
213
|
+
});
|
|
214
|
+
describe('TickComponent', function () {
|
|
215
|
+
var defaultCategories = [{
|
|
216
|
+
value: 1,
|
|
217
|
+
label: 'Category A',
|
|
218
|
+
editable: true,
|
|
219
|
+
interactive: true
|
|
220
|
+
}, {
|
|
221
|
+
value: 2,
|
|
222
|
+
label: 'Category B',
|
|
223
|
+
editable: true,
|
|
224
|
+
interactive: true
|
|
225
|
+
}];
|
|
226
|
+
var renderComponent = function renderComponent(extras) {
|
|
227
|
+
var defaults = {
|
|
228
|
+
graphProps: (0, _utils.graphProps)(),
|
|
229
|
+
xBand: (0, _utils.createBandScale)(['a', 'b', 'c'], [0, 400]),
|
|
230
|
+
categories: defaultCategories,
|
|
231
|
+
formattedValue: '0-Category A',
|
|
232
|
+
bandWidth: 100,
|
|
233
|
+
barWidth: 100,
|
|
234
|
+
x: 50,
|
|
235
|
+
y: 50,
|
|
236
|
+
top: 0,
|
|
237
|
+
onChangeCategory: jest.fn()
|
|
238
|
+
};
|
|
239
|
+
var props = _objectSpread(_objectSpread({}, defaults), extras);
|
|
240
|
+
return (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_styles.ThemeProvider, {
|
|
241
|
+
theme: theme
|
|
242
|
+
}, /*#__PURE__*/_react["default"].createElement("svg", null, /*#__PURE__*/_react["default"].createElement(_axes.TickComponent, props))));
|
|
243
|
+
};
|
|
244
|
+
describe('rendering', function () {
|
|
245
|
+
it('renders tick component', function () {
|
|
246
|
+
var _renderComponent1 = renderComponent(),
|
|
247
|
+
container = _renderComponent1.container;
|
|
248
|
+
var svg = container.querySelector('svg');
|
|
249
|
+
expect(svg).toBeInTheDocument();
|
|
250
|
+
expect(container.querySelector('g')).toBeInTheDocument();
|
|
251
|
+
});
|
|
252
|
+
it('renders with categories', function () {
|
|
253
|
+
var _renderComponent10 = renderComponent({
|
|
254
|
+
formattedValue: '0-test',
|
|
255
|
+
categories: [{
|
|
256
|
+
value: 1,
|
|
257
|
+
label: 'test',
|
|
258
|
+
editable: false,
|
|
259
|
+
interactive: false
|
|
260
|
+
}]
|
|
261
|
+
}),
|
|
262
|
+
container = _renderComponent10.container;
|
|
263
|
+
var svg = container.querySelector('svg');
|
|
264
|
+
expect(svg).toBeInTheDocument();
|
|
265
|
+
expect(container.querySelector('g')).toBeInTheDocument();
|
|
266
|
+
});
|
|
267
|
+
it('renders MarkLabel component', function () {
|
|
268
|
+
var _renderComponent11 = renderComponent(),
|
|
269
|
+
getAllByTestId = _renderComponent11.getAllByTestId;
|
|
270
|
+
var markLabels = getAllByTestId('mark-label');
|
|
271
|
+
expect(markLabels.length).toBeGreaterThan(0);
|
|
272
|
+
});
|
|
273
|
+
it('renders foreignObject for labels', function () {
|
|
274
|
+
var _renderComponent12 = renderComponent(),
|
|
275
|
+
container = _renderComponent12.container;
|
|
276
|
+
var foreignObject = container.querySelector('foreignObject');
|
|
277
|
+
expect(foreignObject).toBeInTheDocument();
|
|
278
|
+
});
|
|
279
|
+
it('does not render when formattedValue is null', function () {
|
|
280
|
+
var _renderComponent13 = renderComponent({
|
|
281
|
+
formattedValue: null
|
|
282
|
+
}),
|
|
283
|
+
container = _renderComponent13.container;
|
|
284
|
+
var foreignObject = container.querySelector('foreignObject');
|
|
285
|
+
expect(foreignObject).not.toBeInTheDocument();
|
|
286
|
+
});
|
|
287
|
+
it('does not render when formattedValue is undefined', function () {
|
|
288
|
+
var _renderComponent14 = renderComponent({
|
|
289
|
+
formattedValue: undefined
|
|
290
|
+
}),
|
|
291
|
+
container = _renderComponent14.container;
|
|
292
|
+
var foreignObject = container.querySelector('foreignObject');
|
|
293
|
+
expect(foreignObject).not.toBeInTheDocument();
|
|
294
|
+
});
|
|
295
|
+
it('renders hidden label for longest category', function () {
|
|
296
|
+
var _renderComponent15 = renderComponent(),
|
|
297
|
+
getAllByTestId = _renderComponent15.getAllByTestId;
|
|
298
|
+
var markLabels = getAllByTestId('mark-label');
|
|
299
|
+
expect(markLabels.length).toBeGreaterThan(0);
|
|
300
|
+
});
|
|
301
|
+
});
|
|
302
|
+
describe('category label editing', function () {
|
|
303
|
+
it('allows editing category label', function () {
|
|
304
|
+
var onChangeCategory = jest.fn();
|
|
305
|
+
var _renderComponent16 = renderComponent({
|
|
306
|
+
onChangeCategory: onChangeCategory
|
|
307
|
+
}),
|
|
308
|
+
getAllByTestId = _renderComponent16.getAllByTestId;
|
|
309
|
+
var inputs = getAllByTestId('mark-label-input');
|
|
310
|
+
var input = inputs[inputs.length - 1];
|
|
311
|
+
_testUtils.fireEvent.change(input, {
|
|
312
|
+
target: {
|
|
313
|
+
value: 'New Label'
|
|
314
|
+
}
|
|
315
|
+
});
|
|
316
|
+
expect(onChangeCategory).toHaveBeenCalled();
|
|
317
|
+
});
|
|
318
|
+
it('calls changeCategory with correct parameters', function () {
|
|
319
|
+
var onChangeCategory = jest.fn();
|
|
320
|
+
var _renderComponent17 = renderComponent({
|
|
321
|
+
onChangeCategory: onChangeCategory
|
|
322
|
+
}),
|
|
323
|
+
getAllByTestId = _renderComponent17.getAllByTestId;
|
|
324
|
+
var inputs = getAllByTestId('mark-label-input');
|
|
325
|
+
var input = inputs[inputs.length - 1];
|
|
326
|
+
_testUtils.fireEvent.change(input, {
|
|
327
|
+
target: {
|
|
328
|
+
value: 'Updated'
|
|
329
|
+
}
|
|
330
|
+
});
|
|
331
|
+
expect(onChangeCategory).toHaveBeenCalledWith(0, expect.objectContaining({
|
|
332
|
+
label: 'Updated'
|
|
333
|
+
}));
|
|
334
|
+
});
|
|
335
|
+
it('disables editing when editable is false', function () {
|
|
336
|
+
var categories = [{
|
|
337
|
+
value: 1,
|
|
338
|
+
label: 'test',
|
|
339
|
+
editable: false,
|
|
340
|
+
interactive: true
|
|
341
|
+
}];
|
|
342
|
+
var _renderComponent18 = renderComponent({
|
|
343
|
+
categories: categories,
|
|
344
|
+
formattedValue: '0-test'
|
|
345
|
+
}),
|
|
346
|
+
getAllByTestId = _renderComponent18.getAllByTestId;
|
|
347
|
+
var inputs = getAllByTestId('mark-label-input');
|
|
348
|
+
var input = inputs[inputs.length - 1];
|
|
349
|
+
expect(input).toBeDisabled();
|
|
350
|
+
});
|
|
351
|
+
it('enables editing in define chart mode', function () {
|
|
352
|
+
var categories = [{
|
|
353
|
+
value: 1,
|
|
354
|
+
label: 'test',
|
|
355
|
+
editable: true,
|
|
356
|
+
interactive: true
|
|
357
|
+
}];
|
|
358
|
+
var _renderComponent19 = renderComponent({
|
|
359
|
+
categories: categories,
|
|
360
|
+
formattedValue: '0-test',
|
|
361
|
+
defineChart: true
|
|
362
|
+
}),
|
|
363
|
+
getAllByTestId = _renderComponent19.getAllByTestId;
|
|
364
|
+
var inputs = getAllByTestId('mark-label-input');
|
|
365
|
+
var input = inputs[inputs.length - 1];
|
|
366
|
+
expect(input).not.toBeDisabled();
|
|
367
|
+
});
|
|
368
|
+
it('respects editable property when not in define chart mode', function () {
|
|
369
|
+
var categories = [{
|
|
370
|
+
value: 1,
|
|
371
|
+
label: 'test',
|
|
372
|
+
editable: true,
|
|
373
|
+
interactive: true
|
|
374
|
+
}];
|
|
375
|
+
var _renderComponent20 = renderComponent({
|
|
376
|
+
categories: categories,
|
|
377
|
+
formattedValue: '0-test',
|
|
378
|
+
defineChart: false
|
|
379
|
+
}),
|
|
380
|
+
getAllByTestId = _renderComponent20.getAllByTestId;
|
|
381
|
+
var inputs = getAllByTestId('mark-label-input');
|
|
382
|
+
var input = inputs[inputs.length - 1];
|
|
383
|
+
expect(input).not.toBeDisabled();
|
|
384
|
+
});
|
|
385
|
+
});
|
|
386
|
+
describe('interactive checkbox', function () {
|
|
387
|
+
it('shows warning when disabling interactive with correct answer', function () {
|
|
388
|
+
var categories = [{
|
|
389
|
+
value: 1,
|
|
390
|
+
label: 'test',
|
|
391
|
+
editable: true,
|
|
392
|
+
interactive: true,
|
|
393
|
+
correctness: {
|
|
394
|
+
value: 'correct'
|
|
395
|
+
}
|
|
396
|
+
}];
|
|
397
|
+
var component = new _axes.TickComponent({
|
|
398
|
+
categories: categories,
|
|
399
|
+
onChangeCategory: jest.fn()
|
|
400
|
+
});
|
|
401
|
+
component.setState = jest.fn();
|
|
402
|
+
component.changeInteractive(0, false);
|
|
403
|
+
expect(component.setState).toHaveBeenCalledWith(expect.objectContaining({
|
|
404
|
+
dialog: expect.objectContaining({
|
|
405
|
+
open: true,
|
|
406
|
+
title: 'Warning'
|
|
407
|
+
})
|
|
408
|
+
}));
|
|
409
|
+
});
|
|
410
|
+
it('changes interactive without warning when enabling', function () {
|
|
411
|
+
var onChangeCategory = jest.fn();
|
|
412
|
+
var categories = [{
|
|
413
|
+
value: 1,
|
|
414
|
+
label: 'test',
|
|
415
|
+
editable: true,
|
|
416
|
+
interactive: false
|
|
417
|
+
}];
|
|
418
|
+
var component = new _axes.TickComponent({
|
|
419
|
+
categories: categories,
|
|
420
|
+
onChangeCategory: onChangeCategory
|
|
421
|
+
});
|
|
422
|
+
component.changeInteractive(0, true);
|
|
423
|
+
expect(onChangeCategory).toHaveBeenCalledWith(0, expect.objectContaining({
|
|
424
|
+
interactive: true
|
|
425
|
+
}));
|
|
426
|
+
});
|
|
427
|
+
});
|
|
428
|
+
describe('editable checkbox', function () {
|
|
429
|
+
it('shows warning when disabling editable with correct answer name', function () {
|
|
430
|
+
var categories = [{
|
|
431
|
+
value: 1,
|
|
432
|
+
label: 'test',
|
|
433
|
+
editable: true,
|
|
434
|
+
interactive: true,
|
|
435
|
+
correctness: {
|
|
436
|
+
value: 'correct'
|
|
437
|
+
}
|
|
438
|
+
}];
|
|
439
|
+
var component = new _axes.TickComponent({
|
|
440
|
+
categories: categories,
|
|
441
|
+
onChangeCategory: jest.fn()
|
|
442
|
+
});
|
|
443
|
+
component.setState = jest.fn();
|
|
444
|
+
component.changeEditable(0, false);
|
|
445
|
+
expect(component.setState).toHaveBeenCalledWith(expect.objectContaining({
|
|
446
|
+
dialog: expect.objectContaining({
|
|
447
|
+
open: true,
|
|
448
|
+
title: 'Warning'
|
|
449
|
+
})
|
|
450
|
+
}));
|
|
451
|
+
});
|
|
452
|
+
it('changes editable without warning when enabling', function () {
|
|
453
|
+
var onChangeCategory = jest.fn();
|
|
454
|
+
var categories = [{
|
|
455
|
+
value: 1,
|
|
456
|
+
label: 'test',
|
|
457
|
+
editable: false,
|
|
458
|
+
interactive: true
|
|
459
|
+
}];
|
|
460
|
+
var component = new _axes.TickComponent({
|
|
461
|
+
categories: categories,
|
|
462
|
+
onChangeCategory: onChangeCategory
|
|
463
|
+
});
|
|
464
|
+
component.changeEditable(0, true);
|
|
465
|
+
expect(onChangeCategory).toHaveBeenCalledWith(0, expect.objectContaining({
|
|
466
|
+
editable: true
|
|
467
|
+
}));
|
|
468
|
+
});
|
|
469
|
+
});
|
|
470
|
+
describe('splitText method', function () {
|
|
471
|
+
it('splits text into chunks', function () {
|
|
472
|
+
var component = new _axes.TickComponent({
|
|
473
|
+
categories: []
|
|
474
|
+
});
|
|
475
|
+
var result = component.splitText('This is a long text', 10);
|
|
476
|
+
expect(result.length).toBeGreaterThan(1);
|
|
477
|
+
});
|
|
478
|
+
it('splits at word boundaries', function () {
|
|
479
|
+
var component = new _axes.TickComponent({
|
|
480
|
+
categories: []
|
|
481
|
+
});
|
|
482
|
+
var result = component.splitText('Hello world test', 11);
|
|
483
|
+
expect(result[0]).toBe('Hello world');
|
|
484
|
+
});
|
|
485
|
+
it('handles text shorter than max', function () {
|
|
486
|
+
var component = new _axes.TickComponent({
|
|
487
|
+
categories: []
|
|
488
|
+
});
|
|
489
|
+
var result = component.splitText('Short', 20);
|
|
490
|
+
expect(result).toEqual(['Short']);
|
|
491
|
+
});
|
|
492
|
+
it('handles empty text', function () {
|
|
493
|
+
var component = new _axes.TickComponent({
|
|
494
|
+
categories: []
|
|
495
|
+
});
|
|
496
|
+
var result = component.splitText('', 10);
|
|
497
|
+
expect(result).toEqual([]);
|
|
498
|
+
});
|
|
499
|
+
it('handles null text', function () {
|
|
500
|
+
var component = new _axes.TickComponent({
|
|
501
|
+
categories: []
|
|
502
|
+
});
|
|
503
|
+
var result = component.splitText(null, 10);
|
|
504
|
+
expect(result).toEqual([]);
|
|
505
|
+
});
|
|
506
|
+
it('forces split when no spaces', function () {
|
|
507
|
+
var component = new _axes.TickComponent({
|
|
508
|
+
categories: []
|
|
509
|
+
});
|
|
510
|
+
var result = component.splitText('verylongwordwithoutspaces', 10);
|
|
511
|
+
expect(result.length).toBeGreaterThan(1);
|
|
512
|
+
expect(result[0].length).toBeLessThanOrEqual(10);
|
|
513
|
+
});
|
|
514
|
+
});
|
|
515
|
+
describe('correctness display', function () {
|
|
516
|
+
it('renders correctness indicator when showCorrectness is true', function () {
|
|
517
|
+
var categories = [{
|
|
518
|
+
value: 1,
|
|
519
|
+
label: 'test',
|
|
520
|
+
editable: true,
|
|
521
|
+
interactive: true,
|
|
522
|
+
correctness: {
|
|
523
|
+
value: 'correct',
|
|
524
|
+
label: 'Correct!'
|
|
525
|
+
}
|
|
526
|
+
}];
|
|
527
|
+
var _renderComponent21 = renderComponent({
|
|
528
|
+
categories: categories,
|
|
529
|
+
formattedValue: '0-test',
|
|
530
|
+
showCorrectness: true
|
|
531
|
+
}),
|
|
532
|
+
getByTestId = _renderComponent21.getByTestId;
|
|
533
|
+
expect(getByTestId('tick-correctness-indicator')).toBeInTheDocument();
|
|
534
|
+
});
|
|
535
|
+
it('does not render correctness indicator when showCorrectness is false', function () {
|
|
536
|
+
var categories = [{
|
|
537
|
+
value: 1,
|
|
538
|
+
label: 'test',
|
|
539
|
+
editable: true,
|
|
540
|
+
interactive: true,
|
|
541
|
+
correctness: {
|
|
542
|
+
value: 'correct',
|
|
543
|
+
label: 'Correct!'
|
|
544
|
+
}
|
|
545
|
+
}];
|
|
546
|
+
var _renderComponent22 = renderComponent({
|
|
547
|
+
categories: categories,
|
|
548
|
+
formattedValue: '0-test',
|
|
549
|
+
showCorrectness: false
|
|
550
|
+
}),
|
|
551
|
+
queryByTestId = _renderComponent22.queryByTestId;
|
|
552
|
+
expect(queryByTestId('tick-correctness-indicator')).not.toBeInTheDocument();
|
|
553
|
+
});
|
|
554
|
+
it('does not render correctness indicator when not interactive', function () {
|
|
555
|
+
var categories = [{
|
|
556
|
+
value: 1,
|
|
557
|
+
label: 'test',
|
|
558
|
+
editable: true,
|
|
559
|
+
interactive: false,
|
|
560
|
+
correctness: {
|
|
561
|
+
value: 'correct',
|
|
562
|
+
label: 'Correct!'
|
|
563
|
+
}
|
|
564
|
+
}];
|
|
565
|
+
var _renderComponent23 = renderComponent({
|
|
566
|
+
categories: categories,
|
|
567
|
+
formattedValue: '0-test',
|
|
568
|
+
showCorrectness: true
|
|
569
|
+
}),
|
|
570
|
+
queryByTestId = _renderComponent23.queryByTestId;
|
|
571
|
+
expect(queryByTestId('tick-correctness-indicator')).not.toBeInTheDocument();
|
|
572
|
+
});
|
|
573
|
+
});
|
|
574
|
+
describe('error display', function () {
|
|
575
|
+
it('renders error message for first category', function () {
|
|
576
|
+
var error = {
|
|
577
|
+
0: 'Error message'
|
|
578
|
+
};
|
|
579
|
+
var _renderComponent24 = renderComponent({
|
|
580
|
+
error: error,
|
|
581
|
+
formattedValue: '0-test'
|
|
582
|
+
}),
|
|
583
|
+
getByTestId = _renderComponent24.getByTestId;
|
|
584
|
+
expect(getByTestId('mark-label-error')).toBeInTheDocument();
|
|
585
|
+
});
|
|
586
|
+
it('renders distinct error messages', function () {
|
|
587
|
+
var error = {
|
|
588
|
+
0: 'Error 1',
|
|
589
|
+
1: 'Error 1',
|
|
590
|
+
2: 'Error 2'
|
|
591
|
+
};
|
|
592
|
+
var _renderComponent25 = renderComponent({
|
|
593
|
+
error: error,
|
|
594
|
+
formattedValue: '0-test'
|
|
595
|
+
}),
|
|
596
|
+
container = _renderComponent25.container;
|
|
597
|
+
var errorText = container.querySelector('text');
|
|
598
|
+
expect(errorText).toBeInTheDocument();
|
|
599
|
+
});
|
|
600
|
+
it('does not render error when no error prop', function () {
|
|
601
|
+
var _renderComponent26 = renderComponent({
|
|
602
|
+
error: null
|
|
603
|
+
}),
|
|
604
|
+
queryByTestId = _renderComponent26.queryByTestId;
|
|
605
|
+
expect(queryByTestId('mark-label-error')).not.toBeInTheDocument();
|
|
606
|
+
});
|
|
607
|
+
});
|
|
608
|
+
describe('autoFocus handling', function () {
|
|
609
|
+
it('handles autoFocus prop', function () {
|
|
610
|
+
var onAutoFocusUsed = jest.fn();
|
|
611
|
+
var _renderComponent27 = renderComponent({
|
|
612
|
+
autoFocus: false,
|
|
613
|
+
onAutoFocusUsed: onAutoFocusUsed
|
|
614
|
+
}),
|
|
615
|
+
rerender = _renderComponent27.rerender;
|
|
616
|
+
rerender(/*#__PURE__*/_react["default"].createElement(_styles.ThemeProvider, {
|
|
617
|
+
theme: theme
|
|
618
|
+
}, /*#__PURE__*/_react["default"].createElement("svg", null, /*#__PURE__*/_react["default"].createElement(_axes.TickComponent, {
|
|
619
|
+
graphProps: (0, _utils.graphProps)(),
|
|
620
|
+
xBand: (0, _utils.createBandScale)(['a', 'b', 'c'], [0, 400]),
|
|
621
|
+
categories: defaultCategories,
|
|
622
|
+
formattedValue: '0-Category A',
|
|
623
|
+
bandWidth: 100,
|
|
624
|
+
barWidth: 100,
|
|
625
|
+
x: 50,
|
|
626
|
+
y: 50,
|
|
627
|
+
top: 0,
|
|
628
|
+
onChangeCategory: jest.fn(),
|
|
629
|
+
autoFocus: true,
|
|
630
|
+
onAutoFocusUsed: onAutoFocusUsed
|
|
631
|
+
}))));
|
|
632
|
+
expect(onAutoFocusUsed).toHaveBeenCalled();
|
|
633
|
+
});
|
|
634
|
+
});
|
|
635
|
+
describe('define chart mode', function () {
|
|
636
|
+
it('renders interactive checkboxes when changeInteractiveEnabled', function () {
|
|
637
|
+
var chartingOptions = {
|
|
638
|
+
changeInteractive: {
|
|
639
|
+
authoringLabel: 'Allow students to change'
|
|
640
|
+
}
|
|
641
|
+
};
|
|
642
|
+
var _renderComponent28 = renderComponent({
|
|
643
|
+
defineChart: true,
|
|
644
|
+
chartingOptions: chartingOptions,
|
|
645
|
+
changeInteractiveEnabled: true,
|
|
646
|
+
formattedValue: '0-test'
|
|
647
|
+
}),
|
|
648
|
+
container = _renderComponent28.container;
|
|
649
|
+
var text = container.querySelector('text');
|
|
650
|
+
expect(text).toBeInTheDocument();
|
|
651
|
+
});
|
|
652
|
+
it('renders editable checkboxes when changeEditableEnabled', function () {
|
|
653
|
+
var chartingOptions = {
|
|
654
|
+
changeEditable: {
|
|
655
|
+
authoringLabel: 'Allow label editing'
|
|
656
|
+
}
|
|
657
|
+
};
|
|
658
|
+
var _renderComponent29 = renderComponent({
|
|
659
|
+
defineChart: true,
|
|
660
|
+
chartingOptions: chartingOptions,
|
|
661
|
+
changeEditableEnabled: true,
|
|
662
|
+
formattedValue: '0-test'
|
|
663
|
+
}),
|
|
664
|
+
container = _renderComponent29.container;
|
|
665
|
+
var text = container.querySelector('text');
|
|
666
|
+
expect(text).toBeInTheDocument();
|
|
667
|
+
});
|
|
668
|
+
it('splits long authoring labels', function () {
|
|
669
|
+
var chartingOptions = {
|
|
670
|
+
changeInteractive: {
|
|
671
|
+
authoringLabel: 'This is a very long label that needs to be split'
|
|
672
|
+
}
|
|
673
|
+
};
|
|
674
|
+
var _renderComponent30 = renderComponent({
|
|
675
|
+
defineChart: true,
|
|
676
|
+
chartingOptions: chartingOptions,
|
|
677
|
+
changeInteractiveEnabled: true,
|
|
678
|
+
formattedValue: '0-test'
|
|
679
|
+
}),
|
|
680
|
+
container = _renderComponent30.container;
|
|
681
|
+
var tspans = container.querySelectorAll('tspan');
|
|
682
|
+
expect(tspans.length).toBeGreaterThan(1);
|
|
683
|
+
});
|
|
684
|
+
});
|
|
685
|
+
describe('edge cases', function () {
|
|
686
|
+
it('handles missing category', function () {
|
|
687
|
+
var _renderComponent31 = renderComponent({
|
|
688
|
+
categories: [],
|
|
689
|
+
formattedValue: '0-missing'
|
|
690
|
+
}),
|
|
691
|
+
container = _renderComponent31.container;
|
|
692
|
+
expect(container).toBeInTheDocument();
|
|
693
|
+
});
|
|
694
|
+
it('handles invalid formattedValue format', function () {
|
|
695
|
+
var _renderComponent32 = renderComponent({
|
|
696
|
+
formattedValue: 'invalid'
|
|
697
|
+
}),
|
|
698
|
+
container = _renderComponent32.container;
|
|
699
|
+
expect(container).toBeInTheDocument();
|
|
700
|
+
});
|
|
701
|
+
it('handles missing graphProps', function () {
|
|
702
|
+
var _renderComponent33 = renderComponent({
|
|
703
|
+
graphProps: null
|
|
704
|
+
}),
|
|
705
|
+
container = _renderComponent33.container;
|
|
706
|
+
expect(container).toBeInTheDocument();
|
|
707
|
+
});
|
|
708
|
+
it('handles zero barWidth', function () {
|
|
709
|
+
var _renderComponent34 = renderComponent({
|
|
710
|
+
barWidth: 0
|
|
711
|
+
}),
|
|
712
|
+
container = _renderComponent34.container;
|
|
713
|
+
expect(container).toBeInTheDocument();
|
|
714
|
+
});
|
|
715
|
+
it('handles negative coordinates', function () {
|
|
716
|
+
var _renderComponent35 = renderComponent({
|
|
717
|
+
x: -10,
|
|
718
|
+
y: -20
|
|
719
|
+
}),
|
|
720
|
+
container = _renderComponent35.container;
|
|
721
|
+
expect(container).toBeInTheDocument();
|
|
722
|
+
});
|
|
723
|
+
});
|
|
724
|
+
describe('componentDidUpdate', function () {
|
|
725
|
+
it('calls onAutoFocusUsed when autoFocus changes to true', function () {
|
|
726
|
+
var onAutoFocusUsed = jest.fn();
|
|
727
|
+
var component = new _axes.TickComponent({
|
|
728
|
+
autoFocus: false,
|
|
729
|
+
onAutoFocusUsed: onAutoFocusUsed
|
|
730
|
+
});
|
|
731
|
+
component.componentDidUpdate({
|
|
732
|
+
autoFocus: false
|
|
733
|
+
});
|
|
734
|
+
expect(onAutoFocusUsed).not.toHaveBeenCalled();
|
|
735
|
+
component.props = {
|
|
736
|
+
autoFocus: true,
|
|
737
|
+
onAutoFocusUsed: onAutoFocusUsed
|
|
738
|
+
};
|
|
739
|
+
component.componentDidUpdate({
|
|
740
|
+
autoFocus: false
|
|
741
|
+
});
|
|
742
|
+
expect(onAutoFocusUsed).toHaveBeenCalled();
|
|
743
|
+
});
|
|
744
|
+
});
|
|
745
|
+
});
|
|
746
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_testUtils","_styles","_axes","_interopRequireWildcard","_utils","_excluded","_excluded2","e","t","WeakMap","r","n","__esModule","o","i","f","__proto__","_typeof","has","get","set","_t","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","ownKeys","keys","getOwnPropertySymbols","filter","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","jest","mock","AxisLeft","_ref","children","props","_objectWithoutProperties2","createElement","_extends2","formattedValue","AxisBottom","_ref2","tickValues","map","v","index","MarkLabel","_ref3","mark","disabled","onChange","error","autoFocus","inputRef","correctnessIndicator","ref","value","label","target","AlertDialog","_ref4","open","title","text","onClose","onConfirm","onClick","TickCorrectnessIndicator","_ref5","correctness","interactive","renderMath","fn","theme","createTheme","describe","renderComponent","extras","defaults","classes","className","graphProps","xBand","createBandScale","categories","render","ThemeProvider","it","_renderComponent","container","expect","firstChild","toBeInTheDocument","_renderComponent2","svg","querySelector","axesGroup","_renderComponent3","groups","querySelectorAll","toBeGreaterThan","_renderComponent4","undefined","_renderComponent5","_renderComponent6","RawChartAxes","_renderComponent7","_renderComponent8","_renderComponent9","leftAxis","getByTestId","_renderComponent0","queryByTestId","not","defaultCategories","editable","bandWidth","barWidth","x","y","top","onChangeCategory","TickComponent","_renderComponent1","_renderComponent10","_renderComponent11","getAllByTestId","markLabels","_renderComponent12","foreignObject","_renderComponent13","_renderComponent14","_renderComponent15","_renderComponent16","inputs","input","fireEvent","change","toHaveBeenCalled","_renderComponent17","toHaveBeenCalledWith","objectContaining","_renderComponent18","toBeDisabled","_renderComponent19","defineChart","_renderComponent20","component","setState","changeInteractive","dialog","changeEditable","result","splitText","toBe","toEqual","toBeLessThanOrEqual","_renderComponent21","showCorrectness","_renderComponent22","_renderComponent23","_renderComponent24","_renderComponent25","errorText","_renderComponent26","onAutoFocusUsed","_renderComponent27","rerender","chartingOptions","authoringLabel","_renderComponent28","changeInteractiveEnabled","_renderComponent29","changeEditableEnabled","_renderComponent30","tspans","_renderComponent31","_renderComponent32","_renderComponent33","_renderComponent34","_renderComponent35","componentDidUpdate"],"sources":["../../src/__tests__/axes.test.jsx"],"sourcesContent":["import React from 'react';\nimport { fireEvent, render } from '@pie-lib/test-utils';\nimport { createTheme, ThemeProvider } from '@mui/material/styles';\nimport ChartAxes, { RawChartAxes, TickComponent } from '../axes';\nimport { createBandScale, graphProps } from './utils';\n\njest.mock('@visx/axis', () => ({\n  AxisLeft: ({ children, ...props }) => (\n    <g data-testid=\"axis-left\" {...props}>\n      {typeof children === 'function' ? children({ formattedValue: '5' }) : children}\n    </g>\n  ),\n  AxisBottom: ({ children, tickValues, ...props }) => (\n    <g data-testid=\"axis-bottom\" {...props}>\n      {typeof children === 'function'\n        ? (tickValues || ['0-A', '1-B', '2-C']).map((v, i) => children({ formattedValue: v, index: i }))\n        : children}\n    </g>\n  ),\n}));\n\njest.mock('../mark-label', () => {\n  return function MarkLabel({ mark, disabled, onChange, error, autoFocus, inputRef, correctnessIndicator }) {\n    return (\n      <div data-testid=\"mark-label\">\n        <input\n          data-testid=\"mark-label-input\"\n          ref={inputRef}\n          value={mark?.label || ''}\n          disabled={disabled}\n          onChange={(e) => onChange && onChange(e.target.value)}\n          autoFocus={autoFocus}\n        />\n        {error && <span data-testid=\"mark-label-error\">{error}</span>}\n        {correctnessIndicator}\n      </div>\n    );\n  };\n});\n\njest.mock('@pie-lib/config-ui', () => ({\n  AlertDialog: ({ open, title, text, onClose, onConfirm }) =>\n    open ? (\n      <div data-testid=\"alert-dialog\">\n        <h2>{title}</h2>\n        <p>{text}</p>\n        <button data-testid=\"alert-cancel\" onClick={onClose}>\n          Cancel\n        </button>\n        <button data-testid=\"alert-confirm\" onClick={onConfirm}>\n          Confirm\n        </button>\n      </div>\n    ) : null,\n}));\n\njest.mock('../common/correctness-indicators', () => ({\n  TickCorrectnessIndicator: ({ correctness, interactive }) =>\n    correctness && interactive ? (\n      <div data-testid=\"tick-correctness-indicator\">{correctness.value === 'correct' ? '✓' : '✗'}</div>\n    ) : null,\n}));\n\njest.mock('@pie-lib/math-rendering', () => ({\n  renderMath: jest.fn((text) => text),\n}));\n\nconst theme = createTheme();\n\ndescribe('ChartAxes', () => {\n  const renderComponent = (extras) => {\n    const defaults = {\n      classes: {},\n      className: 'className',\n      graphProps: graphProps(),\n      xBand: createBandScale(['a', 'b', 'c'], [0, 400]),\n      categories: [],\n    };\n    const props = { ...defaults, ...extras };\n    return render(\n      <ThemeProvider theme={theme}>\n        <svg>\n          <ChartAxes {...props} />\n        </svg>\n      </ThemeProvider>,\n    );\n  };\n\n  describe('rendering', () => {\n    it('renders axes container', () => {\n      const { container } = renderComponent();\n      expect(container.firstChild).toBeInTheDocument();\n    });\n\n    it('renders SVG with axes group', () => {\n      const { container } = renderComponent();\n      const svg = container.querySelector('svg');\n      expect(svg).toBeInTheDocument();\n      const axesGroup = container.querySelector('g');\n      expect(axesGroup).toBeInTheDocument();\n    });\n\n    it('renders axes elements', () => {\n      const { container } = renderComponent();\n      const groups = container.querySelectorAll('g');\n      expect(groups.length).toBeGreaterThan(0);\n    });\n  });\n\n  describe('edge cases', () => {\n    it('handles missing xBand', () => {\n      const { container } = renderComponent({ xBand: undefined });\n      expect(container).toBeInTheDocument();\n    });\n\n    it('handles empty categories', () => {\n      const { container } = renderComponent({ categories: [] });\n      expect(container).toBeInTheDocument();\n    });\n\n    it('handles null categories', () => {\n      const { container } = renderComponent({ categories: null });\n      expect(container).toBeInTheDocument();\n    });\n  });\n});\n\ndescribe('RawChartAxes', () => {\n  const renderComponent = (extras) => {\n    const defaults = {\n      classes: {},\n      className: 'className',\n      graphProps: graphProps(),\n      xBand: createBandScale(['a', 'b', 'c'], [0, 400]),\n      categories: [],\n    };\n    const props = { ...defaults, ...extras };\n    return render(\n      <ThemeProvider theme={theme}>\n        <svg>\n          <RawChartAxes {...props} />\n        </svg>\n      </ThemeProvider>,\n    );\n  };\n\n  describe('rendering', () => {\n    it('renders raw axes container', () => {\n      const { container } = renderComponent();\n      expect(container.firstChild).toBeInTheDocument();\n    });\n\n    it('renders SVG with axes group', () => {\n      const { container } = renderComponent();\n      const svg = container.querySelector('svg');\n      expect(svg).toBeInTheDocument();\n      const axesGroup = container.querySelector('g');\n      expect(axesGroup).toBeInTheDocument();\n    });\n\n    it('renders both axes when leftAxis is true', () => {\n      const { getByTestId } = renderComponent({ leftAxis: true });\n      expect(getByTestId('axis-left')).toBeInTheDocument();\n      expect(getByTestId('axis-bottom')).toBeInTheDocument();\n    });\n\n    it('renders only bottom axis when leftAxis is false', () => {\n      const { queryByTestId, getByTestId } = renderComponent({ leftAxis: false });\n      expect(queryByTestId('axis-left')).not.toBeInTheDocument();\n      expect(getByTestId('axis-bottom')).toBeInTheDocument();\n    });\n  });\n});\n\ndescribe('TickComponent', () => {\n  const defaultCategories = [\n    { value: 1, label: 'Category A', editable: true, interactive: true },\n    { value: 2, label: 'Category B', editable: true, interactive: true },\n  ];\n\n  const renderComponent = (extras) => {\n    const defaults = {\n      graphProps: graphProps(),\n      xBand: createBandScale(['a', 'b', 'c'], [0, 400]),\n      categories: defaultCategories,\n      formattedValue: '0-Category A',\n      bandWidth: 100,\n      barWidth: 100,\n      x: 50,\n      y: 50,\n      top: 0,\n      onChangeCategory: jest.fn(),\n    };\n    const props = { ...defaults, ...extras };\n    return render(\n      <ThemeProvider theme={theme}>\n        <svg>\n          <TickComponent {...props} />\n        </svg>\n      </ThemeProvider>,\n    );\n  };\n\n  describe('rendering', () => {\n    it('renders tick component', () => {\n      const { container } = renderComponent();\n      const svg = container.querySelector('svg');\n      expect(svg).toBeInTheDocument();\n      expect(container.querySelector('g')).toBeInTheDocument();\n    });\n\n    it('renders with categories', () => {\n      const { container } = renderComponent({\n        formattedValue: '0-test',\n        categories: [{ value: 1, label: 'test', editable: false, interactive: false }],\n      });\n      const svg = container.querySelector('svg');\n      expect(svg).toBeInTheDocument();\n      expect(container.querySelector('g')).toBeInTheDocument();\n    });\n\n    it('renders MarkLabel component', () => {\n      const { getAllByTestId } = renderComponent();\n      const markLabels = getAllByTestId('mark-label');\n      expect(markLabels.length).toBeGreaterThan(0);\n    });\n\n    it('renders foreignObject for labels', () => {\n      const { container } = renderComponent();\n      const foreignObject = container.querySelector('foreignObject');\n      expect(foreignObject).toBeInTheDocument();\n    });\n\n    it('does not render when formattedValue is null', () => {\n      const { container } = renderComponent({ formattedValue: null });\n      const foreignObject = container.querySelector('foreignObject');\n      expect(foreignObject).not.toBeInTheDocument();\n    });\n\n    it('does not render when formattedValue is undefined', () => {\n      const { container } = renderComponent({ formattedValue: undefined });\n      const foreignObject = container.querySelector('foreignObject');\n      expect(foreignObject).not.toBeInTheDocument();\n    });\n\n    it('renders hidden label for longest category', () => {\n      const { getAllByTestId } = renderComponent();\n      const markLabels = getAllByTestId('mark-label');\n      expect(markLabels.length).toBeGreaterThan(0);\n    });\n  });\n\n  describe('category label editing', () => {\n    it('allows editing category label', () => {\n      const onChangeCategory = jest.fn();\n      const { getAllByTestId } = renderComponent({ onChangeCategory });\n\n      const inputs = getAllByTestId('mark-label-input');\n      const input = inputs[inputs.length - 1];\n      fireEvent.change(input, { target: { value: 'New Label' } });\n\n      expect(onChangeCategory).toHaveBeenCalled();\n    });\n\n    it('calls changeCategory with correct parameters', () => {\n      const onChangeCategory = jest.fn();\n      const { getAllByTestId } = renderComponent({ onChangeCategory });\n\n      const inputs = getAllByTestId('mark-label-input');\n      const input = inputs[inputs.length - 1];\n      fireEvent.change(input, { target: { value: 'Updated' } });\n\n      expect(onChangeCategory).toHaveBeenCalledWith(0, expect.objectContaining({ label: 'Updated' }));\n    });\n\n    it('disables editing when editable is false', () => {\n      const categories = [{ value: 1, label: 'test', editable: false, interactive: true }];\n      const { getAllByTestId } = renderComponent({ categories, formattedValue: '0-test' });\n\n      const inputs = getAllByTestId('mark-label-input');\n      const input = inputs[inputs.length - 1];\n      expect(input).toBeDisabled();\n    });\n\n    it('enables editing in define chart mode', () => {\n      const categories = [{ value: 1, label: 'test', editable: true, interactive: true }];\n      const { getAllByTestId } = renderComponent({\n        categories,\n        formattedValue: '0-test',\n        defineChart: true,\n      });\n\n      const inputs = getAllByTestId('mark-label-input');\n      const input = inputs[inputs.length - 1];\n      expect(input).not.toBeDisabled();\n    });\n\n    it('respects editable property when not in define chart mode', () => {\n      const categories = [{ value: 1, label: 'test', editable: true, interactive: true }];\n      const { getAllByTestId } = renderComponent({\n        categories,\n        formattedValue: '0-test',\n        defineChart: false,\n      });\n\n      const inputs = getAllByTestId('mark-label-input');\n      const input = inputs[inputs.length - 1];\n      expect(input).not.toBeDisabled();\n    });\n  });\n\n  describe('interactive checkbox', () => {\n    it('shows warning when disabling interactive with correct answer', () => {\n      const categories = [\n        {\n          value: 1,\n          label: 'test',\n          editable: true,\n          interactive: true,\n          correctness: { value: 'correct' },\n        },\n      ];\n      const component = new TickComponent({\n        categories,\n        onChangeCategory: jest.fn(),\n      });\n\n      component.setState = jest.fn();\n      component.changeInteractive(0, false);\n\n      expect(component.setState).toHaveBeenCalledWith(\n        expect.objectContaining({\n          dialog: expect.objectContaining({\n            open: true,\n            title: 'Warning',\n          }),\n        }),\n      );\n    });\n\n    it('changes interactive without warning when enabling', () => {\n      const onChangeCategory = jest.fn();\n      const categories = [{ value: 1, label: 'test', editable: true, interactive: false }];\n      const component = new TickComponent({\n        categories,\n        onChangeCategory,\n      });\n\n      component.changeInteractive(0, true);\n\n      expect(onChangeCategory).toHaveBeenCalledWith(0, expect.objectContaining({ interactive: true }));\n    });\n  });\n\n  describe('editable checkbox', () => {\n    it('shows warning when disabling editable with correct answer name', () => {\n      const categories = [\n        {\n          value: 1,\n          label: 'test',\n          editable: true,\n          interactive: true,\n          correctness: { value: 'correct' },\n        },\n      ];\n      const component = new TickComponent({\n        categories,\n        onChangeCategory: jest.fn(),\n      });\n\n      component.setState = jest.fn();\n      component.changeEditable(0, false);\n\n      expect(component.setState).toHaveBeenCalledWith(\n        expect.objectContaining({\n          dialog: expect.objectContaining({\n            open: true,\n            title: 'Warning',\n          }),\n        }),\n      );\n    });\n\n    it('changes editable without warning when enabling', () => {\n      const onChangeCategory = jest.fn();\n      const categories = [{ value: 1, label: 'test', editable: false, interactive: true }];\n      const component = new TickComponent({\n        categories,\n        onChangeCategory,\n      });\n\n      component.changeEditable(0, true);\n\n      expect(onChangeCategory).toHaveBeenCalledWith(0, expect.objectContaining({ editable: true }));\n    });\n  });\n\n  describe('splitText method', () => {\n    it('splits text into chunks', () => {\n      const component = new TickComponent({ categories: [] });\n      const result = component.splitText('This is a long text', 10);\n\n      expect(result.length).toBeGreaterThan(1);\n    });\n\n    it('splits at word boundaries', () => {\n      const component = new TickComponent({ categories: [] });\n      const result = component.splitText('Hello world test', 11);\n\n      expect(result[0]).toBe('Hello world');\n    });\n\n    it('handles text shorter than max', () => {\n      const component = new TickComponent({ categories: [] });\n      const result = component.splitText('Short', 20);\n\n      expect(result).toEqual(['Short']);\n    });\n\n    it('handles empty text', () => {\n      const component = new TickComponent({ categories: [] });\n      const result = component.splitText('', 10);\n\n      expect(result).toEqual([]);\n    });\n\n    it('handles null text', () => {\n      const component = new TickComponent({ categories: [] });\n      const result = component.splitText(null, 10);\n\n      expect(result).toEqual([]);\n    });\n\n    it('forces split when no spaces', () => {\n      const component = new TickComponent({ categories: [] });\n      const result = component.splitText('verylongwordwithoutspaces', 10);\n\n      expect(result.length).toBeGreaterThan(1);\n      expect(result[0].length).toBeLessThanOrEqual(10);\n    });\n  });\n\n  describe('correctness display', () => {\n    it('renders correctness indicator when showCorrectness is true', () => {\n      const categories = [\n        {\n          value: 1,\n          label: 'test',\n          editable: true,\n          interactive: true,\n          correctness: { value: 'correct', label: 'Correct!' },\n        },\n      ];\n      const { getByTestId } = renderComponent({\n        categories,\n        formattedValue: '0-test',\n        showCorrectness: true,\n      });\n\n      expect(getByTestId('tick-correctness-indicator')).toBeInTheDocument();\n    });\n\n    it('does not render correctness indicator when showCorrectness is false', () => {\n      const categories = [\n        {\n          value: 1,\n          label: 'test',\n          editable: true,\n          interactive: true,\n          correctness: { value: 'correct', label: 'Correct!' },\n        },\n      ];\n      const { queryByTestId } = renderComponent({\n        categories,\n        formattedValue: '0-test',\n        showCorrectness: false,\n      });\n\n      expect(queryByTestId('tick-correctness-indicator')).not.toBeInTheDocument();\n    });\n\n    it('does not render correctness indicator when not interactive', () => {\n      const categories = [\n        {\n          value: 1,\n          label: 'test',\n          editable: true,\n          interactive: false,\n          correctness: { value: 'correct', label: 'Correct!' },\n        },\n      ];\n      const { queryByTestId } = renderComponent({\n        categories,\n        formattedValue: '0-test',\n        showCorrectness: true,\n      });\n\n      expect(queryByTestId('tick-correctness-indicator')).not.toBeInTheDocument();\n    });\n  });\n\n  describe('error display', () => {\n    it('renders error message for first category', () => {\n      const error = { 0: 'Error message' };\n      const { getByTestId } = renderComponent({\n        error,\n        formattedValue: '0-test',\n      });\n\n      expect(getByTestId('mark-label-error')).toBeInTheDocument();\n    });\n\n    it('renders distinct error messages', () => {\n      const error = { 0: 'Error 1', 1: 'Error 1', 2: 'Error 2' };\n      const { container } = renderComponent({\n        error,\n        formattedValue: '0-test',\n      });\n\n      const errorText = container.querySelector('text');\n      expect(errorText).toBeInTheDocument();\n    });\n\n    it('does not render error when no error prop', () => {\n      const { queryByTestId } = renderComponent({ error: null });\n      expect(queryByTestId('mark-label-error')).not.toBeInTheDocument();\n    });\n  });\n\n  describe('autoFocus handling', () => {\n    it('handles autoFocus prop', () => {\n      const onAutoFocusUsed = jest.fn();\n      const { rerender } = renderComponent({\n        autoFocus: false,\n        onAutoFocusUsed,\n      });\n\n      rerender(\n        <ThemeProvider theme={theme}>\n          <svg>\n            <TickComponent\n              {...{\n                graphProps: graphProps(),\n                xBand: createBandScale(['a', 'b', 'c'], [0, 400]),\n                categories: defaultCategories,\n                formattedValue: '0-Category A',\n                bandWidth: 100,\n                barWidth: 100,\n                x: 50,\n                y: 50,\n                top: 0,\n                onChangeCategory: jest.fn(),\n                autoFocus: true,\n                onAutoFocusUsed,\n              }}\n            />\n          </svg>\n        </ThemeProvider>,\n      );\n\n      expect(onAutoFocusUsed).toHaveBeenCalled();\n    });\n  });\n\n  describe('define chart mode', () => {\n    it('renders interactive checkboxes when changeInteractiveEnabled', () => {\n      const chartingOptions = {\n        changeInteractive: { authoringLabel: 'Allow students to change' },\n      };\n      const { container } = renderComponent({\n        defineChart: true,\n        chartingOptions,\n        changeInteractiveEnabled: true,\n        formattedValue: '0-test',\n      });\n\n      const text = container.querySelector('text');\n      expect(text).toBeInTheDocument();\n    });\n\n    it('renders editable checkboxes when changeEditableEnabled', () => {\n      const chartingOptions = {\n        changeEditable: { authoringLabel: 'Allow label editing' },\n      };\n      const { container } = renderComponent({\n        defineChart: true,\n        chartingOptions,\n        changeEditableEnabled: true,\n        formattedValue: '0-test',\n      });\n\n      const text = container.querySelector('text');\n      expect(text).toBeInTheDocument();\n    });\n\n    it('splits long authoring labels', () => {\n      const chartingOptions = {\n        changeInteractive: { authoringLabel: 'This is a very long label that needs to be split' },\n      };\n      const { container } = renderComponent({\n        defineChart: true,\n        chartingOptions,\n        changeInteractiveEnabled: true,\n        formattedValue: '0-test',\n      });\n\n      const tspans = container.querySelectorAll('tspan');\n      expect(tspans.length).toBeGreaterThan(1);\n    });\n  });\n\n  describe('edge cases', () => {\n    it('handles missing category', () => {\n      const { container } = renderComponent({\n        categories: [],\n        formattedValue: '0-missing',\n      });\n      expect(container).toBeInTheDocument();\n    });\n\n    it('handles invalid formattedValue format', () => {\n      const { container } = renderComponent({\n        formattedValue: 'invalid',\n      });\n      expect(container).toBeInTheDocument();\n    });\n\n    it('handles missing graphProps', () => {\n      const { container } = renderComponent({\n        graphProps: null,\n      });\n      expect(container).toBeInTheDocument();\n    });\n\n    it('handles zero barWidth', () => {\n      const { container } = renderComponent({\n        barWidth: 0,\n      });\n      expect(container).toBeInTheDocument();\n    });\n\n    it('handles negative coordinates', () => {\n      const { container } = renderComponent({\n        x: -10,\n        y: -20,\n      });\n      expect(container).toBeInTheDocument();\n    });\n  });\n\n  describe('componentDidUpdate', () => {\n    it('calls onAutoFocusUsed when autoFocus changes to true', () => {\n      const onAutoFocusUsed = jest.fn();\n      const component = new TickComponent({\n        autoFocus: false,\n        onAutoFocusUsed,\n      });\n\n      component.componentDidUpdate({ autoFocus: false });\n      expect(onAutoFocusUsed).not.toHaveBeenCalled();\n\n      component.props = { autoFocus: true, onAutoFocusUsed };\n      component.componentDidUpdate({ autoFocus: false });\n      expect(onAutoFocusUsed).toHaveBeenCalled();\n    });\n  });\n});\n"],"mappings":";;;;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,UAAA,GAAAD,OAAA;AACA,IAAAE,OAAA,GAAAF,OAAA;AACA,IAAAG,KAAA,GAAAC,uBAAA,CAAAJ,OAAA;AACA,IAAAK,MAAA,GAAAL,OAAA;AAAsD,IAAAM,SAAA;EAAAC,UAAA;AAAA,SAAAH,wBAAAI,CAAA,EAAAC,CAAA,6BAAAC,OAAA,MAAAC,CAAA,OAAAD,OAAA,IAAAE,CAAA,OAAAF,OAAA,YAAAN,uBAAA,YAAAA,wBAAAI,CAAA,EAAAC,CAAA,SAAAA,CAAA,IAAAD,CAAA,IAAAA,CAAA,CAAAK,UAAA,SAAAL,CAAA,MAAAM,CAAA,EAAAC,CAAA,EAAAC,CAAA,KAAAC,SAAA,mBAAAT,CAAA,iBAAAA,CAAA,gBAAAU,OAAA,CAAAV,CAAA,0BAAAA,CAAA,SAAAQ,CAAA,MAAAF,CAAA,GAAAL,CAAA,GAAAG,CAAA,GAAAD,CAAA,QAAAG,CAAA,CAAAK,GAAA,CAAAX,CAAA,UAAAM,CAAA,CAAAM,GAAA,CAAAZ,CAAA,GAAAM,CAAA,CAAAO,GAAA,CAAAb,CAAA,EAAAQ,CAAA,cAAAM,EAAA,IAAAd,CAAA,gBAAAc,EAAA,OAAAC,cAAA,CAAAC,IAAA,CAAAhB,CAAA,EAAAc,EAAA,OAAAP,CAAA,IAAAD,CAAA,GAAAW,MAAA,CAAAC,cAAA,KAAAD,MAAA,CAAAE,wBAAA,CAAAnB,CAAA,EAAAc,EAAA,OAAAP,CAAA,CAAAK,GAAA,IAAAL,CAAA,CAAAM,GAAA,IAAAP,CAAA,CAAAE,CAAA,EAAAM,EAAA,EAAAP,CAAA,IAAAC,CAAA,CAAAM,EAAA,IAAAd,CAAA,CAAAc,EAAA,WAAAN,CAAA,KAAAR,CAAA,EAAAC,CAAA;AAAA,SAAAmB,QAAApB,CAAA,EAAAG,CAAA,QAAAF,CAAA,GAAAgB,MAAA,CAAAI,IAAA,CAAArB,CAAA,OAAAiB,MAAA,CAAAK,qBAAA,QAAAhB,CAAA,GAAAW,MAAA,CAAAK,qBAAA,CAAAtB,CAAA,GAAAG,CAAA,KAAAG,CAAA,GAAAA,CAAA,CAAAiB,MAAA,WAAApB,CAAA,WAAAc,MAAA,CAAAE,wBAAA,CAAAnB,CAAA,EAAAG,CAAA,EAAAqB,UAAA,OAAAvB,CAAA,CAAAwB,IAAA,CAAAC,KAAA,CAAAzB,CAAA,EAAAK,CAAA,YAAAL,CAAA;AAAA,SAAA0B,cAAA3B,CAAA,aAAAG,CAAA,MAAAA,CAAA,GAAAyB,SAAA,CAAAC,MAAA,EAAA1B,CAAA,UAAAF,CAAA,WAAA2B,SAAA,CAAAzB,CAAA,IAAAyB,SAAA,CAAAzB,CAAA,QAAAA,CAAA,OAAAiB,OAAA,CAAAH,MAAA,CAAAhB,CAAA,OAAA6B,OAAA,WAAA3B,CAAA,QAAA4B,gBAAA,aAAA/B,CAAA,EAAAG,CAAA,EAAAF,CAAA,CAAAE,CAAA,SAAAc,MAAA,CAAAe,yBAAA,GAAAf,MAAA,CAAAgB,gBAAA,CAAAjC,CAAA,EAAAiB,MAAA,CAAAe,yBAAA,CAAA/B,CAAA,KAAAmB,OAAA,CAAAH,MAAA,CAAAhB,CAAA,GAAA6B,OAAA,WAAA3B,CAAA,IAAAc,MAAA,CAAAC,cAAA,CAAAlB,CAAA,EAAAG,CAAA,EAAAc,MAAA,CAAAE,wBAAA,CAAAlB,CAAA,EAAAE,CAAA,iBAAAH,CAAA;AAEtDkC,IAAI,CAACC,IAAI,CAAC,YAAY,EAAE;EAAA,OAAO;IAC7BC,QAAQ,EAAE,SAAVA,QAAQA,CAAAC,IAAA;MAAA,IAAKC,QAAQ,GAAAD,IAAA,CAARC,QAAQ;QAAKC,KAAK,OAAAC,yBAAA,aAAAH,IAAA,EAAAvC,SAAA;MAAA,oBAC7BR,MAAA,YAAAmD,aAAA,UAAAC,SAAA;QAAG,eAAY;MAAW,GAAKH,KAAK,GACjC,OAAOD,QAAQ,KAAK,UAAU,GAAGA,QAAQ,CAAC;QAAEK,cAAc,EAAE;MAAI,CAAC,CAAC,GAAGL,QACrE,CAAC;IAAA,CACL;IACDM,UAAU,EAAE,SAAZA,UAAUA,CAAAC,KAAA;MAAA,IAAKP,QAAQ,GAAAO,KAAA,CAARP,QAAQ;QAAEQ,UAAU,GAAAD,KAAA,CAAVC,UAAU;QAAKP,KAAK,OAAAC,yBAAA,aAAAK,KAAA,EAAA9C,UAAA;MAAA,oBAC3CT,MAAA,YAAAmD,aAAA,UAAAC,SAAA;QAAG,eAAY;MAAa,GAAKH,KAAK,GACnC,OAAOD,QAAQ,KAAK,UAAU,GAC3B,CAACQ,UAAU,IAAI,CAAC,KAAK,EAAE,KAAK,EAAE,KAAK,CAAC,EAAEC,GAAG,CAAC,UAACC,CAAC,EAAEzC,CAAC;QAAA,OAAK+B,QAAQ,CAAC;UAAEK,cAAc,EAAEK,CAAC;UAAEC,KAAK,EAAE1C;QAAE,CAAC,CAAC;MAAA,EAAC,GAC9F+B,QACH,CAAC;IAAA;EAER,CAAC;AAAA,CAAC,CAAC;AAEHJ,IAAI,CAACC,IAAI,CAAC,eAAe,EAAE,YAAM;EAC/B,OAAO,SAASe,SAASA,CAAAC,KAAA,EAAiF;IAAA,IAA9EC,IAAI,GAAAD,KAAA,CAAJC,IAAI;MAAEC,QAAQ,GAAAF,KAAA,CAARE,QAAQ;MAAEC,SAAQ,GAAAH,KAAA,CAARG,QAAQ;MAAEC,KAAK,GAAAJ,KAAA,CAALI,KAAK;MAAEC,SAAS,GAAAL,KAAA,CAATK,SAAS;MAAEC,QAAQ,GAAAN,KAAA,CAARM,QAAQ;MAAEC,oBAAoB,GAAAP,KAAA,CAApBO,oBAAoB;IACpG,oBACEpE,MAAA,YAAAmD,aAAA;MAAK,eAAY;IAAY,gBAC3BnD,MAAA,YAAAmD,aAAA;MACE,eAAY,kBAAkB;MAC9BkB,GAAG,EAAEF,QAAS;MACdG,KAAK,EAAE,CAAAR,IAAI,aAAJA,IAAI,uBAAJA,IAAI,CAAES,KAAK,KAAI,EAAG;MACzBR,QAAQ,EAAEA,QAAS;MACnBC,QAAQ,EAAE,SAAVA,QAAQA,CAAGtD,CAAC;QAAA,OAAKsD,SAAQ,IAAIA,SAAQ,CAACtD,CAAC,CAAC8D,MAAM,CAACF,KAAK,CAAC;MAAA,CAAC;MACtDJ,SAAS,EAAEA;IAAU,CACtB,CAAC,EACDD,KAAK,iBAAIjE,MAAA,YAAAmD,aAAA;MAAM,eAAY;IAAkB,GAAEc,KAAY,CAAC,EAC5DG,oBACE,CAAC;EAEV,CAAC;AACH,CAAC,CAAC;AAEFxB,IAAI,CAACC,IAAI,CAAC,oBAAoB,EAAE;EAAA,OAAO;IACrC4B,WAAW,EAAE,SAAbA,WAAWA,CAAAC,KAAA;MAAA,IAAKC,IAAI,GAAAD,KAAA,CAAJC,IAAI;QAAEC,KAAK,GAAAF,KAAA,CAALE,KAAK;QAAEC,IAAI,GAAAH,KAAA,CAAJG,IAAI;QAAEC,OAAO,GAAAJ,KAAA,CAAPI,OAAO;QAAEC,SAAS,GAAAL,KAAA,CAATK,SAAS;MAAA,OACnDJ,IAAI,gBACF3E,MAAA,YAAAmD,aAAA;QAAK,eAAY;MAAc,gBAC7BnD,MAAA,YAAAmD,aAAA,aAAKyB,KAAU,CAAC,eAChB5E,MAAA,YAAAmD,aAAA,YAAI0B,IAAQ,CAAC,eACb7E,MAAA,YAAAmD,aAAA;QAAQ,eAAY,cAAc;QAAC6B,OAAO,EAAEF;MAAQ,GAAC,QAE7C,CAAC,eACT9E,MAAA,YAAAmD,aAAA;QAAQ,eAAY,eAAe;QAAC6B,OAAO,EAAED;MAAU,GAAC,SAEhD,CACL,CAAC,GACJ,IAAI;IAAA;EACZ,CAAC;AAAA,CAAC,CAAC;AAEHnC,IAAI,CAACC,IAAI,CAAC,kCAAkC,EAAE;EAAA,OAAO;IACnDoC,wBAAwB,EAAE,SAA1BA,wBAAwBA,CAAAC,KAAA;MAAA,IAAKC,WAAW,GAAAD,KAAA,CAAXC,WAAW;QAAEC,WAAW,GAAAF,KAAA,CAAXE,WAAW;MAAA,OACnDD,WAAW,IAAIC,WAAW,gBACxBpF,MAAA,YAAAmD,aAAA;QAAK,eAAY;MAA4B,GAAEgC,WAAW,CAACb,KAAK,KAAK,SAAS,GAAG,GAAG,GAAG,GAAS,CAAC,GAC/F,IAAI;IAAA;EACZ,CAAC;AAAA,CAAC,CAAC;AAEH1B,IAAI,CAACC,IAAI,CAAC,yBAAyB,EAAE;EAAA,OAAO;IAC1CwC,UAAU,EAAEzC,IAAI,CAAC0C,EAAE,CAAC,UAACT,IAAI;MAAA,OAAKA,IAAI;IAAA;EACpC,CAAC;AAAA,CAAC,CAAC;AAEH,IAAMU,KAAK,GAAG,IAAAC,mBAAW,EAAC,CAAC;AAE3BC,QAAQ,CAAC,WAAW,EAAE,YAAM;EAC1B,IAAMC,eAAe,GAAG,SAAlBA,eAAeA,CAAIC,MAAM,EAAK;IAClC,IAAMC,QAAQ,GAAG;MACfC,OAAO,EAAE,CAAC,CAAC;MACXC,SAAS,EAAE,WAAW;MACtBC,UAAU,EAAE,IAAAA,iBAAU,EAAC,CAAC;MACxBC,KAAK,EAAE,IAAAC,sBAAe,EAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;MACjDC,UAAU,EAAE;IACd,CAAC;IACD,IAAMjD,KAAK,GAAAZ,aAAA,CAAAA,aAAA,KAAQuD,QAAQ,GAAKD,MAAM,CAAE;IACxC,OAAO,IAAAQ,iBAAM,eACXnG,MAAA,YAAAmD,aAAA,CAAC/C,OAAA,CAAAgG,aAAa;MAACb,KAAK,EAAEA;IAAM,gBAC1BvF,MAAA,YAAAmD,aAAA,2BACEnD,MAAA,YAAAmD,aAAA,CAAC9C,KAAA,WAAS,EAAK4C,KAAQ,CACpB,CACQ,CACjB,CAAC;EACH,CAAC;EAEDwC,QAAQ,CAAC,WAAW,EAAE,YAAM;IAC1BY,EAAE,CAAC,wBAAwB,EAAE,YAAM;MACjC,IAAAC,gBAAA,GAAsBZ,eAAe,CAAC,CAAC;QAA/Ba,SAAS,GAAAD,gBAAA,CAATC,SAAS;MACjBC,MAAM,CAACD,SAAS,CAACE,UAAU,CAAC,CAACC,iBAAiB,CAAC,CAAC;IAClD,CAAC,CAAC;IAEFL,EAAE,CAAC,6BAA6B,EAAE,YAAM;MACtC,IAAAM,iBAAA,GAAsBjB,eAAe,CAAC,CAAC;QAA/Ba,SAAS,GAAAI,iBAAA,CAATJ,SAAS;MACjB,IAAMK,GAAG,GAAGL,SAAS,CAACM,aAAa,CAAC,KAAK,CAAC;MAC1CL,MAAM,CAACI,GAAG,CAAC,CAACF,iBAAiB,CAAC,CAAC;MAC/B,IAAMI,SAAS,GAAGP,SAAS,CAACM,aAAa,CAAC,GAAG,CAAC;MAC9CL,MAAM,CAACM,SAAS,CAAC,CAACJ,iBAAiB,CAAC,CAAC;IACvC,CAAC,CAAC;IAEFL,EAAE,CAAC,uBAAuB,EAAE,YAAM;MAChC,IAAAU,iBAAA,GAAsBrB,eAAe,CAAC,CAAC;QAA/Ba,SAAS,GAAAQ,iBAAA,CAATR,SAAS;MACjB,IAAMS,MAAM,GAAGT,SAAS,CAACU,gBAAgB,CAAC,GAAG,CAAC;MAC9CT,MAAM,CAACQ,MAAM,CAACzE,MAAM,CAAC,CAAC2E,eAAe,CAAC,CAAC,CAAC;IAC1C,CAAC,CAAC;EACJ,CAAC,CAAC;EAEFzB,QAAQ,CAAC,YAAY,EAAE,YAAM;IAC3BY,EAAE,CAAC,uBAAuB,EAAE,YAAM;MAChC,IAAAc,iBAAA,GAAsBzB,eAAe,CAAC;UAAEM,KAAK,EAAEoB;QAAU,CAAC,CAAC;QAAnDb,SAAS,GAAAY,iBAAA,CAATZ,SAAS;MACjBC,MAAM,CAACD,SAAS,CAAC,CAACG,iBAAiB,CAAC,CAAC;IACvC,CAAC,CAAC;IAEFL,EAAE,CAAC,0BAA0B,EAAE,YAAM;MACnC,IAAAgB,iBAAA,GAAsB3B,eAAe,CAAC;UAAEQ,UAAU,EAAE;QAAG,CAAC,CAAC;QAAjDK,SAAS,GAAAc,iBAAA,CAATd,SAAS;MACjBC,MAAM,CAACD,SAAS,CAAC,CAACG,iBAAiB,CAAC,CAAC;IACvC,CAAC,CAAC;IAEFL,EAAE,CAAC,yBAAyB,EAAE,YAAM;MAClC,IAAAiB,iBAAA,GAAsB5B,eAAe,CAAC;UAAEQ,UAAU,EAAE;QAAK,CAAC,CAAC;QAAnDK,SAAS,GAAAe,iBAAA,CAATf,SAAS;MACjBC,MAAM,CAACD,SAAS,CAAC,CAACG,iBAAiB,CAAC,CAAC;IACvC,CAAC,CAAC;EACJ,CAAC,CAAC;AACJ,CAAC,CAAC;AAEFjB,QAAQ,CAAC,cAAc,EAAE,YAAM;EAC7B,IAAMC,eAAe,GAAG,SAAlBA,eAAeA,CAAIC,MAAM,EAAK;IAClC,IAAMC,QAAQ,GAAG;MACfC,OAAO,EAAE,CAAC,CAAC;MACXC,SAAS,EAAE,WAAW;MACtBC,UAAU,EAAE,IAAAA,iBAAU,EAAC,CAAC;MACxBC,KAAK,EAAE,IAAAC,sBAAe,EAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;MACjDC,UAAU,EAAE;IACd,CAAC;IACD,IAAMjD,KAAK,GAAAZ,aAAA,CAAAA,aAAA,KAAQuD,QAAQ,GAAKD,MAAM,CAAE;IACxC,OAAO,IAAAQ,iBAAM,eACXnG,MAAA,YAAAmD,aAAA,CAAC/C,OAAA,CAAAgG,aAAa;MAACb,KAAK,EAAEA;IAAM,gBAC1BvF,MAAA,YAAAmD,aAAA,2BACEnD,MAAA,YAAAmD,aAAA,CAAC9C,KAAA,CAAAkH,YAAY,EAAKtE,KAAQ,CACvB,CACQ,CACjB,CAAC;EACH,CAAC;EAEDwC,QAAQ,CAAC,WAAW,EAAE,YAAM;IAC1BY,EAAE,CAAC,4BAA4B,EAAE,YAAM;MACrC,IAAAmB,iBAAA,GAAsB9B,eAAe,CAAC,CAAC;QAA/Ba,SAAS,GAAAiB,iBAAA,CAATjB,SAAS;MACjBC,MAAM,CAACD,SAAS,CAACE,UAAU,CAAC,CAACC,iBAAiB,CAAC,CAAC;IAClD,CAAC,CAAC;IAEFL,EAAE,CAAC,6BAA6B,EAAE,YAAM;MACtC,IAAAoB,iBAAA,GAAsB/B,eAAe,CAAC,CAAC;QAA/Ba,SAAS,GAAAkB,iBAAA,CAATlB,SAAS;MACjB,IAAMK,GAAG,GAAGL,SAAS,CAACM,aAAa,CAAC,KAAK,CAAC;MAC1CL,MAAM,CAACI,GAAG,CAAC,CAACF,iBAAiB,CAAC,CAAC;MAC/B,IAAMI,SAAS,GAAGP,SAAS,CAACM,aAAa,CAAC,GAAG,CAAC;MAC9CL,MAAM,CAACM,SAAS,CAAC,CAACJ,iBAAiB,CAAC,CAAC;IACvC,CAAC,CAAC;IAEFL,EAAE,CAAC,yCAAyC,EAAE,YAAM;MAClD,IAAAqB,iBAAA,GAAwBhC,eAAe,CAAC;UAAEiC,QAAQ,EAAE;QAAK,CAAC,CAAC;QAAnDC,WAAW,GAAAF,iBAAA,CAAXE,WAAW;MACnBpB,MAAM,CAACoB,WAAW,CAAC,WAAW,CAAC,CAAC,CAAClB,iBAAiB,CAAC,CAAC;MACpDF,MAAM,CAACoB,WAAW,CAAC,aAAa,CAAC,CAAC,CAAClB,iBAAiB,CAAC,CAAC;IACxD,CAAC,CAAC;IAEFL,EAAE,CAAC,iDAAiD,EAAE,YAAM;MAC1D,IAAAwB,iBAAA,GAAuCnC,eAAe,CAAC;UAAEiC,QAAQ,EAAE;QAAM,CAAC,CAAC;QAAnEG,aAAa,GAAAD,iBAAA,CAAbC,aAAa;QAAEF,WAAW,GAAAC,iBAAA,CAAXD,WAAW;MAClCpB,MAAM,CAACsB,aAAa,CAAC,WAAW,CAAC,CAAC,CAACC,GAAG,CAACrB,iBAAiB,CAAC,CAAC;MAC1DF,MAAM,CAACoB,WAAW,CAAC,aAAa,CAAC,CAAC,CAAClB,iBAAiB,CAAC,CAAC;IACxD,CAAC,CAAC;EACJ,CAAC,CAAC;AACJ,CAAC,CAAC;AAEFjB,QAAQ,CAAC,eAAe,EAAE,YAAM;EAC9B,IAAMuC,iBAAiB,GAAG,CACxB;IAAE1D,KAAK,EAAE,CAAC;IAAEC,KAAK,EAAE,YAAY;IAAE0D,QAAQ,EAAE,IAAI;IAAE7C,WAAW,EAAE;EAAK,CAAC,EACpE;IAAEd,KAAK,EAAE,CAAC;IAAEC,KAAK,EAAE,YAAY;IAAE0D,QAAQ,EAAE,IAAI;IAAE7C,WAAW,EAAE;EAAK,CAAC,CACrE;EAED,IAAMM,eAAe,GAAG,SAAlBA,eAAeA,CAAIC,MAAM,EAAK;IAClC,IAAMC,QAAQ,GAAG;MACfG,UAAU,EAAE,IAAAA,iBAAU,EAAC,CAAC;MACxBC,KAAK,EAAE,IAAAC,sBAAe,EAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;MACjDC,UAAU,EAAE8B,iBAAiB;MAC7B3E,cAAc,EAAE,cAAc;MAC9B6E,SAAS,EAAE,GAAG;MACdC,QAAQ,EAAE,GAAG;MACbC,CAAC,EAAE,EAAE;MACLC,CAAC,EAAE,EAAE;MACLC,GAAG,EAAE,CAAC;MACNC,gBAAgB,EAAE3F,IAAI,CAAC0C,EAAE,CAAC;IAC5B,CAAC;IACD,IAAMrC,KAAK,GAAAZ,aAAA,CAAAA,aAAA,KAAQuD,QAAQ,GAAKD,MAAM,CAAE;IACxC,OAAO,IAAAQ,iBAAM,eACXnG,MAAA,YAAAmD,aAAA,CAAC/C,OAAA,CAAAgG,aAAa;MAACb,KAAK,EAAEA;IAAM,gBAC1BvF,MAAA,YAAAmD,aAAA,2BACEnD,MAAA,YAAAmD,aAAA,CAAC9C,KAAA,CAAAmI,aAAa,EAAKvF,KAAQ,CACxB,CACQ,CACjB,CAAC;EACH,CAAC;EAEDwC,QAAQ,CAAC,WAAW,EAAE,YAAM;IAC1BY,EAAE,CAAC,wBAAwB,EAAE,YAAM;MACjC,IAAAoC,iBAAA,GAAsB/C,eAAe,CAAC,CAAC;QAA/Ba,SAAS,GAAAkC,iBAAA,CAATlC,SAAS;MACjB,IAAMK,GAAG,GAAGL,SAAS,CAACM,aAAa,CAAC,KAAK,CAAC;MAC1CL,MAAM,CAACI,GAAG,CAAC,CAACF,iBAAiB,CAAC,CAAC;MAC/BF,MAAM,CAACD,SAAS,CAACM,aAAa,CAAC,GAAG,CAAC,CAAC,CAACH,iBAAiB,CAAC,CAAC;IAC1D,CAAC,CAAC;IAEFL,EAAE,CAAC,yBAAyB,EAAE,YAAM;MAClC,IAAAqC,kBAAA,GAAsBhD,eAAe,CAAC;UACpCrC,cAAc,EAAE,QAAQ;UACxB6C,UAAU,EAAE,CAAC;YAAE5B,KAAK,EAAE,CAAC;YAAEC,KAAK,EAAE,MAAM;YAAE0D,QAAQ,EAAE,KAAK;YAAE7C,WAAW,EAAE;UAAM,CAAC;QAC/E,CAAC,CAAC;QAHMmB,SAAS,GAAAmC,kBAAA,CAATnC,SAAS;MAIjB,IAAMK,GAAG,GAAGL,SAAS,CAACM,aAAa,CAAC,KAAK,CAAC;MAC1CL,MAAM,CAACI,GAAG,CAAC,CAACF,iBAAiB,CAAC,CAAC;MAC/BF,MAAM,CAACD,SAAS,CAACM,aAAa,CAAC,GAAG,CAAC,CAAC,CAACH,iBAAiB,CAAC,CAAC;IAC1D,CAAC,CAAC;IAEFL,EAAE,CAAC,6BAA6B,EAAE,YAAM;MACtC,IAAAsC,kBAAA,GAA2BjD,eAAe,CAAC,CAAC;QAApCkD,cAAc,GAAAD,kBAAA,CAAdC,cAAc;MACtB,IAAMC,UAAU,GAAGD,cAAc,CAAC,YAAY,CAAC;MAC/CpC,MAAM,CAACqC,UAAU,CAACtG,MAAM,CAAC,CAAC2E,eAAe,CAAC,CAAC,CAAC;IAC9C,CAAC,CAAC;IAEFb,EAAE,CAAC,kCAAkC,EAAE,YAAM;MAC3C,IAAAyC,kBAAA,GAAsBpD,eAAe,CAAC,CAAC;QAA/Ba,SAAS,GAAAuC,kBAAA,CAATvC,SAAS;MACjB,IAAMwC,aAAa,GAAGxC,SAAS,CAACM,aAAa,CAAC,eAAe,CAAC;MAC9DL,MAAM,CAACuC,aAAa,CAAC,CAACrC,iBAAiB,CAAC,CAAC;IAC3C,CAAC,CAAC;IAEFL,EAAE,CAAC,6CAA6C,EAAE,YAAM;MACtD,IAAA2C,kBAAA,GAAsBtD,eAAe,CAAC;UAAErC,cAAc,EAAE;QAAK,CAAC,CAAC;QAAvDkD,SAAS,GAAAyC,kBAAA,CAATzC,SAAS;MACjB,IAAMwC,aAAa,GAAGxC,SAAS,CAACM,aAAa,CAAC,eAAe,CAAC;MAC9DL,MAAM,CAACuC,aAAa,CAAC,CAAChB,GAAG,CAACrB,iBAAiB,CAAC,CAAC;IAC/C,CAAC,CAAC;IAEFL,EAAE,CAAC,kDAAkD,EAAE,YAAM;MAC3D,IAAA4C,kBAAA,GAAsBvD,eAAe,CAAC;UAAErC,cAAc,EAAE+D;QAAU,CAAC,CAAC;QAA5Db,SAAS,GAAA0C,kBAAA,CAAT1C,SAAS;MACjB,IAAMwC,aAAa,GAAGxC,SAAS,CAACM,aAAa,CAAC,eAAe,CAAC;MAC9DL,MAAM,CAACuC,aAAa,CAAC,CAAChB,GAAG,CAACrB,iBAAiB,CAAC,CAAC;IAC/C,CAAC,CAAC;IAEFL,EAAE,CAAC,2CAA2C,EAAE,YAAM;MACpD,IAAA6C,kBAAA,GAA2BxD,eAAe,CAAC,CAAC;QAApCkD,cAAc,GAAAM,kBAAA,CAAdN,cAAc;MACtB,IAAMC,UAAU,GAAGD,cAAc,CAAC,YAAY,CAAC;MAC/CpC,MAAM,CAACqC,UAAU,CAACtG,MAAM,CAAC,CAAC2E,eAAe,CAAC,CAAC,CAAC;IAC9C,CAAC,CAAC;EACJ,CAAC,CAAC;EAEFzB,QAAQ,CAAC,wBAAwB,EAAE,YAAM;IACvCY,EAAE,CAAC,+BAA+B,EAAE,YAAM;MACxC,IAAMkC,gBAAgB,GAAG3F,IAAI,CAAC0C,EAAE,CAAC,CAAC;MAClC,IAAA6D,kBAAA,GAA2BzD,eAAe,CAAC;UAAE6C,gBAAgB,EAAhBA;QAAiB,CAAC,CAAC;QAAxDK,cAAc,GAAAO,kBAAA,CAAdP,cAAc;MAEtB,IAAMQ,MAAM,GAAGR,cAAc,CAAC,kBAAkB,CAAC;MACjD,IAAMS,KAAK,GAAGD,MAAM,CAACA,MAAM,CAAC7G,MAAM,GAAG,CAAC,CAAC;MACvC+G,oBAAS,CAACC,MAAM,CAACF,KAAK,EAAE;QAAE7E,MAAM,EAAE;UAAEF,KAAK,EAAE;QAAY;MAAE,CAAC,CAAC;MAE3DkC,MAAM,CAAC+B,gBAAgB,CAAC,CAACiB,gBAAgB,CAAC,CAAC;IAC7C,CAAC,CAAC;IAEFnD,EAAE,CAAC,8CAA8C,EAAE,YAAM;MACvD,IAAMkC,gBAAgB,GAAG3F,IAAI,CAAC0C,EAAE,CAAC,CAAC;MAClC,IAAAmE,kBAAA,GAA2B/D,eAAe,CAAC;UAAE6C,gBAAgB,EAAhBA;QAAiB,CAAC,CAAC;QAAxDK,cAAc,GAAAa,kBAAA,CAAdb,cAAc;MAEtB,IAAMQ,MAAM,GAAGR,cAAc,CAAC,kBAAkB,CAAC;MACjD,IAAMS,KAAK,GAAGD,MAAM,CAACA,MAAM,CAAC7G,MAAM,GAAG,CAAC,CAAC;MACvC+G,oBAAS,CAACC,MAAM,CAACF,KAAK,EAAE;QAAE7E,MAAM,EAAE;UAAEF,KAAK,EAAE;QAAU;MAAE,CAAC,CAAC;MAEzDkC,MAAM,CAAC+B,gBAAgB,CAAC,CAACmB,oBAAoB,CAAC,CAAC,EAAElD,MAAM,CAACmD,gBAAgB,CAAC;QAAEpF,KAAK,EAAE;MAAU,CAAC,CAAC,CAAC;IACjG,CAAC,CAAC;IAEF8B,EAAE,CAAC,yCAAyC,EAAE,YAAM;MAClD,IAAMH,UAAU,GAAG,CAAC;QAAE5B,KAAK,EAAE,CAAC;QAAEC,KAAK,EAAE,MAAM;QAAE0D,QAAQ,EAAE,KAAK;QAAE7C,WAAW,EAAE;MAAK,CAAC,CAAC;MACpF,IAAAwE,kBAAA,GAA2BlE,eAAe,CAAC;UAAEQ,UAAU,EAAVA,UAAU;UAAE7C,cAAc,EAAE;QAAS,CAAC,CAAC;QAA5EuF,cAAc,GAAAgB,kBAAA,CAAdhB,cAAc;MAEtB,IAAMQ,MAAM,GAAGR,cAAc,CAAC,kBAAkB,CAAC;MACjD,IAAMS,KAAK,GAAGD,MAAM,CAACA,MAAM,CAAC7G,MAAM,GAAG,CAAC,CAAC;MACvCiE,MAAM,CAAC6C,KAAK,CAAC,CAACQ,YAAY,CAAC,CAAC;IAC9B,CAAC,CAAC;IAEFxD,EAAE,CAAC,sCAAsC,EAAE,YAAM;MAC/C,IAAMH,UAAU,GAAG,CAAC;QAAE5B,KAAK,EAAE,CAAC;QAAEC,KAAK,EAAE,MAAM;QAAE0D,QAAQ,EAAE,IAAI;QAAE7C,WAAW,EAAE;MAAK,CAAC,CAAC;MACnF,IAAA0E,kBAAA,GAA2BpE,eAAe,CAAC;UACzCQ,UAAU,EAAVA,UAAU;UACV7C,cAAc,EAAE,QAAQ;UACxB0G,WAAW,EAAE;QACf,CAAC,CAAC;QAJMnB,cAAc,GAAAkB,kBAAA,CAAdlB,cAAc;MAMtB,IAAMQ,MAAM,GAAGR,cAAc,CAAC,kBAAkB,CAAC;MACjD,IAAMS,KAAK,GAAGD,MAAM,CAACA,MAAM,CAAC7G,MAAM,GAAG,CAAC,CAAC;MACvCiE,MAAM,CAAC6C,KAAK,CAAC,CAACtB,GAAG,CAAC8B,YAAY,CAAC,CAAC;IAClC,CAAC,CAAC;IAEFxD,EAAE,CAAC,0DAA0D,EAAE,YAAM;MACnE,IAAMH,UAAU,GAAG,CAAC;QAAE5B,KAAK,EAAE,CAAC;QAAEC,KAAK,EAAE,MAAM;QAAE0D,QAAQ,EAAE,IAAI;QAAE7C,WAAW,EAAE;MAAK,CAAC,CAAC;MACnF,IAAA4E,kBAAA,GAA2BtE,eAAe,CAAC;UACzCQ,UAAU,EAAVA,UAAU;UACV7C,cAAc,EAAE,QAAQ;UACxB0G,WAAW,EAAE;QACf,CAAC,CAAC;QAJMnB,cAAc,GAAAoB,kBAAA,CAAdpB,cAAc;MAMtB,IAAMQ,MAAM,GAAGR,cAAc,CAAC,kBAAkB,CAAC;MACjD,IAAMS,KAAK,GAAGD,MAAM,CAACA,MAAM,CAAC7G,MAAM,GAAG,CAAC,CAAC;MACvCiE,MAAM,CAAC6C,KAAK,CAAC,CAACtB,GAAG,CAAC8B,YAAY,CAAC,CAAC;IAClC,CAAC,CAAC;EACJ,CAAC,CAAC;EAEFpE,QAAQ,CAAC,sBAAsB,EAAE,YAAM;IACrCY,EAAE,CAAC,8DAA8D,EAAE,YAAM;MACvE,IAAMH,UAAU,GAAG,CACjB;QACE5B,KAAK,EAAE,CAAC;QACRC,KAAK,EAAE,MAAM;QACb0D,QAAQ,EAAE,IAAI;QACd7C,WAAW,EAAE,IAAI;QACjBD,WAAW,EAAE;UAAEb,KAAK,EAAE;QAAU;MAClC,CAAC,CACF;MACD,IAAM2F,SAAS,GAAG,IAAIzB,mBAAa,CAAC;QAClCtC,UAAU,EAAVA,UAAU;QACVqC,gBAAgB,EAAE3F,IAAI,CAAC0C,EAAE,CAAC;MAC5B,CAAC,CAAC;MAEF2E,SAAS,CAACC,QAAQ,GAAGtH,IAAI,CAAC0C,EAAE,CAAC,CAAC;MAC9B2E,SAAS,CAACE,iBAAiB,CAAC,CAAC,EAAE,KAAK,CAAC;MAErC3D,MAAM,CAACyD,SAAS,CAACC,QAAQ,CAAC,CAACR,oBAAoB,CAC7ClD,MAAM,CAACmD,gBAAgB,CAAC;QACtBS,MAAM,EAAE5D,MAAM,CAACmD,gBAAgB,CAAC;UAC9BhF,IAAI,EAAE,IAAI;UACVC,KAAK,EAAE;QACT,CAAC;MACH,CAAC,CACH,CAAC;IACH,CAAC,CAAC;IAEFyB,EAAE,CAAC,mDAAmD,EAAE,YAAM;MAC5D,IAAMkC,gBAAgB,GAAG3F,IAAI,CAAC0C,EAAE,CAAC,CAAC;MAClC,IAAMY,UAAU,GAAG,CAAC;QAAE5B,KAAK,EAAE,CAAC;QAAEC,KAAK,EAAE,MAAM;QAAE0D,QAAQ,EAAE,IAAI;QAAE7C,WAAW,EAAE;MAAM,CAAC,CAAC;MACpF,IAAM6E,SAAS,GAAG,IAAIzB,mBAAa,CAAC;QAClCtC,UAAU,EAAVA,UAAU;QACVqC,gBAAgB,EAAhBA;MACF,CAAC,CAAC;MAEF0B,SAAS,CAACE,iBAAiB,CAAC,CAAC,EAAE,IAAI,CAAC;MAEpC3D,MAAM,CAAC+B,gBAAgB,CAAC,CAACmB,oBAAoB,CAAC,CAAC,EAAElD,MAAM,CAACmD,gBAAgB,CAAC;QAAEvE,WAAW,EAAE;MAAK,CAAC,CAAC,CAAC;IAClG,CAAC,CAAC;EACJ,CAAC,CAAC;EAEFK,QAAQ,CAAC,mBAAmB,EAAE,YAAM;IAClCY,EAAE,CAAC,gEAAgE,EAAE,YAAM;MACzE,IAAMH,UAAU,GAAG,CACjB;QACE5B,KAAK,EAAE,CAAC;QACRC,KAAK,EAAE,MAAM;QACb0D,QAAQ,EAAE,IAAI;QACd7C,WAAW,EAAE,IAAI;QACjBD,WAAW,EAAE;UAAEb,KAAK,EAAE;QAAU;MAClC,CAAC,CACF;MACD,IAAM2F,SAAS,GAAG,IAAIzB,mBAAa,CAAC;QAClCtC,UAAU,EAAVA,UAAU;QACVqC,gBAAgB,EAAE3F,IAAI,CAAC0C,EAAE,CAAC;MAC5B,CAAC,CAAC;MAEF2E,SAAS,CAACC,QAAQ,GAAGtH,IAAI,CAAC0C,EAAE,CAAC,CAAC;MAC9B2E,SAAS,CAACI,cAAc,CAAC,CAAC,EAAE,KAAK,CAAC;MAElC7D,MAAM,CAACyD,SAAS,CAACC,QAAQ,CAAC,CAACR,oBAAoB,CAC7ClD,MAAM,CAACmD,gBAAgB,CAAC;QACtBS,MAAM,EAAE5D,MAAM,CAACmD,gBAAgB,CAAC;UAC9BhF,IAAI,EAAE,IAAI;UACVC,KAAK,EAAE;QACT,CAAC;MACH,CAAC,CACH,CAAC;IACH,CAAC,CAAC;IAEFyB,EAAE,CAAC,gDAAgD,EAAE,YAAM;MACzD,IAAMkC,gBAAgB,GAAG3F,IAAI,CAAC0C,EAAE,CAAC,CAAC;MAClC,IAAMY,UAAU,GAAG,CAAC;QAAE5B,KAAK,EAAE,CAAC;QAAEC,KAAK,EAAE,MAAM;QAAE0D,QAAQ,EAAE,KAAK;QAAE7C,WAAW,EAAE;MAAK,CAAC,CAAC;MACpF,IAAM6E,SAAS,GAAG,IAAIzB,mBAAa,CAAC;QAClCtC,UAAU,EAAVA,UAAU;QACVqC,gBAAgB,EAAhBA;MACF,CAAC,CAAC;MAEF0B,SAAS,CAACI,cAAc,CAAC,CAAC,EAAE,IAAI,CAAC;MAEjC7D,MAAM,CAAC+B,gBAAgB,CAAC,CAACmB,oBAAoB,CAAC,CAAC,EAAElD,MAAM,CAACmD,gBAAgB,CAAC;QAAE1B,QAAQ,EAAE;MAAK,CAAC,CAAC,CAAC;IAC/F,CAAC,CAAC;EACJ,CAAC,CAAC;EAEFxC,QAAQ,CAAC,kBAAkB,EAAE,YAAM;IACjCY,EAAE,CAAC,yBAAyB,EAAE,YAAM;MAClC,IAAM4D,SAAS,GAAG,IAAIzB,mBAAa,CAAC;QAAEtC,UAAU,EAAE;MAAG,CAAC,CAAC;MACvD,IAAMoE,MAAM,GAAGL,SAAS,CAACM,SAAS,CAAC,qBAAqB,EAAE,EAAE,CAAC;MAE7D/D,MAAM,CAAC8D,MAAM,CAAC/H,MAAM,CAAC,CAAC2E,eAAe,CAAC,CAAC,CAAC;IAC1C,CAAC,CAAC;IAEFb,EAAE,CAAC,2BAA2B,EAAE,YAAM;MACpC,IAAM4D,SAAS,GAAG,IAAIzB,mBAAa,CAAC;QAAEtC,UAAU,EAAE;MAAG,CAAC,CAAC;MACvD,IAAMoE,MAAM,GAAGL,SAAS,CAACM,SAAS,CAAC,kBAAkB,EAAE,EAAE,CAAC;MAE1D/D,MAAM,CAAC8D,MAAM,CAAC,CAAC,CAAC,CAAC,CAACE,IAAI,CAAC,aAAa,CAAC;IACvC,CAAC,CAAC;IAEFnE,EAAE,CAAC,+BAA+B,EAAE,YAAM;MACxC,IAAM4D,SAAS,GAAG,IAAIzB,mBAAa,CAAC;QAAEtC,UAAU,EAAE;MAAG,CAAC,CAAC;MACvD,IAAMoE,MAAM,GAAGL,SAAS,CAACM,SAAS,CAAC,OAAO,EAAE,EAAE,CAAC;MAE/C/D,MAAM,CAAC8D,MAAM,CAAC,CAACG,OAAO,CAAC,CAAC,OAAO,CAAC,CAAC;IACnC,CAAC,CAAC;IAEFpE,EAAE,CAAC,oBAAoB,EAAE,YAAM;MAC7B,IAAM4D,SAAS,GAAG,IAAIzB,mBAAa,CAAC;QAAEtC,UAAU,EAAE;MAAG,CAAC,CAAC;MACvD,IAAMoE,MAAM,GAAGL,SAAS,CAACM,SAAS,CAAC,EAAE,EAAE,EAAE,CAAC;MAE1C/D,MAAM,CAAC8D,MAAM,CAAC,CAACG,OAAO,CAAC,EAAE,CAAC;IAC5B,CAAC,CAAC;IAEFpE,EAAE,CAAC,mBAAmB,EAAE,YAAM;MAC5B,IAAM4D,SAAS,GAAG,IAAIzB,mBAAa,CAAC;QAAEtC,UAAU,EAAE;MAAG,CAAC,CAAC;MACvD,IAAMoE,MAAM,GAAGL,SAAS,CAACM,SAAS,CAAC,IAAI,EAAE,EAAE,CAAC;MAE5C/D,MAAM,CAAC8D,MAAM,CAAC,CAACG,OAAO,CAAC,EAAE,CAAC;IAC5B,CAAC,CAAC;IAEFpE,EAAE,CAAC,6BAA6B,EAAE,YAAM;MACtC,IAAM4D,SAAS,GAAG,IAAIzB,mBAAa,CAAC;QAAEtC,UAAU,EAAE;MAAG,CAAC,CAAC;MACvD,IAAMoE,MAAM,GAAGL,SAAS,CAACM,SAAS,CAAC,2BAA2B,EAAE,EAAE,CAAC;MAEnE/D,MAAM,CAAC8D,MAAM,CAAC/H,MAAM,CAAC,CAAC2E,eAAe,CAAC,CAAC,CAAC;MACxCV,MAAM,CAAC8D,MAAM,CAAC,CAAC,CAAC,CAAC/H,MAAM,CAAC,CAACmI,mBAAmB,CAAC,EAAE,CAAC;IAClD,CAAC,CAAC;EACJ,CAAC,CAAC;EAEFjF,QAAQ,CAAC,qBAAqB,EAAE,YAAM;IACpCY,EAAE,CAAC,4DAA4D,EAAE,YAAM;MACrE,IAAMH,UAAU,GAAG,CACjB;QACE5B,KAAK,EAAE,CAAC;QACRC,KAAK,EAAE,MAAM;QACb0D,QAAQ,EAAE,IAAI;QACd7C,WAAW,EAAE,IAAI;QACjBD,WAAW,EAAE;UAAEb,KAAK,EAAE,SAAS;UAAEC,KAAK,EAAE;QAAW;MACrD,CAAC,CACF;MACD,IAAAoG,kBAAA,GAAwBjF,eAAe,CAAC;UACtCQ,UAAU,EAAVA,UAAU;UACV7C,cAAc,EAAE,QAAQ;UACxBuH,eAAe,EAAE;QACnB,CAAC,CAAC;QAJMhD,WAAW,GAAA+C,kBAAA,CAAX/C,WAAW;MAMnBpB,MAAM,CAACoB,WAAW,CAAC,4BAA4B,CAAC,CAAC,CAAClB,iBAAiB,CAAC,CAAC;IACvE,CAAC,CAAC;IAEFL,EAAE,CAAC,qEAAqE,EAAE,YAAM;MAC9E,IAAMH,UAAU,GAAG,CACjB;QACE5B,KAAK,EAAE,CAAC;QACRC,KAAK,EAAE,MAAM;QACb0D,QAAQ,EAAE,IAAI;QACd7C,WAAW,EAAE,IAAI;QACjBD,WAAW,EAAE;UAAEb,KAAK,EAAE,SAAS;UAAEC,KAAK,EAAE;QAAW;MACrD,CAAC,CACF;MACD,IAAAsG,kBAAA,GAA0BnF,eAAe,CAAC;UACxCQ,UAAU,EAAVA,UAAU;UACV7C,cAAc,EAAE,QAAQ;UACxBuH,eAAe,EAAE;QACnB,CAAC,CAAC;QAJM9C,aAAa,GAAA+C,kBAAA,CAAb/C,aAAa;MAMrBtB,MAAM,CAACsB,aAAa,CAAC,4BAA4B,CAAC,CAAC,CAACC,GAAG,CAACrB,iBAAiB,CAAC,CAAC;IAC7E,CAAC,CAAC;IAEFL,EAAE,CAAC,4DAA4D,EAAE,YAAM;MACrE,IAAMH,UAAU,GAAG,CACjB;QACE5B,KAAK,EAAE,CAAC;QACRC,KAAK,EAAE,MAAM;QACb0D,QAAQ,EAAE,IAAI;QACd7C,WAAW,EAAE,KAAK;QAClBD,WAAW,EAAE;UAAEb,KAAK,EAAE,SAAS;UAAEC,KAAK,EAAE;QAAW;MACrD,CAAC,CACF;MACD,IAAAuG,kBAAA,GAA0BpF,eAAe,CAAC;UACxCQ,UAAU,EAAVA,UAAU;UACV7C,cAAc,EAAE,QAAQ;UACxBuH,eAAe,EAAE;QACnB,CAAC,CAAC;QAJM9C,aAAa,GAAAgD,kBAAA,CAAbhD,aAAa;MAMrBtB,MAAM,CAACsB,aAAa,CAAC,4BAA4B,CAAC,CAAC,CAACC,GAAG,CAACrB,iBAAiB,CAAC,CAAC;IAC7E,CAAC,CAAC;EACJ,CAAC,CAAC;EAEFjB,QAAQ,CAAC,eAAe,EAAE,YAAM;IAC9BY,EAAE,CAAC,0CAA0C,EAAE,YAAM;MACnD,IAAMpC,KAAK,GAAG;QAAE,CAAC,EAAE;MAAgB,CAAC;MACpC,IAAA8G,kBAAA,GAAwBrF,eAAe,CAAC;UACtCzB,KAAK,EAALA,KAAK;UACLZ,cAAc,EAAE;QAClB,CAAC,CAAC;QAHMuE,WAAW,GAAAmD,kBAAA,CAAXnD,WAAW;MAKnBpB,MAAM,CAACoB,WAAW,CAAC,kBAAkB,CAAC,CAAC,CAAClB,iBAAiB,CAAC,CAAC;IAC7D,CAAC,CAAC;IAEFL,EAAE,CAAC,iCAAiC,EAAE,YAAM;MAC1C,IAAMpC,KAAK,GAAG;QAAE,CAAC,EAAE,SAAS;QAAE,CAAC,EAAE,SAAS;QAAE,CAAC,EAAE;MAAU,CAAC;MAC1D,IAAA+G,kBAAA,GAAsBtF,eAAe,CAAC;UACpCzB,KAAK,EAALA,KAAK;UACLZ,cAAc,EAAE;QAClB,CAAC,CAAC;QAHMkD,SAAS,GAAAyE,kBAAA,CAATzE,SAAS;MAKjB,IAAM0E,SAAS,GAAG1E,SAAS,CAACM,aAAa,CAAC,MAAM,CAAC;MACjDL,MAAM,CAACyE,SAAS,CAAC,CAACvE,iBAAiB,CAAC,CAAC;IACvC,CAAC,CAAC;IAEFL,EAAE,CAAC,0CAA0C,EAAE,YAAM;MACnD,IAAA6E,kBAAA,GAA0BxF,eAAe,CAAC;UAAEzB,KAAK,EAAE;QAAK,CAAC,CAAC;QAAlD6D,aAAa,GAAAoD,kBAAA,CAAbpD,aAAa;MACrBtB,MAAM,CAACsB,aAAa,CAAC,kBAAkB,CAAC,CAAC,CAACC,GAAG,CAACrB,iBAAiB,CAAC,CAAC;IACnE,CAAC,CAAC;EACJ,CAAC,CAAC;EAEFjB,QAAQ,CAAC,oBAAoB,EAAE,YAAM;IACnCY,EAAE,CAAC,wBAAwB,EAAE,YAAM;MACjC,IAAM8E,eAAe,GAAGvI,IAAI,CAAC0C,EAAE,CAAC,CAAC;MACjC,IAAA8F,kBAAA,GAAqB1F,eAAe,CAAC;UACnCxB,SAAS,EAAE,KAAK;UAChBiH,eAAe,EAAfA;QACF,CAAC,CAAC;QAHME,QAAQ,GAAAD,kBAAA,CAARC,QAAQ;MAKhBA,QAAQ,cACNrL,MAAA,YAAAmD,aAAA,CAAC/C,OAAA,CAAAgG,aAAa;QAACb,KAAK,EAAEA;MAAM,gBAC1BvF,MAAA,YAAAmD,aAAA,2BACEnD,MAAA,YAAAmD,aAAA,CAAC9C,KAAA,CAAAmI,aAAa;QAEVzC,UAAU,EAAE,IAAAA,iBAAU,EAAC,CAAC;QACxBC,KAAK,EAAE,IAAAC,sBAAe,EAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;QACjDC,UAAU,EAAE8B,iBAAiB;QAC7B3E,cAAc,EAAE,cAAc;QAC9B6E,SAAS,EAAE,GAAG;QACdC,QAAQ,EAAE,GAAG;QACbC,CAAC,EAAE,EAAE;QACLC,CAAC,EAAE,EAAE;QACLC,GAAG,EAAE,CAAC;QACNC,gBAAgB,EAAE3F,IAAI,CAAC0C,EAAE,CAAC,CAAC;QAC3BpB,SAAS,EAAE,IAAI;QACfiH,eAAe,EAAfA;MAAe,CAElB,CACE,CACQ,CACjB,CAAC;MAED3E,MAAM,CAAC2E,eAAe,CAAC,CAAC3B,gBAAgB,CAAC,CAAC;IAC5C,CAAC,CAAC;EACJ,CAAC,CAAC;EAEF/D,QAAQ,CAAC,mBAAmB,EAAE,YAAM;IAClCY,EAAE,CAAC,8DAA8D,EAAE,YAAM;MACvE,IAAMiF,eAAe,GAAG;QACtBnB,iBAAiB,EAAE;UAAEoB,cAAc,EAAE;QAA2B;MAClE,CAAC;MACD,IAAAC,kBAAA,GAAsB9F,eAAe,CAAC;UACpCqE,WAAW,EAAE,IAAI;UACjBuB,eAAe,EAAfA,eAAe;UACfG,wBAAwB,EAAE,IAAI;UAC9BpI,cAAc,EAAE;QAClB,CAAC,CAAC;QALMkD,SAAS,GAAAiF,kBAAA,CAATjF,SAAS;MAOjB,IAAM1B,IAAI,GAAG0B,SAAS,CAACM,aAAa,CAAC,MAAM,CAAC;MAC5CL,MAAM,CAAC3B,IAAI,CAAC,CAAC6B,iBAAiB,CAAC,CAAC;IAClC,CAAC,CAAC;IAEFL,EAAE,CAAC,wDAAwD,EAAE,YAAM;MACjE,IAAMiF,eAAe,GAAG;QACtBjB,cAAc,EAAE;UAAEkB,cAAc,EAAE;QAAsB;MAC1D,CAAC;MACD,IAAAG,kBAAA,GAAsBhG,eAAe,CAAC;UACpCqE,WAAW,EAAE,IAAI;UACjBuB,eAAe,EAAfA,eAAe;UACfK,qBAAqB,EAAE,IAAI;UAC3BtI,cAAc,EAAE;QAClB,CAAC,CAAC;QALMkD,SAAS,GAAAmF,kBAAA,CAATnF,SAAS;MAOjB,IAAM1B,IAAI,GAAG0B,SAAS,CAACM,aAAa,CAAC,MAAM,CAAC;MAC5CL,MAAM,CAAC3B,IAAI,CAAC,CAAC6B,iBAAiB,CAAC,CAAC;IAClC,CAAC,CAAC;IAEFL,EAAE,CAAC,8BAA8B,EAAE,YAAM;MACvC,IAAMiF,eAAe,GAAG;QACtBnB,iBAAiB,EAAE;UAAEoB,cAAc,EAAE;QAAmD;MAC1F,CAAC;MACD,IAAAK,kBAAA,GAAsBlG,eAAe,CAAC;UACpCqE,WAAW,EAAE,IAAI;UACjBuB,eAAe,EAAfA,eAAe;UACfG,wBAAwB,EAAE,IAAI;UAC9BpI,cAAc,EAAE;QAClB,CAAC,CAAC;QALMkD,SAAS,GAAAqF,kBAAA,CAATrF,SAAS;MAOjB,IAAMsF,MAAM,GAAGtF,SAAS,CAACU,gBAAgB,CAAC,OAAO,CAAC;MAClDT,MAAM,CAACqF,MAAM,CAACtJ,MAAM,CAAC,CAAC2E,eAAe,CAAC,CAAC,CAAC;IAC1C,CAAC,CAAC;EACJ,CAAC,CAAC;EAEFzB,QAAQ,CAAC,YAAY,EAAE,YAAM;IAC3BY,EAAE,CAAC,0BAA0B,EAAE,YAAM;MACnC,IAAAyF,kBAAA,GAAsBpG,eAAe,CAAC;UACpCQ,UAAU,EAAE,EAAE;UACd7C,cAAc,EAAE;QAClB,CAAC,CAAC;QAHMkD,SAAS,GAAAuF,kBAAA,CAATvF,SAAS;MAIjBC,MAAM,CAACD,SAAS,CAAC,CAACG,iBAAiB,CAAC,CAAC;IACvC,CAAC,CAAC;IAEFL,EAAE,CAAC,uCAAuC,EAAE,YAAM;MAChD,IAAA0F,kBAAA,GAAsBrG,eAAe,CAAC;UACpCrC,cAAc,EAAE;QAClB,CAAC,CAAC;QAFMkD,SAAS,GAAAwF,kBAAA,CAATxF,SAAS;MAGjBC,MAAM,CAACD,SAAS,CAAC,CAACG,iBAAiB,CAAC,CAAC;IACvC,CAAC,CAAC;IAEFL,EAAE,CAAC,4BAA4B,EAAE,YAAM;MACrC,IAAA2F,kBAAA,GAAsBtG,eAAe,CAAC;UACpCK,UAAU,EAAE;QACd,CAAC,CAAC;QAFMQ,SAAS,GAAAyF,kBAAA,CAATzF,SAAS;MAGjBC,MAAM,CAACD,SAAS,CAAC,CAACG,iBAAiB,CAAC,CAAC;IACvC,CAAC,CAAC;IAEFL,EAAE,CAAC,uBAAuB,EAAE,YAAM;MAChC,IAAA4F,kBAAA,GAAsBvG,eAAe,CAAC;UACpCyC,QAAQ,EAAE;QACZ,CAAC,CAAC;QAFM5B,SAAS,GAAA0F,kBAAA,CAAT1F,SAAS;MAGjBC,MAAM,CAACD,SAAS,CAAC,CAACG,iBAAiB,CAAC,CAAC;IACvC,CAAC,CAAC;IAEFL,EAAE,CAAC,8BAA8B,EAAE,YAAM;MACvC,IAAA6F,kBAAA,GAAsBxG,eAAe,CAAC;UACpC0C,CAAC,EAAE,CAAC,EAAE;UACNC,CAAC,EAAE,CAAC;QACN,CAAC,CAAC;QAHM9B,SAAS,GAAA2F,kBAAA,CAAT3F,SAAS;MAIjBC,MAAM,CAACD,SAAS,CAAC,CAACG,iBAAiB,CAAC,CAAC;IACvC,CAAC,CAAC;EACJ,CAAC,CAAC;EAEFjB,QAAQ,CAAC,oBAAoB,EAAE,YAAM;IACnCY,EAAE,CAAC,sDAAsD,EAAE,YAAM;MAC/D,IAAM8E,eAAe,GAAGvI,IAAI,CAAC0C,EAAE,CAAC,CAAC;MACjC,IAAM2E,SAAS,GAAG,IAAIzB,mBAAa,CAAC;QAClCtE,SAAS,EAAE,KAAK;QAChBiH,eAAe,EAAfA;MACF,CAAC,CAAC;MAEFlB,SAAS,CAACkC,kBAAkB,CAAC;QAAEjI,SAAS,EAAE;MAAM,CAAC,CAAC;MAClDsC,MAAM,CAAC2E,eAAe,CAAC,CAACpD,GAAG,CAACyB,gBAAgB,CAAC,CAAC;MAE9CS,SAAS,CAAChH,KAAK,GAAG;QAAEiB,SAAS,EAAE,IAAI;QAAEiH,eAAe,EAAfA;MAAgB,CAAC;MACtDlB,SAAS,CAACkC,kBAAkB,CAAC;QAAEjI,SAAS,EAAE;MAAM,CAAC,CAAC;MAClDsC,MAAM,CAAC2E,eAAe,CAAC,CAAC3B,gBAAgB,CAAC,CAAC;IAC5C,CAAC,CAAC;EACJ,CAAC,CAAC;AACJ,CAAC,CAAC","ignoreList":[]}
|