@pie-lib/mask-markup 1.33.3-next.2 → 1.33.4-next.0
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 +6 -76
- package/lib/__tests__/drag-in-the-blank.test.js +129 -0
- package/lib/__tests__/index.test.js +42 -0
- package/lib/__tests__/mask.test.js +163 -0
- package/lib/__tests__/serialization.test.js +44 -0
- package/lib/__tests__/utils.js +14 -0
- package/lib/__tests__/with-mask.test.js +110 -0
- package/lib/choices/__tests__/index.test.js +101 -0
- package/lib/choices/choice.js +99 -204
- package/lib/choices/choice.js.map +1 -1
- package/lib/choices/index.js +22 -54
- package/lib/choices/index.js.map +1 -1
- package/lib/componentize.js +2 -6
- package/lib/componentize.js.map +1 -1
- package/lib/components/__tests__/blank.test.js +189 -0
- package/lib/components/__tests__/correct-input.test.js +132 -0
- package/lib/components/__tests__/dropdown.test.js +134 -0
- package/lib/components/__tests__/input.test.js +129 -0
- package/lib/components/blank.js +304 -362
- package/lib/components/blank.js.map +1 -1
- package/lib/components/correct-input.js +42 -66
- package/lib/components/correct-input.js.map +1 -1
- package/lib/components/dropdown.js +219 -258
- package/lib/components/dropdown.js.map +1 -1
- package/lib/components/input.js +11 -18
- package/lib/components/input.js.map +1 -1
- package/lib/constructed-response.js +39 -53
- package/lib/constructed-response.js.map +1 -1
- package/lib/customizable.js +6 -10
- package/lib/customizable.js.map +1 -1
- package/lib/drag-in-the-blank.js +141 -106
- package/lib/drag-in-the-blank.js.map +1 -1
- package/lib/index.js +1 -8
- package/lib/index.js.map +1 -1
- package/lib/inline-dropdown.js +5 -13
- package/lib/inline-dropdown.js.map +1 -1
- package/lib/mask.js +61 -119
- package/lib/mask.js.map +1 -1
- package/lib/serialization.js +9 -49
- package/lib/serialization.js.map +1 -1
- package/lib/with-mask.js +31 -59
- package/lib/with-mask.js.map +1 -1
- package/package.json +12 -20
- package/src/__tests__/drag-in-the-blank.test.js +66 -26
- package/src/__tests__/mask.test.js +147 -112
- package/src/__tests__/with-mask.test.js +44 -19
- package/src/choices/__tests__/index.test.js +38 -25
- package/src/choices/choice.jsx +86 -153
- package/src/choices/index.jsx +9 -3
- package/src/components/__tests__/blank.test.js +92 -156
- package/src/components/__tests__/correct-input.test.js +60 -19
- package/src/components/__tests__/dropdown.test.js +61 -19
- package/src/components/__tests__/input.test.js +72 -20
- package/src/components/blank.jsx +273 -272
- package/src/components/correct-input.jsx +33 -39
- package/src/components/dropdown.jsx +173 -161
- package/src/constructed-response.jsx +22 -18
- package/src/drag-in-the-blank.jsx +131 -42
- package/src/mask.jsx +38 -29
- package/src/with-mask.jsx +7 -4
- package/esm/index.css +0 -847
- package/esm/index.js +0 -195939
- package/esm/index.js.map +0 -1
- package/esm/package.json +0 -3
- package/src/__tests__/__snapshots__/drag-in-the-blank.test.js.snap +0 -316
- package/src/__tests__/__snapshots__/mask.test.js.snap +0 -55
- package/src/__tests__/__snapshots__/with-mask.test.js.snap +0 -62
- package/src/choices/__tests__/__snapshots__/index.test.js.snap +0 -209
- package/src/components/__tests__/__snapshots__/blank.test.js.snap +0 -111
- package/src/components/__tests__/__snapshots__/correct-input.test.js.snap +0 -64
- package/src/components/__tests__/__snapshots__/dropdown.test.js.snap +0 -136
- package/src/components/__tests__/__snapshots__/input.test.js.snap +0 -34
|
@@ -0,0 +1,132 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
5
|
+
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
6
|
+
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
7
|
+
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
|
|
8
|
+
var React = _interopRequireWildcard(require("react"));
|
|
9
|
+
var _react2 = require("@testing-library/react");
|
|
10
|
+
var _userEvent = _interopRequireDefault(require("@testing-library/user-event"));
|
|
11
|
+
var _correctInput = _interopRequireDefault(require("../correct-input"));
|
|
12
|
+
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); }
|
|
13
|
+
describe('CorrectInput', function () {
|
|
14
|
+
var onChange = jest.fn();
|
|
15
|
+
var defaultProps = {
|
|
16
|
+
disabled: false,
|
|
17
|
+
correct: false,
|
|
18
|
+
variant: 'outlined',
|
|
19
|
+
value: 'Cow',
|
|
20
|
+
onChange: onChange
|
|
21
|
+
};
|
|
22
|
+
beforeEach(function () {
|
|
23
|
+
onChange.mockClear();
|
|
24
|
+
});
|
|
25
|
+
describe('rendering', function () {
|
|
26
|
+
it('renders input with default props', function () {
|
|
27
|
+
(0, _react2.render)(/*#__PURE__*/React.createElement(_correctInput["default"], defaultProps));
|
|
28
|
+
var input = _react2.screen.getByRole('textbox');
|
|
29
|
+
expect(input).toBeInTheDocument();
|
|
30
|
+
expect(input).toHaveValue('Cow');
|
|
31
|
+
});
|
|
32
|
+
it('renders as disabled when disabled prop is true', function () {
|
|
33
|
+
(0, _react2.render)(/*#__PURE__*/React.createElement(_correctInput["default"], (0, _extends2["default"])({}, defaultProps, {
|
|
34
|
+
disabled: true
|
|
35
|
+
})));
|
|
36
|
+
var input = _react2.screen.getByRole('textbox');
|
|
37
|
+
expect(input).toBeDisabled();
|
|
38
|
+
});
|
|
39
|
+
it('renders with correct state as false', function () {
|
|
40
|
+
var _render = (0, _react2.render)(/*#__PURE__*/React.createElement(_correctInput["default"], (0, _extends2["default"])({}, defaultProps, {
|
|
41
|
+
correct: false
|
|
42
|
+
}))),
|
|
43
|
+
container = _render.container;
|
|
44
|
+
var input = _react2.screen.getByRole('textbox');
|
|
45
|
+
expect(input).toBeInTheDocument();
|
|
46
|
+
});
|
|
47
|
+
it('renders with correct state as true', function () {
|
|
48
|
+
var _render2 = (0, _react2.render)(/*#__PURE__*/React.createElement(_correctInput["default"], (0, _extends2["default"])({}, defaultProps, {
|
|
49
|
+
correct: true
|
|
50
|
+
}))),
|
|
51
|
+
container = _render2.container;
|
|
52
|
+
var input = _react2.screen.getByRole('textbox');
|
|
53
|
+
expect(input).toBeInTheDocument();
|
|
54
|
+
// Should show visual indication of correctness
|
|
55
|
+
});
|
|
56
|
+
it('renders with outlined variant', function () {
|
|
57
|
+
(0, _react2.render)(/*#__PURE__*/React.createElement(_correctInput["default"], (0, _extends2["default"])({}, defaultProps, {
|
|
58
|
+
variant: "outlined"
|
|
59
|
+
})));
|
|
60
|
+
var input = _react2.screen.getByRole('textbox');
|
|
61
|
+
expect(input).toBeInTheDocument();
|
|
62
|
+
});
|
|
63
|
+
});
|
|
64
|
+
describe('user interactions', function () {
|
|
65
|
+
it('calls onChange when user types', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee() {
|
|
66
|
+
var user, input;
|
|
67
|
+
return _regenerator["default"].wrap(function (_context) {
|
|
68
|
+
while (1) switch (_context.prev = _context.next) {
|
|
69
|
+
case 0:
|
|
70
|
+
user = _userEvent["default"].setup();
|
|
71
|
+
(0, _react2.render)(/*#__PURE__*/React.createElement(_correctInput["default"], defaultProps));
|
|
72
|
+
input = _react2.screen.getByRole('textbox');
|
|
73
|
+
_context.next = 1;
|
|
74
|
+
return user.clear(input);
|
|
75
|
+
case 1:
|
|
76
|
+
_context.next = 2;
|
|
77
|
+
return user.type(input, '1');
|
|
78
|
+
case 2:
|
|
79
|
+
expect(onChange).toHaveBeenCalled();
|
|
80
|
+
case 3:
|
|
81
|
+
case "end":
|
|
82
|
+
return _context.stop();
|
|
83
|
+
}
|
|
84
|
+
}, _callee);
|
|
85
|
+
})));
|
|
86
|
+
it('calls onChange with event object', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee2() {
|
|
87
|
+
var user, input, lastCall;
|
|
88
|
+
return _regenerator["default"].wrap(function (_context2) {
|
|
89
|
+
while (1) switch (_context2.prev = _context2.next) {
|
|
90
|
+
case 0:
|
|
91
|
+
user = _userEvent["default"].setup();
|
|
92
|
+
(0, _react2.render)(/*#__PURE__*/React.createElement(_correctInput["default"], (0, _extends2["default"])({}, defaultProps, {
|
|
93
|
+
value: ""
|
|
94
|
+
})));
|
|
95
|
+
input = _react2.screen.getByRole('textbox');
|
|
96
|
+
_context2.next = 1;
|
|
97
|
+
return user.type(input, 'test');
|
|
98
|
+
case 1:
|
|
99
|
+
expect(onChange).toHaveBeenCalled();
|
|
100
|
+
// Check that onChange receives an event-like object
|
|
101
|
+
lastCall = onChange.mock.calls[onChange.mock.calls.length - 1][0];
|
|
102
|
+
expect(lastCall).toHaveProperty('target');
|
|
103
|
+
case 2:
|
|
104
|
+
case "end":
|
|
105
|
+
return _context2.stop();
|
|
106
|
+
}
|
|
107
|
+
}, _callee2);
|
|
108
|
+
})));
|
|
109
|
+
it('updates value when user changes input', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee3() {
|
|
110
|
+
var user, input;
|
|
111
|
+
return _regenerator["default"].wrap(function (_context3) {
|
|
112
|
+
while (1) switch (_context3.prev = _context3.next) {
|
|
113
|
+
case 0:
|
|
114
|
+
user = _userEvent["default"].setup();
|
|
115
|
+
(0, _react2.render)(/*#__PURE__*/React.createElement(_correctInput["default"], defaultProps));
|
|
116
|
+
input = _react2.screen.getByRole('textbox');
|
|
117
|
+
_context3.next = 1;
|
|
118
|
+
return user.clear(input);
|
|
119
|
+
case 1:
|
|
120
|
+
_context3.next = 2;
|
|
121
|
+
return user.type(input, 'Dog');
|
|
122
|
+
case 2:
|
|
123
|
+
expect(onChange).toHaveBeenCalled();
|
|
124
|
+
case 3:
|
|
125
|
+
case "end":
|
|
126
|
+
return _context3.stop();
|
|
127
|
+
}
|
|
128
|
+
}, _callee3);
|
|
129
|
+
})));
|
|
130
|
+
});
|
|
131
|
+
});
|
|
132
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","_interopRequireWildcard","require","_react2","_userEvent","_interopRequireDefault","_correctInput","e","t","WeakMap","r","n","__esModule","o","i","f","__proto__","_typeof","has","get","set","_t","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","describe","onChange","jest","fn","defaultProps","disabled","correct","variant","value","beforeEach","mockClear","it","render","createElement","input","screen","getByRole","expect","toBeInTheDocument","toHaveValue","_extends2","toBeDisabled","_render","container","_render2","_asyncToGenerator2","_regenerator","mark","_callee","user","wrap","_context","prev","next","userEvent","setup","clear","type","toHaveBeenCalled","stop","_callee2","lastCall","_context2","mock","calls","length","toHaveProperty","_callee3","_context3"],"sources":["../../../src/components/__tests__/correct-input.test.js"],"sourcesContent":["import * as React from 'react';\nimport { render, screen } from '@testing-library/react';\nimport userEvent from '@testing-library/user-event';\nimport CorrectInput from '../correct-input';\n\ndescribe('CorrectInput', () => {\n  const onChange = jest.fn();\n  const defaultProps = {\n    disabled: false,\n    correct: false,\n    variant: 'outlined',\n    value: 'Cow',\n    onChange,\n  };\n\n  beforeEach(() => {\n    onChange.mockClear();\n  });\n\n  describe('rendering', () => {\n    it('renders input with default props', () => {\n      render(<CorrectInput {...defaultProps} />);\n      const input = screen.getByRole('textbox');\n      expect(input).toBeInTheDocument();\n      expect(input).toHaveValue('Cow');\n    });\n\n    it('renders as disabled when disabled prop is true', () => {\n      render(<CorrectInput {...defaultProps} disabled={true} />);\n      const input = screen.getByRole('textbox');\n      expect(input).toBeDisabled();\n    });\n\n    it('renders with correct state as false', () => {\n      const { container } = render(<CorrectInput {...defaultProps} correct={false} />);\n      const input = screen.getByRole('textbox');\n      expect(input).toBeInTheDocument();\n    });\n\n    it('renders with correct state as true', () => {\n      const { container } = render(<CorrectInput {...defaultProps} correct={true} />);\n      const input = screen.getByRole('textbox');\n      expect(input).toBeInTheDocument();\n      // Should show visual indication of correctness\n    });\n\n    it('renders with outlined variant', () => {\n      render(<CorrectInput {...defaultProps} variant=\"outlined\" />);\n      const input = screen.getByRole('textbox');\n      expect(input).toBeInTheDocument();\n    });\n  });\n\n  describe('user interactions', () => {\n    it('calls onChange when user types', async () => {\n      const user = userEvent.setup();\n      render(<CorrectInput {...defaultProps} />);\n\n      const input = screen.getByRole('textbox');\n      await user.clear(input);\n      await user.type(input, '1');\n\n      expect(onChange).toHaveBeenCalled();\n    });\n\n    it('calls onChange with event object', async () => {\n      const user = userEvent.setup();\n      render(<CorrectInput {...defaultProps} value=\"\" />);\n\n      const input = screen.getByRole('textbox');\n      await user.type(input, 'test');\n\n      expect(onChange).toHaveBeenCalled();\n      // Check that onChange receives an event-like object\n      const lastCall = onChange.mock.calls[onChange.mock.calls.length - 1][0];\n      expect(lastCall).toHaveProperty('target');\n    });\n\n    it('updates value when user changes input', async () => {\n      const user = userEvent.setup();\n      render(<CorrectInput {...defaultProps} />);\n\n      const input = screen.getByRole('textbox');\n      await user.clear(input);\n      await user.type(input, 'Dog');\n\n      expect(onChange).toHaveBeenCalled();\n    });\n  });\n});\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,134 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
5
|
+
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
6
|
+
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
|
|
7
|
+
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
8
|
+
var React = _interopRequireWildcard(require("react"));
|
|
9
|
+
var _react2 = require("@testing-library/react");
|
|
10
|
+
var _userEvent = _interopRequireDefault(require("@testing-library/user-event"));
|
|
11
|
+
var _utils = require("../../__tests__/utils");
|
|
12
|
+
var _dropdown = _interopRequireDefault(require("../dropdown"));
|
|
13
|
+
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); }
|
|
14
|
+
describe('Dropdown', function () {
|
|
15
|
+
var onChange = jest.fn();
|
|
16
|
+
var defaultProps = {
|
|
17
|
+
onChange: onChange,
|
|
18
|
+
id: '1',
|
|
19
|
+
correct: false,
|
|
20
|
+
disabled: false,
|
|
21
|
+
value: 'Jumped',
|
|
22
|
+
choices: [(0, _utils.choice)('Jumped'), (0, _utils.choice)('Laughed'), (0, _utils.choice)('Smiled')]
|
|
23
|
+
};
|
|
24
|
+
beforeEach(function () {
|
|
25
|
+
onChange.mockClear();
|
|
26
|
+
});
|
|
27
|
+
describe('rendering', function () {
|
|
28
|
+
it('renders dropdown with default props', function () {
|
|
29
|
+
(0, _react2.render)(/*#__PURE__*/React.createElement(_dropdown["default"], defaultProps));
|
|
30
|
+
var button = _react2.screen.getByRole('combobox');
|
|
31
|
+
expect(button).toBeInTheDocument();
|
|
32
|
+
// Button displays the selected value
|
|
33
|
+
expect(button).toHaveTextContent('Jumped');
|
|
34
|
+
});
|
|
35
|
+
it('renders with all choices as options when opened', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee() {
|
|
36
|
+
var user, button, options;
|
|
37
|
+
return _regenerator["default"].wrap(function (_context) {
|
|
38
|
+
while (1) switch (_context.prev = _context.next) {
|
|
39
|
+
case 0:
|
|
40
|
+
user = _userEvent["default"].setup();
|
|
41
|
+
(0, _react2.render)(/*#__PURE__*/React.createElement(_dropdown["default"], defaultProps));
|
|
42
|
+
button = _react2.screen.getByRole('combobox');
|
|
43
|
+
_context.next = 1;
|
|
44
|
+
return user.click(button);
|
|
45
|
+
case 1:
|
|
46
|
+
// Options should now be visible - find them by role
|
|
47
|
+
options = _react2.screen.getAllByRole('option');
|
|
48
|
+
expect(options).toHaveLength(3);
|
|
49
|
+
// Verify the text content of options using specific elements
|
|
50
|
+
expect(options[0]).toHaveTextContent('Jumped');
|
|
51
|
+
expect(options[1]).toHaveTextContent('Laughed');
|
|
52
|
+
expect(options[2]).toHaveTextContent('Smiled');
|
|
53
|
+
case 2:
|
|
54
|
+
case "end":
|
|
55
|
+
return _context.stop();
|
|
56
|
+
}
|
|
57
|
+
}, _callee);
|
|
58
|
+
})));
|
|
59
|
+
it('renders as disabled when disabled prop is true', function () {
|
|
60
|
+
(0, _react2.render)(/*#__PURE__*/React.createElement(_dropdown["default"], (0, _extends2["default"])({}, defaultProps, {
|
|
61
|
+
disabled: true
|
|
62
|
+
})));
|
|
63
|
+
var button = _react2.screen.getByRole('combobox');
|
|
64
|
+
expect(button).toBeDisabled();
|
|
65
|
+
});
|
|
66
|
+
it('shows correct state when correct is true', function () {
|
|
67
|
+
var _render = (0, _react2.render)(/*#__PURE__*/React.createElement(_dropdown["default"], (0, _extends2["default"])({}, defaultProps, {
|
|
68
|
+
correct: true
|
|
69
|
+
}))),
|
|
70
|
+
container = _render.container;
|
|
71
|
+
var button = _react2.screen.getByRole('combobox');
|
|
72
|
+
expect(button).toBeInTheDocument();
|
|
73
|
+
});
|
|
74
|
+
});
|
|
75
|
+
describe('user interactions', function () {
|
|
76
|
+
it('calls onChange when user selects a different option', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee2() {
|
|
77
|
+
var user, button, options, laughedOption;
|
|
78
|
+
return _regenerator["default"].wrap(function (_context2) {
|
|
79
|
+
while (1) switch (_context2.prev = _context2.next) {
|
|
80
|
+
case 0:
|
|
81
|
+
user = _userEvent["default"].setup();
|
|
82
|
+
(0, _react2.render)(/*#__PURE__*/React.createElement(_dropdown["default"], defaultProps));
|
|
83
|
+
|
|
84
|
+
// Click button to open menu
|
|
85
|
+
button = _react2.screen.getByRole('combobox');
|
|
86
|
+
_context2.next = 1;
|
|
87
|
+
return user.click(button);
|
|
88
|
+
case 1:
|
|
89
|
+
// Find the option by getting all options and selecting the one with "Laughed" text
|
|
90
|
+
options = _react2.screen.getAllByRole('option');
|
|
91
|
+
laughedOption = options.find(function (opt) {
|
|
92
|
+
return opt.textContent.includes('Laughed');
|
|
93
|
+
});
|
|
94
|
+
_context2.next = 2;
|
|
95
|
+
return user.click(laughedOption);
|
|
96
|
+
case 2:
|
|
97
|
+
expect(onChange).toHaveBeenCalledWith('1', 'Laughed');
|
|
98
|
+
case 3:
|
|
99
|
+
case "end":
|
|
100
|
+
return _context2.stop();
|
|
101
|
+
}
|
|
102
|
+
}, _callee2);
|
|
103
|
+
})));
|
|
104
|
+
it('calls onChange with correct value', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee3() {
|
|
105
|
+
var user, button, options, smiledOption;
|
|
106
|
+
return _regenerator["default"].wrap(function (_context3) {
|
|
107
|
+
while (1) switch (_context3.prev = _context3.next) {
|
|
108
|
+
case 0:
|
|
109
|
+
user = _userEvent["default"].setup();
|
|
110
|
+
(0, _react2.render)(/*#__PURE__*/React.createElement(_dropdown["default"], defaultProps));
|
|
111
|
+
|
|
112
|
+
// Click button to open menu
|
|
113
|
+
button = _react2.screen.getByRole('combobox');
|
|
114
|
+
_context3.next = 1;
|
|
115
|
+
return user.click(button);
|
|
116
|
+
case 1:
|
|
117
|
+
// Find the option by getting all options and selecting the one with "Smiled" text
|
|
118
|
+
options = _react2.screen.getAllByRole('option');
|
|
119
|
+
smiledOption = options.find(function (opt) {
|
|
120
|
+
return opt.textContent.includes('Smiled');
|
|
121
|
+
});
|
|
122
|
+
_context3.next = 2;
|
|
123
|
+
return user.click(smiledOption);
|
|
124
|
+
case 2:
|
|
125
|
+
expect(onChange).toHaveBeenCalledWith('1', 'Smiled');
|
|
126
|
+
case 3:
|
|
127
|
+
case "end":
|
|
128
|
+
return _context3.stop();
|
|
129
|
+
}
|
|
130
|
+
}, _callee3);
|
|
131
|
+
})));
|
|
132
|
+
});
|
|
133
|
+
});
|
|
134
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","_interopRequireWildcard","require","_react2","_userEvent","_interopRequireDefault","_utils","_dropdown","e","t","WeakMap","r","n","__esModule","o","i","f","__proto__","_typeof","has","get","set","_t","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","describe","onChange","jest","fn","defaultProps","id","correct","disabled","value","choices","choice","beforeEach","mockClear","it","render","createElement","button","screen","getByRole","expect","toBeInTheDocument","toHaveTextContent","_asyncToGenerator2","_regenerator","mark","_callee","user","options","wrap","_context","prev","next","userEvent","setup","click","getAllByRole","toHaveLength","stop","_extends2","toBeDisabled","_render","container","_callee2","laughedOption","_context2","find","opt","textContent","includes","toHaveBeenCalledWith","_callee3","smiledOption","_context3"],"sources":["../../../src/components/__tests__/dropdown.test.js"],"sourcesContent":["import * as React from 'react';\nimport { render, screen } from '@testing-library/react';\nimport userEvent from '@testing-library/user-event';\nimport { choice } from '../../__tests__/utils';\nimport Dropdown from '../dropdown';\n\ndescribe('Dropdown', () => {\n  const onChange = jest.fn();\n  const defaultProps = {\n    onChange,\n    id: '1',\n    correct: false,\n    disabled: false,\n    value: 'Jumped',\n    choices: [choice('Jumped'), choice('Laughed'), choice('Smiled')],\n  };\n\n  beforeEach(() => {\n    onChange.mockClear();\n  });\n\n  describe('rendering', () => {\n    it('renders dropdown with default props', () => {\n      render(<Dropdown {...defaultProps} />);\n      const button = screen.getByRole('combobox');\n      expect(button).toBeInTheDocument();\n      // Button displays the selected value\n      expect(button).toHaveTextContent('Jumped');\n    });\n\n    it('renders with all choices as options when opened', async () => {\n      const user = userEvent.setup();\n      render(<Dropdown {...defaultProps} />);\n\n      const button = screen.getByRole('combobox');\n      await user.click(button);\n\n      // Options should now be visible - find them by role\n      const options = screen.getAllByRole('option');\n      expect(options).toHaveLength(3);\n      // Verify the text content of options using specific elements\n      expect(options[0]).toHaveTextContent('Jumped');\n      expect(options[1]).toHaveTextContent('Laughed');\n      expect(options[2]).toHaveTextContent('Smiled');\n    });\n\n    it('renders as disabled when disabled prop is true', () => {\n      render(<Dropdown {...defaultProps} disabled={true} />);\n      const button = screen.getByRole('combobox');\n      expect(button).toBeDisabled();\n    });\n\n    it('shows correct state when correct is true', () => {\n      const { container } = render(<Dropdown {...defaultProps} correct={true} />);\n      const button = screen.getByRole('combobox');\n      expect(button).toBeInTheDocument();\n    });\n  });\n\n  describe('user interactions', () => {\n    it('calls onChange when user selects a different option', async () => {\n      const user = userEvent.setup();\n      render(<Dropdown {...defaultProps} />);\n\n      // Click button to open menu\n      const button = screen.getByRole('combobox');\n      await user.click(button);\n\n      // Find the option by getting all options and selecting the one with \"Laughed\" text\n      const options = screen.getAllByRole('option');\n      const laughedOption = options.find(opt => opt.textContent.includes('Laughed'));\n      await user.click(laughedOption);\n\n      expect(onChange).toHaveBeenCalledWith('1', 'Laughed');\n    });\n\n    it('calls onChange with correct value', async () => {\n      const user = userEvent.setup();\n      render(<Dropdown {...defaultProps} />);\n\n      // Click button to open menu\n      const button = screen.getByRole('combobox');\n      await user.click(button);\n\n      // Find the option by getting all options and selecting the one with \"Smiled\" text\n      const options = screen.getAllByRole('option');\n      const smiledOption = options.find(opt => opt.textContent.includes('Smiled'));\n      await user.click(smiledOption);\n\n      expect(onChange).toHaveBeenCalledWith('1', 'Smiled');\n    });\n  });\n});\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,129 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
5
|
+
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
6
|
+
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
7
|
+
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
|
|
8
|
+
var React = _interopRequireWildcard(require("react"));
|
|
9
|
+
var _react2 = require("@testing-library/react");
|
|
10
|
+
var _userEvent = _interopRequireDefault(require("@testing-library/user-event"));
|
|
11
|
+
var _input = _interopRequireDefault(require("../input"));
|
|
12
|
+
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); }
|
|
13
|
+
// Mock CorrectInput to simplify testing
|
|
14
|
+
jest.mock('../correct-input', function () {
|
|
15
|
+
return function CorrectInput(_ref) {
|
|
16
|
+
var value = _ref.value,
|
|
17
|
+
onChange = _ref.onChange,
|
|
18
|
+
disabled = _ref.disabled,
|
|
19
|
+
correct = _ref.correct,
|
|
20
|
+
variant = _ref.variant;
|
|
21
|
+
return /*#__PURE__*/React.createElement("input", {
|
|
22
|
+
"data-testid": "correct-input",
|
|
23
|
+
value: value || '',
|
|
24
|
+
onChange: onChange,
|
|
25
|
+
disabled: disabled,
|
|
26
|
+
"data-correct": correct,
|
|
27
|
+
"data-variant": variant
|
|
28
|
+
});
|
|
29
|
+
};
|
|
30
|
+
});
|
|
31
|
+
describe('Input', function () {
|
|
32
|
+
var onChange = jest.fn();
|
|
33
|
+
var defaultProps = {
|
|
34
|
+
disabled: false,
|
|
35
|
+
correct: false,
|
|
36
|
+
value: 'Cow',
|
|
37
|
+
id: '1',
|
|
38
|
+
onChange: onChange
|
|
39
|
+
};
|
|
40
|
+
beforeEach(function () {
|
|
41
|
+
onChange.mockClear();
|
|
42
|
+
});
|
|
43
|
+
describe('rendering', function () {
|
|
44
|
+
it('renders with default props', function () {
|
|
45
|
+
(0, _react2.render)(/*#__PURE__*/React.createElement(_input["default"], defaultProps));
|
|
46
|
+
var input = _react2.screen.getByTestId('correct-input');
|
|
47
|
+
expect(input).toBeInTheDocument();
|
|
48
|
+
expect(input).toHaveValue('Cow');
|
|
49
|
+
expect(input).not.toBeDisabled();
|
|
50
|
+
expect(input).toHaveAttribute('data-correct', 'false');
|
|
51
|
+
});
|
|
52
|
+
it('renders as disabled when disabled prop is true', function () {
|
|
53
|
+
(0, _react2.render)(/*#__PURE__*/React.createElement(_input["default"], (0, _extends2["default"])({}, defaultProps, {
|
|
54
|
+
disabled: true
|
|
55
|
+
})));
|
|
56
|
+
var input = _react2.screen.getByTestId('correct-input');
|
|
57
|
+
expect(input).toBeDisabled();
|
|
58
|
+
});
|
|
59
|
+
it('renders with correct state', function () {
|
|
60
|
+
(0, _react2.render)(/*#__PURE__*/React.createElement(_input["default"], (0, _extends2["default"])({}, defaultProps, {
|
|
61
|
+
correct: true
|
|
62
|
+
})));
|
|
63
|
+
var input = _react2.screen.getByTestId('correct-input');
|
|
64
|
+
expect(input).toHaveAttribute('data-correct', 'true');
|
|
65
|
+
});
|
|
66
|
+
it('shows correct answer when showCorrectAnswer is true', function () {
|
|
67
|
+
(0, _react2.render)(/*#__PURE__*/React.createElement(_input["default"], (0, _extends2["default"])({}, defaultProps, {
|
|
68
|
+
showCorrectAnswer: true
|
|
69
|
+
})));
|
|
70
|
+
var input = _react2.screen.getByTestId('correct-input');
|
|
71
|
+
expect(input).toHaveAttribute('data-correct', 'true');
|
|
72
|
+
});
|
|
73
|
+
});
|
|
74
|
+
describe('user interactions', function () {
|
|
75
|
+
it('calls onChange with id and value when user types', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee() {
|
|
76
|
+
var user, input;
|
|
77
|
+
return _regenerator["default"].wrap(function (_context) {
|
|
78
|
+
while (1) switch (_context.prev = _context.next) {
|
|
79
|
+
case 0:
|
|
80
|
+
user = _userEvent["default"].setup();
|
|
81
|
+
(0, _react2.render)(/*#__PURE__*/React.createElement(_input["default"], (0, _extends2["default"])({}, defaultProps, {
|
|
82
|
+
value: ""
|
|
83
|
+
})));
|
|
84
|
+
input = _react2.screen.getByTestId('correct-input');
|
|
85
|
+
_context.next = 1;
|
|
86
|
+
return user.type(input, '20');
|
|
87
|
+
case 1:
|
|
88
|
+
// userEvent.type types character by character, so onChange is called for each character
|
|
89
|
+
expect(onChange).toHaveBeenCalled();
|
|
90
|
+
expect(onChange).toHaveBeenCalledTimes(2);
|
|
91
|
+
// Check the last call has both characters
|
|
92
|
+
expect(onChange).toHaveBeenLastCalledWith('1', '0');
|
|
93
|
+
case 2:
|
|
94
|
+
case "end":
|
|
95
|
+
return _context.stop();
|
|
96
|
+
}
|
|
97
|
+
}, _callee);
|
|
98
|
+
})));
|
|
99
|
+
it('calls onChange with updated value', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee2() {
|
|
100
|
+
var user, input;
|
|
101
|
+
return _regenerator["default"].wrap(function (_context2) {
|
|
102
|
+
while (1) switch (_context2.prev = _context2.next) {
|
|
103
|
+
case 0:
|
|
104
|
+
user = _userEvent["default"].setup();
|
|
105
|
+
(0, _react2.render)(/*#__PURE__*/React.createElement(_input["default"], defaultProps));
|
|
106
|
+
input = _react2.screen.getByTestId('correct-input');
|
|
107
|
+
_context2.next = 1;
|
|
108
|
+
return user.clear(input);
|
|
109
|
+
case 1:
|
|
110
|
+
_context2.next = 2;
|
|
111
|
+
return user.type(input, 'New Value');
|
|
112
|
+
case 2:
|
|
113
|
+
// userEvent.type types character by character
|
|
114
|
+
// After clear, we start with empty string, and each character is typed
|
|
115
|
+
// The last call should have the full accumulated value up to the last character
|
|
116
|
+
expect(onChange).toHaveBeenCalled();
|
|
117
|
+
// With clear + "New Value", onChange is called for clearing ("") and each typed character
|
|
118
|
+
// The value accumulated in the input element after typing will be "CowNew Value"
|
|
119
|
+
// because the component starts with value="Cow" and we clear then type
|
|
120
|
+
expect(onChange.mock.calls.length).toBeGreaterThan(0);
|
|
121
|
+
case 3:
|
|
122
|
+
case "end":
|
|
123
|
+
return _context2.stop();
|
|
124
|
+
}
|
|
125
|
+
}, _callee2);
|
|
126
|
+
})));
|
|
127
|
+
});
|
|
128
|
+
});
|
|
129
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","_interopRequireWildcard","require","_react2","_userEvent","_interopRequireDefault","_input","e","t","WeakMap","r","n","__esModule","o","i","f","__proto__","_typeof","has","get","set","_t","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","jest","mock","CorrectInput","_ref","value","onChange","disabled","correct","variant","createElement","describe","fn","defaultProps","id","beforeEach","mockClear","it","render","input","screen","getByTestId","expect","toBeInTheDocument","toHaveValue","not","toBeDisabled","toHaveAttribute","_extends2","showCorrectAnswer","_asyncToGenerator2","_regenerator","mark","_callee","user","wrap","_context","prev","next","userEvent","setup","type","toHaveBeenCalled","toHaveBeenCalledTimes","toHaveBeenLastCalledWith","stop","_callee2","_context2","clear","calls","length","toBeGreaterThan"],"sources":["../../../src/components/__tests__/input.test.js"],"sourcesContent":["import * as React from 'react';\nimport { render, screen } from '@testing-library/react';\nimport userEvent from '@testing-library/user-event';\nimport Input from '../input';\n\n// Mock CorrectInput to simplify testing\njest.mock('../correct-input', () => {\n  return function CorrectInput({ value, onChange, disabled, correct, variant }) {\n    return (\n      <input\n        data-testid=\"correct-input\"\n        value={value || ''}\n        onChange={onChange}\n        disabled={disabled}\n        data-correct={correct}\n        data-variant={variant}\n      />\n    );\n  };\n});\n\ndescribe('Input', () => {\n  const onChange = jest.fn();\n  const defaultProps = {\n    disabled: false,\n    correct: false,\n    value: 'Cow',\n    id: '1',\n    onChange,\n  };\n\n  beforeEach(() => {\n    onChange.mockClear();\n  });\n\n  describe('rendering', () => {\n    it('renders with default props', () => {\n      render(<Input {...defaultProps} />);\n      const input = screen.getByTestId('correct-input');\n\n      expect(input).toBeInTheDocument();\n      expect(input).toHaveValue('Cow');\n      expect(input).not.toBeDisabled();\n      expect(input).toHaveAttribute('data-correct', 'false');\n    });\n\n    it('renders as disabled when disabled prop is true', () => {\n      render(<Input {...defaultProps} disabled={true} />);\n      const input = screen.getByTestId('correct-input');\n\n      expect(input).toBeDisabled();\n    });\n\n    it('renders with correct state', () => {\n      render(<Input {...defaultProps} correct={true} />);\n      const input = screen.getByTestId('correct-input');\n\n      expect(input).toHaveAttribute('data-correct', 'true');\n    });\n\n    it('shows correct answer when showCorrectAnswer is true', () => {\n      render(<Input {...defaultProps} showCorrectAnswer={true} />);\n      const input = screen.getByTestId('correct-input');\n\n      expect(input).toHaveAttribute('data-correct', 'true');\n    });\n  });\n\n  describe('user interactions', () => {\n    it('calls onChange with id and value when user types', async () => {\n      const user = userEvent.setup();\n      render(<Input {...defaultProps} value=\"\" />);\n\n      const input = screen.getByTestId('correct-input');\n      await user.type(input, '20');\n\n      // userEvent.type types character by character, so onChange is called for each character\n      expect(onChange).toHaveBeenCalled();\n      expect(onChange).toHaveBeenCalledTimes(2);\n      // Check the last call has both characters\n      expect(onChange).toHaveBeenLastCalledWith('1', '0');\n    });\n\n    it('calls onChange with updated value', async () => {\n      const user = userEvent.setup();\n      render(<Input {...defaultProps} />);\n\n      const input = screen.getByTestId('correct-input');\n      await user.clear(input);\n      await user.type(input, 'New Value');\n\n      // userEvent.type types character by character\n      // After clear, we start with empty string, and each character is typed\n      // The last call should have the full accumulated value up to the last character\n      expect(onChange).toHaveBeenCalled();\n      // With clear + \"New Value\", onChange is called for clearing (\"\") and each typed character\n      // The value accumulated in the input element after typing will be \"CowNew Value\"\n      // because the component starts with value=\"Cow\" and we clear then type\n      expect(onChange.mock.calls.length).toBeGreaterThan(0);\n    });\n  });\n});\n"],"mappings":";;;;;;;AAAA,IAAAA,KAAA,GAAAC,uBAAA,CAAAC,OAAA;AACA,IAAAC,OAAA,GAAAD,OAAA;AACA,IAAAE,UAAA,GAAAC,sBAAA,CAAAH,OAAA;AACA,IAAAI,MAAA,GAAAD,sBAAA,CAAAH,OAAA;AAA6B,SAAAD,wBAAAM,CAAA,EAAAC,CAAA,6BAAAC,OAAA,MAAAC,CAAA,OAAAD,OAAA,IAAAE,CAAA,OAAAF,OAAA,YAAAR,uBAAA,YAAAA,wBAAAM,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;AAE7B;AACAmB,IAAI,CAACC,IAAI,CAAC,kBAAkB,EAAE,YAAM;EAClC,OAAO,SAASC,YAAYA,CAAAC,IAAA,EAAkD;IAAA,IAA/CC,KAAK,GAAAD,IAAA,CAALC,KAAK;MAAEC,QAAQ,GAAAF,IAAA,CAARE,QAAQ;MAAEC,QAAQ,GAAAH,IAAA,CAARG,QAAQ;MAAEC,OAAO,GAAAJ,IAAA,CAAPI,OAAO;MAAEC,OAAO,GAAAL,IAAA,CAAPK,OAAO;IACxE,oBACEnC,KAAA,CAAAoC,aAAA;MACE,eAAY,eAAe;MAC3BL,KAAK,EAAEA,KAAK,IAAI,EAAG;MACnBC,QAAQ,EAAEA,QAAS;MACnBC,QAAQ,EAAEA,QAAS;MACnB,gBAAcC,OAAQ;MACtB,gBAAcC;IAAQ,CACvB,CAAC;EAEN,CAAC;AACH,CAAC,CAAC;AAEFE,QAAQ,CAAC,OAAO,EAAE,YAAM;EACtB,IAAML,QAAQ,GAAGL,IAAI,CAACW,EAAE,CAAC,CAAC;EAC1B,IAAMC,YAAY,GAAG;IACnBN,QAAQ,EAAE,KAAK;IACfC,OAAO,EAAE,KAAK;IACdH,KAAK,EAAE,KAAK;IACZS,EAAE,EAAE,GAAG;IACPR,QAAQ,EAARA;EACF,CAAC;EAEDS,UAAU,CAAC,YAAM;IACfT,QAAQ,CAACU,SAAS,CAAC,CAAC;EACtB,CAAC,CAAC;EAEFL,QAAQ,CAAC,WAAW,EAAE,YAAM;IAC1BM,EAAE,CAAC,4BAA4B,EAAE,YAAM;MACrC,IAAAC,cAAM,eAAC5C,KAAA,CAAAoC,aAAA,CAAC9B,MAAA,WAAK,EAAKiC,YAAe,CAAC,CAAC;MACnC,IAAMM,KAAK,GAAGC,cAAM,CAACC,WAAW,CAAC,eAAe,CAAC;MAEjDC,MAAM,CAACH,KAAK,CAAC,CAACI,iBAAiB,CAAC,CAAC;MACjCD,MAAM,CAACH,KAAK,CAAC,CAACK,WAAW,CAAC,KAAK,CAAC;MAChCF,MAAM,CAACH,KAAK,CAAC,CAACM,GAAG,CAACC,YAAY,CAAC,CAAC;MAChCJ,MAAM,CAACH,KAAK,CAAC,CAACQ,eAAe,CAAC,cAAc,EAAE,OAAO,CAAC;IACxD,CAAC,CAAC;IAEFV,EAAE,CAAC,gDAAgD,EAAE,YAAM;MACzD,IAAAC,cAAM,eAAC5C,KAAA,CAAAoC,aAAA,CAAC9B,MAAA,WAAK,MAAAgD,SAAA,iBAAKf,YAAY;QAAEN,QAAQ,EAAE;MAAK,EAAE,CAAC,CAAC;MACnD,IAAMY,KAAK,GAAGC,cAAM,CAACC,WAAW,CAAC,eAAe,CAAC;MAEjDC,MAAM,CAACH,KAAK,CAAC,CAACO,YAAY,CAAC,CAAC;IAC9B,CAAC,CAAC;IAEFT,EAAE,CAAC,4BAA4B,EAAE,YAAM;MACrC,IAAAC,cAAM,eAAC5C,KAAA,CAAAoC,aAAA,CAAC9B,MAAA,WAAK,MAAAgD,SAAA,iBAAKf,YAAY;QAAEL,OAAO,EAAE;MAAK,EAAE,CAAC,CAAC;MAClD,IAAMW,KAAK,GAAGC,cAAM,CAACC,WAAW,CAAC,eAAe,CAAC;MAEjDC,MAAM,CAACH,KAAK,CAAC,CAACQ,eAAe,CAAC,cAAc,EAAE,MAAM,CAAC;IACvD,CAAC,CAAC;IAEFV,EAAE,CAAC,qDAAqD,EAAE,YAAM;MAC9D,IAAAC,cAAM,eAAC5C,KAAA,CAAAoC,aAAA,CAAC9B,MAAA,WAAK,MAAAgD,SAAA,iBAAKf,YAAY;QAAEgB,iBAAiB,EAAE;MAAK,EAAE,CAAC,CAAC;MAC5D,IAAMV,KAAK,GAAGC,cAAM,CAACC,WAAW,CAAC,eAAe,CAAC;MAEjDC,MAAM,CAACH,KAAK,CAAC,CAACQ,eAAe,CAAC,cAAc,EAAE,MAAM,CAAC;IACvD,CAAC,CAAC;EACJ,CAAC,CAAC;EAEFhB,QAAQ,CAAC,mBAAmB,EAAE,YAAM;IAClCM,EAAE,CAAC,kDAAkD,mBAAAa,kBAAA,0BAAAC,YAAA,YAAAC,IAAA,CAAE,SAAAC,QAAA;MAAA,IAAAC,IAAA,EAAAf,KAAA;MAAA,OAAAY,YAAA,YAAAI,IAAA,WAAAC,QAAA;QAAA,kBAAAA,QAAA,CAAAC,IAAA,GAAAD,QAAA,CAAAE,IAAA;UAAA;YAC/CJ,IAAI,GAAGK,qBAAS,CAACC,KAAK,CAAC,CAAC;YAC9B,IAAAtB,cAAM,eAAC5C,KAAA,CAAAoC,aAAA,CAAC9B,MAAA,WAAK,MAAAgD,SAAA,iBAAKf,YAAY;cAAER,KAAK,EAAC;YAAE,EAAE,CAAC,CAAC;YAEtCc,KAAK,GAAGC,cAAM,CAACC,WAAW,CAAC,eAAe,CAAC;YAAAe,QAAA,CAAAE,IAAA;YAAA,OAC3CJ,IAAI,CAACO,IAAI,CAACtB,KAAK,EAAE,IAAI,CAAC;UAAA;YAE5B;YACAG,MAAM,CAAChB,QAAQ,CAAC,CAACoC,gBAAgB,CAAC,CAAC;YACnCpB,MAAM,CAAChB,QAAQ,CAAC,CAACqC,qBAAqB,CAAC,CAAC,CAAC;YACzC;YACArB,MAAM,CAAChB,QAAQ,CAAC,CAACsC,wBAAwB,CAAC,GAAG,EAAE,GAAG,CAAC;UAAC;UAAA;YAAA,OAAAR,QAAA,CAAAS,IAAA;QAAA;MAAA,GAAAZ,OAAA;IAAA,CACrD,GAAC;IAEFhB,EAAE,CAAC,mCAAmC,mBAAAa,kBAAA,0BAAAC,YAAA,YAAAC,IAAA,CAAE,SAAAc,SAAA;MAAA,IAAAZ,IAAA,EAAAf,KAAA;MAAA,OAAAY,YAAA,YAAAI,IAAA,WAAAY,SAAA;QAAA,kBAAAA,SAAA,CAAAV,IAAA,GAAAU,SAAA,CAAAT,IAAA;UAAA;YAChCJ,IAAI,GAAGK,qBAAS,CAACC,KAAK,CAAC,CAAC;YAC9B,IAAAtB,cAAM,eAAC5C,KAAA,CAAAoC,aAAA,CAAC9B,MAAA,WAAK,EAAKiC,YAAe,CAAC,CAAC;YAE7BM,KAAK,GAAGC,cAAM,CAACC,WAAW,CAAC,eAAe,CAAC;YAAA0B,SAAA,CAAAT,IAAA;YAAA,OAC3CJ,IAAI,CAACc,KAAK,CAAC7B,KAAK,CAAC;UAAA;YAAA4B,SAAA,CAAAT,IAAA;YAAA,OACjBJ,IAAI,CAACO,IAAI,CAACtB,KAAK,EAAE,WAAW,CAAC;UAAA;YAEnC;YACA;YACA;YACAG,MAAM,CAAChB,QAAQ,CAAC,CAACoC,gBAAgB,CAAC,CAAC;YACnC;YACA;YACA;YACApB,MAAM,CAAChB,QAAQ,CAACJ,IAAI,CAAC+C,KAAK,CAACC,MAAM,CAAC,CAACC,eAAe,CAAC,CAAC,CAAC;UAAC;UAAA;YAAA,OAAAJ,SAAA,CAAAF,IAAA;QAAA;MAAA,GAAAC,QAAA;IAAA,CACvD,GAAC;EACJ,CAAC,CAAC;AACJ,CAAC,CAAC","ignoreList":[]}
|