@pie-lib/config-ui 11.30.3-next.2 → 11.30.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 +7 -78
- package/lib/__tests__/alert-dialog.test.js +262 -0
- package/lib/__tests__/checkbox.test.js +227 -0
- package/lib/__tests__/choice-utils.test.js +14 -0
- package/lib/__tests__/form-section.test.js +252 -0
- package/lib/__tests__/help.test.js +270 -0
- package/lib/__tests__/input.test.js +268 -0
- package/lib/__tests__/langs.test.js +541 -0
- package/lib/__tests__/number-text-field-custom.test.js +362 -0
- package/lib/__tests__/number-text-field.test.js +421 -0
- package/lib/__tests__/radio-with-label.test.js +233 -0
- package/lib/__tests__/settings-panel.test.js +184 -0
- package/lib/__tests__/settings.test.js +653 -0
- package/lib/__tests__/tabs.test.js +211 -0
- package/lib/__tests__/two-choice.test.js +124 -0
- package/lib/__tests__/with-stateful-model.test.js +221 -0
- package/lib/alert-dialog.js +36 -43
- package/lib/alert-dialog.js.map +1 -1
- package/lib/checkbox.js +57 -72
- package/lib/checkbox.js.map +1 -1
- package/lib/choice-configuration/__tests__/feedback-menu.test.js +287 -0
- package/lib/choice-configuration/__tests__/index.test.js +253 -0
- package/lib/choice-configuration/feedback-menu.js +30 -65
- package/lib/choice-configuration/feedback-menu.js.map +1 -1
- package/lib/choice-configuration/index.js +203 -263
- package/lib/choice-configuration/index.js.map +1 -1
- package/lib/choice-utils.js +7 -19
- package/lib/choice-utils.js.map +1 -1
- package/lib/feedback-config/__tests__/feedback-config.test.js +201 -0
- package/lib/feedback-config/__tests__/feedback-selector.test.js +177 -0
- package/lib/feedback-config/feedback-selector.js +80 -116
- package/lib/feedback-config/feedback-selector.js.map +1 -1
- package/lib/feedback-config/group.js +27 -41
- package/lib/feedback-config/group.js.map +1 -1
- package/lib/feedback-config/index.js +48 -91
- package/lib/feedback-config/index.js.map +1 -1
- package/lib/form-section.js +32 -34
- package/lib/form-section.js.map +1 -1
- package/lib/help.js +40 -81
- package/lib/help.js.map +1 -1
- package/lib/index.js +2 -32
- package/lib/index.js.map +1 -1
- package/lib/input.js +22 -55
- package/lib/input.js.map +1 -1
- package/lib/inputs.js +62 -96
- package/lib/inputs.js.map +1 -1
- package/lib/langs.js +59 -102
- package/lib/langs.js.map +1 -1
- package/lib/layout/__tests__/config.layout.test.js +70 -0
- package/lib/layout/__tests__/layout-content.test.js +6 -0
- package/lib/layout/config-layout.js +41 -71
- package/lib/layout/config-layout.js.map +1 -1
- package/lib/layout/index.js +1 -4
- package/lib/layout/index.js.map +1 -1
- package/lib/layout/layout-contents.js +73 -104
- package/lib/layout/layout-contents.js.map +1 -1
- package/lib/layout/settings-box.js +28 -57
- package/lib/layout/settings-box.js.map +1 -1
- package/lib/mui-box/index.js +42 -58
- package/lib/mui-box/index.js.map +1 -1
- package/lib/number-text-field-custom.js +80 -162
- package/lib/number-text-field-custom.js.map +1 -1
- package/lib/number-text-field.js +81 -115
- package/lib/number-text-field.js.map +1 -1
- package/lib/radio-with-label.js +31 -32
- package/lib/radio-with-label.js.map +1 -1
- package/lib/settings/display-size.js +17 -33
- package/lib/settings/display-size.js.map +1 -1
- package/lib/settings/index.js +15 -48
- package/lib/settings/index.js.map +1 -1
- package/lib/settings/panel.js +160 -230
- package/lib/settings/panel.js.map +1 -1
- package/lib/settings/settings-radio-label.js +29 -31
- package/lib/settings/settings-radio-label.js.map +1 -1
- package/lib/settings/toggle.js +36 -47
- package/lib/settings/toggle.js.map +1 -1
- package/lib/tabs/index.js +23 -58
- package/lib/tabs/index.js.map +1 -1
- package/lib/tags-input/__tests__/index.test.js +183 -0
- package/lib/tags-input/index.js +51 -100
- package/lib/tags-input/index.js.map +1 -1
- package/lib/two-choice.js +47 -91
- package/lib/two-choice.js.map +1 -1
- package/lib/with-stateful-model.js +9 -32
- package/lib/with-stateful-model.js.map +1 -1
- package/package.json +12 -20
- package/src/__tests__/alert-dialog.test.jsx +283 -0
- package/src/__tests__/checkbox.test.jsx +249 -0
- package/src/__tests__/form-section.test.jsx +334 -0
- package/src/__tests__/help.test.jsx +184 -0
- package/src/__tests__/input.test.jsx +192 -0
- package/src/__tests__/langs.test.jsx +435 -15
- package/src/__tests__/number-text-field-custom.test.jsx +438 -0
- package/src/__tests__/number-text-field.test.jsx +295 -102
- package/src/__tests__/radio-with-label.test.jsx +259 -0
- package/src/__tests__/settings-panel.test.js +66 -83
- package/src/__tests__/settings.test.jsx +515 -0
- package/src/__tests__/tabs.test.jsx +193 -0
- package/src/__tests__/two-choice.test.js +104 -18
- package/src/__tests__/with-stateful-model.test.jsx +145 -0
- package/src/alert-dialog.jsx +21 -19
- package/src/checkbox.jsx +42 -46
- package/src/choice-configuration/__tests__/feedback-menu.test.jsx +157 -4
- package/src/choice-configuration/__tests__/index.test.jsx +198 -56
- package/src/choice-configuration/feedback-menu.jsx +6 -6
- package/src/choice-configuration/index.jsx +201 -196
- package/src/feedback-config/__tests__/feedback-config.test.jsx +130 -60
- package/src/feedback-config/__tests__/feedback-selector.test.jsx +87 -40
- package/src/feedback-config/feedback-selector.jsx +52 -53
- package/src/feedback-config/group.jsx +21 -22
- package/src/feedback-config/index.jsx +27 -29
- package/src/form-section.jsx +26 -18
- package/src/help.jsx +20 -28
- package/src/input.jsx +1 -1
- package/src/inputs.jsx +34 -50
- package/src/langs.jsx +41 -46
- package/src/layout/__tests__/config.layout.test.jsx +55 -38
- package/src/layout/config-layout.jsx +38 -32
- package/src/layout/layout-contents.jsx +38 -39
- package/src/layout/settings-box.jsx +16 -19
- package/src/mui-box/index.jsx +35 -43
- package/src/number-text-field-custom.jsx +30 -36
- package/src/number-text-field.jsx +45 -29
- package/src/radio-with-label.jsx +25 -13
- package/src/settings/display-size.jsx +12 -11
- package/src/settings/panel.jsx +97 -91
- package/src/settings/settings-radio-label.jsx +25 -13
- package/src/settings/toggle.jsx +30 -29
- package/src/tabs/index.jsx +8 -8
- package/src/tags-input/__tests__/index.test.jsx +88 -37
- package/src/tags-input/index.jsx +35 -38
- package/src/two-choice.jsx +15 -19
- package/esm/index.css +0 -847
- package/esm/index.js +0 -213950
- package/esm/index.js.map +0 -1
- package/esm/package.json +0 -3
- package/src/__tests__/__snapshots__/langs.test.jsx.snap +0 -32
- package/src/__tests__/__snapshots__/settings-panel.test.js.snap +0 -115
- package/src/__tests__/__snapshots__/two-choice.test.js.snap +0 -171
- package/src/choice-configuration/__tests__/__snapshots__/feedback-menu.test.jsx.snap +0 -51
- package/src/choice-configuration/__tests__/__snapshots__/index.test.jsx.snap +0 -519
- package/src/feedback-config/__tests__/__snapshots__/feedback-config.test.jsx.snap +0 -27
- package/src/feedback-config/__tests__/__snapshots__/feedback-selector.test.jsx.snap +0 -38
- package/src/layout/__tests__/__snapshots__/config.layout.test.jsx.snap +0 -59
- package/src/tags-input/__tests__/__snapshots__/index.test.jsx.snap +0 -170
|
@@ -0,0 +1,227 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
5
|
+
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
6
|
+
var _react = _interopRequireDefault(require("react"));
|
|
7
|
+
var _react2 = require("@testing-library/react");
|
|
8
|
+
var _userEvent = _interopRequireDefault(require("@testing-library/user-event"));
|
|
9
|
+
var _checkbox = _interopRequireDefault(require("../checkbox"));
|
|
10
|
+
describe('Checkbox Component', function () {
|
|
11
|
+
var onChange = jest.fn();
|
|
12
|
+
beforeEach(function () {
|
|
13
|
+
onChange.mockClear();
|
|
14
|
+
});
|
|
15
|
+
describe('Rendering', function () {
|
|
16
|
+
it('should render checkbox with label', function () {
|
|
17
|
+
(0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_checkbox["default"], {
|
|
18
|
+
checked: false,
|
|
19
|
+
onChange: onChange,
|
|
20
|
+
label: "Accept terms"
|
|
21
|
+
}));
|
|
22
|
+
expect(_react2.screen.getByText('Accept terms')).toBeInTheDocument();
|
|
23
|
+
expect(_react2.screen.getByRole('checkbox')).toBeInTheDocument();
|
|
24
|
+
});
|
|
25
|
+
it('should render checkbox in checked state', function () {
|
|
26
|
+
(0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_checkbox["default"], {
|
|
27
|
+
checked: true,
|
|
28
|
+
onChange: onChange,
|
|
29
|
+
label: "Accept terms"
|
|
30
|
+
}));
|
|
31
|
+
expect(_react2.screen.getByRole('checkbox')).toBeChecked();
|
|
32
|
+
});
|
|
33
|
+
it('should render checkbox in unchecked state', function () {
|
|
34
|
+
(0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_checkbox["default"], {
|
|
35
|
+
checked: false,
|
|
36
|
+
onChange: onChange,
|
|
37
|
+
label: "Accept terms"
|
|
38
|
+
}));
|
|
39
|
+
expect(_react2.screen.getByRole('checkbox')).not.toBeChecked();
|
|
40
|
+
});
|
|
41
|
+
it('should render mini checkbox with reduced styling', function () {
|
|
42
|
+
(0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_checkbox["default"], {
|
|
43
|
+
checked: false,
|
|
44
|
+
onChange: onChange,
|
|
45
|
+
label: "Mini",
|
|
46
|
+
mini: true
|
|
47
|
+
}));
|
|
48
|
+
expect(_react2.screen.getByRole('checkbox')).toBeInTheDocument();
|
|
49
|
+
expect(_react2.screen.getByText('Mini')).toBeInTheDocument();
|
|
50
|
+
});
|
|
51
|
+
});
|
|
52
|
+
describe('User interaction', function () {
|
|
53
|
+
it('should call onChange when checkbox is clicked', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee() {
|
|
54
|
+
var user, checkbox;
|
|
55
|
+
return _regenerator["default"].wrap(function (_context) {
|
|
56
|
+
while (1) switch (_context.prev = _context.next) {
|
|
57
|
+
case 0:
|
|
58
|
+
user = _userEvent["default"].setup();
|
|
59
|
+
(0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_checkbox["default"], {
|
|
60
|
+
checked: false,
|
|
61
|
+
onChange: onChange,
|
|
62
|
+
label: "Accept"
|
|
63
|
+
}));
|
|
64
|
+
checkbox = _react2.screen.getByRole('checkbox');
|
|
65
|
+
_context.next = 1;
|
|
66
|
+
return user.click(checkbox);
|
|
67
|
+
case 1:
|
|
68
|
+
expect(onChange).toHaveBeenCalled();
|
|
69
|
+
case 2:
|
|
70
|
+
case "end":
|
|
71
|
+
return _context.stop();
|
|
72
|
+
}
|
|
73
|
+
}, _callee);
|
|
74
|
+
})));
|
|
75
|
+
it('should call onChange when label is clicked', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee2() {
|
|
76
|
+
var user, label;
|
|
77
|
+
return _regenerator["default"].wrap(function (_context2) {
|
|
78
|
+
while (1) switch (_context2.prev = _context2.next) {
|
|
79
|
+
case 0:
|
|
80
|
+
user = _userEvent["default"].setup();
|
|
81
|
+
(0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_checkbox["default"], {
|
|
82
|
+
checked: false,
|
|
83
|
+
onChange: onChange,
|
|
84
|
+
label: "Click label"
|
|
85
|
+
}));
|
|
86
|
+
label = _react2.screen.getByText('Click label');
|
|
87
|
+
_context2.next = 1;
|
|
88
|
+
return user.click(label);
|
|
89
|
+
case 1:
|
|
90
|
+
expect(onChange).toHaveBeenCalled();
|
|
91
|
+
case 2:
|
|
92
|
+
case "end":
|
|
93
|
+
return _context2.stop();
|
|
94
|
+
}
|
|
95
|
+
}, _callee2);
|
|
96
|
+
})));
|
|
97
|
+
});
|
|
98
|
+
describe('Props', function () {
|
|
99
|
+
it('should handle value prop', function () {
|
|
100
|
+
(0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_checkbox["default"], {
|
|
101
|
+
checked: true,
|
|
102
|
+
onChange: onChange,
|
|
103
|
+
label: "With value",
|
|
104
|
+
value: "option1"
|
|
105
|
+
}));
|
|
106
|
+
expect(_react2.screen.getByRole('checkbox')).toBeInTheDocument();
|
|
107
|
+
});
|
|
108
|
+
it('should display error styling when error is true', function () {
|
|
109
|
+
(0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_checkbox["default"], {
|
|
110
|
+
checked: false,
|
|
111
|
+
onChange: onChange,
|
|
112
|
+
label: "Error state",
|
|
113
|
+
error: true
|
|
114
|
+
}));
|
|
115
|
+
expect(_react2.screen.getByRole('checkbox')).toBeInTheDocument();
|
|
116
|
+
expect(_react2.screen.getByText('Error state')).toBeInTheDocument();
|
|
117
|
+
});
|
|
118
|
+
});
|
|
119
|
+
describe('Default props', function () {
|
|
120
|
+
it('should have mini default to false', function () {
|
|
121
|
+
var _render = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_checkbox["default"], {
|
|
122
|
+
checked: true,
|
|
123
|
+
onChange: onChange,
|
|
124
|
+
label: "Test"
|
|
125
|
+
})),
|
|
126
|
+
container = _render.container;
|
|
127
|
+
expect(_react2.screen.getByRole('checkbox')).toBeInTheDocument();
|
|
128
|
+
});
|
|
129
|
+
it('should have error default to false', function () {
|
|
130
|
+
var _render2 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_checkbox["default"], {
|
|
131
|
+
checked: true,
|
|
132
|
+
onChange: onChange,
|
|
133
|
+
label: "Test"
|
|
134
|
+
})),
|
|
135
|
+
container = _render2.container;
|
|
136
|
+
expect(_react2.screen.getByRole('checkbox')).toBeInTheDocument();
|
|
137
|
+
});
|
|
138
|
+
it('should have value default to empty string', function () {
|
|
139
|
+
(0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_checkbox["default"], {
|
|
140
|
+
checked: true,
|
|
141
|
+
onChange: onChange,
|
|
142
|
+
label: "Test"
|
|
143
|
+
}));
|
|
144
|
+
expect(_react2.screen.getByRole('checkbox')).toBeInTheDocument();
|
|
145
|
+
});
|
|
146
|
+
});
|
|
147
|
+
describe('Accessibility', function () {
|
|
148
|
+
it('should have proper label association', function () {
|
|
149
|
+
(0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_checkbox["default"], {
|
|
150
|
+
checked: false,
|
|
151
|
+
onChange: onChange,
|
|
152
|
+
label: "Accessible label"
|
|
153
|
+
}));
|
|
154
|
+
expect(_react2.screen.getByLabelText('Accessible label')).toBeInTheDocument();
|
|
155
|
+
});
|
|
156
|
+
it('should be keyboard accessible', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee3() {
|
|
157
|
+
var user, checkbox;
|
|
158
|
+
return _regenerator["default"].wrap(function (_context3) {
|
|
159
|
+
while (1) switch (_context3.prev = _context3.next) {
|
|
160
|
+
case 0:
|
|
161
|
+
user = _userEvent["default"].setup();
|
|
162
|
+
(0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_checkbox["default"], {
|
|
163
|
+
checked: false,
|
|
164
|
+
onChange: onChange,
|
|
165
|
+
label: "Keyboard test"
|
|
166
|
+
}));
|
|
167
|
+
checkbox = _react2.screen.getByRole('checkbox');
|
|
168
|
+
checkbox.focus();
|
|
169
|
+
expect(checkbox).toHaveFocus();
|
|
170
|
+
_context3.next = 1;
|
|
171
|
+
return user.keyboard(' ');
|
|
172
|
+
case 1:
|
|
173
|
+
expect(onChange).toHaveBeenCalled();
|
|
174
|
+
case 2:
|
|
175
|
+
case "end":
|
|
176
|
+
return _context3.stop();
|
|
177
|
+
}
|
|
178
|
+
}, _callee3);
|
|
179
|
+
})));
|
|
180
|
+
});
|
|
181
|
+
describe('Multiple checkboxes', function () {
|
|
182
|
+
it('should render multiple independent checkboxes', function () {
|
|
183
|
+
var onChange1 = jest.fn();
|
|
184
|
+
var onChange2 = jest.fn();
|
|
185
|
+
(0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement(_checkbox["default"], {
|
|
186
|
+
checked: true,
|
|
187
|
+
onChange: onChange1,
|
|
188
|
+
label: "Option 1"
|
|
189
|
+
}), /*#__PURE__*/_react["default"].createElement(_checkbox["default"], {
|
|
190
|
+
checked: false,
|
|
191
|
+
onChange: onChange2,
|
|
192
|
+
label: "Option 2"
|
|
193
|
+
})));
|
|
194
|
+
expect(_react2.screen.getByLabelText('Option 1')).toBeChecked();
|
|
195
|
+
expect(_react2.screen.getByLabelText('Option 2')).not.toBeChecked();
|
|
196
|
+
});
|
|
197
|
+
it('should handle independent onChange callbacks', /*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee4() {
|
|
198
|
+
var user, onChange1, onChange2;
|
|
199
|
+
return _regenerator["default"].wrap(function (_context4) {
|
|
200
|
+
while (1) switch (_context4.prev = _context4.next) {
|
|
201
|
+
case 0:
|
|
202
|
+
user = _userEvent["default"].setup();
|
|
203
|
+
onChange1 = jest.fn();
|
|
204
|
+
onChange2 = jest.fn();
|
|
205
|
+
(0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement(_checkbox["default"], {
|
|
206
|
+
checked: true,
|
|
207
|
+
onChange: onChange1,
|
|
208
|
+
label: "Option 1"
|
|
209
|
+
}), /*#__PURE__*/_react["default"].createElement(_checkbox["default"], {
|
|
210
|
+
checked: false,
|
|
211
|
+
onChange: onChange2,
|
|
212
|
+
label: "Option 2"
|
|
213
|
+
})));
|
|
214
|
+
_context4.next = 1;
|
|
215
|
+
return user.click(_react2.screen.getByLabelText('Option 2'));
|
|
216
|
+
case 1:
|
|
217
|
+
expect(onChange2).toHaveBeenCalled();
|
|
218
|
+
expect(onChange1).not.toHaveBeenCalled();
|
|
219
|
+
case 2:
|
|
220
|
+
case "end":
|
|
221
|
+
return _context4.stop();
|
|
222
|
+
}
|
|
223
|
+
}, _callee4);
|
|
224
|
+
})));
|
|
225
|
+
});
|
|
226
|
+
});
|
|
227
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_react2","_userEvent","_checkbox","describe","onChange","jest","fn","beforeEach","mockClear","it","render","createElement","checked","label","expect","screen","getByText","toBeInTheDocument","getByRole","toBeChecked","not","mini","_asyncToGenerator2","_regenerator","mark","_callee","user","checkbox","wrap","_context","prev","next","userEvent","setup","click","toHaveBeenCalled","stop","_callee2","_context2","value","error","_render","container","_render2","getByLabelText","_callee3","_context3","focus","toHaveFocus","keyboard","onChange1","onChange2","Fragment","_callee4","_context4"],"sources":["../../src/__tests__/checkbox.test.jsx"],"sourcesContent":["import React from 'react';\nimport { render, screen } from '@testing-library/react';\nimport userEvent from '@testing-library/user-event';\nimport Checkbox from '../checkbox';\n\ndescribe('Checkbox Component', () => {\n  const onChange = jest.fn();\n\n  beforeEach(() => {\n    onChange.mockClear();\n  });\n\n  describe('Rendering', () => {\n    it('should render checkbox with label', () => {\n      render(\n        <Checkbox \n          checked={false} \n          onChange={onChange} \n          label=\"Accept terms\" \n        />,\n      );\n\n      expect(screen.getByText('Accept terms')).toBeInTheDocument();\n      expect(screen.getByRole('checkbox')).toBeInTheDocument();\n    });\n\n    it('should render checkbox in checked state', () => {\n      render(\n        <Checkbox \n          checked={true} \n          onChange={onChange} \n          label=\"Accept terms\" \n        />,\n      );\n\n      expect(screen.getByRole('checkbox')).toBeChecked();\n    });\n\n    it('should render checkbox in unchecked state', () => {\n      render(\n        <Checkbox \n          checked={false} \n          onChange={onChange} \n          label=\"Accept terms\" \n        />,\n      );\n\n      expect(screen.getByRole('checkbox')).not.toBeChecked();\n    });\n\n    it('should render mini checkbox with reduced styling', () => {\n      render(\n        <Checkbox \n          checked={false} \n          onChange={onChange} \n          label=\"Mini\" \n          mini={true}\n        />,\n      );\n\n      expect(screen.getByRole('checkbox')).toBeInTheDocument();\n      expect(screen.getByText('Mini')).toBeInTheDocument();\n    });\n  });\n\n  describe('User interaction', () => {\n    it('should call onChange when checkbox is clicked', async () => {\n      const user = userEvent.setup();\n      render(\n        <Checkbox \n          checked={false} \n          onChange={onChange} \n          label=\"Accept\" \n        />,\n      );\n\n      const checkbox = screen.getByRole('checkbox');\n      await user.click(checkbox);\n\n      expect(onChange).toHaveBeenCalled();\n    });\n\n    it('should call onChange when label is clicked', async () => {\n      const user = userEvent.setup();\n      render(\n        <Checkbox \n          checked={false} \n          onChange={onChange} \n          label=\"Click label\" \n        />,\n      );\n\n      const label = screen.getByText('Click label');\n      await user.click(label);\n\n      expect(onChange).toHaveBeenCalled();\n    });\n  });\n\n  describe('Props', () => {\n    it('should handle value prop', () => {\n      render(\n        <Checkbox \n          checked={true} \n          onChange={onChange} \n          label=\"With value\"\n          value=\"option1\"\n        />,\n      );\n\n      expect(screen.getByRole('checkbox')).toBeInTheDocument();\n    });\n\n    it('should display error styling when error is true', () => {\n      render(\n        <Checkbox \n          checked={false} \n          onChange={onChange} \n          label=\"Error state\"\n          error={true}\n        />,\n      );\n\n      expect(screen.getByRole('checkbox')).toBeInTheDocument();\n      expect(screen.getByText('Error state')).toBeInTheDocument();\n    });\n  });\n\n  describe('Default props', () => {\n    it('should have mini default to false', () => {\n      const { container } = render(\n        <Checkbox \n          checked={true} \n          onChange={onChange} \n          label=\"Test\"\n        />,\n      );\n\n      expect(screen.getByRole('checkbox')).toBeInTheDocument();\n    });\n\n    it('should have error default to false', () => {\n      const { container } = render(\n        <Checkbox \n          checked={true} \n          onChange={onChange} \n          label=\"Test\"\n        />,\n      );\n\n      expect(screen.getByRole('checkbox')).toBeInTheDocument();\n    });\n\n    it('should have value default to empty string', () => {\n      render(\n        <Checkbox \n          checked={true} \n          onChange={onChange} \n          label=\"Test\"\n        />,\n      );\n\n      expect(screen.getByRole('checkbox')).toBeInTheDocument();\n    });\n  });\n\n  describe('Accessibility', () => {\n    it('should have proper label association', () => {\n      render(\n        <Checkbox \n          checked={false} \n          onChange={onChange} \n          label=\"Accessible label\"\n        />,\n      );\n\n      expect(screen.getByLabelText('Accessible label')).toBeInTheDocument();\n    });\n\n    it('should be keyboard accessible', async () => {\n      const user = userEvent.setup();\n      render(\n        <Checkbox \n          checked={false} \n          onChange={onChange} \n          label=\"Keyboard test\"\n        />,\n      );\n\n      const checkbox = screen.getByRole('checkbox');\n      checkbox.focus();\n      expect(checkbox).toHaveFocus();\n\n      await user.keyboard(' ');\n      expect(onChange).toHaveBeenCalled();\n    });\n  });\n\n  describe('Multiple checkboxes', () => {\n    it('should render multiple independent checkboxes', () => {\n      const onChange1 = jest.fn();\n      const onChange2 = jest.fn();\n\n      render(\n        <>\n          <Checkbox \n            checked={true} \n            onChange={onChange1} \n            label=\"Option 1\"\n          />\n          <Checkbox \n            checked={false} \n            onChange={onChange2} \n            label=\"Option 2\"\n          />\n        </>,\n      );\n\n      expect(screen.getByLabelText('Option 1')).toBeChecked();\n      expect(screen.getByLabelText('Option 2')).not.toBeChecked();\n    });\n\n    it('should handle independent onChange callbacks', async () => {\n      const user = userEvent.setup();\n      const onChange1 = jest.fn();\n      const onChange2 = jest.fn();\n\n      render(\n        <>\n          <Checkbox \n            checked={true} \n            onChange={onChange1} \n            label=\"Option 1\"\n          />\n          <Checkbox \n            checked={false} \n            onChange={onChange2} \n            label=\"Option 2\"\n          />\n        </>,\n      );\n\n      await user.click(screen.getByLabelText('Option 2'));\n\n      expect(onChange2).toHaveBeenCalled();\n      expect(onChange1).not.toHaveBeenCalled();\n    });\n  });\n});\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _choiceUtils = require("../choice-utils");
|
|
4
|
+
describe('firstAvailableIndex', function () {
|
|
5
|
+
var assert = function assert(values, index, expected) {
|
|
6
|
+
it("[".concat(values.join(','), "], ").concat(index, " ==> ").concat(expected), function () {
|
|
7
|
+
expect((0, _choiceUtils.firstAvailableIndex)(['0'], 0)).toEqual('1');
|
|
8
|
+
});
|
|
9
|
+
};
|
|
10
|
+
assert(['0'], 0, '1');
|
|
11
|
+
assert(['0', '1', '2'], 0, '3');
|
|
12
|
+
assert(['0', '1', '2'], 100, '100');
|
|
13
|
+
});
|
|
14
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfY2hvaWNlVXRpbHMiLCJyZXF1aXJlIiwiZGVzY3JpYmUiLCJhc3NlcnQiLCJ2YWx1ZXMiLCJpbmRleCIsImV4cGVjdGVkIiwiaXQiLCJjb25jYXQiLCJqb2luIiwiZXhwZWN0IiwiZmlyc3RBdmFpbGFibGVJbmRleCIsInRvRXF1YWwiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvX190ZXN0c19fL2Nob2ljZS11dGlscy50ZXN0LmpzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGZpcnN0QXZhaWxhYmxlSW5kZXggfSBmcm9tICcuLi9jaG9pY2UtdXRpbHMnO1xuXG5kZXNjcmliZSgnZmlyc3RBdmFpbGFibGVJbmRleCcsICgpID0+IHtcbiAgY29uc3QgYXNzZXJ0ID0gKHZhbHVlcywgaW5kZXgsIGV4cGVjdGVkKSA9PiB7XG4gICAgaXQoYFske3ZhbHVlcy5qb2luKCcsJyl9XSwgJHtpbmRleH0gPT0+ICR7ZXhwZWN0ZWR9YCwgKCkgPT4ge1xuICAgICAgZXhwZWN0KGZpcnN0QXZhaWxhYmxlSW5kZXgoWycwJ10sIDApKS50b0VxdWFsKCcxJyk7XG4gICAgfSk7XG4gIH07XG4gIGFzc2VydChbJzAnXSwgMCwgJzEnKTtcbiAgYXNzZXJ0KFsnMCcsICcxJywgJzInXSwgMCwgJzMnKTtcbiAgYXNzZXJ0KFsnMCcsICcxJywgJzInXSwgMTAwLCAnMTAwJyk7XG59KTtcbiJdLCJtYXBwaW5ncyI6Ijs7QUFBQSxJQUFBQSxZQUFBLEdBQUFDLE9BQUE7QUFFQUMsUUFBUSxDQUFDLHFCQUFxQixFQUFFLFlBQU07RUFDcEMsSUFBTUMsTUFBTSxHQUFHLFNBQVRBLE1BQU1BLENBQUlDLE1BQU0sRUFBRUMsS0FBSyxFQUFFQyxRQUFRLEVBQUs7SUFDMUNDLEVBQUUsS0FBQUMsTUFBQSxDQUFLSixNQUFNLENBQUNLLElBQUksQ0FBQyxHQUFHLENBQUMsU0FBQUQsTUFBQSxDQUFNSCxLQUFLLFdBQUFHLE1BQUEsQ0FBUUYsUUFBUSxHQUFJLFlBQU07TUFDMURJLE1BQU0sQ0FBQyxJQUFBQyxnQ0FBbUIsRUFBQyxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUNDLE9BQU8sQ0FBQyxHQUFHLENBQUM7SUFDcEQsQ0FBQyxDQUFDO0VBQ0osQ0FBQztFQUNEVCxNQUFNLENBQUMsQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEVBQUUsR0FBRyxDQUFDO0VBQ3JCQSxNQUFNLENBQUMsQ0FBQyxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsQ0FBQyxFQUFFLENBQUMsRUFBRSxHQUFHLENBQUM7RUFDL0JBLE1BQU0sQ0FBQyxDQUFDLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxDQUFDLEVBQUUsR0FBRyxFQUFFLEtBQUssQ0FBQztBQUNyQyxDQUFDLENBQUMiLCJpZ25vcmVMaXN0IjpbXX0=
|
|
@@ -0,0 +1,252 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _react = _interopRequireDefault(require("react"));
|
|
5
|
+
var _react2 = require("@testing-library/react");
|
|
6
|
+
var _formSection = _interopRequireDefault(require("../form-section"));
|
|
7
|
+
describe('FormSection Component', function () {
|
|
8
|
+
describe('Rendering', function () {
|
|
9
|
+
it('should render with label and children', function () {
|
|
10
|
+
(0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_formSection["default"], {
|
|
11
|
+
label: "Settings"
|
|
12
|
+
}, /*#__PURE__*/_react["default"].createElement("div", null, "Child content")));
|
|
13
|
+
expect(_react2.screen.getByText('Settings')).toBeInTheDocument();
|
|
14
|
+
expect(_react2.screen.getByText('Child content')).toBeInTheDocument();
|
|
15
|
+
});
|
|
16
|
+
it('should render label as subtitle1 typography', function () {
|
|
17
|
+
var _render = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_formSection["default"], {
|
|
18
|
+
label: "Configuration"
|
|
19
|
+
}, /*#__PURE__*/_react["default"].createElement("div", null, "Content"))),
|
|
20
|
+
container = _render.container;
|
|
21
|
+
var typography = container.querySelector('[class*="MuiTypography"]');
|
|
22
|
+
expect(typography).toBeInTheDocument();
|
|
23
|
+
});
|
|
24
|
+
it('should render with custom className', function () {
|
|
25
|
+
var _render2 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_formSection["default"], {
|
|
26
|
+
label: "Custom",
|
|
27
|
+
className: "custom-class"
|
|
28
|
+
}, /*#__PURE__*/_react["default"].createElement("div", null, "Content"))),
|
|
29
|
+
container = _render2.container;
|
|
30
|
+
expect(container.querySelector('.custom-class')).toBeInTheDocument();
|
|
31
|
+
});
|
|
32
|
+
it('should render multiple children', function () {
|
|
33
|
+
(0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_formSection["default"], {
|
|
34
|
+
label: "Multiple Children"
|
|
35
|
+
}, /*#__PURE__*/_react["default"].createElement("div", null, "First child"), /*#__PURE__*/_react["default"].createElement("div", null, "Second child"), /*#__PURE__*/_react["default"].createElement("div", null, "Third child")));
|
|
36
|
+
expect(_react2.screen.getByText('First child')).toBeInTheDocument();
|
|
37
|
+
expect(_react2.screen.getByText('Second child')).toBeInTheDocument();
|
|
38
|
+
expect(_react2.screen.getByText('Third child')).toBeInTheDocument();
|
|
39
|
+
});
|
|
40
|
+
it('should render with single child', function () {
|
|
41
|
+
(0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_formSection["default"], {
|
|
42
|
+
label: "Single Child"
|
|
43
|
+
}, /*#__PURE__*/_react["default"].createElement("input", {
|
|
44
|
+
type: "text",
|
|
45
|
+
placeholder: "Input"
|
|
46
|
+
})));
|
|
47
|
+
expect(_react2.screen.getByPlaceholderText('Input')).toBeInTheDocument();
|
|
48
|
+
});
|
|
49
|
+
it('should render with complex child components', function () {
|
|
50
|
+
(0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_formSection["default"], {
|
|
51
|
+
label: "Complex"
|
|
52
|
+
}, /*#__PURE__*/_react["default"].createElement("div", null, /*#__PURE__*/_react["default"].createElement("label", null, "Name:"), /*#__PURE__*/_react["default"].createElement("input", {
|
|
53
|
+
type: "text",
|
|
54
|
+
placeholder: "Enter name"
|
|
55
|
+
})), /*#__PURE__*/_react["default"].createElement("div", null, /*#__PURE__*/_react["default"].createElement("label", null, "Email:"), /*#__PURE__*/_react["default"].createElement("input", {
|
|
56
|
+
type: "email",
|
|
57
|
+
placeholder: "Enter email"
|
|
58
|
+
}))));
|
|
59
|
+
expect(_react2.screen.getByPlaceholderText('Enter name')).toBeInTheDocument();
|
|
60
|
+
expect(_react2.screen.getByPlaceholderText('Enter email')).toBeInTheDocument();
|
|
61
|
+
});
|
|
62
|
+
});
|
|
63
|
+
describe('Labels', function () {
|
|
64
|
+
it('should display different labels', function () {
|
|
65
|
+
var _render3 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_formSection["default"], {
|
|
66
|
+
label: "First Label"
|
|
67
|
+
}, /*#__PURE__*/_react["default"].createElement("div", null, "Content"))),
|
|
68
|
+
rerender = _render3.rerender;
|
|
69
|
+
expect(_react2.screen.getByText('First Label')).toBeInTheDocument();
|
|
70
|
+
rerender(/*#__PURE__*/_react["default"].createElement(_formSection["default"], {
|
|
71
|
+
label: "Second Label"
|
|
72
|
+
}, /*#__PURE__*/_react["default"].createElement("div", null, "Content")));
|
|
73
|
+
expect(_react2.screen.getByText('Second Label')).toBeInTheDocument();
|
|
74
|
+
expect(_react2.screen.queryByText('First Label')).not.toBeInTheDocument();
|
|
75
|
+
});
|
|
76
|
+
it('should handle empty label', function () {
|
|
77
|
+
var _render4 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_formSection["default"], {
|
|
78
|
+
label: ""
|
|
79
|
+
}, /*#__PURE__*/_react["default"].createElement("div", null, "Content"))),
|
|
80
|
+
container = _render4.container;
|
|
81
|
+
expect(container.querySelector('[class*="MuiTypography"]')).toBeInTheDocument();
|
|
82
|
+
expect(_react2.screen.getByText('Content')).toBeInTheDocument();
|
|
83
|
+
});
|
|
84
|
+
it('should handle long labels', function () {
|
|
85
|
+
var longLabel = 'This is a very long label that should wrap properly within the form section';
|
|
86
|
+
(0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_formSection["default"], {
|
|
87
|
+
label: longLabel
|
|
88
|
+
}, /*#__PURE__*/_react["default"].createElement("div", null, "Content")));
|
|
89
|
+
expect(_react2.screen.getByText(longLabel)).toBeInTheDocument();
|
|
90
|
+
});
|
|
91
|
+
it('should handle special characters in labels', function () {
|
|
92
|
+
var specialLabel = 'Settings & Configuration < Advanced > Test @ #1';
|
|
93
|
+
(0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_formSection["default"], {
|
|
94
|
+
label: specialLabel
|
|
95
|
+
}, /*#__PURE__*/_react["default"].createElement("div", null, "Content")));
|
|
96
|
+
expect(_react2.screen.getByText(specialLabel)).toBeInTheDocument();
|
|
97
|
+
});
|
|
98
|
+
});
|
|
99
|
+
describe('Styling and Layout', function () {
|
|
100
|
+
it('should apply default spacing', function () {
|
|
101
|
+
var _render5 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_formSection["default"], {
|
|
102
|
+
label: "Spaced"
|
|
103
|
+
}, /*#__PURE__*/_react["default"].createElement("div", null, "Content"))),
|
|
104
|
+
container = _render5.container;
|
|
105
|
+
var formSection = container.querySelector('[class*="MuiBox"], div');
|
|
106
|
+
expect(formSection).toBeInTheDocument();
|
|
107
|
+
});
|
|
108
|
+
it('should apply labelExtraStyle to the label', function () {
|
|
109
|
+
var _render6 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_formSection["default"], {
|
|
110
|
+
label: "Styled Label",
|
|
111
|
+
labelExtraStyle: {
|
|
112
|
+
color: 'red',
|
|
113
|
+
fontWeight: 'bold'
|
|
114
|
+
}
|
|
115
|
+
}, /*#__PURE__*/_react["default"].createElement("div", null, "Content"))),
|
|
116
|
+
container = _render6.container;
|
|
117
|
+
var typography = container.querySelector('[class*="MuiTypography"]');
|
|
118
|
+
expect(typography).toHaveStyle('color: red');
|
|
119
|
+
expect(typography).toHaveStyle('fontWeight: bold');
|
|
120
|
+
});
|
|
121
|
+
it('should apply multiple labelExtraStyle properties', function () {
|
|
122
|
+
var extraStyle = {
|
|
123
|
+
fontSize: '18px',
|
|
124
|
+
margin: '10px',
|
|
125
|
+
padding: '5px'
|
|
126
|
+
};
|
|
127
|
+
var _render7 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_formSection["default"], {
|
|
128
|
+
label: "Multi-styled",
|
|
129
|
+
labelExtraStyle: extraStyle
|
|
130
|
+
}, /*#__PURE__*/_react["default"].createElement("div", null, "Content"))),
|
|
131
|
+
container = _render7.container;
|
|
132
|
+
var typography = container.querySelector('[class*="MuiTypography"]');
|
|
133
|
+
expect(typography).toHaveStyle('fontSize: 18px');
|
|
134
|
+
expect(typography).toHaveStyle('margin: 10px');
|
|
135
|
+
expect(typography).toHaveStyle('padding: 5px');
|
|
136
|
+
});
|
|
137
|
+
it('should handle no labelExtraStyle', function () {
|
|
138
|
+
var _render8 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_formSection["default"], {
|
|
139
|
+
label: "No Extra Style"
|
|
140
|
+
}, /*#__PURE__*/_react["default"].createElement("div", null, "Content"))),
|
|
141
|
+
container = _render8.container;
|
|
142
|
+
expect(container.querySelector('[class*="MuiTypography"]')).toBeInTheDocument();
|
|
143
|
+
});
|
|
144
|
+
});
|
|
145
|
+
describe('CSS classes', function () {
|
|
146
|
+
it('should support multiple custom classes', function () {
|
|
147
|
+
var _render9 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_formSection["default"], {
|
|
148
|
+
label: "Test",
|
|
149
|
+
className: "class1 class2 class3"
|
|
150
|
+
}, /*#__PURE__*/_react["default"].createElement("div", null, "Content"))),
|
|
151
|
+
container = _render9.container;
|
|
152
|
+
var element = container.querySelector('.class1.class2.class3');
|
|
153
|
+
expect(element).toBeInTheDocument();
|
|
154
|
+
});
|
|
155
|
+
it('should work without custom className', function () {
|
|
156
|
+
var _render0 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_formSection["default"], {
|
|
157
|
+
label: "Test"
|
|
158
|
+
}, /*#__PURE__*/_react["default"].createElement("div", null, "Content"))),
|
|
159
|
+
container = _render0.container;
|
|
160
|
+
expect(container.firstChild).toBeInTheDocument();
|
|
161
|
+
});
|
|
162
|
+
});
|
|
163
|
+
describe('Content variations', function () {
|
|
164
|
+
it('should render form inputs as children', function () {
|
|
165
|
+
(0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_formSection["default"], {
|
|
166
|
+
label: "Form Inputs"
|
|
167
|
+
}, /*#__PURE__*/_react["default"].createElement("input", {
|
|
168
|
+
type: "text",
|
|
169
|
+
placeholder: "Text input"
|
|
170
|
+
}), /*#__PURE__*/_react["default"].createElement("input", {
|
|
171
|
+
type: "number",
|
|
172
|
+
placeholder: "Number input"
|
|
173
|
+
}), /*#__PURE__*/_react["default"].createElement("textarea", {
|
|
174
|
+
placeholder: "Text area"
|
|
175
|
+
})));
|
|
176
|
+
expect(_react2.screen.getByPlaceholderText('Text input')).toBeInTheDocument();
|
|
177
|
+
expect(_react2.screen.getByPlaceholderText('Number input')).toBeInTheDocument();
|
|
178
|
+
expect(_react2.screen.getByPlaceholderText('Text area')).toBeInTheDocument();
|
|
179
|
+
});
|
|
180
|
+
it('should render lists as children', function () {
|
|
181
|
+
(0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_formSection["default"], {
|
|
182
|
+
label: "Options"
|
|
183
|
+
}, /*#__PURE__*/_react["default"].createElement("ul", null, /*#__PURE__*/_react["default"].createElement("li", null, "Option 1"), /*#__PURE__*/_react["default"].createElement("li", null, "Option 2"), /*#__PURE__*/_react["default"].createElement("li", null, "Option 3"))));
|
|
184
|
+
expect(_react2.screen.getByText('Option 1')).toBeInTheDocument();
|
|
185
|
+
expect(_react2.screen.getByText('Option 2')).toBeInTheDocument();
|
|
186
|
+
expect(_react2.screen.getByText('Option 3')).toBeInTheDocument();
|
|
187
|
+
});
|
|
188
|
+
it('should render buttons as children', function () {
|
|
189
|
+
(0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_formSection["default"], {
|
|
190
|
+
label: "Actions"
|
|
191
|
+
}, /*#__PURE__*/_react["default"].createElement("button", null, "Save"), /*#__PURE__*/_react["default"].createElement("button", null, "Cancel")));
|
|
192
|
+
expect(_react2.screen.getByRole('button', {
|
|
193
|
+
name: 'Save'
|
|
194
|
+
})).toBeInTheDocument();
|
|
195
|
+
expect(_react2.screen.getByRole('button', {
|
|
196
|
+
name: 'Cancel'
|
|
197
|
+
})).toBeInTheDocument();
|
|
198
|
+
});
|
|
199
|
+
it('should render nested form sections', function () {
|
|
200
|
+
(0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_formSection["default"], {
|
|
201
|
+
label: "Outer"
|
|
202
|
+
}, /*#__PURE__*/_react["default"].createElement(_formSection["default"], {
|
|
203
|
+
label: "Inner"
|
|
204
|
+
}, /*#__PURE__*/_react["default"].createElement("div", null, "Nested content"))));
|
|
205
|
+
expect(_react2.screen.getByText('Outer')).toBeInTheDocument();
|
|
206
|
+
expect(_react2.screen.getByText('Inner')).toBeInTheDocument();
|
|
207
|
+
expect(_react2.screen.getByText('Nested content')).toBeInTheDocument();
|
|
208
|
+
});
|
|
209
|
+
});
|
|
210
|
+
describe('Edge cases', function () {
|
|
211
|
+
it('should render with conditional children', function () {
|
|
212
|
+
var showContent = true;
|
|
213
|
+
(0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_formSection["default"], {
|
|
214
|
+
label: "Conditional"
|
|
215
|
+
}, showContent && /*#__PURE__*/_react["default"].createElement("div", null, "Visible"), !showContent && /*#__PURE__*/_react["default"].createElement("div", null, "Hidden")));
|
|
216
|
+
expect(_react2.screen.getByText('Visible')).toBeInTheDocument();
|
|
217
|
+
expect(_react2.screen.queryByText('Hidden')).not.toBeInTheDocument();
|
|
218
|
+
});
|
|
219
|
+
it('should update when children change', function () {
|
|
220
|
+
var _render1 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_formSection["default"], {
|
|
221
|
+
label: "Dynamic"
|
|
222
|
+
}, /*#__PURE__*/_react["default"].createElement("div", null, "Initial content"))),
|
|
223
|
+
rerender = _render1.rerender;
|
|
224
|
+
expect(_react2.screen.getByText('Initial content')).toBeInTheDocument();
|
|
225
|
+
rerender(/*#__PURE__*/_react["default"].createElement(_formSection["default"], {
|
|
226
|
+
label: "Dynamic"
|
|
227
|
+
}, /*#__PURE__*/_react["default"].createElement("div", null, "Updated content")));
|
|
228
|
+
expect(_react2.screen.queryByText('Initial content')).not.toBeInTheDocument();
|
|
229
|
+
expect(_react2.screen.getByText('Updated content')).toBeInTheDocument();
|
|
230
|
+
});
|
|
231
|
+
});
|
|
232
|
+
describe('Accessibility', function () {
|
|
233
|
+
it('should have proper heading hierarchy', function () {
|
|
234
|
+
var _render10 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_formSection["default"], {
|
|
235
|
+
label: "Accessible Section"
|
|
236
|
+
}, /*#__PURE__*/_react["default"].createElement("div", null, "Content"))),
|
|
237
|
+
container = _render10.container;
|
|
238
|
+
var typography = container.querySelector('[class*="MuiTypography"]');
|
|
239
|
+
expect(typography).toBeInTheDocument();
|
|
240
|
+
});
|
|
241
|
+
it('should be properly semantically structured', function () {
|
|
242
|
+
var _render11 = (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_formSection["default"], {
|
|
243
|
+
label: "Semantic"
|
|
244
|
+
}, /*#__PURE__*/_react["default"].createElement("input", {
|
|
245
|
+
type: "text"
|
|
246
|
+
}))),
|
|
247
|
+
container = _render11.container;
|
|
248
|
+
expect(container.querySelector('div')).toBeInTheDocument();
|
|
249
|
+
});
|
|
250
|
+
});
|
|
251
|
+
});
|
|
252
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_react2","_formSection","describe","it","render","createElement","label","expect","screen","getByText","toBeInTheDocument","_render","container","typography","querySelector","_render2","className","type","placeholder","getByPlaceholderText","_render3","rerender","queryByText","not","_render4","longLabel","specialLabel","_render5","formSection","_render6","labelExtraStyle","color","fontWeight","toHaveStyle","extraStyle","fontSize","margin","padding","_render7","_render8","_render9","element","_render0","firstChild","getByRole","name","showContent","_render1","_render10","_render11"],"sources":["../../src/__tests__/form-section.test.jsx"],"sourcesContent":["import React from 'react';\nimport { render, screen } from '@testing-library/react';\nimport FormSection from '../form-section';\n\ndescribe('FormSection Component', () => {\n  describe('Rendering', () => {\n    it('should render with label and children', () => {\n      render(\n        <FormSection label=\"Settings\">\n          <div>Child content</div>\n        </FormSection>,\n      );\n\n      expect(screen.getByText('Settings')).toBeInTheDocument();\n      expect(screen.getByText('Child content')).toBeInTheDocument();\n    });\n\n    it('should render label as subtitle1 typography', () => {\n      const { container } = render(\n        <FormSection label=\"Configuration\">\n          <div>Content</div>\n        </FormSection>,\n      );\n\n      const typography = container.querySelector('[class*=\"MuiTypography\"]');\n      expect(typography).toBeInTheDocument();\n    });\n\n    it('should render with custom className', () => {\n      const { container } = render(\n        <FormSection label=\"Custom\" className=\"custom-class\">\n          <div>Content</div>\n        </FormSection>,\n      );\n\n      expect(container.querySelector('.custom-class')).toBeInTheDocument();\n    });\n\n    it('should render multiple children', () => {\n      render(\n        <FormSection label=\"Multiple Children\">\n          <div>First child</div>\n          <div>Second child</div>\n          <div>Third child</div>\n        </FormSection>,\n      );\n\n      expect(screen.getByText('First child')).toBeInTheDocument();\n      expect(screen.getByText('Second child')).toBeInTheDocument();\n      expect(screen.getByText('Third child')).toBeInTheDocument();\n    });\n\n    it('should render with single child', () => {\n      render(\n        <FormSection label=\"Single Child\">\n          <input type=\"text\" placeholder=\"Input\" />\n        </FormSection>,\n      );\n\n      expect(screen.getByPlaceholderText('Input')).toBeInTheDocument();\n    });\n\n    it('should render with complex child components', () => {\n      render(\n        <FormSection label=\"Complex\">\n          <div>\n            <label>Name:</label>\n            <input type=\"text\" placeholder=\"Enter name\" />\n          </div>\n          <div>\n            <label>Email:</label>\n            <input type=\"email\" placeholder=\"Enter email\" />\n          </div>\n        </FormSection>,\n      );\n\n      expect(screen.getByPlaceholderText('Enter name')).toBeInTheDocument();\n      expect(screen.getByPlaceholderText('Enter email')).toBeInTheDocument();\n    });\n  });\n\n  describe('Labels', () => {\n    it('should display different labels', () => {\n      const { rerender } = render(\n        <FormSection label=\"First Label\">\n          <div>Content</div>\n        </FormSection>,\n      );\n\n      expect(screen.getByText('First Label')).toBeInTheDocument();\n\n      rerender(\n        <FormSection label=\"Second Label\">\n          <div>Content</div>\n        </FormSection>,\n      );\n\n      expect(screen.getByText('Second Label')).toBeInTheDocument();\n      expect(screen.queryByText('First Label')).not.toBeInTheDocument();\n    });\n\n    it('should handle empty label', () => {\n      const { container } = render(\n        <FormSection label=\"\">\n          <div>Content</div>\n        </FormSection>,\n      );\n\n      expect(container.querySelector('[class*=\"MuiTypography\"]')).toBeInTheDocument();\n      expect(screen.getByText('Content')).toBeInTheDocument();\n    });\n\n    it('should handle long labels', () => {\n      const longLabel = 'This is a very long label that should wrap properly within the form section';\n      render(\n        <FormSection label={longLabel}>\n          <div>Content</div>\n        </FormSection>,\n      );\n\n      expect(screen.getByText(longLabel)).toBeInTheDocument();\n    });\n\n    it('should handle special characters in labels', () => {\n      const specialLabel = 'Settings & Configuration < Advanced > Test @ #1';\n      render(\n        <FormSection label={specialLabel}>\n          <div>Content</div>\n        </FormSection>,\n      );\n\n      expect(screen.getByText(specialLabel)).toBeInTheDocument();\n    });\n  });\n\n  describe('Styling and Layout', () => {\n    it('should apply default spacing', () => {\n      const { container } = render(\n        <FormSection label=\"Spaced\">\n          <div>Content</div>\n        </FormSection>,\n      );\n\n      const formSection = container.querySelector('[class*=\"MuiBox\"], div');\n      expect(formSection).toBeInTheDocument();\n    });\n\n    it('should apply labelExtraStyle to the label', () => {\n      const { container } = render(\n        <FormSection \n          label=\"Styled Label\" \n          labelExtraStyle={{ color: 'red', fontWeight: 'bold' }}\n        >\n          <div>Content</div>\n        </FormSection>,\n      );\n\n      const typography = container.querySelector('[class*=\"MuiTypography\"]');\n      expect(typography).toHaveStyle('color: red');\n      expect(typography).toHaveStyle('fontWeight: bold');\n    });\n\n    it('should apply multiple labelExtraStyle properties', () => {\n      const extraStyle = {\n        fontSize: '18px',\n        margin: '10px',\n        padding: '5px',\n      };\n\n      const { container } = render(\n        <FormSection \n          label=\"Multi-styled\" \n          labelExtraStyle={extraStyle}\n        >\n          <div>Content</div>\n        </FormSection>,\n      );\n\n      const typography = container.querySelector('[class*=\"MuiTypography\"]');\n      expect(typography).toHaveStyle('fontSize: 18px');\n      expect(typography).toHaveStyle('margin: 10px');\n      expect(typography).toHaveStyle('padding: 5px');\n    });\n\n    it('should handle no labelExtraStyle', () => {\n      const { container } = render(\n        <FormSection label=\"No Extra Style\">\n          <div>Content</div>\n        </FormSection>,\n      );\n\n      expect(container.querySelector('[class*=\"MuiTypography\"]')).toBeInTheDocument();\n    });\n  });\n\n  describe('CSS classes', () => {\n    it('should support multiple custom classes', () => {\n      const { container } = render(\n        <FormSection label=\"Test\" className=\"class1 class2 class3\">\n          <div>Content</div>\n        </FormSection>,\n      );\n\n      const element = container.querySelector('.class1.class2.class3');\n      expect(element).toBeInTheDocument();\n    });\n\n    it('should work without custom className', () => {\n      const { container } = render(\n        <FormSection label=\"Test\">\n          <div>Content</div>\n        </FormSection>,\n      );\n\n      expect(container.firstChild).toBeInTheDocument();\n    });\n  });\n\n  describe('Content variations', () => {\n    it('should render form inputs as children', () => {\n      render(\n        <FormSection label=\"Form Inputs\">\n          <input type=\"text\" placeholder=\"Text input\" />\n          <input type=\"number\" placeholder=\"Number input\" />\n          <textarea placeholder=\"Text area\"></textarea>\n        </FormSection>,\n      );\n\n      expect(screen.getByPlaceholderText('Text input')).toBeInTheDocument();\n      expect(screen.getByPlaceholderText('Number input')).toBeInTheDocument();\n      expect(screen.getByPlaceholderText('Text area')).toBeInTheDocument();\n    });\n\n    it('should render lists as children', () => {\n      render(\n        <FormSection label=\"Options\">\n          <ul>\n            <li>Option 1</li>\n            <li>Option 2</li>\n            <li>Option 3</li>\n          </ul>\n        </FormSection>,\n      );\n\n      expect(screen.getByText('Option 1')).toBeInTheDocument();\n      expect(screen.getByText('Option 2')).toBeInTheDocument();\n      expect(screen.getByText('Option 3')).toBeInTheDocument();\n    });\n\n    it('should render buttons as children', () => {\n      render(\n        <FormSection label=\"Actions\">\n          <button>Save</button>\n          <button>Cancel</button>\n        </FormSection>,\n      );\n\n      expect(screen.getByRole('button', { name: 'Save' })).toBeInTheDocument();\n      expect(screen.getByRole('button', { name: 'Cancel' })).toBeInTheDocument();\n    });\n\n    it('should render nested form sections', () => {\n      render(\n        <FormSection label=\"Outer\">\n          <FormSection label=\"Inner\">\n            <div>Nested content</div>\n          </FormSection>\n        </FormSection>,\n      );\n\n      expect(screen.getByText('Outer')).toBeInTheDocument();\n      expect(screen.getByText('Inner')).toBeInTheDocument();\n      expect(screen.getByText('Nested content')).toBeInTheDocument();\n    });\n  });\n\n  describe('Edge cases', () => {\n    it('should render with conditional children', () => {\n      const showContent = true;\n\n      render(\n        <FormSection label=\"Conditional\">\n          {showContent && <div>Visible</div>}\n          {!showContent && <div>Hidden</div>}\n        </FormSection>,\n      );\n\n      expect(screen.getByText('Visible')).toBeInTheDocument();\n      expect(screen.queryByText('Hidden')).not.toBeInTheDocument();\n    });\n\n    it('should update when children change', () => {\n      const { rerender } = render(\n        <FormSection label=\"Dynamic\">\n          <div>Initial content</div>\n        </FormSection>,\n      );\n\n      expect(screen.getByText('Initial content')).toBeInTheDocument();\n\n      rerender(\n        <FormSection label=\"Dynamic\">\n          <div>Updated content</div>\n        </FormSection>,\n      );\n\n      expect(screen.queryByText('Initial content')).not.toBeInTheDocument();\n      expect(screen.getByText('Updated content')).toBeInTheDocument();\n    });\n  });\n\n  describe('Accessibility', () => {\n    it('should have proper heading hierarchy', () => {\n      const { container } = render(\n        <FormSection label=\"Accessible Section\">\n          <div>Content</div>\n        </FormSection>,\n      );\n\n      const typography = container.querySelector('[class*=\"MuiTypography\"]');\n      expect(typography).toBeInTheDocument();\n    });\n\n    it('should be properly semantically structured', () => {\n      const { container } = render(\n        <FormSection label=\"Semantic\">\n          <input type=\"text\" />\n        </FormSection>,\n      );\n\n      expect(container.querySelector('div')).toBeInTheDocument();\n    });\n  });\n});\n"],"mappings":"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","ignoreList":[]}
|