@pie-lib/charting 6.2.0-next.2 → 6.2.0-next.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +23 -37
- package/LICENSE.md +5 -0
- package/lib/actions-button.js +1 -1
- package/lib/axes.js +1 -1
- package/lib/bars/bar.js +1 -1
- 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/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/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/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 +3 -3
- package/lib/__tests__/actions-button.test.js +0 -332
- package/lib/__tests__/axes.test.js +0 -746
- package/lib/__tests__/chart-setup.test.js +0 -796
- package/lib/__tests__/chart-type.test.js +0 -25
- package/lib/__tests__/chart.test.js +0 -103
- package/lib/__tests__/grid.test.js +0 -39
- package/lib/__tests__/key-legend.test.js +0 -235
- package/lib/__tests__/mark-label.test.js +0 -46
- package/lib/__tests__/tool-menu.test.js +0 -627
- package/lib/__tests__/utils.js +0 -56
- package/lib/__tests__/utils.test.js +0 -186
- package/lib/bars/__tests__/bar.test.js +0 -53
- package/lib/bars/__tests__/histogram.test.js +0 -53
- package/lib/bars/__tests__/utils.js +0 -50
- package/lib/bars/common/__tests__/bars.test.js +0 -76
- package/lib/bars/common/__tests__/utils.js +0 -50
- package/lib/common/__tests__/correctness-indicators.test.js +0 -887
- package/lib/common/__tests__/drag-handle.test.js +0 -73
- package/lib/common/__tests__/utils.js +0 -50
- package/lib/line/__tests__/line-cross.test.js +0 -617
- package/lib/line/__tests__/line-dot.test.js +0 -47
- package/lib/line/__tests__/utils.js +0 -56
- package/lib/line/common/__tests__/drag-handle.test.js +0 -73
- package/lib/line/common/__tests__/line.test.js +0 -92
- package/lib/line/common/__tests__/utils.js +0 -50
- package/lib/plot/__tests__/dot.test.js +0 -513
- package/lib/plot/__tests__/line.test.js +0 -566
- package/lib/plot/__tests__/utils.js +0 -50
- package/lib/plot/common/__tests__/plot.test.js +0 -79
- package/lib/plot/common/__tests__/utils.js +0 -50
|
@@ -1,627 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
5
|
-
var _react = _interopRequireDefault(require("react"));
|
|
6
|
-
var _react2 = require("@testing-library/react");
|
|
7
|
-
var _styles = require("@mui/material/styles");
|
|
8
|
-
var _toolMenu = require("../tool-menu");
|
|
9
|
-
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; }
|
|
10
|
-
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; }
|
|
11
|
-
jest.mock('@pie-lib/translator', function () {
|
|
12
|
-
return {
|
|
13
|
-
__esModule: true,
|
|
14
|
-
"default": {
|
|
15
|
-
translator: {
|
|
16
|
-
t: jest.fn(function (key, options) {
|
|
17
|
-
var translations = {
|
|
18
|
-
'charting.addCategory': 'Add Category'
|
|
19
|
-
};
|
|
20
|
-
return translations[key] || key;
|
|
21
|
-
})
|
|
22
|
-
}
|
|
23
|
-
}
|
|
24
|
-
};
|
|
25
|
-
});
|
|
26
|
-
jest.mock('@pie-lib/render-ui', function () {
|
|
27
|
-
return {
|
|
28
|
-
color: {
|
|
29
|
-
text: function text() {
|
|
30
|
-
return '#000000';
|
|
31
|
-
},
|
|
32
|
-
secondary: function secondary() {
|
|
33
|
-
return '#cccccc';
|
|
34
|
-
},
|
|
35
|
-
background: function background() {
|
|
36
|
-
return '#ffffff';
|
|
37
|
-
},
|
|
38
|
-
primary: function primary() {
|
|
39
|
-
return '#0000ff';
|
|
40
|
-
},
|
|
41
|
-
primaryDark: function primaryDark() {
|
|
42
|
-
return '#000080';
|
|
43
|
-
},
|
|
44
|
-
disabled: function disabled() {
|
|
45
|
-
return '#f0f0f0';
|
|
46
|
-
}
|
|
47
|
-
}
|
|
48
|
-
};
|
|
49
|
-
});
|
|
50
|
-
var theme;
|
|
51
|
-
beforeAll(function () {
|
|
52
|
-
theme = (0, _styles.createTheme)();
|
|
53
|
-
});
|
|
54
|
-
describe('MiniButton', function () {
|
|
55
|
-
var onClick = jest.fn();
|
|
56
|
-
beforeEach(function () {
|
|
57
|
-
jest.clearAllMocks();
|
|
58
|
-
});
|
|
59
|
-
var renderComponent = function renderComponent() {
|
|
60
|
-
var extras = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
61
|
-
var defaults = {
|
|
62
|
-
value: 'Test Button',
|
|
63
|
-
onClick: onClick,
|
|
64
|
-
disabled: false,
|
|
65
|
-
selected: false
|
|
66
|
-
};
|
|
67
|
-
var props = _objectSpread(_objectSpread({}, defaults), extras);
|
|
68
|
-
return (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_styles.ThemeProvider, {
|
|
69
|
-
theme: theme
|
|
70
|
-
}, /*#__PURE__*/_react["default"].createElement(_toolMenu.MiniButton, props)));
|
|
71
|
-
};
|
|
72
|
-
describe('rendering', function () {
|
|
73
|
-
it('should render with value text', function () {
|
|
74
|
-
var _renderComponent = renderComponent({
|
|
75
|
-
value: 'Click Me'
|
|
76
|
-
}),
|
|
77
|
-
getByText = _renderComponent.getByText;
|
|
78
|
-
expect(getByText('Click Me')).toBeInTheDocument();
|
|
79
|
-
});
|
|
80
|
-
it('should render as a button element', function () {
|
|
81
|
-
var _renderComponent2 = renderComponent(),
|
|
82
|
-
getByRole = _renderComponent2.getByRole;
|
|
83
|
-
expect(getByRole('button')).toBeInTheDocument();
|
|
84
|
-
});
|
|
85
|
-
it('should have correct button attributes', function () {
|
|
86
|
-
var _renderComponent3 = renderComponent({
|
|
87
|
-
value: 'Test'
|
|
88
|
-
}),
|
|
89
|
-
getByRole = _renderComponent3.getByRole;
|
|
90
|
-
var button = getByRole('button');
|
|
91
|
-
expect(button).toHaveAttribute('value', 'Test');
|
|
92
|
-
});
|
|
93
|
-
it('should render with variant outlined', function () {
|
|
94
|
-
var _renderComponent4 = renderComponent(),
|
|
95
|
-
getByRole = _renderComponent4.getByRole;
|
|
96
|
-
var button = getByRole('button');
|
|
97
|
-
expect(button).toHaveClass('MuiButton-outlined');
|
|
98
|
-
});
|
|
99
|
-
it('should render with size small', function () {
|
|
100
|
-
var _renderComponent5 = renderComponent(),
|
|
101
|
-
getByRole = _renderComponent5.getByRole;
|
|
102
|
-
var button = getByRole('button');
|
|
103
|
-
expect(button).toHaveClass('MuiButton-sizeSmall');
|
|
104
|
-
});
|
|
105
|
-
});
|
|
106
|
-
describe('disabled state', function () {
|
|
107
|
-
it('should render as disabled when disabled prop is true', function () {
|
|
108
|
-
var _renderComponent6 = renderComponent({
|
|
109
|
-
disabled: true
|
|
110
|
-
}),
|
|
111
|
-
getByRole = _renderComponent6.getByRole;
|
|
112
|
-
expect(getByRole('button')).toBeDisabled();
|
|
113
|
-
});
|
|
114
|
-
it('should not render as disabled when disabled prop is false', function () {
|
|
115
|
-
var _renderComponent7 = renderComponent({
|
|
116
|
-
disabled: false
|
|
117
|
-
}),
|
|
118
|
-
getByRole = _renderComponent7.getByRole;
|
|
119
|
-
expect(getByRole('button')).not.toBeDisabled();
|
|
120
|
-
});
|
|
121
|
-
it('should not trigger onClick when disabled', function () {
|
|
122
|
-
var _renderComponent8 = renderComponent({
|
|
123
|
-
disabled: true
|
|
124
|
-
}),
|
|
125
|
-
getByRole = _renderComponent8.getByRole;
|
|
126
|
-
_react2.fireEvent.click(getByRole('button'));
|
|
127
|
-
expect(onClick).not.toHaveBeenCalled();
|
|
128
|
-
});
|
|
129
|
-
});
|
|
130
|
-
describe('selected state', function () {
|
|
131
|
-
it('should apply selected styling when selected is true', function () {
|
|
132
|
-
var _renderComponent9 = renderComponent({
|
|
133
|
-
selected: true
|
|
134
|
-
}),
|
|
135
|
-
getByRole = _renderComponent9.getByRole;
|
|
136
|
-
var button = getByRole('button');
|
|
137
|
-
expect(button.className).toContain('MuiButton-colorSecondary');
|
|
138
|
-
});
|
|
139
|
-
it('should apply default color when selected is false', function () {
|
|
140
|
-
var _renderComponent0 = renderComponent({
|
|
141
|
-
selected: false
|
|
142
|
-
}),
|
|
143
|
-
getByRole = _renderComponent0.getByRole;
|
|
144
|
-
var button = getByRole('button');
|
|
145
|
-
expect(button.className).toContain('MuiButton-colorDefault');
|
|
146
|
-
});
|
|
147
|
-
it('should render correctly with both selected and disabled', function () {
|
|
148
|
-
var _renderComponent1 = renderComponent({
|
|
149
|
-
selected: true,
|
|
150
|
-
disabled: true
|
|
151
|
-
}),
|
|
152
|
-
getByRole = _renderComponent1.getByRole;
|
|
153
|
-
var button = getByRole('button');
|
|
154
|
-
expect(button).toBeDisabled();
|
|
155
|
-
expect(button.className).toContain('MuiButton-colorSecondary');
|
|
156
|
-
});
|
|
157
|
-
});
|
|
158
|
-
describe('interactions', function () {
|
|
159
|
-
it('should call onClick when clicked', function () {
|
|
160
|
-
var _renderComponent10 = renderComponent(),
|
|
161
|
-
getByRole = _renderComponent10.getByRole;
|
|
162
|
-
_react2.fireEvent.click(getByRole('button'));
|
|
163
|
-
expect(onClick).toHaveBeenCalledTimes(1);
|
|
164
|
-
});
|
|
165
|
-
it('should call onClick with correct event when clicked', function () {
|
|
166
|
-
var _renderComponent11 = renderComponent(),
|
|
167
|
-
getByRole = _renderComponent11.getByRole;
|
|
168
|
-
var button = getByRole('button');
|
|
169
|
-
_react2.fireEvent.click(button);
|
|
170
|
-
expect(onClick).toHaveBeenCalled();
|
|
171
|
-
expect(onClick.mock.calls[0][0]).toBeTruthy();
|
|
172
|
-
});
|
|
173
|
-
it('should handle multiple clicks', function () {
|
|
174
|
-
var _renderComponent12 = renderComponent(),
|
|
175
|
-
getByRole = _renderComponent12.getByRole;
|
|
176
|
-
var button = getByRole('button');
|
|
177
|
-
_react2.fireEvent.click(button);
|
|
178
|
-
_react2.fireEvent.click(button);
|
|
179
|
-
_react2.fireEvent.click(button);
|
|
180
|
-
expect(onClick).toHaveBeenCalledTimes(3);
|
|
181
|
-
});
|
|
182
|
-
it('should handle rapid clicks', function () {
|
|
183
|
-
var _renderComponent13 = renderComponent(),
|
|
184
|
-
getByRole = _renderComponent13.getByRole;
|
|
185
|
-
var button = getByRole('button');
|
|
186
|
-
for (var i = 0; i < 10; i++) {
|
|
187
|
-
_react2.fireEvent.click(button);
|
|
188
|
-
}
|
|
189
|
-
expect(onClick).toHaveBeenCalledTimes(10);
|
|
190
|
-
});
|
|
191
|
-
});
|
|
192
|
-
describe('edge cases', function () {
|
|
193
|
-
it('should render with empty string value', function () {
|
|
194
|
-
var _renderComponent14 = renderComponent({
|
|
195
|
-
value: ''
|
|
196
|
-
}),
|
|
197
|
-
getByRole = _renderComponent14.getByRole;
|
|
198
|
-
expect(getByRole('button')).toBeInTheDocument();
|
|
199
|
-
});
|
|
200
|
-
it('should render with undefined onClick', function () {
|
|
201
|
-
var _render = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_styles.ThemeProvider, {
|
|
202
|
-
theme: theme
|
|
203
|
-
}, /*#__PURE__*/_react["default"].createElement(_toolMenu.MiniButton, {
|
|
204
|
-
value: "Test",
|
|
205
|
-
onClick: undefined
|
|
206
|
-
}))),
|
|
207
|
-
getByRole = _render.getByRole;
|
|
208
|
-
expect(getByRole('button')).toBeInTheDocument();
|
|
209
|
-
});
|
|
210
|
-
it('should render with null onClick', function () {
|
|
211
|
-
var _render2 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_styles.ThemeProvider, {
|
|
212
|
-
theme: theme
|
|
213
|
-
}, /*#__PURE__*/_react["default"].createElement(_toolMenu.MiniButton, {
|
|
214
|
-
value: "Test",
|
|
215
|
-
onClick: null
|
|
216
|
-
}))),
|
|
217
|
-
getByRole = _render2.getByRole;
|
|
218
|
-
expect(getByRole('button')).toBeInTheDocument();
|
|
219
|
-
});
|
|
220
|
-
it('should render with very long value text', function () {
|
|
221
|
-
var longText = 'This is a very long button text that might cause layout issues';
|
|
222
|
-
var _renderComponent15 = renderComponent({
|
|
223
|
-
value: longText
|
|
224
|
-
}),
|
|
225
|
-
getByText = _renderComponent15.getByText;
|
|
226
|
-
expect(getByText(longText)).toBeInTheDocument();
|
|
227
|
-
});
|
|
228
|
-
it('should render with special characters in value', function () {
|
|
229
|
-
var specialText = 'Test <>&"\'';
|
|
230
|
-
var _renderComponent16 = renderComponent({
|
|
231
|
-
value: specialText
|
|
232
|
-
}),
|
|
233
|
-
getByText = _renderComponent16.getByText;
|
|
234
|
-
expect(getByText(specialText)).toBeInTheDocument();
|
|
235
|
-
});
|
|
236
|
-
it('should render with unicode characters in value', function () {
|
|
237
|
-
var unicodeText = 'Test 你好 🎉';
|
|
238
|
-
var _renderComponent17 = renderComponent({
|
|
239
|
-
value: unicodeText
|
|
240
|
-
}),
|
|
241
|
-
getByText = _renderComponent17.getByText;
|
|
242
|
-
expect(getByText(unicodeText)).toBeInTheDocument();
|
|
243
|
-
});
|
|
244
|
-
});
|
|
245
|
-
describe('className prop', function () {
|
|
246
|
-
it('should accept className prop without error', function () {
|
|
247
|
-
var _render3 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_styles.ThemeProvider, {
|
|
248
|
-
theme: theme
|
|
249
|
-
}, /*#__PURE__*/_react["default"].createElement(_toolMenu.MiniButton, {
|
|
250
|
-
value: "Test",
|
|
251
|
-
onClick: onClick,
|
|
252
|
-
className: "custom-class"
|
|
253
|
-
}))),
|
|
254
|
-
getByRole = _render3.getByRole;
|
|
255
|
-
expect(getByRole('button')).toBeInTheDocument();
|
|
256
|
-
});
|
|
257
|
-
});
|
|
258
|
-
});
|
|
259
|
-
describe('ToolMenu', function () {
|
|
260
|
-
var addCategory = jest.fn();
|
|
261
|
-
beforeEach(function () {
|
|
262
|
-
jest.clearAllMocks();
|
|
263
|
-
});
|
|
264
|
-
var renderComponent = function renderComponent() {
|
|
265
|
-
var extras = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
266
|
-
var defaults = {
|
|
267
|
-
addCategory: addCategory,
|
|
268
|
-
disabled: false,
|
|
269
|
-
language: 'en'
|
|
270
|
-
};
|
|
271
|
-
var props = _objectSpread(_objectSpread({}, defaults), extras);
|
|
272
|
-
return (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_styles.ThemeProvider, {
|
|
273
|
-
theme: theme
|
|
274
|
-
}, /*#__PURE__*/_react["default"].createElement(_toolMenu.ToolMenu, props)));
|
|
275
|
-
};
|
|
276
|
-
describe('rendering', function () {
|
|
277
|
-
it('should render without crashing', function () {
|
|
278
|
-
var _renderComponent18 = renderComponent(),
|
|
279
|
-
container = _renderComponent18.container;
|
|
280
|
-
expect(container).toBeInTheDocument();
|
|
281
|
-
});
|
|
282
|
-
it('should render a div container', function () {
|
|
283
|
-
var _renderComponent19 = renderComponent(),
|
|
284
|
-
container = _renderComponent19.container;
|
|
285
|
-
expect(container.firstChild).toBeInstanceOf(HTMLDivElement);
|
|
286
|
-
});
|
|
287
|
-
it('should render MiniButton when not disabled', function () {
|
|
288
|
-
var _renderComponent20 = renderComponent({
|
|
289
|
-
disabled: false
|
|
290
|
-
}),
|
|
291
|
-
getByRole = _renderComponent20.getByRole;
|
|
292
|
-
expect(getByRole('button')).toBeInTheDocument();
|
|
293
|
-
});
|
|
294
|
-
it('should not render MiniButton when disabled', function () {
|
|
295
|
-
var _renderComponent21 = renderComponent({
|
|
296
|
-
disabled: true
|
|
297
|
-
}),
|
|
298
|
-
queryByRole = _renderComponent21.queryByRole;
|
|
299
|
-
expect(queryByRole('button')).not.toBeInTheDocument();
|
|
300
|
-
});
|
|
301
|
-
it('should render translated button text', function () {
|
|
302
|
-
var _renderComponent22 = renderComponent(),
|
|
303
|
-
getByText = _renderComponent22.getByText;
|
|
304
|
-
expect(getByText('Add Category')).toBeInTheDocument();
|
|
305
|
-
});
|
|
306
|
-
it('should use language prop for translation', function () {
|
|
307
|
-
var Translator = require('@pie-lib/translator')["default"];
|
|
308
|
-
var _renderComponent23 = renderComponent({
|
|
309
|
-
language: 'es'
|
|
310
|
-
}),
|
|
311
|
-
getByRole = _renderComponent23.getByRole;
|
|
312
|
-
expect(getByRole('button')).toBeInTheDocument();
|
|
313
|
-
expect(Translator.translator.t).toHaveBeenCalledWith('charting.addCategory', {
|
|
314
|
-
lng: 'es'
|
|
315
|
-
});
|
|
316
|
-
});
|
|
317
|
-
});
|
|
318
|
-
describe('className prop', function () {
|
|
319
|
-
it('should apply custom className to container', function () {
|
|
320
|
-
var _renderComponent24 = renderComponent({
|
|
321
|
-
className: 'custom-tool-menu'
|
|
322
|
-
}),
|
|
323
|
-
container = _renderComponent24.container;
|
|
324
|
-
expect(container.firstChild).toHaveClass('custom-tool-menu');
|
|
325
|
-
});
|
|
326
|
-
it('should render without className', function () {
|
|
327
|
-
var _renderComponent25 = renderComponent({
|
|
328
|
-
className: undefined
|
|
329
|
-
}),
|
|
330
|
-
container = _renderComponent25.container;
|
|
331
|
-
expect(container.firstChild).toBeInTheDocument();
|
|
332
|
-
});
|
|
333
|
-
it('should handle empty string className', function () {
|
|
334
|
-
var _renderComponent26 = renderComponent({
|
|
335
|
-
className: ''
|
|
336
|
-
}),
|
|
337
|
-
container = _renderComponent26.container;
|
|
338
|
-
expect(container.firstChild).toBeInTheDocument();
|
|
339
|
-
});
|
|
340
|
-
});
|
|
341
|
-
describe('disabled state', function () {
|
|
342
|
-
it('should hide button when disabled is true', function () {
|
|
343
|
-
var _renderComponent27 = renderComponent({
|
|
344
|
-
disabled: true
|
|
345
|
-
}),
|
|
346
|
-
queryByRole = _renderComponent27.queryByRole;
|
|
347
|
-
expect(queryByRole('button')).not.toBeInTheDocument();
|
|
348
|
-
});
|
|
349
|
-
it('should show button when disabled is false', function () {
|
|
350
|
-
var _renderComponent28 = renderComponent({
|
|
351
|
-
disabled: false
|
|
352
|
-
}),
|
|
353
|
-
getByRole = _renderComponent28.getByRole;
|
|
354
|
-
expect(getByRole('button')).toBeInTheDocument();
|
|
355
|
-
});
|
|
356
|
-
it('should show button when disabled is undefined', function () {
|
|
357
|
-
var _renderComponent29 = renderComponent({
|
|
358
|
-
disabled: undefined
|
|
359
|
-
}),
|
|
360
|
-
getByRole = _renderComponent29.getByRole;
|
|
361
|
-
expect(getByRole('button')).toBeInTheDocument();
|
|
362
|
-
});
|
|
363
|
-
it('should hide button when disabled is explicitly true', function () {
|
|
364
|
-
var _renderComponent30 = renderComponent({
|
|
365
|
-
disabled: true
|
|
366
|
-
}),
|
|
367
|
-
queryByRole = _renderComponent30.queryByRole;
|
|
368
|
-
expect(queryByRole('button')).toBeNull();
|
|
369
|
-
});
|
|
370
|
-
});
|
|
371
|
-
describe('addCategory functionality', function () {
|
|
372
|
-
it('should call addCategory when button is clicked', function () {
|
|
373
|
-
var _renderComponent31 = renderComponent(),
|
|
374
|
-
getByRole = _renderComponent31.getByRole;
|
|
375
|
-
_react2.fireEvent.click(getByRole('button'));
|
|
376
|
-
expect(addCategory).toHaveBeenCalledTimes(1);
|
|
377
|
-
});
|
|
378
|
-
it('should not call addCategory when disabled', function () {
|
|
379
|
-
var _renderComponent32 = renderComponent({
|
|
380
|
-
disabled: true
|
|
381
|
-
}),
|
|
382
|
-
queryByRole = _renderComponent32.queryByRole;
|
|
383
|
-
expect(queryByRole('button')).not.toBeInTheDocument();
|
|
384
|
-
expect(addCategory).not.toHaveBeenCalled();
|
|
385
|
-
});
|
|
386
|
-
it('should handle multiple clicks on add category button', function () {
|
|
387
|
-
var _renderComponent33 = renderComponent(),
|
|
388
|
-
getByRole = _renderComponent33.getByRole;
|
|
389
|
-
var button = getByRole('button');
|
|
390
|
-
_react2.fireEvent.click(button);
|
|
391
|
-
_react2.fireEvent.click(button);
|
|
392
|
-
_react2.fireEvent.click(button);
|
|
393
|
-
expect(addCategory).toHaveBeenCalledTimes(3);
|
|
394
|
-
});
|
|
395
|
-
it('should render with undefined addCategory without crashing', function () {
|
|
396
|
-
var _render4 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_styles.ThemeProvider, {
|
|
397
|
-
theme: theme
|
|
398
|
-
}, /*#__PURE__*/_react["default"].createElement(_toolMenu.ToolMenu, {
|
|
399
|
-
addCategory: undefined,
|
|
400
|
-
language: "en"
|
|
401
|
-
}))),
|
|
402
|
-
container = _render4.container;
|
|
403
|
-
expect(container).toBeInTheDocument();
|
|
404
|
-
});
|
|
405
|
-
});
|
|
406
|
-
describe('language prop', function () {
|
|
407
|
-
it('should pass language to translator', function () {
|
|
408
|
-
var Translator = require('@pie-lib/translator')["default"];
|
|
409
|
-
renderComponent({
|
|
410
|
-
language: 'fr'
|
|
411
|
-
});
|
|
412
|
-
expect(Translator.translator.t).toHaveBeenCalledWith('charting.addCategory', {
|
|
413
|
-
lng: 'fr'
|
|
414
|
-
});
|
|
415
|
-
});
|
|
416
|
-
it('should handle default english language', function () {
|
|
417
|
-
var Translator = require('@pie-lib/translator')["default"];
|
|
418
|
-
renderComponent({
|
|
419
|
-
language: 'en'
|
|
420
|
-
});
|
|
421
|
-
expect(Translator.translator.t).toHaveBeenCalledWith('charting.addCategory', {
|
|
422
|
-
lng: 'en'
|
|
423
|
-
});
|
|
424
|
-
});
|
|
425
|
-
it('should handle undefined language', function () {
|
|
426
|
-
var Translator = require('@pie-lib/translator')["default"];
|
|
427
|
-
renderComponent({
|
|
428
|
-
language: undefined
|
|
429
|
-
});
|
|
430
|
-
expect(Translator.translator.t).toHaveBeenCalledWith('charting.addCategory', {
|
|
431
|
-
lng: undefined
|
|
432
|
-
});
|
|
433
|
-
});
|
|
434
|
-
it('should handle empty string language', function () {
|
|
435
|
-
var Translator = require('@pie-lib/translator')["default"];
|
|
436
|
-
renderComponent({
|
|
437
|
-
language: ''
|
|
438
|
-
});
|
|
439
|
-
expect(Translator.translator.t).toHaveBeenCalledWith('charting.addCategory', {
|
|
440
|
-
lng: ''
|
|
441
|
-
});
|
|
442
|
-
});
|
|
443
|
-
it('should handle non-standard language codes', function () {
|
|
444
|
-
var Translator = require('@pie-lib/translator')["default"];
|
|
445
|
-
renderComponent({
|
|
446
|
-
language: 'zh-CN'
|
|
447
|
-
});
|
|
448
|
-
expect(Translator.translator.t).toHaveBeenCalledWith('charting.addCategory', {
|
|
449
|
-
lng: 'zh-CN'
|
|
450
|
-
});
|
|
451
|
-
});
|
|
452
|
-
});
|
|
453
|
-
describe('edge cases', function () {
|
|
454
|
-
it('should render with all props undefined', function () {
|
|
455
|
-
var _render5 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_styles.ThemeProvider, {
|
|
456
|
-
theme: theme
|
|
457
|
-
}, /*#__PURE__*/_react["default"].createElement(_toolMenu.ToolMenu, null))),
|
|
458
|
-
container = _render5.container;
|
|
459
|
-
expect(container).toBeInTheDocument();
|
|
460
|
-
});
|
|
461
|
-
it('should render with null props', function () {
|
|
462
|
-
var _render6 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_styles.ThemeProvider, {
|
|
463
|
-
theme: theme
|
|
464
|
-
}, /*#__PURE__*/_react["default"].createElement(_toolMenu.ToolMenu, {
|
|
465
|
-
addCategory: null,
|
|
466
|
-
disabled: null,
|
|
467
|
-
language: null
|
|
468
|
-
}))),
|
|
469
|
-
container = _render6.container;
|
|
470
|
-
expect(container).toBeInTheDocument();
|
|
471
|
-
});
|
|
472
|
-
it('should handle component unmounting', function () {
|
|
473
|
-
var _renderComponent34 = renderComponent(),
|
|
474
|
-
unmount = _renderComponent34.unmount;
|
|
475
|
-
expect(function () {
|
|
476
|
-
return unmount();
|
|
477
|
-
}).not.toThrow();
|
|
478
|
-
});
|
|
479
|
-
it('should handle re-rendering with different props', function () {
|
|
480
|
-
var _renderComponent35 = renderComponent({
|
|
481
|
-
disabled: false
|
|
482
|
-
}),
|
|
483
|
-
rerender = _renderComponent35.rerender,
|
|
484
|
-
getByRole = _renderComponent35.getByRole,
|
|
485
|
-
queryByRole = _renderComponent35.queryByRole;
|
|
486
|
-
expect(getByRole('button')).toBeInTheDocument();
|
|
487
|
-
rerender(/*#__PURE__*/_react["default"].createElement(_styles.ThemeProvider, {
|
|
488
|
-
theme: theme
|
|
489
|
-
}, /*#__PURE__*/_react["default"].createElement(_toolMenu.ToolMenu, {
|
|
490
|
-
addCategory: addCategory,
|
|
491
|
-
disabled: true,
|
|
492
|
-
language: "en"
|
|
493
|
-
})));
|
|
494
|
-
expect(queryByRole('button')).not.toBeInTheDocument();
|
|
495
|
-
rerender(/*#__PURE__*/_react["default"].createElement(_styles.ThemeProvider, {
|
|
496
|
-
theme: theme
|
|
497
|
-
}, /*#__PURE__*/_react["default"].createElement(_toolMenu.ToolMenu, {
|
|
498
|
-
addCategory: addCategory,
|
|
499
|
-
disabled: false,
|
|
500
|
-
language: "es"
|
|
501
|
-
})));
|
|
502
|
-
expect(getByRole('button')).toBeInTheDocument();
|
|
503
|
-
});
|
|
504
|
-
it('should handle rapid prop changes', function () {
|
|
505
|
-
var _renderComponent36 = renderComponent({
|
|
506
|
-
disabled: false
|
|
507
|
-
}),
|
|
508
|
-
rerender = _renderComponent36.rerender,
|
|
509
|
-
getByRole = _renderComponent36.getByRole;
|
|
510
|
-
expect(getByRole('button')).toBeInTheDocument();
|
|
511
|
-
for (var i = 0; i < 10; i++) {
|
|
512
|
-
rerender(/*#__PURE__*/_react["default"].createElement(_styles.ThemeProvider, {
|
|
513
|
-
theme: theme
|
|
514
|
-
}, /*#__PURE__*/_react["default"].createElement(_toolMenu.ToolMenu, {
|
|
515
|
-
addCategory: addCategory,
|
|
516
|
-
disabled: i % 2 === 0,
|
|
517
|
-
language: "en"
|
|
518
|
-
})));
|
|
519
|
-
}
|
|
520
|
-
expect(getByRole('button')).toBeInTheDocument();
|
|
521
|
-
});
|
|
522
|
-
});
|
|
523
|
-
describe('component lifecycle', function () {
|
|
524
|
-
it('should render as class component', function () {
|
|
525
|
-
var _renderComponent37 = renderComponent(),
|
|
526
|
-
container = _renderComponent37.container;
|
|
527
|
-
expect(container).toBeInTheDocument();
|
|
528
|
-
});
|
|
529
|
-
it('should handle updates correctly', function () {
|
|
530
|
-
var _renderComponent38 = renderComponent({
|
|
531
|
-
language: 'en'
|
|
532
|
-
}),
|
|
533
|
-
rerender = _renderComponent38.rerender,
|
|
534
|
-
getByRole = _renderComponent38.getByRole;
|
|
535
|
-
expect(getByRole('button')).toBeInTheDocument();
|
|
536
|
-
rerender(/*#__PURE__*/_react["default"].createElement(_styles.ThemeProvider, {
|
|
537
|
-
theme: theme
|
|
538
|
-
}, /*#__PURE__*/_react["default"].createElement(_toolMenu.ToolMenu, {
|
|
539
|
-
addCategory: addCategory,
|
|
540
|
-
disabled: false,
|
|
541
|
-
language: "fr"
|
|
542
|
-
})));
|
|
543
|
-
expect(getByRole('button')).toBeInTheDocument();
|
|
544
|
-
});
|
|
545
|
-
it('should cleanup properly on unmount', function () {
|
|
546
|
-
var _renderComponent39 = renderComponent(),
|
|
547
|
-
unmount = _renderComponent39.unmount;
|
|
548
|
-
expect(function () {
|
|
549
|
-
return unmount();
|
|
550
|
-
}).not.toThrow();
|
|
551
|
-
});
|
|
552
|
-
});
|
|
553
|
-
describe('accessibility', function () {
|
|
554
|
-
it('should have accessible button element', function () {
|
|
555
|
-
var _renderComponent40 = renderComponent(),
|
|
556
|
-
getByRole = _renderComponent40.getByRole;
|
|
557
|
-
var button = getByRole('button');
|
|
558
|
-
expect(button).toBeInTheDocument();
|
|
559
|
-
});
|
|
560
|
-
it('should have button with text content', function () {
|
|
561
|
-
var _renderComponent41 = renderComponent(),
|
|
562
|
-
getByRole = _renderComponent41.getByRole;
|
|
563
|
-
var button = getByRole('button');
|
|
564
|
-
expect(button).toHaveTextContent('Add Category');
|
|
565
|
-
});
|
|
566
|
-
it('should maintain button accessibility when enabled', function () {
|
|
567
|
-
var _renderComponent42 = renderComponent({
|
|
568
|
-
disabled: false
|
|
569
|
-
}),
|
|
570
|
-
getByRole = _renderComponent42.getByRole;
|
|
571
|
-
var button = getByRole('button');
|
|
572
|
-
expect(button).not.toBeDisabled();
|
|
573
|
-
expect(button).toHaveTextContent('Add Category');
|
|
574
|
-
});
|
|
575
|
-
});
|
|
576
|
-
describe('integration', function () {
|
|
577
|
-
it('should work correctly with all props provided', function () {
|
|
578
|
-
var customAddCategory = jest.fn();
|
|
579
|
-
var _renderComponent43 = renderComponent({
|
|
580
|
-
addCategory: customAddCategory,
|
|
581
|
-
disabled: false,
|
|
582
|
-
language: 'de',
|
|
583
|
-
className: 'test-class'
|
|
584
|
-
}),
|
|
585
|
-
getByRole = _renderComponent43.getByRole;
|
|
586
|
-
var button = getByRole('button');
|
|
587
|
-
expect(button).toBeInTheDocument();
|
|
588
|
-
_react2.fireEvent.click(button);
|
|
589
|
-
expect(customAddCategory).toHaveBeenCalledTimes(1);
|
|
590
|
-
});
|
|
591
|
-
it('should toggle between enabled and disabled states', function () {
|
|
592
|
-
var _renderComponent44 = renderComponent({
|
|
593
|
-
disabled: false
|
|
594
|
-
}),
|
|
595
|
-
rerender = _renderComponent44.rerender,
|
|
596
|
-
getByRole = _renderComponent44.getByRole,
|
|
597
|
-
queryByRole = _renderComponent44.queryByRole;
|
|
598
|
-
expect(getByRole('button')).toBeInTheDocument();
|
|
599
|
-
rerender(/*#__PURE__*/_react["default"].createElement(_styles.ThemeProvider, {
|
|
600
|
-
theme: theme
|
|
601
|
-
}, /*#__PURE__*/_react["default"].createElement(_toolMenu.ToolMenu, {
|
|
602
|
-
addCategory: addCategory,
|
|
603
|
-
disabled: true,
|
|
604
|
-
language: "en"
|
|
605
|
-
})));
|
|
606
|
-
expect(queryByRole('button')).not.toBeInTheDocument();
|
|
607
|
-
});
|
|
608
|
-
it('should handle language switching', function () {
|
|
609
|
-
var Translator = require('@pie-lib/translator')["default"];
|
|
610
|
-
var _renderComponent45 = renderComponent({
|
|
611
|
-
language: 'en'
|
|
612
|
-
}),
|
|
613
|
-
rerender = _renderComponent45.rerender;
|
|
614
|
-
rerender(/*#__PURE__*/_react["default"].createElement(_styles.ThemeProvider, {
|
|
615
|
-
theme: theme
|
|
616
|
-
}, /*#__PURE__*/_react["default"].createElement(_toolMenu.ToolMenu, {
|
|
617
|
-
addCategory: addCategory,
|
|
618
|
-
disabled: false,
|
|
619
|
-
language: "es"
|
|
620
|
-
})));
|
|
621
|
-
expect(Translator.translator.t).toHaveBeenCalledWith('charting.addCategory', {
|
|
622
|
-
lng: 'es'
|
|
623
|
-
});
|
|
624
|
-
});
|
|
625
|
-
});
|
|
626
|
-
});
|
|
627
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_react2","_styles","_toolMenu","ownKeys","e","r","t","Object","keys","getOwnPropertySymbols","o","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","jest","mock","__esModule","translator","fn","key","options","translations","color","text","secondary","background","primary","primaryDark","disabled","theme","beforeAll","createTheme","describe","onClick","beforeEach","clearAllMocks","renderComponent","extras","undefined","defaults","value","selected","props","render","createElement","ThemeProvider","MiniButton","it","_renderComponent","getByText","expect","toBeInTheDocument","_renderComponent2","getByRole","_renderComponent3","button","toHaveAttribute","_renderComponent4","toHaveClass","_renderComponent5","_renderComponent6","toBeDisabled","_renderComponent7","not","_renderComponent8","fireEvent","click","toHaveBeenCalled","_renderComponent9","className","toContain","_renderComponent0","_renderComponent1","_renderComponent10","toHaveBeenCalledTimes","_renderComponent11","calls","toBeTruthy","_renderComponent12","_renderComponent13","i","_renderComponent14","_render","_render2","longText","_renderComponent15","specialText","_renderComponent16","unicodeText","_renderComponent17","_render3","addCategory","language","ToolMenu","_renderComponent18","container","_renderComponent19","firstChild","toBeInstanceOf","HTMLDivElement","_renderComponent20","_renderComponent21","queryByRole","_renderComponent22","Translator","_renderComponent23","toHaveBeenCalledWith","lng","_renderComponent24","_renderComponent25","_renderComponent26","_renderComponent27","_renderComponent28","_renderComponent29","_renderComponent30","toBeNull","_renderComponent31","_renderComponent32","_renderComponent33","_render4","_render5","_render6","_renderComponent34","unmount","toThrow","_renderComponent35","rerender","_renderComponent36","_renderComponent37","_renderComponent38","_renderComponent39","_renderComponent40","_renderComponent41","toHaveTextContent","_renderComponent42","customAddCategory","_renderComponent43","_renderComponent44","_renderComponent45"],"sources":["../../src/__tests__/tool-menu.test.jsx"],"sourcesContent":["import React from 'react';\nimport { fireEvent, render } from '@testing-library/react';\nimport { createTheme, ThemeProvider } from '@mui/material/styles';\nimport { MiniButton, ToolMenu } from '../tool-menu';\n\njest.mock('@pie-lib/translator', () => ({\n  __esModule: true,\n  default: {\n    translator: {\n      t: jest.fn((key, options) => {\n        const translations = {\n          'charting.addCategory': 'Add Category',\n        };\n        return translations[key] || key;\n      }),\n    },\n  },\n}));\n\njest.mock('@pie-lib/render-ui', () => ({\n  color: {\n    text: () => '#000000',\n    secondary: () => '#cccccc',\n    background: () => '#ffffff',\n    primary: () => '#0000ff',\n    primaryDark: () => '#000080',\n    disabled: () => '#f0f0f0',\n  },\n}));\n\nlet theme;\n\nbeforeAll(() => {\n  theme = createTheme();\n});\n\ndescribe('MiniButton', () => {\n  const onClick = jest.fn();\n\n  beforeEach(() => {\n    jest.clearAllMocks();\n  });\n\n  const renderComponent = (extras = {}) => {\n    const defaults = {\n      value: 'Test Button',\n      onClick,\n      disabled: false,\n      selected: false,\n    };\n    const props = { ...defaults, ...extras };\n    return render(\n      <ThemeProvider theme={theme}>\n        <MiniButton {...props} />\n      </ThemeProvider>,\n    );\n  };\n\n  describe('rendering', () => {\n    it('should render with value text', () => {\n      const { getByText } = renderComponent({ value: 'Click Me' });\n      expect(getByText('Click Me')).toBeInTheDocument();\n    });\n\n    it('should render as a button element', () => {\n      const { getByRole } = renderComponent();\n      expect(getByRole('button')).toBeInTheDocument();\n    });\n\n    it('should have correct button attributes', () => {\n      const { getByRole } = renderComponent({ value: 'Test' });\n      const button = getByRole('button');\n      expect(button).toHaveAttribute('value', 'Test');\n    });\n\n    it('should render with variant outlined', () => {\n      const { getByRole } = renderComponent();\n      const button = getByRole('button');\n      expect(button).toHaveClass('MuiButton-outlined');\n    });\n\n    it('should render with size small', () => {\n      const { getByRole } = renderComponent();\n      const button = getByRole('button');\n      expect(button).toHaveClass('MuiButton-sizeSmall');\n    });\n  });\n\n  describe('disabled state', () => {\n    it('should render as disabled when disabled prop is true', () => {\n      const { getByRole } = renderComponent({ disabled: true });\n      expect(getByRole('button')).toBeDisabled();\n    });\n\n    it('should not render as disabled when disabled prop is false', () => {\n      const { getByRole } = renderComponent({ disabled: false });\n      expect(getByRole('button')).not.toBeDisabled();\n    });\n\n    it('should not trigger onClick when disabled', () => {\n      const { getByRole } = renderComponent({ disabled: true });\n      fireEvent.click(getByRole('button'));\n      expect(onClick).not.toHaveBeenCalled();\n    });\n  });\n\n  describe('selected state', () => {\n    it('should apply selected styling when selected is true', () => {\n      const { getByRole } = renderComponent({ selected: true });\n      const button = getByRole('button');\n      expect(button.className).toContain('MuiButton-colorSecondary');\n    });\n\n    it('should apply default color when selected is false', () => {\n      const { getByRole } = renderComponent({ selected: false });\n      const button = getByRole('button');\n      expect(button.className).toContain('MuiButton-colorDefault');\n    });\n\n    it('should render correctly with both selected and disabled', () => {\n      const { getByRole } = renderComponent({ selected: true, disabled: true });\n      const button = getByRole('button');\n      expect(button).toBeDisabled();\n      expect(button.className).toContain('MuiButton-colorSecondary');\n    });\n  });\n\n  describe('interactions', () => {\n    it('should call onClick when clicked', () => {\n      const { getByRole } = renderComponent();\n      fireEvent.click(getByRole('button'));\n      expect(onClick).toHaveBeenCalledTimes(1);\n    });\n\n    it('should call onClick with correct event when clicked', () => {\n      const { getByRole } = renderComponent();\n      const button = getByRole('button');\n      fireEvent.click(button);\n      expect(onClick).toHaveBeenCalled();\n      expect(onClick.mock.calls[0][0]).toBeTruthy();\n    });\n\n    it('should handle multiple clicks', () => {\n      const { getByRole } = renderComponent();\n      const button = getByRole('button');\n      fireEvent.click(button);\n      fireEvent.click(button);\n      fireEvent.click(button);\n      expect(onClick).toHaveBeenCalledTimes(3);\n    });\n\n    it('should handle rapid clicks', () => {\n      const { getByRole } = renderComponent();\n      const button = getByRole('button');\n      for (let i = 0; i < 10; i++) {\n        fireEvent.click(button);\n      }\n      expect(onClick).toHaveBeenCalledTimes(10);\n    });\n  });\n\n  describe('edge cases', () => {\n    it('should render with empty string value', () => {\n      const { getByRole } = renderComponent({ value: '' });\n      expect(getByRole('button')).toBeInTheDocument();\n    });\n\n    it('should render with undefined onClick', () => {\n      const { getByRole } = render(\n        <ThemeProvider theme={theme}>\n          <MiniButton value=\"Test\" onClick={undefined} />\n        </ThemeProvider>,\n      );\n      expect(getByRole('button')).toBeInTheDocument();\n    });\n\n    it('should render with null onClick', () => {\n      const { getByRole } = render(\n        <ThemeProvider theme={theme}>\n          <MiniButton value=\"Test\" onClick={null} />\n        </ThemeProvider>,\n      );\n      expect(getByRole('button')).toBeInTheDocument();\n    });\n\n    it('should render with very long value text', () => {\n      const longText = 'This is a very long button text that might cause layout issues';\n      const { getByText } = renderComponent({ value: longText });\n      expect(getByText(longText)).toBeInTheDocument();\n    });\n\n    it('should render with special characters in value', () => {\n      const specialText = 'Test <>&\"\\'';\n      const { getByText } = renderComponent({ value: specialText });\n      expect(getByText(specialText)).toBeInTheDocument();\n    });\n\n    it('should render with unicode characters in value', () => {\n      const unicodeText = 'Test 你好 🎉';\n      const { getByText } = renderComponent({ value: unicodeText });\n      expect(getByText(unicodeText)).toBeInTheDocument();\n    });\n  });\n\n  describe('className prop', () => {\n    it('should accept className prop without error', () => {\n      const { getByRole } = render(\n        <ThemeProvider theme={theme}>\n          <MiniButton value=\"Test\" onClick={onClick} className=\"custom-class\" />\n        </ThemeProvider>,\n      );\n      expect(getByRole('button')).toBeInTheDocument();\n    });\n  });\n});\n\ndescribe('ToolMenu', () => {\n  const addCategory = jest.fn();\n\n  beforeEach(() => {\n    jest.clearAllMocks();\n  });\n\n  const renderComponent = (extras = {}) => {\n    const defaults = {\n      addCategory,\n      disabled: false,\n      language: 'en',\n    };\n    const props = { ...defaults, ...extras };\n    return render(\n      <ThemeProvider theme={theme}>\n        <ToolMenu {...props} />\n      </ThemeProvider>,\n    );\n  };\n\n  describe('rendering', () => {\n    it('should render without crashing', () => {\n      const { container } = renderComponent();\n      expect(container).toBeInTheDocument();\n    });\n\n    it('should render a div container', () => {\n      const { container } = renderComponent();\n      expect(container.firstChild).toBeInstanceOf(HTMLDivElement);\n    });\n\n    it('should render MiniButton when not disabled', () => {\n      const { getByRole } = renderComponent({ disabled: false });\n      expect(getByRole('button')).toBeInTheDocument();\n    });\n\n    it('should not render MiniButton when disabled', () => {\n      const { queryByRole } = renderComponent({ disabled: true });\n      expect(queryByRole('button')).not.toBeInTheDocument();\n    });\n\n    it('should render translated button text', () => {\n      const { getByText } = renderComponent();\n      expect(getByText('Add Category')).toBeInTheDocument();\n    });\n\n    it('should use language prop for translation', () => {\n      const Translator = require('@pie-lib/translator').default;\n      const { getByRole } = renderComponent({ language: 'es' });\n      expect(getByRole('button')).toBeInTheDocument();\n      expect(Translator.translator.t).toHaveBeenCalledWith('charting.addCategory', { lng: 'es' });\n    });\n  });\n\n  describe('className prop', () => {\n    it('should apply custom className to container', () => {\n      const { container } = renderComponent({ className: 'custom-tool-menu' });\n      expect(container.firstChild).toHaveClass('custom-tool-menu');\n    });\n\n    it('should render without className', () => {\n      const { container } = renderComponent({ className: undefined });\n      expect(container.firstChild).toBeInTheDocument();\n    });\n\n    it('should handle empty string className', () => {\n      const { container } = renderComponent({ className: '' });\n      expect(container.firstChild).toBeInTheDocument();\n    });\n  });\n\n  describe('disabled state', () => {\n    it('should hide button when disabled is true', () => {\n      const { queryByRole } = renderComponent({ disabled: true });\n      expect(queryByRole('button')).not.toBeInTheDocument();\n    });\n\n    it('should show button when disabled is false', () => {\n      const { getByRole } = renderComponent({ disabled: false });\n      expect(getByRole('button')).toBeInTheDocument();\n    });\n\n    it('should show button when disabled is undefined', () => {\n      const { getByRole } = renderComponent({ disabled: undefined });\n      expect(getByRole('button')).toBeInTheDocument();\n    });\n\n    it('should hide button when disabled is explicitly true', () => {\n      const { queryByRole } = renderComponent({ disabled: true });\n      expect(queryByRole('button')).toBeNull();\n    });\n  });\n\n  describe('addCategory functionality', () => {\n    it('should call addCategory when button is clicked', () => {\n      const { getByRole } = renderComponent();\n      fireEvent.click(getByRole('button'));\n      expect(addCategory).toHaveBeenCalledTimes(1);\n    });\n\n    it('should not call addCategory when disabled', () => {\n      const { queryByRole } = renderComponent({ disabled: true });\n      expect(queryByRole('button')).not.toBeInTheDocument();\n      expect(addCategory).not.toHaveBeenCalled();\n    });\n\n    it('should handle multiple clicks on add category button', () => {\n      const { getByRole } = renderComponent();\n      const button = getByRole('button');\n      fireEvent.click(button);\n      fireEvent.click(button);\n      fireEvent.click(button);\n      expect(addCategory).toHaveBeenCalledTimes(3);\n    });\n\n    it('should render with undefined addCategory without crashing', () => {\n      const { container } = render(\n        <ThemeProvider theme={theme}>\n          <ToolMenu addCategory={undefined} language=\"en\" />\n        </ThemeProvider>,\n      );\n      expect(container).toBeInTheDocument();\n    });\n  });\n\n  describe('language prop', () => {\n    it('should pass language to translator', () => {\n      const Translator = require('@pie-lib/translator').default;\n      renderComponent({ language: 'fr' });\n      expect(Translator.translator.t).toHaveBeenCalledWith('charting.addCategory', { lng: 'fr' });\n    });\n\n    it('should handle default english language', () => {\n      const Translator = require('@pie-lib/translator').default;\n      renderComponent({ language: 'en' });\n      expect(Translator.translator.t).toHaveBeenCalledWith('charting.addCategory', { lng: 'en' });\n    });\n\n    it('should handle undefined language', () => {\n      const Translator = require('@pie-lib/translator').default;\n      renderComponent({ language: undefined });\n      expect(Translator.translator.t).toHaveBeenCalledWith('charting.addCategory', { lng: undefined });\n    });\n\n    it('should handle empty string language', () => {\n      const Translator = require('@pie-lib/translator').default;\n      renderComponent({ language: '' });\n      expect(Translator.translator.t).toHaveBeenCalledWith('charting.addCategory', { lng: '' });\n    });\n\n    it('should handle non-standard language codes', () => {\n      const Translator = require('@pie-lib/translator').default;\n      renderComponent({ language: 'zh-CN' });\n      expect(Translator.translator.t).toHaveBeenCalledWith('charting.addCategory', { lng: 'zh-CN' });\n    });\n  });\n\n  describe('edge cases', () => {\n    it('should render with all props undefined', () => {\n      const { container } = render(\n        <ThemeProvider theme={theme}>\n          <ToolMenu />\n        </ThemeProvider>,\n      );\n      expect(container).toBeInTheDocument();\n    });\n\n    it('should render with null props', () => {\n      const { container } = render(\n        <ThemeProvider theme={theme}>\n          <ToolMenu addCategory={null} disabled={null} language={null} />\n        </ThemeProvider>,\n      );\n      expect(container).toBeInTheDocument();\n    });\n\n    it('should handle component unmounting', () => {\n      const { unmount } = renderComponent();\n      expect(() => unmount()).not.toThrow();\n    });\n\n    it('should handle re-rendering with different props', () => {\n      const { rerender, getByRole, queryByRole } = renderComponent({ disabled: false });\n      expect(getByRole('button')).toBeInTheDocument();\n\n      rerender(\n        <ThemeProvider theme={theme}>\n          <ToolMenu addCategory={addCategory} disabled={true} language=\"en\" />\n        </ThemeProvider>,\n      );\n      expect(queryByRole('button')).not.toBeInTheDocument();\n\n      rerender(\n        <ThemeProvider theme={theme}>\n          <ToolMenu addCategory={addCategory} disabled={false} language=\"es\" />\n        </ThemeProvider>,\n      );\n      expect(getByRole('button')).toBeInTheDocument();\n    });\n\n    it('should handle rapid prop changes', () => {\n      const { rerender, getByRole } = renderComponent({ disabled: false });\n\n      expect(getByRole('button')).toBeInTheDocument();\n\n      for (let i = 0; i < 10; i++) {\n        rerender(\n          <ThemeProvider theme={theme}>\n            <ToolMenu addCategory={addCategory} disabled={i % 2 === 0} language=\"en\" />\n          </ThemeProvider>,\n        );\n      }\n\n      expect(getByRole('button')).toBeInTheDocument();\n    });\n  });\n\n  describe('component lifecycle', () => {\n    it('should render as class component', () => {\n      const { container } = renderComponent();\n      expect(container).toBeInTheDocument();\n    });\n\n    it('should handle updates correctly', () => {\n      const { rerender, getByRole } = renderComponent({ language: 'en' });\n      expect(getByRole('button')).toBeInTheDocument();\n\n      rerender(\n        <ThemeProvider theme={theme}>\n          <ToolMenu addCategory={addCategory} disabled={false} language=\"fr\" />\n        </ThemeProvider>,\n      );\n      expect(getByRole('button')).toBeInTheDocument();\n    });\n\n    it('should cleanup properly on unmount', () => {\n      const { unmount } = renderComponent();\n      expect(() => unmount()).not.toThrow();\n    });\n  });\n\n  describe('accessibility', () => {\n    it('should have accessible button element', () => {\n      const { getByRole } = renderComponent();\n      const button = getByRole('button');\n      expect(button).toBeInTheDocument();\n    });\n\n    it('should have button with text content', () => {\n      const { getByRole } = renderComponent();\n      const button = getByRole('button');\n      expect(button).toHaveTextContent('Add Category');\n    });\n\n    it('should maintain button accessibility when enabled', () => {\n      const { getByRole } = renderComponent({ disabled: false });\n      const button = getByRole('button');\n      expect(button).not.toBeDisabled();\n      expect(button).toHaveTextContent('Add Category');\n    });\n  });\n\n  describe('integration', () => {\n    it('should work correctly with all props provided', () => {\n      const customAddCategory = jest.fn();\n      const { getByRole } = renderComponent({\n        addCategory: customAddCategory,\n        disabled: false,\n        language: 'de',\n        className: 'test-class',\n      });\n\n      const button = getByRole('button');\n      expect(button).toBeInTheDocument();\n\n      fireEvent.click(button);\n      expect(customAddCategory).toHaveBeenCalledTimes(1);\n    });\n\n    it('should toggle between enabled and disabled states', () => {\n      const { rerender, getByRole, queryByRole } = renderComponent({ disabled: false });\n      expect(getByRole('button')).toBeInTheDocument();\n\n      rerender(\n        <ThemeProvider theme={theme}>\n          <ToolMenu addCategory={addCategory} disabled={true} language=\"en\" />\n        </ThemeProvider>,\n      );\n      expect(queryByRole('button')).not.toBeInTheDocument();\n    });\n\n    it('should handle language switching', () => {\n      const Translator = require('@pie-lib/translator').default;\n      const { rerender } = renderComponent({ language: 'en' });\n\n      rerender(\n        <ThemeProvider theme={theme}>\n          <ToolMenu addCategory={addCategory} disabled={false} language=\"es\" />\n        </ThemeProvider>,\n      );\n\n      expect(Translator.translator.t).toHaveBeenCalledWith('charting.addCategory', { lng: 'es' });\n    });\n  });\n});\n"],"mappings":";;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,OAAA,GAAAD,OAAA;AACA,IAAAE,OAAA,GAAAF,OAAA;AACA,IAAAG,SAAA,GAAAH,OAAA;AAAoD,SAAAI,QAAAC,CAAA,EAAAC,CAAA,QAAAC,CAAA,GAAAC,MAAA,CAAAC,IAAA,CAAAJ,CAAA,OAAAG,MAAA,CAAAE,qBAAA,QAAAC,CAAA,GAAAH,MAAA,CAAAE,qBAAA,CAAAL,CAAA,GAAAC,CAAA,KAAAK,CAAA,GAAAA,CAAA,CAAAC,MAAA,WAAAN,CAAA,WAAAE,MAAA,CAAAK,wBAAA,CAAAR,CAAA,EAAAC,CAAA,EAAAQ,UAAA,OAAAP,CAAA,CAAAQ,IAAA,CAAAC,KAAA,CAAAT,CAAA,EAAAI,CAAA,YAAAJ,CAAA;AAAA,SAAAU,cAAAZ,CAAA,aAAAC,CAAA,MAAAA,CAAA,GAAAY,SAAA,CAAAC,MAAA,EAAAb,CAAA,UAAAC,CAAA,WAAAW,SAAA,CAAAZ,CAAA,IAAAY,SAAA,CAAAZ,CAAA,QAAAA,CAAA,OAAAF,OAAA,CAAAI,MAAA,CAAAD,CAAA,OAAAa,OAAA,WAAAd,CAAA,QAAAe,gBAAA,aAAAhB,CAAA,EAAAC,CAAA,EAAAC,CAAA,CAAAD,CAAA,SAAAE,MAAA,CAAAc,yBAAA,GAAAd,MAAA,CAAAe,gBAAA,CAAAlB,CAAA,EAAAG,MAAA,CAAAc,yBAAA,CAAAf,CAAA,KAAAH,OAAA,CAAAI,MAAA,CAAAD,CAAA,GAAAa,OAAA,WAAAd,CAAA,IAAAE,MAAA,CAAAgB,cAAA,CAAAnB,CAAA,EAAAC,CAAA,EAAAE,MAAA,CAAAK,wBAAA,CAAAN,CAAA,EAAAD,CAAA,iBAAAD,CAAA;AAEpDoB,IAAI,CAACC,IAAI,CAAC,qBAAqB,EAAE;EAAA,OAAO;IACtCC,UAAU,EAAE,IAAI;IAChB,WAAS;MACPC,UAAU,EAAE;QACVrB,CAAC,EAAEkB,IAAI,CAACI,EAAE,CAAC,UAACC,GAAG,EAAEC,OAAO,EAAK;UAC3B,IAAMC,YAAY,GAAG;YACnB,sBAAsB,EAAE;UAC1B,CAAC;UACD,OAAOA,YAAY,CAACF,GAAG,CAAC,IAAIA,GAAG;QACjC,CAAC;MACH;IACF;EACF,CAAC;AAAA,CAAC,CAAC;AAEHL,IAAI,CAACC,IAAI,CAAC,oBAAoB,EAAE;EAAA,OAAO;IACrCO,KAAK,EAAE;MACLC,IAAI,EAAE,SAANA,IAAIA,CAAA;QAAA,OAAQ,SAAS;MAAA;MACrBC,SAAS,EAAE,SAAXA,SAASA,CAAA;QAAA,OAAQ,SAAS;MAAA;MAC1BC,UAAU,EAAE,SAAZA,UAAUA,CAAA;QAAA,OAAQ,SAAS;MAAA;MAC3BC,OAAO,EAAE,SAATA,OAAOA,CAAA;QAAA,OAAQ,SAAS;MAAA;MACxBC,WAAW,EAAE,SAAbA,WAAWA,CAAA;QAAA,OAAQ,SAAS;MAAA;MAC5BC,QAAQ,EAAE,SAAVA,QAAQA,CAAA;QAAA,OAAQ,SAAS;MAAA;IAC3B;EACF,CAAC;AAAA,CAAC,CAAC;AAEH,IAAIC,KAAK;AAETC,SAAS,CAAC,YAAM;EACdD,KAAK,GAAG,IAAAE,mBAAW,EAAC,CAAC;AACvB,CAAC,CAAC;AAEFC,QAAQ,CAAC,YAAY,EAAE,YAAM;EAC3B,IAAMC,OAAO,GAAGnB,IAAI,CAACI,EAAE,CAAC,CAAC;EAEzBgB,UAAU,CAAC,YAAM;IACfpB,IAAI,CAACqB,aAAa,CAAC,CAAC;EACtB,CAAC,CAAC;EAEF,IAAMC,eAAe,GAAG,SAAlBA,eAAeA,CAAA,EAAoB;IAAA,IAAhBC,MAAM,GAAA9B,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAA+B,SAAA,GAAA/B,SAAA,MAAG,CAAC,CAAC;IAClC,IAAMgC,QAAQ,GAAG;MACfC,KAAK,EAAE,aAAa;MACpBP,OAAO,EAAPA,OAAO;MACPL,QAAQ,EAAE,KAAK;MACfa,QAAQ,EAAE;IACZ,CAAC;IACD,IAAMC,KAAK,GAAApC,aAAA,CAAAA,aAAA,KAAQiC,QAAQ,GAAKF,MAAM,CAAE;IACxC,OAAO,IAAAM,cAAM,eACXxD,MAAA,YAAAyD,aAAA,CAACrD,OAAA,CAAAsD,aAAa;MAAChB,KAAK,EAAEA;IAAM,gBAC1B1C,MAAA,YAAAyD,aAAA,CAACpD,SAAA,CAAAsD,UAAU,EAAKJ,KAAQ,CACX,CACjB,CAAC;EACH,CAAC;EAEDV,QAAQ,CAAC,WAAW,EAAE,YAAM;IAC1Be,EAAE,CAAC,+BAA+B,EAAE,YAAM;MACxC,IAAAC,gBAAA,GAAsBZ,eAAe,CAAC;UAAEI,KAAK,EAAE;QAAW,CAAC,CAAC;QAApDS,SAAS,GAAAD,gBAAA,CAATC,SAAS;MACjBC,MAAM,CAACD,SAAS,CAAC,UAAU,CAAC,CAAC,CAACE,iBAAiB,CAAC,CAAC;IACnD,CAAC,CAAC;IAEFJ,EAAE,CAAC,mCAAmC,EAAE,YAAM;MAC5C,IAAAK,iBAAA,GAAsBhB,eAAe,CAAC,CAAC;QAA/BiB,SAAS,GAAAD,iBAAA,CAATC,SAAS;MACjBH,MAAM,CAACG,SAAS,CAAC,QAAQ,CAAC,CAAC,CAACF,iBAAiB,CAAC,CAAC;IACjD,CAAC,CAAC;IAEFJ,EAAE,CAAC,uCAAuC,EAAE,YAAM;MAChD,IAAAO,iBAAA,GAAsBlB,eAAe,CAAC;UAAEI,KAAK,EAAE;QAAO,CAAC,CAAC;QAAhDa,SAAS,GAAAC,iBAAA,CAATD,SAAS;MACjB,IAAME,MAAM,GAAGF,SAAS,CAAC,QAAQ,CAAC;MAClCH,MAAM,CAACK,MAAM,CAAC,CAACC,eAAe,CAAC,OAAO,EAAE,MAAM,CAAC;IACjD,CAAC,CAAC;IAEFT,EAAE,CAAC,qCAAqC,EAAE,YAAM;MAC9C,IAAAU,iBAAA,GAAsBrB,eAAe,CAAC,CAAC;QAA/BiB,SAAS,GAAAI,iBAAA,CAATJ,SAAS;MACjB,IAAME,MAAM,GAAGF,SAAS,CAAC,QAAQ,CAAC;MAClCH,MAAM,CAACK,MAAM,CAAC,CAACG,WAAW,CAAC,oBAAoB,CAAC;IAClD,CAAC,CAAC;IAEFX,EAAE,CAAC,+BAA+B,EAAE,YAAM;MACxC,IAAAY,iBAAA,GAAsBvB,eAAe,CAAC,CAAC;QAA/BiB,SAAS,GAAAM,iBAAA,CAATN,SAAS;MACjB,IAAME,MAAM,GAAGF,SAAS,CAAC,QAAQ,CAAC;MAClCH,MAAM,CAACK,MAAM,CAAC,CAACG,WAAW,CAAC,qBAAqB,CAAC;IACnD,CAAC,CAAC;EACJ,CAAC,CAAC;EAEF1B,QAAQ,CAAC,gBAAgB,EAAE,YAAM;IAC/Be,EAAE,CAAC,sDAAsD,EAAE,YAAM;MAC/D,IAAAa,iBAAA,GAAsBxB,eAAe,CAAC;UAAER,QAAQ,EAAE;QAAK,CAAC,CAAC;QAAjDyB,SAAS,GAAAO,iBAAA,CAATP,SAAS;MACjBH,MAAM,CAACG,SAAS,CAAC,QAAQ,CAAC,CAAC,CAACQ,YAAY,CAAC,CAAC;IAC5C,CAAC,CAAC;IAEFd,EAAE,CAAC,2DAA2D,EAAE,YAAM;MACpE,IAAAe,iBAAA,GAAsB1B,eAAe,CAAC;UAAER,QAAQ,EAAE;QAAM,CAAC,CAAC;QAAlDyB,SAAS,GAAAS,iBAAA,CAATT,SAAS;MACjBH,MAAM,CAACG,SAAS,CAAC,QAAQ,CAAC,CAAC,CAACU,GAAG,CAACF,YAAY,CAAC,CAAC;IAChD,CAAC,CAAC;IAEFd,EAAE,CAAC,0CAA0C,EAAE,YAAM;MACnD,IAAAiB,iBAAA,GAAsB5B,eAAe,CAAC;UAAER,QAAQ,EAAE;QAAK,CAAC,CAAC;QAAjDyB,SAAS,GAAAW,iBAAA,CAATX,SAAS;MACjBY,iBAAS,CAACC,KAAK,CAACb,SAAS,CAAC,QAAQ,CAAC,CAAC;MACpCH,MAAM,CAACjB,OAAO,CAAC,CAAC8B,GAAG,CAACI,gBAAgB,CAAC,CAAC;IACxC,CAAC,CAAC;EACJ,CAAC,CAAC;EAEFnC,QAAQ,CAAC,gBAAgB,EAAE,YAAM;IAC/Be,EAAE,CAAC,qDAAqD,EAAE,YAAM;MAC9D,IAAAqB,iBAAA,GAAsBhC,eAAe,CAAC;UAAEK,QAAQ,EAAE;QAAK,CAAC,CAAC;QAAjDY,SAAS,GAAAe,iBAAA,CAATf,SAAS;MACjB,IAAME,MAAM,GAAGF,SAAS,CAAC,QAAQ,CAAC;MAClCH,MAAM,CAACK,MAAM,CAACc,SAAS,CAAC,CAACC,SAAS,CAAC,0BAA0B,CAAC;IAChE,CAAC,CAAC;IAEFvB,EAAE,CAAC,mDAAmD,EAAE,YAAM;MAC5D,IAAAwB,iBAAA,GAAsBnC,eAAe,CAAC;UAAEK,QAAQ,EAAE;QAAM,CAAC,CAAC;QAAlDY,SAAS,GAAAkB,iBAAA,CAATlB,SAAS;MACjB,IAAME,MAAM,GAAGF,SAAS,CAAC,QAAQ,CAAC;MAClCH,MAAM,CAACK,MAAM,CAACc,SAAS,CAAC,CAACC,SAAS,CAAC,wBAAwB,CAAC;IAC9D,CAAC,CAAC;IAEFvB,EAAE,CAAC,yDAAyD,EAAE,YAAM;MAClE,IAAAyB,iBAAA,GAAsBpC,eAAe,CAAC;UAAEK,QAAQ,EAAE,IAAI;UAAEb,QAAQ,EAAE;QAAK,CAAC,CAAC;QAAjEyB,SAAS,GAAAmB,iBAAA,CAATnB,SAAS;MACjB,IAAME,MAAM,GAAGF,SAAS,CAAC,QAAQ,CAAC;MAClCH,MAAM,CAACK,MAAM,CAAC,CAACM,YAAY,CAAC,CAAC;MAC7BX,MAAM,CAACK,MAAM,CAACc,SAAS,CAAC,CAACC,SAAS,CAAC,0BAA0B,CAAC;IAChE,CAAC,CAAC;EACJ,CAAC,CAAC;EAEFtC,QAAQ,CAAC,cAAc,EAAE,YAAM;IAC7Be,EAAE,CAAC,kCAAkC,EAAE,YAAM;MAC3C,IAAA0B,kBAAA,GAAsBrC,eAAe,CAAC,CAAC;QAA/BiB,SAAS,GAAAoB,kBAAA,CAATpB,SAAS;MACjBY,iBAAS,CAACC,KAAK,CAACb,SAAS,CAAC,QAAQ,CAAC,CAAC;MACpCH,MAAM,CAACjB,OAAO,CAAC,CAACyC,qBAAqB,CAAC,CAAC,CAAC;IAC1C,CAAC,CAAC;IAEF3B,EAAE,CAAC,qDAAqD,EAAE,YAAM;MAC9D,IAAA4B,kBAAA,GAAsBvC,eAAe,CAAC,CAAC;QAA/BiB,SAAS,GAAAsB,kBAAA,CAATtB,SAAS;MACjB,IAAME,MAAM,GAAGF,SAAS,CAAC,QAAQ,CAAC;MAClCY,iBAAS,CAACC,KAAK,CAACX,MAAM,CAAC;MACvBL,MAAM,CAACjB,OAAO,CAAC,CAACkC,gBAAgB,CAAC,CAAC;MAClCjB,MAAM,CAACjB,OAAO,CAAClB,IAAI,CAAC6D,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAACC,UAAU,CAAC,CAAC;IAC/C,CAAC,CAAC;IAEF9B,EAAE,CAAC,+BAA+B,EAAE,YAAM;MACxC,IAAA+B,kBAAA,GAAsB1C,eAAe,CAAC,CAAC;QAA/BiB,SAAS,GAAAyB,kBAAA,CAATzB,SAAS;MACjB,IAAME,MAAM,GAAGF,SAAS,CAAC,QAAQ,CAAC;MAClCY,iBAAS,CAACC,KAAK,CAACX,MAAM,CAAC;MACvBU,iBAAS,CAACC,KAAK,CAACX,MAAM,CAAC;MACvBU,iBAAS,CAACC,KAAK,CAACX,MAAM,CAAC;MACvBL,MAAM,CAACjB,OAAO,CAAC,CAACyC,qBAAqB,CAAC,CAAC,CAAC;IAC1C,CAAC,CAAC;IAEF3B,EAAE,CAAC,4BAA4B,EAAE,YAAM;MACrC,IAAAgC,kBAAA,GAAsB3C,eAAe,CAAC,CAAC;QAA/BiB,SAAS,GAAA0B,kBAAA,CAAT1B,SAAS;MACjB,IAAME,MAAM,GAAGF,SAAS,CAAC,QAAQ,CAAC;MAClC,KAAK,IAAI2B,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAG,EAAE,EAAEA,CAAC,EAAE,EAAE;QAC3Bf,iBAAS,CAACC,KAAK,CAACX,MAAM,CAAC;MACzB;MACAL,MAAM,CAACjB,OAAO,CAAC,CAACyC,qBAAqB,CAAC,EAAE,CAAC;IAC3C,CAAC,CAAC;EACJ,CAAC,CAAC;EAEF1C,QAAQ,CAAC,YAAY,EAAE,YAAM;IAC3Be,EAAE,CAAC,uCAAuC,EAAE,YAAM;MAChD,IAAAkC,kBAAA,GAAsB7C,eAAe,CAAC;UAAEI,KAAK,EAAE;QAAG,CAAC,CAAC;QAA5Ca,SAAS,GAAA4B,kBAAA,CAAT5B,SAAS;MACjBH,MAAM,CAACG,SAAS,CAAC,QAAQ,CAAC,CAAC,CAACF,iBAAiB,CAAC,CAAC;IACjD,CAAC,CAAC;IAEFJ,EAAE,CAAC,sCAAsC,EAAE,YAAM;MAC/C,IAAAmC,OAAA,GAAsB,IAAAvC,cAAM,eAC1BxD,MAAA,YAAAyD,aAAA,CAACrD,OAAA,CAAAsD,aAAa;UAAChB,KAAK,EAAEA;QAAM,gBAC1B1C,MAAA,YAAAyD,aAAA,CAACpD,SAAA,CAAAsD,UAAU;UAACN,KAAK,EAAC,MAAM;UAACP,OAAO,EAAEK;QAAU,CAAE,CACjC,CACjB,CAAC;QAJOe,SAAS,GAAA6B,OAAA,CAAT7B,SAAS;MAKjBH,MAAM,CAACG,SAAS,CAAC,QAAQ,CAAC,CAAC,CAACF,iBAAiB,CAAC,CAAC;IACjD,CAAC,CAAC;IAEFJ,EAAE,CAAC,iCAAiC,EAAE,YAAM;MAC1C,IAAAoC,QAAA,GAAsB,IAAAxC,cAAM,eAC1BxD,MAAA,YAAAyD,aAAA,CAACrD,OAAA,CAAAsD,aAAa;UAAChB,KAAK,EAAEA;QAAM,gBAC1B1C,MAAA,YAAAyD,aAAA,CAACpD,SAAA,CAAAsD,UAAU;UAACN,KAAK,EAAC,MAAM;UAACP,OAAO,EAAE;QAAK,CAAE,CAC5B,CACjB,CAAC;QAJOoB,SAAS,GAAA8B,QAAA,CAAT9B,SAAS;MAKjBH,MAAM,CAACG,SAAS,CAAC,QAAQ,CAAC,CAAC,CAACF,iBAAiB,CAAC,CAAC;IACjD,CAAC,CAAC;IAEFJ,EAAE,CAAC,yCAAyC,EAAE,YAAM;MAClD,IAAMqC,QAAQ,GAAG,gEAAgE;MACjF,IAAAC,kBAAA,GAAsBjD,eAAe,CAAC;UAAEI,KAAK,EAAE4C;QAAS,CAAC,CAAC;QAAlDnC,SAAS,GAAAoC,kBAAA,CAATpC,SAAS;MACjBC,MAAM,CAACD,SAAS,CAACmC,QAAQ,CAAC,CAAC,CAACjC,iBAAiB,CAAC,CAAC;IACjD,CAAC,CAAC;IAEFJ,EAAE,CAAC,gDAAgD,EAAE,YAAM;MACzD,IAAMuC,WAAW,GAAG,aAAa;MACjC,IAAAC,kBAAA,GAAsBnD,eAAe,CAAC;UAAEI,KAAK,EAAE8C;QAAY,CAAC,CAAC;QAArDrC,SAAS,GAAAsC,kBAAA,CAATtC,SAAS;MACjBC,MAAM,CAACD,SAAS,CAACqC,WAAW,CAAC,CAAC,CAACnC,iBAAiB,CAAC,CAAC;IACpD,CAAC,CAAC;IAEFJ,EAAE,CAAC,gDAAgD,EAAE,YAAM;MACzD,IAAMyC,WAAW,GAAG,YAAY;MAChC,IAAAC,kBAAA,GAAsBrD,eAAe,CAAC;UAAEI,KAAK,EAAEgD;QAAY,CAAC,CAAC;QAArDvC,SAAS,GAAAwC,kBAAA,CAATxC,SAAS;MACjBC,MAAM,CAACD,SAAS,CAACuC,WAAW,CAAC,CAAC,CAACrC,iBAAiB,CAAC,CAAC;IACpD,CAAC,CAAC;EACJ,CAAC,CAAC;EAEFnB,QAAQ,CAAC,gBAAgB,EAAE,YAAM;IAC/Be,EAAE,CAAC,4CAA4C,EAAE,YAAM;MACrD,IAAA2C,QAAA,GAAsB,IAAA/C,cAAM,eAC1BxD,MAAA,YAAAyD,aAAA,CAACrD,OAAA,CAAAsD,aAAa;UAAChB,KAAK,EAAEA;QAAM,gBAC1B1C,MAAA,YAAAyD,aAAA,CAACpD,SAAA,CAAAsD,UAAU;UAACN,KAAK,EAAC,MAAM;UAACP,OAAO,EAAEA,OAAQ;UAACoC,SAAS,EAAC;QAAc,CAAE,CACxD,CACjB,CAAC;QAJOhB,SAAS,GAAAqC,QAAA,CAATrC,SAAS;MAKjBH,MAAM,CAACG,SAAS,CAAC,QAAQ,CAAC,CAAC,CAACF,iBAAiB,CAAC,CAAC;IACjD,CAAC,CAAC;EACJ,CAAC,CAAC;AACJ,CAAC,CAAC;AAEFnB,QAAQ,CAAC,UAAU,EAAE,YAAM;EACzB,IAAM2D,WAAW,GAAG7E,IAAI,CAACI,EAAE,CAAC,CAAC;EAE7BgB,UAAU,CAAC,YAAM;IACfpB,IAAI,CAACqB,aAAa,CAAC,CAAC;EACtB,CAAC,CAAC;EAEF,IAAMC,eAAe,GAAG,SAAlBA,eAAeA,CAAA,EAAoB;IAAA,IAAhBC,MAAM,GAAA9B,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAA+B,SAAA,GAAA/B,SAAA,MAAG,CAAC,CAAC;IAClC,IAAMgC,QAAQ,GAAG;MACfoD,WAAW,EAAXA,WAAW;MACX/D,QAAQ,EAAE,KAAK;MACfgE,QAAQ,EAAE;IACZ,CAAC;IACD,IAAMlD,KAAK,GAAApC,aAAA,CAAAA,aAAA,KAAQiC,QAAQ,GAAKF,MAAM,CAAE;IACxC,OAAO,IAAAM,cAAM,eACXxD,MAAA,YAAAyD,aAAA,CAACrD,OAAA,CAAAsD,aAAa;MAAChB,KAAK,EAAEA;IAAM,gBAC1B1C,MAAA,YAAAyD,aAAA,CAACpD,SAAA,CAAAqG,QAAQ,EAAKnD,KAAQ,CACT,CACjB,CAAC;EACH,CAAC;EAEDV,QAAQ,CAAC,WAAW,EAAE,YAAM;IAC1Be,EAAE,CAAC,gCAAgC,EAAE,YAAM;MACzC,IAAA+C,kBAAA,GAAsB1D,eAAe,CAAC,CAAC;QAA/B2D,SAAS,GAAAD,kBAAA,CAATC,SAAS;MACjB7C,MAAM,CAAC6C,SAAS,CAAC,CAAC5C,iBAAiB,CAAC,CAAC;IACvC,CAAC,CAAC;IAEFJ,EAAE,CAAC,+BAA+B,EAAE,YAAM;MACxC,IAAAiD,kBAAA,GAAsB5D,eAAe,CAAC,CAAC;QAA/B2D,SAAS,GAAAC,kBAAA,CAATD,SAAS;MACjB7C,MAAM,CAAC6C,SAAS,CAACE,UAAU,CAAC,CAACC,cAAc,CAACC,cAAc,CAAC;IAC7D,CAAC,CAAC;IAEFpD,EAAE,CAAC,4CAA4C,EAAE,YAAM;MACrD,IAAAqD,kBAAA,GAAsBhE,eAAe,CAAC;UAAER,QAAQ,EAAE;QAAM,CAAC,CAAC;QAAlDyB,SAAS,GAAA+C,kBAAA,CAAT/C,SAAS;MACjBH,MAAM,CAACG,SAAS,CAAC,QAAQ,CAAC,CAAC,CAACF,iBAAiB,CAAC,CAAC;IACjD,CAAC,CAAC;IAEFJ,EAAE,CAAC,4CAA4C,EAAE,YAAM;MACrD,IAAAsD,kBAAA,GAAwBjE,eAAe,CAAC;UAAER,QAAQ,EAAE;QAAK,CAAC,CAAC;QAAnD0E,WAAW,GAAAD,kBAAA,CAAXC,WAAW;MACnBpD,MAAM,CAACoD,WAAW,CAAC,QAAQ,CAAC,CAAC,CAACvC,GAAG,CAACZ,iBAAiB,CAAC,CAAC;IACvD,CAAC,CAAC;IAEFJ,EAAE,CAAC,sCAAsC,EAAE,YAAM;MAC/C,IAAAwD,kBAAA,GAAsBnE,eAAe,CAAC,CAAC;QAA/Ba,SAAS,GAAAsD,kBAAA,CAATtD,SAAS;MACjBC,MAAM,CAACD,SAAS,CAAC,cAAc,CAAC,CAAC,CAACE,iBAAiB,CAAC,CAAC;IACvD,CAAC,CAAC;IAEFJ,EAAE,CAAC,0CAA0C,EAAE,YAAM;MACnD,IAAMyD,UAAU,GAAGnH,OAAO,CAAC,qBAAqB,CAAC,WAAQ;MACzD,IAAAoH,kBAAA,GAAsBrE,eAAe,CAAC;UAAEwD,QAAQ,EAAE;QAAK,CAAC,CAAC;QAAjDvC,SAAS,GAAAoD,kBAAA,CAATpD,SAAS;MACjBH,MAAM,CAACG,SAAS,CAAC,QAAQ,CAAC,CAAC,CAACF,iBAAiB,CAAC,CAAC;MAC/CD,MAAM,CAACsD,UAAU,CAACvF,UAAU,CAACrB,CAAC,CAAC,CAAC8G,oBAAoB,CAAC,sBAAsB,EAAE;QAAEC,GAAG,EAAE;MAAK,CAAC,CAAC;IAC7F,CAAC,CAAC;EACJ,CAAC,CAAC;EAEF3E,QAAQ,CAAC,gBAAgB,EAAE,YAAM;IAC/Be,EAAE,CAAC,4CAA4C,EAAE,YAAM;MACrD,IAAA6D,kBAAA,GAAsBxE,eAAe,CAAC;UAAEiC,SAAS,EAAE;QAAmB,CAAC,CAAC;QAAhE0B,SAAS,GAAAa,kBAAA,CAATb,SAAS;MACjB7C,MAAM,CAAC6C,SAAS,CAACE,UAAU,CAAC,CAACvC,WAAW,CAAC,kBAAkB,CAAC;IAC9D,CAAC,CAAC;IAEFX,EAAE,CAAC,iCAAiC,EAAE,YAAM;MAC1C,IAAA8D,kBAAA,GAAsBzE,eAAe,CAAC;UAAEiC,SAAS,EAAE/B;QAAU,CAAC,CAAC;QAAvDyD,SAAS,GAAAc,kBAAA,CAATd,SAAS;MACjB7C,MAAM,CAAC6C,SAAS,CAACE,UAAU,CAAC,CAAC9C,iBAAiB,CAAC,CAAC;IAClD,CAAC,CAAC;IAEFJ,EAAE,CAAC,sCAAsC,EAAE,YAAM;MAC/C,IAAA+D,kBAAA,GAAsB1E,eAAe,CAAC;UAAEiC,SAAS,EAAE;QAAG,CAAC,CAAC;QAAhD0B,SAAS,GAAAe,kBAAA,CAATf,SAAS;MACjB7C,MAAM,CAAC6C,SAAS,CAACE,UAAU,CAAC,CAAC9C,iBAAiB,CAAC,CAAC;IAClD,CAAC,CAAC;EACJ,CAAC,CAAC;EAEFnB,QAAQ,CAAC,gBAAgB,EAAE,YAAM;IAC/Be,EAAE,CAAC,0CAA0C,EAAE,YAAM;MACnD,IAAAgE,kBAAA,GAAwB3E,eAAe,CAAC;UAAER,QAAQ,EAAE;QAAK,CAAC,CAAC;QAAnD0E,WAAW,GAAAS,kBAAA,CAAXT,WAAW;MACnBpD,MAAM,CAACoD,WAAW,CAAC,QAAQ,CAAC,CAAC,CAACvC,GAAG,CAACZ,iBAAiB,CAAC,CAAC;IACvD,CAAC,CAAC;IAEFJ,EAAE,CAAC,2CAA2C,EAAE,YAAM;MACpD,IAAAiE,kBAAA,GAAsB5E,eAAe,CAAC;UAAER,QAAQ,EAAE;QAAM,CAAC,CAAC;QAAlDyB,SAAS,GAAA2D,kBAAA,CAAT3D,SAAS;MACjBH,MAAM,CAACG,SAAS,CAAC,QAAQ,CAAC,CAAC,CAACF,iBAAiB,CAAC,CAAC;IACjD,CAAC,CAAC;IAEFJ,EAAE,CAAC,+CAA+C,EAAE,YAAM;MACxD,IAAAkE,kBAAA,GAAsB7E,eAAe,CAAC;UAAER,QAAQ,EAAEU;QAAU,CAAC,CAAC;QAAtDe,SAAS,GAAA4D,kBAAA,CAAT5D,SAAS;MACjBH,MAAM,CAACG,SAAS,CAAC,QAAQ,CAAC,CAAC,CAACF,iBAAiB,CAAC,CAAC;IACjD,CAAC,CAAC;IAEFJ,EAAE,CAAC,qDAAqD,EAAE,YAAM;MAC9D,IAAAmE,kBAAA,GAAwB9E,eAAe,CAAC;UAAER,QAAQ,EAAE;QAAK,CAAC,CAAC;QAAnD0E,WAAW,GAAAY,kBAAA,CAAXZ,WAAW;MACnBpD,MAAM,CAACoD,WAAW,CAAC,QAAQ,CAAC,CAAC,CAACa,QAAQ,CAAC,CAAC;IAC1C,CAAC,CAAC;EACJ,CAAC,CAAC;EAEFnF,QAAQ,CAAC,2BAA2B,EAAE,YAAM;IAC1Ce,EAAE,CAAC,gDAAgD,EAAE,YAAM;MACzD,IAAAqE,kBAAA,GAAsBhF,eAAe,CAAC,CAAC;QAA/BiB,SAAS,GAAA+D,kBAAA,CAAT/D,SAAS;MACjBY,iBAAS,CAACC,KAAK,CAACb,SAAS,CAAC,QAAQ,CAAC,CAAC;MACpCH,MAAM,CAACyC,WAAW,CAAC,CAACjB,qBAAqB,CAAC,CAAC,CAAC;IAC9C,CAAC,CAAC;IAEF3B,EAAE,CAAC,2CAA2C,EAAE,YAAM;MACpD,IAAAsE,kBAAA,GAAwBjF,eAAe,CAAC;UAAER,QAAQ,EAAE;QAAK,CAAC,CAAC;QAAnD0E,WAAW,GAAAe,kBAAA,CAAXf,WAAW;MACnBpD,MAAM,CAACoD,WAAW,CAAC,QAAQ,CAAC,CAAC,CAACvC,GAAG,CAACZ,iBAAiB,CAAC,CAAC;MACrDD,MAAM,CAACyC,WAAW,CAAC,CAAC5B,GAAG,CAACI,gBAAgB,CAAC,CAAC;IAC5C,CAAC,CAAC;IAEFpB,EAAE,CAAC,sDAAsD,EAAE,YAAM;MAC/D,IAAAuE,kBAAA,GAAsBlF,eAAe,CAAC,CAAC;QAA/BiB,SAAS,GAAAiE,kBAAA,CAATjE,SAAS;MACjB,IAAME,MAAM,GAAGF,SAAS,CAAC,QAAQ,CAAC;MAClCY,iBAAS,CAACC,KAAK,CAACX,MAAM,CAAC;MACvBU,iBAAS,CAACC,KAAK,CAACX,MAAM,CAAC;MACvBU,iBAAS,CAACC,KAAK,CAACX,MAAM,CAAC;MACvBL,MAAM,CAACyC,WAAW,CAAC,CAACjB,qBAAqB,CAAC,CAAC,CAAC;IAC9C,CAAC,CAAC;IAEF3B,EAAE,CAAC,2DAA2D,EAAE,YAAM;MACpE,IAAAwE,QAAA,GAAsB,IAAA5E,cAAM,eAC1BxD,MAAA,YAAAyD,aAAA,CAACrD,OAAA,CAAAsD,aAAa;UAAChB,KAAK,EAAEA;QAAM,gBAC1B1C,MAAA,YAAAyD,aAAA,CAACpD,SAAA,CAAAqG,QAAQ;UAACF,WAAW,EAAErD,SAAU;UAACsD,QAAQ,EAAC;QAAI,CAAE,CACpC,CACjB,CAAC;QAJOG,SAAS,GAAAwB,QAAA,CAATxB,SAAS;MAKjB7C,MAAM,CAAC6C,SAAS,CAAC,CAAC5C,iBAAiB,CAAC,CAAC;IACvC,CAAC,CAAC;EACJ,CAAC,CAAC;EAEFnB,QAAQ,CAAC,eAAe,EAAE,YAAM;IAC9Be,EAAE,CAAC,oCAAoC,EAAE,YAAM;MAC7C,IAAMyD,UAAU,GAAGnH,OAAO,CAAC,qBAAqB,CAAC,WAAQ;MACzD+C,eAAe,CAAC;QAAEwD,QAAQ,EAAE;MAAK,CAAC,CAAC;MACnC1C,MAAM,CAACsD,UAAU,CAACvF,UAAU,CAACrB,CAAC,CAAC,CAAC8G,oBAAoB,CAAC,sBAAsB,EAAE;QAAEC,GAAG,EAAE;MAAK,CAAC,CAAC;IAC7F,CAAC,CAAC;IAEF5D,EAAE,CAAC,wCAAwC,EAAE,YAAM;MACjD,IAAMyD,UAAU,GAAGnH,OAAO,CAAC,qBAAqB,CAAC,WAAQ;MACzD+C,eAAe,CAAC;QAAEwD,QAAQ,EAAE;MAAK,CAAC,CAAC;MACnC1C,MAAM,CAACsD,UAAU,CAACvF,UAAU,CAACrB,CAAC,CAAC,CAAC8G,oBAAoB,CAAC,sBAAsB,EAAE;QAAEC,GAAG,EAAE;MAAK,CAAC,CAAC;IAC7F,CAAC,CAAC;IAEF5D,EAAE,CAAC,kCAAkC,EAAE,YAAM;MAC3C,IAAMyD,UAAU,GAAGnH,OAAO,CAAC,qBAAqB,CAAC,WAAQ;MACzD+C,eAAe,CAAC;QAAEwD,QAAQ,EAAEtD;MAAU,CAAC,CAAC;MACxCY,MAAM,CAACsD,UAAU,CAACvF,UAAU,CAACrB,CAAC,CAAC,CAAC8G,oBAAoB,CAAC,sBAAsB,EAAE;QAAEC,GAAG,EAAErE;MAAU,CAAC,CAAC;IAClG,CAAC,CAAC;IAEFS,EAAE,CAAC,qCAAqC,EAAE,YAAM;MAC9C,IAAMyD,UAAU,GAAGnH,OAAO,CAAC,qBAAqB,CAAC,WAAQ;MACzD+C,eAAe,CAAC;QAAEwD,QAAQ,EAAE;MAAG,CAAC,CAAC;MACjC1C,MAAM,CAACsD,UAAU,CAACvF,UAAU,CAACrB,CAAC,CAAC,CAAC8G,oBAAoB,CAAC,sBAAsB,EAAE;QAAEC,GAAG,EAAE;MAAG,CAAC,CAAC;IAC3F,CAAC,CAAC;IAEF5D,EAAE,CAAC,2CAA2C,EAAE,YAAM;MACpD,IAAMyD,UAAU,GAAGnH,OAAO,CAAC,qBAAqB,CAAC,WAAQ;MACzD+C,eAAe,CAAC;QAAEwD,QAAQ,EAAE;MAAQ,CAAC,CAAC;MACtC1C,MAAM,CAACsD,UAAU,CAACvF,UAAU,CAACrB,CAAC,CAAC,CAAC8G,oBAAoB,CAAC,sBAAsB,EAAE;QAAEC,GAAG,EAAE;MAAQ,CAAC,CAAC;IAChG,CAAC,CAAC;EACJ,CAAC,CAAC;EAEF3E,QAAQ,CAAC,YAAY,EAAE,YAAM;IAC3Be,EAAE,CAAC,wCAAwC,EAAE,YAAM;MACjD,IAAAyE,QAAA,GAAsB,IAAA7E,cAAM,eAC1BxD,MAAA,YAAAyD,aAAA,CAACrD,OAAA,CAAAsD,aAAa;UAAChB,KAAK,EAAEA;QAAM,gBAC1B1C,MAAA,YAAAyD,aAAA,CAACpD,SAAA,CAAAqG,QAAQ,MAAE,CACE,CACjB,CAAC;QAJOE,SAAS,GAAAyB,QAAA,CAATzB,SAAS;MAKjB7C,MAAM,CAAC6C,SAAS,CAAC,CAAC5C,iBAAiB,CAAC,CAAC;IACvC,CAAC,CAAC;IAEFJ,EAAE,CAAC,+BAA+B,EAAE,YAAM;MACxC,IAAA0E,QAAA,GAAsB,IAAA9E,cAAM,eAC1BxD,MAAA,YAAAyD,aAAA,CAACrD,OAAA,CAAAsD,aAAa;UAAChB,KAAK,EAAEA;QAAM,gBAC1B1C,MAAA,YAAAyD,aAAA,CAACpD,SAAA,CAAAqG,QAAQ;UAACF,WAAW,EAAE,IAAK;UAAC/D,QAAQ,EAAE,IAAK;UAACgE,QAAQ,EAAE;QAAK,CAAE,CACjD,CACjB,CAAC;QAJOG,SAAS,GAAA0B,QAAA,CAAT1B,SAAS;MAKjB7C,MAAM,CAAC6C,SAAS,CAAC,CAAC5C,iBAAiB,CAAC,CAAC;IACvC,CAAC,CAAC;IAEFJ,EAAE,CAAC,oCAAoC,EAAE,YAAM;MAC7C,IAAA2E,kBAAA,GAAoBtF,eAAe,CAAC,CAAC;QAA7BuF,OAAO,GAAAD,kBAAA,CAAPC,OAAO;MACfzE,MAAM,CAAC;QAAA,OAAMyE,OAAO,CAAC,CAAC;MAAA,EAAC,CAAC5D,GAAG,CAAC6D,OAAO,CAAC,CAAC;IACvC,CAAC,CAAC;IAEF7E,EAAE,CAAC,iDAAiD,EAAE,YAAM;MAC1D,IAAA8E,kBAAA,GAA6CzF,eAAe,CAAC;UAAER,QAAQ,EAAE;QAAM,CAAC,CAAC;QAAzEkG,QAAQ,GAAAD,kBAAA,CAARC,QAAQ;QAAEzE,SAAS,GAAAwE,kBAAA,CAATxE,SAAS;QAAEiD,WAAW,GAAAuB,kBAAA,CAAXvB,WAAW;MACxCpD,MAAM,CAACG,SAAS,CAAC,QAAQ,CAAC,CAAC,CAACF,iBAAiB,CAAC,CAAC;MAE/C2E,QAAQ,cACN3I,MAAA,YAAAyD,aAAA,CAACrD,OAAA,CAAAsD,aAAa;QAAChB,KAAK,EAAEA;MAAM,gBAC1B1C,MAAA,YAAAyD,aAAA,CAACpD,SAAA,CAAAqG,QAAQ;QAACF,WAAW,EAAEA,WAAY;QAAC/D,QAAQ,EAAE,IAAK;QAACgE,QAAQ,EAAC;MAAI,CAAE,CACtD,CACjB,CAAC;MACD1C,MAAM,CAACoD,WAAW,CAAC,QAAQ,CAAC,CAAC,CAACvC,GAAG,CAACZ,iBAAiB,CAAC,CAAC;MAErD2E,QAAQ,cACN3I,MAAA,YAAAyD,aAAA,CAACrD,OAAA,CAAAsD,aAAa;QAAChB,KAAK,EAAEA;MAAM,gBAC1B1C,MAAA,YAAAyD,aAAA,CAACpD,SAAA,CAAAqG,QAAQ;QAACF,WAAW,EAAEA,WAAY;QAAC/D,QAAQ,EAAE,KAAM;QAACgE,QAAQ,EAAC;MAAI,CAAE,CACvD,CACjB,CAAC;MACD1C,MAAM,CAACG,SAAS,CAAC,QAAQ,CAAC,CAAC,CAACF,iBAAiB,CAAC,CAAC;IACjD,CAAC,CAAC;IAEFJ,EAAE,CAAC,kCAAkC,EAAE,YAAM;MAC3C,IAAAgF,kBAAA,GAAgC3F,eAAe,CAAC;UAAER,QAAQ,EAAE;QAAM,CAAC,CAAC;QAA5DkG,QAAQ,GAAAC,kBAAA,CAARD,QAAQ;QAAEzE,SAAS,GAAA0E,kBAAA,CAAT1E,SAAS;MAE3BH,MAAM,CAACG,SAAS,CAAC,QAAQ,CAAC,CAAC,CAACF,iBAAiB,CAAC,CAAC;MAE/C,KAAK,IAAI6B,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAG,EAAE,EAAEA,CAAC,EAAE,EAAE;QAC3B8C,QAAQ,cACN3I,MAAA,YAAAyD,aAAA,CAACrD,OAAA,CAAAsD,aAAa;UAAChB,KAAK,EAAEA;QAAM,gBAC1B1C,MAAA,YAAAyD,aAAA,CAACpD,SAAA,CAAAqG,QAAQ;UAACF,WAAW,EAAEA,WAAY;UAAC/D,QAAQ,EAAEoD,CAAC,GAAG,CAAC,KAAK,CAAE;UAACY,QAAQ,EAAC;QAAI,CAAE,CAC7D,CACjB,CAAC;MACH;MAEA1C,MAAM,CAACG,SAAS,CAAC,QAAQ,CAAC,CAAC,CAACF,iBAAiB,CAAC,CAAC;IACjD,CAAC,CAAC;EACJ,CAAC,CAAC;EAEFnB,QAAQ,CAAC,qBAAqB,EAAE,YAAM;IACpCe,EAAE,CAAC,kCAAkC,EAAE,YAAM;MAC3C,IAAAiF,kBAAA,GAAsB5F,eAAe,CAAC,CAAC;QAA/B2D,SAAS,GAAAiC,kBAAA,CAATjC,SAAS;MACjB7C,MAAM,CAAC6C,SAAS,CAAC,CAAC5C,iBAAiB,CAAC,CAAC;IACvC,CAAC,CAAC;IAEFJ,EAAE,CAAC,iCAAiC,EAAE,YAAM;MAC1C,IAAAkF,kBAAA,GAAgC7F,eAAe,CAAC;UAAEwD,QAAQ,EAAE;QAAK,CAAC,CAAC;QAA3DkC,QAAQ,GAAAG,kBAAA,CAARH,QAAQ;QAAEzE,SAAS,GAAA4E,kBAAA,CAAT5E,SAAS;MAC3BH,MAAM,CAACG,SAAS,CAAC,QAAQ,CAAC,CAAC,CAACF,iBAAiB,CAAC,CAAC;MAE/C2E,QAAQ,cACN3I,MAAA,YAAAyD,aAAA,CAACrD,OAAA,CAAAsD,aAAa;QAAChB,KAAK,EAAEA;MAAM,gBAC1B1C,MAAA,YAAAyD,aAAA,CAACpD,SAAA,CAAAqG,QAAQ;QAACF,WAAW,EAAEA,WAAY;QAAC/D,QAAQ,EAAE,KAAM;QAACgE,QAAQ,EAAC;MAAI,CAAE,CACvD,CACjB,CAAC;MACD1C,MAAM,CAACG,SAAS,CAAC,QAAQ,CAAC,CAAC,CAACF,iBAAiB,CAAC,CAAC;IACjD,CAAC,CAAC;IAEFJ,EAAE,CAAC,oCAAoC,EAAE,YAAM;MAC7C,IAAAmF,kBAAA,GAAoB9F,eAAe,CAAC,CAAC;QAA7BuF,OAAO,GAAAO,kBAAA,CAAPP,OAAO;MACfzE,MAAM,CAAC;QAAA,OAAMyE,OAAO,CAAC,CAAC;MAAA,EAAC,CAAC5D,GAAG,CAAC6D,OAAO,CAAC,CAAC;IACvC,CAAC,CAAC;EACJ,CAAC,CAAC;EAEF5F,QAAQ,CAAC,eAAe,EAAE,YAAM;IAC9Be,EAAE,CAAC,uCAAuC,EAAE,YAAM;MAChD,IAAAoF,kBAAA,GAAsB/F,eAAe,CAAC,CAAC;QAA/BiB,SAAS,GAAA8E,kBAAA,CAAT9E,SAAS;MACjB,IAAME,MAAM,GAAGF,SAAS,CAAC,QAAQ,CAAC;MAClCH,MAAM,CAACK,MAAM,CAAC,CAACJ,iBAAiB,CAAC,CAAC;IACpC,CAAC,CAAC;IAEFJ,EAAE,CAAC,sCAAsC,EAAE,YAAM;MAC/C,IAAAqF,kBAAA,GAAsBhG,eAAe,CAAC,CAAC;QAA/BiB,SAAS,GAAA+E,kBAAA,CAAT/E,SAAS;MACjB,IAAME,MAAM,GAAGF,SAAS,CAAC,QAAQ,CAAC;MAClCH,MAAM,CAACK,MAAM,CAAC,CAAC8E,iBAAiB,CAAC,cAAc,CAAC;IAClD,CAAC,CAAC;IAEFtF,EAAE,CAAC,mDAAmD,EAAE,YAAM;MAC5D,IAAAuF,kBAAA,GAAsBlG,eAAe,CAAC;UAAER,QAAQ,EAAE;QAAM,CAAC,CAAC;QAAlDyB,SAAS,GAAAiF,kBAAA,CAATjF,SAAS;MACjB,IAAME,MAAM,GAAGF,SAAS,CAAC,QAAQ,CAAC;MAClCH,MAAM,CAACK,MAAM,CAAC,CAACQ,GAAG,CAACF,YAAY,CAAC,CAAC;MACjCX,MAAM,CAACK,MAAM,CAAC,CAAC8E,iBAAiB,CAAC,cAAc,CAAC;IAClD,CAAC,CAAC;EACJ,CAAC,CAAC;EAEFrG,QAAQ,CAAC,aAAa,EAAE,YAAM;IAC5Be,EAAE,CAAC,+CAA+C,EAAE,YAAM;MACxD,IAAMwF,iBAAiB,GAAGzH,IAAI,CAACI,EAAE,CAAC,CAAC;MACnC,IAAAsH,kBAAA,GAAsBpG,eAAe,CAAC;UACpCuD,WAAW,EAAE4C,iBAAiB;UAC9B3G,QAAQ,EAAE,KAAK;UACfgE,QAAQ,EAAE,IAAI;UACdvB,SAAS,EAAE;QACb,CAAC,CAAC;QALMhB,SAAS,GAAAmF,kBAAA,CAATnF,SAAS;MAOjB,IAAME,MAAM,GAAGF,SAAS,CAAC,QAAQ,CAAC;MAClCH,MAAM,CAACK,MAAM,CAAC,CAACJ,iBAAiB,CAAC,CAAC;MAElCc,iBAAS,CAACC,KAAK,CAACX,MAAM,CAAC;MACvBL,MAAM,CAACqF,iBAAiB,CAAC,CAAC7D,qBAAqB,CAAC,CAAC,CAAC;IACpD,CAAC,CAAC;IAEF3B,EAAE,CAAC,mDAAmD,EAAE,YAAM;MAC5D,IAAA0F,kBAAA,GAA6CrG,eAAe,CAAC;UAAER,QAAQ,EAAE;QAAM,CAAC,CAAC;QAAzEkG,QAAQ,GAAAW,kBAAA,CAARX,QAAQ;QAAEzE,SAAS,GAAAoF,kBAAA,CAATpF,SAAS;QAAEiD,WAAW,GAAAmC,kBAAA,CAAXnC,WAAW;MACxCpD,MAAM,CAACG,SAAS,CAAC,QAAQ,CAAC,CAAC,CAACF,iBAAiB,CAAC,CAAC;MAE/C2E,QAAQ,cACN3I,MAAA,YAAAyD,aAAA,CAACrD,OAAA,CAAAsD,aAAa;QAAChB,KAAK,EAAEA;MAAM,gBAC1B1C,MAAA,YAAAyD,aAAA,CAACpD,SAAA,CAAAqG,QAAQ;QAACF,WAAW,EAAEA,WAAY;QAAC/D,QAAQ,EAAE,IAAK;QAACgE,QAAQ,EAAC;MAAI,CAAE,CACtD,CACjB,CAAC;MACD1C,MAAM,CAACoD,WAAW,CAAC,QAAQ,CAAC,CAAC,CAACvC,GAAG,CAACZ,iBAAiB,CAAC,CAAC;IACvD,CAAC,CAAC;IAEFJ,EAAE,CAAC,kCAAkC,EAAE,YAAM;MAC3C,IAAMyD,UAAU,GAAGnH,OAAO,CAAC,qBAAqB,CAAC,WAAQ;MACzD,IAAAqJ,kBAAA,GAAqBtG,eAAe,CAAC;UAAEwD,QAAQ,EAAE;QAAK,CAAC,CAAC;QAAhDkC,QAAQ,GAAAY,kBAAA,CAARZ,QAAQ;MAEhBA,QAAQ,cACN3I,MAAA,YAAAyD,aAAA,CAACrD,OAAA,CAAAsD,aAAa;QAAChB,KAAK,EAAEA;MAAM,gBAC1B1C,MAAA,YAAAyD,aAAA,CAACpD,SAAA,CAAAqG,QAAQ;QAACF,WAAW,EAAEA,WAAY;QAAC/D,QAAQ,EAAE,KAAM;QAACgE,QAAQ,EAAC;MAAI,CAAE,CACvD,CACjB,CAAC;MAED1C,MAAM,CAACsD,UAAU,CAACvF,UAAU,CAACrB,CAAC,CAAC,CAAC8G,oBAAoB,CAAC,sBAAsB,EAAE;QAAEC,GAAG,EAAE;MAAK,CAAC,CAAC;IAC7F,CAAC,CAAC;EACJ,CAAC,CAAC;AACJ,CAAC,CAAC","ignoreList":[]}
|