@dxc-technology/halstack-react 0.0.0-d3554d7 → 0.0.0-d3ac293
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/BackgroundColorContext.d.ts +2 -2
- package/BackgroundColorContext.js +1 -1
- package/HalstackContext.d.ts +1336 -0
- package/HalstackContext.js +335 -0
- package/accordion/Accordion.d.ts +1 -1
- package/accordion/Accordion.js +118 -126
- package/accordion/Accordion.stories.tsx +115 -27
- package/accordion/Accordion.test.js +26 -12
- package/accordion/types.d.ts +9 -4
- package/accordion-group/AccordionGroup.d.ts +1 -1
- package/accordion-group/AccordionGroup.js +17 -38
- package/accordion-group/AccordionGroup.stories.tsx +28 -2
- package/accordion-group/AccordionGroup.test.js +31 -38
- package/accordion-group/types.d.ts +14 -3
- package/alert/Alert.js +7 -4
- package/alert/Alert.stories.tsx +28 -0
- package/alert/Alert.test.js +1 -1
- package/badge/Badge.d.ts +1 -1
- package/badge/Badge.js +5 -3
- package/badge/types.d.ts +1 -0
- package/bleed/Bleed.js +1 -34
- package/bleed/Bleed.stories.tsx +94 -95
- package/bleed/types.d.ts +25 -1
- package/box/Box.js +25 -37
- package/box/Box.stories.tsx +15 -0
- package/box/Box.test.js +1 -1
- package/box/types.d.ts +1 -0
- package/bulleted-list/BulletedList.d.ts +7 -0
- package/bulleted-list/BulletedList.js +123 -0
- package/bulleted-list/BulletedList.stories.tsx +200 -0
- package/bulleted-list/types.d.ts +11 -0
- package/button/Button.js +52 -69
- package/button/Button.stories.tsx +159 -8
- package/button/Button.test.js +1 -1
- package/button/types.d.ts +7 -7
- package/card/Card.js +25 -28
- package/card/Card.test.js +1 -1
- package/card/types.d.ts +1 -0
- package/checkbox/Checkbox.d.ts +2 -2
- package/checkbox/Checkbox.js +107 -110
- package/checkbox/Checkbox.stories.tsx +198 -130
- package/checkbox/Checkbox.test.js +101 -11
- package/checkbox/types.d.ts +13 -5
- package/chip/Chip.js +18 -24
- package/chip/Chip.stories.tsx +96 -9
- package/chip/Chip.test.js +3 -5
- package/chip/types.d.ts +1 -1
- package/common/utils.d.ts +1 -0
- package/common/utils.js +4 -4
- package/common/variables.d.ts +1625 -0
- package/common/variables.js +483 -352
- package/date-input/Calendar.d.ts +4 -0
- package/date-input/Calendar.js +258 -0
- package/date-input/DateInput.js +169 -258
- package/date-input/DateInput.stories.tsx +199 -33
- package/date-input/DateInput.test.js +521 -155
- package/date-input/DatePicker.d.ts +4 -0
- package/date-input/DatePicker.js +146 -0
- package/date-input/Icons.d.ts +6 -0
- package/date-input/Icons.js +75 -0
- package/date-input/YearPicker.d.ts +4 -0
- package/date-input/YearPicker.js +126 -0
- package/date-input/types.d.ts +67 -9
- package/dialog/Dialog.js +76 -93
- package/dialog/Dialog.stories.tsx +230 -123
- package/dialog/Dialog.test.js +334 -5
- package/dialog/types.d.ts +3 -2
- package/dropdown/Dropdown.d.ts +1 -1
- package/dropdown/Dropdown.js +246 -253
- package/dropdown/Dropdown.stories.tsx +245 -56
- package/dropdown/Dropdown.test.js +507 -110
- package/dropdown/DropdownMenu.d.ts +4 -0
- package/dropdown/DropdownMenu.js +70 -0
- package/dropdown/DropdownMenuItem.d.ts +4 -0
- package/dropdown/DropdownMenuItem.js +81 -0
- package/dropdown/types.d.ts +25 -5
- package/file-input/FileInput.d.ts +2 -2
- package/file-input/FileInput.js +181 -223
- package/file-input/FileInput.stories.tsx +122 -11
- package/file-input/FileInput.test.js +14 -14
- package/file-input/FileItem.d.ts +4 -14
- package/file-input/FileItem.js +44 -66
- package/file-input/types.d.ts +17 -0
- package/flex/Flex.d.ts +4 -0
- package/flex/Flex.js +69 -0
- package/flex/Flex.stories.tsx +103 -0
- package/flex/types.d.ts +32 -0
- package/footer/Footer.js +16 -89
- package/footer/Footer.stories.tsx +99 -1
- package/footer/Footer.test.js +14 -26
- package/footer/Icons.js +1 -1
- package/footer/types.d.ts +2 -1
- package/header/Header.js +108 -129
- package/header/Header.stories.tsx +189 -36
- package/header/Header.test.js +20 -4
- package/header/Icons.js +2 -2
- package/header/types.d.ts +3 -2
- package/heading/Heading.js +1 -1
- package/heading/Heading.test.js +1 -1
- package/inset/Inset.js +1 -34
- package/inset/Inset.stories.tsx +36 -36
- package/inset/types.d.ts +25 -1
- package/layout/ApplicationLayout.d.ts +16 -6
- package/layout/ApplicationLayout.js +72 -132
- package/layout/ApplicationLayout.stories.tsx +84 -93
- package/layout/Icons.d.ts +5 -0
- package/layout/Icons.js +13 -2
- package/layout/SidenavContext.d.ts +5 -0
- package/layout/SidenavContext.js +19 -0
- package/layout/types.d.ts +18 -33
- package/link/Link.d.ts +3 -2
- package/link/Link.js +59 -76
- package/link/Link.stories.tsx +155 -53
- package/link/Link.test.js +9 -19
- package/link/types.d.ts +7 -23
- package/main.d.ts +8 -10
- package/main.js +46 -56
- package/nav-tabs/NavTabs.d.ts +8 -0
- package/nav-tabs/NavTabs.js +125 -0
- package/nav-tabs/NavTabs.stories.tsx +260 -0
- package/nav-tabs/NavTabs.test.js +82 -0
- package/nav-tabs/Tab.d.ts +4 -0
- package/nav-tabs/Tab.js +150 -0
- package/nav-tabs/types.d.ts +53 -0
- package/number-input/NumberInput.js +11 -18
- package/number-input/NumberInput.stories.tsx +5 -5
- package/number-input/NumberInput.test.js +46 -12
- package/number-input/types.d.ts +17 -10
- package/package.json +20 -23
- package/paginator/Icons.d.ts +5 -0
- package/paginator/Icons.js +16 -28
- package/paginator/Paginator.js +19 -46
- package/paginator/Paginator.stories.tsx +24 -0
- package/paginator/Paginator.test.js +78 -39
- package/paragraph/Paragraph.d.ts +6 -0
- package/paragraph/Paragraph.js +38 -0
- package/paragraph/Paragraph.stories.tsx +44 -0
- package/password-input/PasswordInput.js +7 -4
- package/password-input/PasswordInput.test.js +17 -19
- package/password-input/types.d.ts +14 -11
- package/progress-bar/ProgressBar.d.ts +2 -2
- package/progress-bar/ProgressBar.js +61 -55
- package/progress-bar/ProgressBar.stories.jsx +47 -12
- package/progress-bar/ProgressBar.test.js +68 -23
- package/progress-bar/types.d.ts +3 -4
- package/quick-nav/QuickNav.d.ts +4 -0
- package/quick-nav/QuickNav.js +117 -0
- package/quick-nav/QuickNav.stories.tsx +356 -0
- package/quick-nav/types.d.ts +21 -0
- package/radio-group/Radio.d.ts +1 -1
- package/radio-group/Radio.js +43 -28
- package/radio-group/RadioGroup.js +32 -28
- package/radio-group/RadioGroup.stories.tsx +135 -17
- package/radio-group/RadioGroup.test.js +145 -117
- package/radio-group/types.d.ts +79 -2
- package/resultsetTable/Icons.d.ts +7 -0
- package/resultsetTable/Icons.js +51 -0
- package/resultsetTable/ResultsetTable.js +49 -108
- package/resultsetTable/ResultsetTable.stories.tsx +50 -25
- package/resultsetTable/ResultsetTable.test.js +61 -42
- package/resultsetTable/types.d.ts +2 -2
- package/select/Icons.d.ts +10 -0
- package/select/Icons.js +93 -0
- package/select/Listbox.d.ts +4 -0
- package/select/Listbox.js +169 -0
- package/select/Option.d.ts +4 -0
- package/select/Option.js +97 -0
- package/select/Select.js +179 -384
- package/select/Select.stories.tsx +531 -142
- package/select/Select.test.js +652 -324
- package/select/types.d.ts +53 -13
- package/sidenav/Sidenav.d.ts +6 -5
- package/sidenav/Sidenav.js +183 -53
- package/sidenav/Sidenav.stories.tsx +249 -149
- package/sidenav/Sidenav.test.js +25 -37
- package/sidenav/types.d.ts +50 -27
- package/slider/Slider.d.ts +2 -2
- package/slider/Slider.js +124 -98
- package/slider/Slider.stories.tsx +72 -9
- package/slider/Slider.test.js +143 -22
- package/slider/types.d.ts +10 -2
- package/spinner/Spinner.js +4 -4
- package/spinner/Spinner.stories.jsx +27 -1
- package/spinner/Spinner.test.js +1 -1
- package/switch/Switch.d.ts +2 -2
- package/switch/Switch.js +152 -69
- package/switch/Switch.stories.tsx +53 -42
- package/switch/Switch.test.js +156 -4
- package/switch/types.d.ts +12 -4
- package/table/Table.js +3 -3
- package/table/Table.stories.jsx +80 -1
- package/table/Table.test.js +2 -2
- package/tabs/Tab.d.ts +4 -0
- package/tabs/Tab.js +133 -0
- package/tabs/Tabs.d.ts +1 -1
- package/tabs/Tabs.js +363 -109
- package/tabs/Tabs.stories.tsx +119 -13
- package/tabs/Tabs.test.js +241 -14
- package/tabs/types.d.ts +19 -5
- package/tag/Tag.js +17 -22
- package/tag/Tag.stories.tsx +25 -8
- package/tag/Tag.test.js +1 -1
- package/tag/types.d.ts +1 -1
- package/text-input/Icons.d.ts +8 -0
- package/text-input/Icons.js +60 -0
- package/text-input/Suggestion.d.ts +4 -0
- package/text-input/Suggestion.js +84 -0
- package/text-input/Suggestions.d.ts +4 -0
- package/text-input/Suggestions.js +134 -0
- package/text-input/TextInput.js +221 -344
- package/text-input/TextInput.stories.tsx +290 -195
- package/text-input/TextInput.test.js +763 -731
- package/text-input/types.d.ts +50 -12
- package/textarea/Textarea.js +17 -26
- package/textarea/Textarea.stories.jsx +65 -6
- package/textarea/Textarea.test.js +38 -37
- package/textarea/types.d.ts +18 -11
- package/toggle-group/ToggleGroup.d.ts +1 -1
- package/toggle-group/ToggleGroup.js +6 -5
- package/toggle-group/ToggleGroup.stories.tsx +46 -4
- package/toggle-group/ToggleGroup.test.js +36 -5
- package/toggle-group/types.d.ts +9 -1
- package/typography/Typography.d.ts +4 -0
- package/typography/Typography.js +32 -0
- package/typography/Typography.stories.tsx +198 -0
- package/typography/types.d.ts +18 -0
- package/typography/types.js +5 -0
- package/useTheme.d.ts +1234 -1
- package/useTheme.js +3 -3
- package/useTranslatedLabels.d.ts +85 -0
- package/useTranslatedLabels.js +20 -0
- package/utils/BaseTypography.d.ts +21 -0
- package/utils/BaseTypography.js +108 -0
- package/utils/FocusLock.d.ts +13 -0
- package/utils/FocusLock.js +139 -0
- package/wizard/Wizard.d.ts +1 -1
- package/wizard/Wizard.js +59 -55
- package/wizard/Wizard.stories.tsx +48 -19
- package/wizard/Wizard.test.js +37 -24
- package/wizard/types.d.ts +10 -5
- package/ThemeContext.d.ts +0 -10
- package/ThemeContext.js +0 -243
- package/common/RequiredComponent.js +0 -32
- package/list/List.d.ts +0 -4
- package/list/List.js +0 -47
- package/list/List.stories.tsx +0 -95
- package/list/types.d.ts +0 -7
- package/radio/Radio.d.ts +0 -4
- package/radio/Radio.js +0 -174
- package/radio/Radio.stories.tsx +0 -192
- package/radio/Radio.test.js +0 -71
- package/radio/types.d.ts +0 -54
- package/row/Row.d.ts +0 -3
- package/row/Row.js +0 -127
- package/row/Row.stories.tsx +0 -237
- package/row/types.d.ts +0 -10
- package/stack/Stack.d.ts +0 -3
- package/stack/Stack.js +0 -97
- package/stack/Stack.stories.tsx +0 -164
- package/stack/types.d.ts +0 -9
- package/text/Text.d.ts +0 -7
- package/text/Text.js +0 -30
- package/text/Text.stories.tsx +0 -19
- /package/{list → bulleted-list}/types.js +0 -0
- /package/{radio → flex}/types.js +0 -0
- /package/{row → nav-tabs}/types.js +0 -0
- /package/{stack → quick-nav}/types.js +0 -0
|
@@ -2,13 +2,50 @@
|
|
|
2
2
|
|
|
3
3
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
4
|
|
|
5
|
+
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
|
|
6
|
+
|
|
7
|
+
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
|
|
8
|
+
|
|
5
9
|
var _react = _interopRequireDefault(require("react"));
|
|
6
10
|
|
|
7
11
|
var _react2 = require("@testing-library/react");
|
|
8
12
|
|
|
9
13
|
var _userEvent = _interopRequireDefault(require("@testing-library/user-event"));
|
|
10
14
|
|
|
11
|
-
var _ResultsetTable = _interopRequireDefault(require("./ResultsetTable"));
|
|
15
|
+
var _ResultsetTable = _interopRequireDefault(require("./ResultsetTable.tsx"));
|
|
16
|
+
|
|
17
|
+
// Mocking DOMRect for Radix Primitive Popover
|
|
18
|
+
global.globalThis = global;
|
|
19
|
+
global.DOMRect = {
|
|
20
|
+
fromRect: function fromRect() {
|
|
21
|
+
return {
|
|
22
|
+
top: 0,
|
|
23
|
+
left: 0,
|
|
24
|
+
bottom: 0,
|
|
25
|
+
right: 0,
|
|
26
|
+
width: 0,
|
|
27
|
+
height: 0
|
|
28
|
+
};
|
|
29
|
+
}
|
|
30
|
+
};
|
|
31
|
+
|
|
32
|
+
global.ResizeObserver = /*#__PURE__*/function () {
|
|
33
|
+
function ResizeObserver() {
|
|
34
|
+
(0, _classCallCheck2["default"])(this, ResizeObserver);
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
(0, _createClass2["default"])(ResizeObserver, [{
|
|
38
|
+
key: "observe",
|
|
39
|
+
value: function observe() {}
|
|
40
|
+
}, {
|
|
41
|
+
key: "unobserve",
|
|
42
|
+
value: function unobserve() {}
|
|
43
|
+
}, {
|
|
44
|
+
key: "disconnect",
|
|
45
|
+
value: function disconnect() {}
|
|
46
|
+
}]);
|
|
47
|
+
return ResizeObserver;
|
|
48
|
+
}();
|
|
12
49
|
|
|
13
50
|
var columns = [{
|
|
14
51
|
displayValue: "Id",
|
|
@@ -38,8 +75,6 @@ var rows = [[{
|
|
|
38
75
|
}, {
|
|
39
76
|
displayValue: "Oviedo",
|
|
40
77
|
sortValue: "Oviedo"
|
|
41
|
-
}, {
|
|
42
|
-
displayValue: ""
|
|
43
78
|
}], [{
|
|
44
79
|
displayValue: "003",
|
|
45
80
|
sortValue: "003"
|
|
@@ -76,8 +111,6 @@ var rows = [[{
|
|
|
76
111
|
}, {
|
|
77
112
|
displayValue: "Barcelona",
|
|
78
113
|
sortValue: "Barcelona"
|
|
79
|
-
}, {
|
|
80
|
-
displayValue: ""
|
|
81
114
|
}], [{
|
|
82
115
|
displayValue: "007",
|
|
83
116
|
sortValue: "007"
|
|
@@ -105,8 +138,6 @@ var rows = [[{
|
|
|
105
138
|
}, {
|
|
106
139
|
displayValue: "Oviedo",
|
|
107
140
|
sortValue: "Oviedo"
|
|
108
|
-
}, {
|
|
109
|
-
displayValue: ""
|
|
110
141
|
}], [{
|
|
111
142
|
displayValue: "010",
|
|
112
143
|
sortValue: "010"
|
|
@@ -116,8 +147,6 @@ var rows = [[{
|
|
|
116
147
|
}, {
|
|
117
148
|
displayValue: "Barcelona",
|
|
118
149
|
sortValue: "Barcelona"
|
|
119
|
-
}, {
|
|
120
|
-
displayValue: ""
|
|
121
150
|
}]];
|
|
122
151
|
var rows2 = [[{
|
|
123
152
|
displayValue: "546",
|
|
@@ -149,8 +178,8 @@ var rows2 = [[{
|
|
|
149
178
|
displayValue: "OtherValue",
|
|
150
179
|
sortValue: "OtherValue"
|
|
151
180
|
}]];
|
|
152
|
-
describe("
|
|
153
|
-
test("
|
|
181
|
+
describe("Resultset table component tests", function () {
|
|
182
|
+
test("Resultset table rendered correctly", function () {
|
|
154
183
|
var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
|
|
155
184
|
columns: columns,
|
|
156
185
|
rows: rows,
|
|
@@ -160,7 +189,7 @@ describe("ResultsetTable component tests", function () {
|
|
|
160
189
|
|
|
161
190
|
expect(getByText("Peter")).toBeTruthy();
|
|
162
191
|
});
|
|
163
|
-
test("
|
|
192
|
+
test("Resultset table shows as many rows as itemsPerPage", function () {
|
|
164
193
|
var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
|
|
165
194
|
columns: columns,
|
|
166
195
|
rows: rows,
|
|
@@ -170,7 +199,7 @@ describe("ResultsetTable component tests", function () {
|
|
|
170
199
|
|
|
171
200
|
expect(getAllByRole("row").length - 1).toEqual(3);
|
|
172
201
|
});
|
|
173
|
-
test("
|
|
202
|
+
test("Resultset table shows rows on second page", function () {
|
|
174
203
|
var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
|
|
175
204
|
columns: columns,
|
|
176
205
|
rows: rows,
|
|
@@ -183,18 +212,17 @@ describe("ResultsetTable component tests", function () {
|
|
|
183
212
|
expect(getByText("Louis")).toBeTruthy();
|
|
184
213
|
expect(getByText("Lana")).toBeTruthy();
|
|
185
214
|
expect(getAllByRole("row").length - 1).toEqual(3);
|
|
186
|
-
var nextButton = getAllByRole("button")[
|
|
215
|
+
var nextButton = getAllByRole("button")[3];
|
|
187
216
|
|
|
188
217
|
_react2.fireEvent.click(nextButton);
|
|
189
218
|
|
|
190
|
-
expect(getByText("4 to 6 of 10")).toBeTruthy();
|
|
191
|
-
|
|
219
|
+
expect(getByText("4 to 6 of 10")).toBeTruthy();
|
|
192
220
|
expect(getByText("Rick")).toBeTruthy();
|
|
193
221
|
expect(getByText("Mark")).toBeTruthy();
|
|
194
222
|
expect(getByText("Cris")).toBeTruthy();
|
|
195
223
|
expect(getAllByRole("row").length - 1).toEqual(3);
|
|
196
224
|
});
|
|
197
|
-
test("
|
|
225
|
+
test("Resultset table goToPage works as expected", function () {
|
|
198
226
|
window.HTMLElement.prototype.scrollIntoView = function () {};
|
|
199
227
|
|
|
200
228
|
window.HTMLElement.prototype.scrollTo = function () {};
|
|
@@ -206,28 +234,27 @@ describe("ResultsetTable component tests", function () {
|
|
|
206
234
|
itemsPerPage: 3
|
|
207
235
|
})),
|
|
208
236
|
getByText = _render4.getByText,
|
|
209
|
-
getAllByRole = _render4.getAllByRole
|
|
210
|
-
getByRole = _render4.getByRole;
|
|
237
|
+
getAllByRole = _render4.getAllByRole;
|
|
211
238
|
|
|
212
239
|
expect(getByText("Peter")).toBeTruthy();
|
|
213
240
|
expect(getByText("Louis")).toBeTruthy();
|
|
214
241
|
expect(getByText("Lana")).toBeTruthy();
|
|
215
242
|
expect(getAllByRole("row").length - 1).toEqual(3);
|
|
216
|
-
var goToPageSelect = getAllByRole("button")[
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
243
|
+
var goToPageSelect = getAllByRole("button")[3];
|
|
244
|
+
|
|
245
|
+
_userEvent["default"].click(goToPageSelect);
|
|
246
|
+
|
|
220
247
|
var goToPageOption = getByText("2");
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
248
|
+
|
|
249
|
+
_userEvent["default"].click(goToPageOption);
|
|
250
|
+
|
|
224
251
|
expect(getByText("4 to 6 of 10")).toBeTruthy();
|
|
225
252
|
expect(getByText("Rick")).toBeTruthy();
|
|
226
253
|
expect(getByText("Mark")).toBeTruthy();
|
|
227
254
|
expect(getByText("Cris")).toBeTruthy();
|
|
228
255
|
expect(getAllByRole("row").length - 1).toEqual(3);
|
|
229
256
|
});
|
|
230
|
-
test("
|
|
257
|
+
test("Resultset table going to the last page shows only one row", function () {
|
|
231
258
|
var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
|
|
232
259
|
columns: columns,
|
|
233
260
|
rows: rows,
|
|
@@ -236,7 +263,7 @@ describe("ResultsetTable component tests", function () {
|
|
|
236
263
|
getByText = _render5.getByText,
|
|
237
264
|
getAllByRole = _render5.getAllByRole;
|
|
238
265
|
|
|
239
|
-
var lastButton = getAllByRole("button")[
|
|
266
|
+
var lastButton = getAllByRole("button")[4];
|
|
240
267
|
|
|
241
268
|
_react2.fireEvent.click(lastButton);
|
|
242
269
|
|
|
@@ -244,7 +271,7 @@ describe("ResultsetTable component tests", function () {
|
|
|
244
271
|
expect(getAllByRole("row")).toHaveLength(2);
|
|
245
272
|
expect(getByText("Cosmin")).toBeTruthy();
|
|
246
273
|
});
|
|
247
|
-
test("
|
|
274
|
+
test("Resultset table sort rows by column", function () {
|
|
248
275
|
var component = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
|
|
249
276
|
columns: columns,
|
|
250
277
|
rows: rows,
|
|
@@ -262,7 +289,7 @@ describe("ResultsetTable component tests", function () {
|
|
|
262
289
|
expect(component.queryByText("Tina")).toBeTruthy();
|
|
263
290
|
expect(component.queryByText("Cosmin")).not.toBeTruthy();
|
|
264
291
|
});
|
|
265
|
-
test("
|
|
292
|
+
test("Resultset table change rows should go to first page", function () {
|
|
266
293
|
var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
|
|
267
294
|
columns: columns,
|
|
268
295
|
rows: rows,
|
|
@@ -279,28 +306,20 @@ describe("ResultsetTable component tests", function () {
|
|
|
279
306
|
}));
|
|
280
307
|
expect(queryByText("1 to 3 of 3")).toBeTruthy();
|
|
281
308
|
});
|
|
282
|
-
test("
|
|
309
|
+
test("Resultset table change itemsPerPage should go to first page", function () {
|
|
283
310
|
var _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
|
|
284
311
|
columns: columns,
|
|
285
312
|
rows: rows,
|
|
286
313
|
itemsPerPage: 3,
|
|
287
314
|
itemsPerPageOptions: [2, 3]
|
|
288
315
|
})),
|
|
289
|
-
getAllByRole = _render7.getAllByRole
|
|
290
|
-
queryByText = _render7.queryByText,
|
|
291
|
-
rerender = _render7.rerender;
|
|
316
|
+
getAllByRole = _render7.getAllByRole;
|
|
292
317
|
|
|
293
|
-
var lastButton = getAllByRole("button")[
|
|
318
|
+
var lastButton = getAllByRole("button")[4];
|
|
319
|
+
expect(getAllByRole("row").length - 1).toEqual(3);
|
|
294
320
|
|
|
295
321
|
_react2.fireEvent.click(lastButton);
|
|
296
322
|
|
|
297
323
|
expect(getAllByRole("row").length - 1).toEqual(1);
|
|
298
|
-
rerender( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
|
|
299
|
-
columns: columns,
|
|
300
|
-
rows: rows,
|
|
301
|
-
itemsPerPage: 6
|
|
302
|
-
}));
|
|
303
|
-
expect(getAllByRole("row").length - 1).toEqual(6);
|
|
304
|
-
expect(queryByText("Peter")).toBeTruthy();
|
|
305
324
|
});
|
|
306
325
|
});
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
/// <reference types="react" />
|
|
2
|
-
declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
|
|
3
|
-
declare type Margin = {
|
|
2
|
+
export declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
|
|
3
|
+
export declare type Margin = {
|
|
4
4
|
top?: Space;
|
|
5
5
|
bottom?: Space;
|
|
6
6
|
left?: Space;
|
package/select/Icons.js
ADDED
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports["default"] = void 0;
|
|
9
|
+
|
|
10
|
+
var _react = _interopRequireDefault(require("react"));
|
|
11
|
+
|
|
12
|
+
var selectIcons = {
|
|
13
|
+
error: /*#__PURE__*/_react["default"].createElement("svg", {
|
|
14
|
+
role: "img",
|
|
15
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
16
|
+
height: "24px",
|
|
17
|
+
viewBox: "0 0 24 24",
|
|
18
|
+
width: "24px",
|
|
19
|
+
fill: "currentColor"
|
|
20
|
+
}, /*#__PURE__*/_react["default"].createElement("path", {
|
|
21
|
+
d: "M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm1 15h-2v-2h2v2zm0-4h-2V7h2v6z"
|
|
22
|
+
})),
|
|
23
|
+
arrowUp: /*#__PURE__*/_react["default"].createElement("svg", {
|
|
24
|
+
role: "img",
|
|
25
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
26
|
+
height: "24px",
|
|
27
|
+
viewBox: "0 0 24 24",
|
|
28
|
+
width: "24px",
|
|
29
|
+
fill: "currentColor"
|
|
30
|
+
}, /*#__PURE__*/_react["default"].createElement("path", {
|
|
31
|
+
d: "M0 0h24v24H0V0z",
|
|
32
|
+
fill: "none"
|
|
33
|
+
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
34
|
+
d: "M7.41 15.41L12 10.83l4.59 4.58L18 14l-6-6-6 6 1.41 1.41z"
|
|
35
|
+
})),
|
|
36
|
+
arrowDown: /*#__PURE__*/_react["default"].createElement("svg", {
|
|
37
|
+
role: "img",
|
|
38
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
39
|
+
height: "24px",
|
|
40
|
+
viewBox: "0 0 24 24",
|
|
41
|
+
width: "24px",
|
|
42
|
+
fill: "currentColor"
|
|
43
|
+
}, /*#__PURE__*/_react["default"].createElement("path", {
|
|
44
|
+
d: "M0 0h24v24H0V0z",
|
|
45
|
+
fill: "none"
|
|
46
|
+
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
47
|
+
d: "M7.41 8.59L12 13.17l4.59-4.58L18 10l-6 6-6-6 1.41-1.41z"
|
|
48
|
+
})),
|
|
49
|
+
clear: /*#__PURE__*/_react["default"].createElement("svg", {
|
|
50
|
+
role: "img",
|
|
51
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
52
|
+
width: "24",
|
|
53
|
+
height: "24",
|
|
54
|
+
viewBox: "0 0 24 24",
|
|
55
|
+
fill: "currentColor"
|
|
56
|
+
}, /*#__PURE__*/_react["default"].createElement("path", {
|
|
57
|
+
d: "M0 0h24v24H0V0z",
|
|
58
|
+
fill: "none"
|
|
59
|
+
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
60
|
+
d: "M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12 19 6.41z"
|
|
61
|
+
})),
|
|
62
|
+
selected: /*#__PURE__*/_react["default"].createElement("svg", {
|
|
63
|
+
role: "img",
|
|
64
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
65
|
+
height: "24px",
|
|
66
|
+
viewBox: "0 0 24 24",
|
|
67
|
+
width: "24px",
|
|
68
|
+
fill: "currentColor"
|
|
69
|
+
}, /*#__PURE__*/_react["default"].createElement("path", {
|
|
70
|
+
d: "M0 0h24v24H0z",
|
|
71
|
+
fill: "none"
|
|
72
|
+
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
73
|
+
d: "M9 16.2L4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4L9 16.2z"
|
|
74
|
+
})),
|
|
75
|
+
searchOff: /*#__PURE__*/_react["default"].createElement("svg", {
|
|
76
|
+
role: "img",
|
|
77
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
78
|
+
height: "24px",
|
|
79
|
+
viewBox: "0 0 24 24",
|
|
80
|
+
width: "24px",
|
|
81
|
+
fill: "currentColor"
|
|
82
|
+
}, /*#__PURE__*/_react["default"].createElement("g", null, /*#__PURE__*/_react["default"].createElement("rect", {
|
|
83
|
+
fill: "none",
|
|
84
|
+
height: "24",
|
|
85
|
+
width: "24"
|
|
86
|
+
})), /*#__PURE__*/_react["default"].createElement("g", null, /*#__PURE__*/_react["default"].createElement("g", null, /*#__PURE__*/_react["default"].createElement("path", {
|
|
87
|
+
d: "M15.5,14h-0.79l-0.28-0.27C15.41,12.59,16,11.11,16,9.5C16,5.91,13.09,3,9.5,3C6.08,3,3.28,5.64,3.03,9h2.02 C5.3,6.75,7.18,5,9.5,5C11.99,5,14,7.01,14,9.5S11.99,14,9.5,14c-0.17,0-0.33-0.03-0.5-0.05v2.02C9.17,15.99,9.33,16,9.5,16 c1.61,0,3.09-0.59,4.23-1.57L14,14.71v0.79l5,4.99L20.49,19L15.5,14z"
|
|
88
|
+
}), /*#__PURE__*/_react["default"].createElement("polygon", {
|
|
89
|
+
points: "6.47,10.82 4,13.29 1.53,10.82 0.82,11.53 3.29,14 0.82,16.47 1.53,17.18 4,14.71 6.47,17.18 7.18,16.47 4.71,14 7.18,11.53"
|
|
90
|
+
}))))
|
|
91
|
+
};
|
|
92
|
+
var _default = selectIcons;
|
|
93
|
+
exports["default"] = _default;
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { ListboxProps } from "./types";
|
|
3
|
+
declare const _default: React.MemoExoticComponent<({ id, currentValue, options, visualFocusIndex, lastOptionIndex, multiple, optional, optionalItem, searchable, handleOptionOnClick, styles, }: ListboxProps) => JSX.Element>;
|
|
4
|
+
export default _default;
|
|
@@ -0,0 +1,169 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
6
|
+
|
|
7
|
+
Object.defineProperty(exports, "__esModule", {
|
|
8
|
+
value: true
|
|
9
|
+
});
|
|
10
|
+
exports["default"] = void 0;
|
|
11
|
+
|
|
12
|
+
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
|
|
13
|
+
|
|
14
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
15
|
+
|
|
16
|
+
var _styledComponents = _interopRequireDefault(require("styled-components"));
|
|
17
|
+
|
|
18
|
+
var _useTranslatedLabels = _interopRequireDefault(require("../useTranslatedLabels"));
|
|
19
|
+
|
|
20
|
+
var _Option = _interopRequireDefault(require("./Option"));
|
|
21
|
+
|
|
22
|
+
var _Icons = _interopRequireDefault(require("./Icons"));
|
|
23
|
+
|
|
24
|
+
var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5;
|
|
25
|
+
|
|
26
|
+
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
27
|
+
|
|
28
|
+
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
29
|
+
|
|
30
|
+
var groupsHaveOptions = function groupsHaveOptions(options) {
|
|
31
|
+
return options !== null && options !== void 0 && options[0].options ? options.some(function (groupOption) {
|
|
32
|
+
var _groupOption$options;
|
|
33
|
+
|
|
34
|
+
return ((_groupOption$options = groupOption.options) === null || _groupOption$options === void 0 ? void 0 : _groupOption$options.length) > 0;
|
|
35
|
+
}) : true;
|
|
36
|
+
};
|
|
37
|
+
|
|
38
|
+
var Listbox = function Listbox(_ref) {
|
|
39
|
+
var id = _ref.id,
|
|
40
|
+
currentValue = _ref.currentValue,
|
|
41
|
+
options = _ref.options,
|
|
42
|
+
visualFocusIndex = _ref.visualFocusIndex,
|
|
43
|
+
lastOptionIndex = _ref.lastOptionIndex,
|
|
44
|
+
multiple = _ref.multiple,
|
|
45
|
+
optional = _ref.optional,
|
|
46
|
+
optionalItem = _ref.optionalItem,
|
|
47
|
+
searchable = _ref.searchable,
|
|
48
|
+
handleOptionOnClick = _ref.handleOptionOnClick,
|
|
49
|
+
styles = _ref.styles;
|
|
50
|
+
var translatedLabels = (0, _useTranslatedLabels["default"])();
|
|
51
|
+
var listboxRef = (0, _react.useRef)(null);
|
|
52
|
+
var globalIndex = optional && !multiple ? 0 : -1;
|
|
53
|
+
|
|
54
|
+
var mapOptionFunc = function mapOptionFunc(option, mapIndex) {
|
|
55
|
+
if (option.options) {
|
|
56
|
+
var groupId = "group-".concat(mapIndex);
|
|
57
|
+
return option.options.length > 0 && /*#__PURE__*/_react["default"].createElement("li", {
|
|
58
|
+
key: "group-".concat(mapIndex)
|
|
59
|
+
}, /*#__PURE__*/_react["default"].createElement(GroupList, {
|
|
60
|
+
role: "group",
|
|
61
|
+
"aria-labelledby": groupId
|
|
62
|
+
}, /*#__PURE__*/_react["default"].createElement(GroupLabel, {
|
|
63
|
+
role: "presentation",
|
|
64
|
+
id: groupId
|
|
65
|
+
}, option.label), option.options.map(function (singleOption) {
|
|
66
|
+
globalIndex++;
|
|
67
|
+
return /*#__PURE__*/_react["default"].createElement(_Option["default"], {
|
|
68
|
+
key: "option-".concat(singleOption.value),
|
|
69
|
+
id: "option-".concat(globalIndex),
|
|
70
|
+
option: singleOption,
|
|
71
|
+
onClick: handleOptionOnClick,
|
|
72
|
+
multiple: multiple,
|
|
73
|
+
visualFocused: visualFocusIndex === globalIndex,
|
|
74
|
+
isGroupedOption: true,
|
|
75
|
+
isLastOption: lastOptionIndex === globalIndex,
|
|
76
|
+
isSelected: multiple ? currentValue.includes(singleOption.value) : currentValue === singleOption.value
|
|
77
|
+
});
|
|
78
|
+
})));
|
|
79
|
+
} else {
|
|
80
|
+
globalIndex++;
|
|
81
|
+
return /*#__PURE__*/_react["default"].createElement(_Option["default"], {
|
|
82
|
+
key: "option-".concat(option.value),
|
|
83
|
+
id: "option-".concat(globalIndex),
|
|
84
|
+
option: option,
|
|
85
|
+
onClick: handleOptionOnClick,
|
|
86
|
+
multiple: multiple,
|
|
87
|
+
visualFocused: visualFocusIndex === globalIndex,
|
|
88
|
+
isLastOption: lastOptionIndex === globalIndex,
|
|
89
|
+
isSelected: multiple ? currentValue.includes(option.value) : currentValue === option.value
|
|
90
|
+
});
|
|
91
|
+
}
|
|
92
|
+
};
|
|
93
|
+
|
|
94
|
+
(0, _react.useLayoutEffect)(function () {
|
|
95
|
+
if (currentValue && !multiple) {
|
|
96
|
+
var _listEl$scrollTo;
|
|
97
|
+
|
|
98
|
+
var listEl = listboxRef === null || listboxRef === void 0 ? void 0 : listboxRef.current;
|
|
99
|
+
var selectedListOptionEl = listEl === null || listEl === void 0 ? void 0 : listEl.querySelector("[aria-selected='true']");
|
|
100
|
+
listEl === null || listEl === void 0 ? void 0 : (_listEl$scrollTo = listEl.scrollTo) === null || _listEl$scrollTo === void 0 ? void 0 : _listEl$scrollTo.call(listEl, {
|
|
101
|
+
top: (selectedListOptionEl === null || selectedListOptionEl === void 0 ? void 0 : selectedListOptionEl.offsetTop) - (listEl === null || listEl === void 0 ? void 0 : listEl.clientHeight) / 2
|
|
102
|
+
});
|
|
103
|
+
}
|
|
104
|
+
}, [currentValue, multiple]);
|
|
105
|
+
(0, _react.useLayoutEffect)(function () {
|
|
106
|
+
var _listboxRef$current, _visualFocusedOptionE;
|
|
107
|
+
|
|
108
|
+
var visualFocusedOptionEl = listboxRef === null || listboxRef === void 0 ? void 0 : (_listboxRef$current = listboxRef.current) === null || _listboxRef$current === void 0 ? void 0 : _listboxRef$current.querySelectorAll("[role='option']")[visualFocusIndex];
|
|
109
|
+
visualFocusedOptionEl === null || visualFocusedOptionEl === void 0 ? void 0 : (_visualFocusedOptionE = visualFocusedOptionEl.scrollIntoView) === null || _visualFocusedOptionE === void 0 ? void 0 : _visualFocusedOptionE.call(visualFocusedOptionEl, {
|
|
110
|
+
block: "nearest",
|
|
111
|
+
inline: "start"
|
|
112
|
+
});
|
|
113
|
+
}, [visualFocusIndex]);
|
|
114
|
+
return /*#__PURE__*/_react["default"].createElement(ListboxContainer, {
|
|
115
|
+
id: id,
|
|
116
|
+
onClick: function onClick(event) {
|
|
117
|
+
event.stopPropagation();
|
|
118
|
+
},
|
|
119
|
+
onMouseDown: function onMouseDown(event) {
|
|
120
|
+
event.preventDefault();
|
|
121
|
+
},
|
|
122
|
+
ref: listboxRef,
|
|
123
|
+
role: "listbox",
|
|
124
|
+
"aria-multiselectable": multiple,
|
|
125
|
+
style: styles
|
|
126
|
+
}, searchable && (options.length === 0 || !groupsHaveOptions(options)) ? /*#__PURE__*/_react["default"].createElement(OptionsSystemMessage, null, /*#__PURE__*/_react["default"].createElement(NoMatchesFoundIcon, null, _Icons["default"].searchOff), translatedLabels.select.noMatchesErrorMessage) : optional && !multiple && /*#__PURE__*/_react["default"].createElement(_Option["default"], {
|
|
127
|
+
key: "option-".concat(optionalItem.value),
|
|
128
|
+
id: "option-".concat(0),
|
|
129
|
+
option: optionalItem,
|
|
130
|
+
onClick: handleOptionOnClick,
|
|
131
|
+
multiple: multiple,
|
|
132
|
+
visualFocused: visualFocusIndex === 0,
|
|
133
|
+
isGroupedOption: false,
|
|
134
|
+
isLastOption: lastOptionIndex === 0,
|
|
135
|
+
isSelected: multiple ? currentValue.includes(optionalItem.value) : currentValue === optionalItem.value
|
|
136
|
+
}), options.map(mapOptionFunc));
|
|
137
|
+
};
|
|
138
|
+
|
|
139
|
+
var ListboxContainer = _styledComponents["default"].ul(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n box-sizing: border-box;\n max-height: 304px;\n overflow-y: auto;\n margin: 0;\n padding: 0.25rem 0;\n background-color: ", ";\n border: 1px solid ", ";\n border-radius: 0.25rem;\n box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);\n cursor: default;\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n"])), function (props) {
|
|
140
|
+
return props.theme.listDialogBackgroundColor;
|
|
141
|
+
}, function (props) {
|
|
142
|
+
return props.theme.listDialogBorderColor;
|
|
143
|
+
}, function (props) {
|
|
144
|
+
return props.theme.listOptionFontColor;
|
|
145
|
+
}, function (props) {
|
|
146
|
+
return props.theme.fontFamily;
|
|
147
|
+
}, function (props) {
|
|
148
|
+
return props.theme.listOptionFontSize;
|
|
149
|
+
}, function (props) {
|
|
150
|
+
return props.theme.listOptionFontStyle;
|
|
151
|
+
}, function (props) {
|
|
152
|
+
return props.theme.listOptionFontWeight;
|
|
153
|
+
});
|
|
154
|
+
|
|
155
|
+
var OptionsSystemMessage = _styledComponents["default"].span(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n padding: 4px 16px;\n color: ", ";\n font-size: 0.875rem;\n line-height: 1.715em;\n"])), function (props) {
|
|
156
|
+
return props.theme.systemMessageFontColor;
|
|
157
|
+
});
|
|
158
|
+
|
|
159
|
+
var NoMatchesFoundIcon = _styledComponents["default"].span(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-wrap: wrap;\n align-content: center;\n height: 16px;\n width: 16px;\n padding: 4px;\n margin-right: 0.25rem;\n"])));
|
|
160
|
+
|
|
161
|
+
var GroupList = _styledComponents["default"].ul(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n padding: 0;\n"])));
|
|
162
|
+
|
|
163
|
+
var GroupLabel = _styledComponents["default"].li(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n padding: 4px 16px;\n font-weight: ", ";\n line-height: 1.715em;\n"])), function (props) {
|
|
164
|
+
return props.theme.listGroupLabelFontWeight;
|
|
165
|
+
});
|
|
166
|
+
|
|
167
|
+
var _default = /*#__PURE__*/_react["default"].memo(Listbox);
|
|
168
|
+
|
|
169
|
+
exports["default"] = _default;
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { OptionProps } from "../select/types";
|
|
3
|
+
declare const _default: React.MemoExoticComponent<({ id, option, onClick, multiple, visualFocused, isGroupedOption, isLastOption, isSelected, }: OptionProps) => JSX.Element>;
|
|
4
|
+
export default _default;
|
package/select/Option.js
ADDED
|
@@ -0,0 +1,97 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports["default"] = void 0;
|
|
9
|
+
|
|
10
|
+
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
|
|
11
|
+
|
|
12
|
+
var _react = _interopRequireDefault(require("react"));
|
|
13
|
+
|
|
14
|
+
var _styledComponents = _interopRequireDefault(require("styled-components"));
|
|
15
|
+
|
|
16
|
+
var _Checkbox = _interopRequireDefault(require("../checkbox/Checkbox"));
|
|
17
|
+
|
|
18
|
+
var _Icons = _interopRequireDefault(require("./Icons"));
|
|
19
|
+
|
|
20
|
+
var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6;
|
|
21
|
+
|
|
22
|
+
var Option = function Option(_ref) {
|
|
23
|
+
var id = _ref.id,
|
|
24
|
+
option = _ref.option,
|
|
25
|
+
_onClick = _ref.onClick,
|
|
26
|
+
multiple = _ref.multiple,
|
|
27
|
+
visualFocused = _ref.visualFocused,
|
|
28
|
+
_ref$isGroupedOption = _ref.isGroupedOption,
|
|
29
|
+
isGroupedOption = _ref$isGroupedOption === void 0 ? false : _ref$isGroupedOption,
|
|
30
|
+
isLastOption = _ref.isLastOption,
|
|
31
|
+
isSelected = _ref.isSelected;
|
|
32
|
+
return /*#__PURE__*/_react["default"].createElement(OptionItem, {
|
|
33
|
+
id: id,
|
|
34
|
+
onClick: function onClick() {
|
|
35
|
+
_onClick(option);
|
|
36
|
+
},
|
|
37
|
+
visualFocused: visualFocused,
|
|
38
|
+
selected: isSelected,
|
|
39
|
+
role: "option",
|
|
40
|
+
"aria-selected": isSelected
|
|
41
|
+
}, /*#__PURE__*/_react["default"].createElement(StyledOption, {
|
|
42
|
+
visualFocused: visualFocused,
|
|
43
|
+
selected: isSelected,
|
|
44
|
+
last: isLastOption,
|
|
45
|
+
grouped: isGroupedOption,
|
|
46
|
+
multiple: multiple
|
|
47
|
+
}, multiple && /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
|
|
48
|
+
checked: isSelected,
|
|
49
|
+
tabIndex: -1
|
|
50
|
+
}), option.icon && /*#__PURE__*/_react["default"].createElement(OptionIcon, {
|
|
51
|
+
grouped: isGroupedOption,
|
|
52
|
+
multiple: multiple,
|
|
53
|
+
role: !(typeof option.icon === "string") ? "img" : undefined
|
|
54
|
+
}, typeof option.icon === "string" ? /*#__PURE__*/_react["default"].createElement("img", {
|
|
55
|
+
src: option.icon
|
|
56
|
+
}) : option.icon), /*#__PURE__*/_react["default"].createElement(OptionContent, {
|
|
57
|
+
grouped: isGroupedOption,
|
|
58
|
+
hasIcon: option.icon ? true : false,
|
|
59
|
+
multiple: multiple
|
|
60
|
+
}, /*#__PURE__*/_react["default"].createElement(OptionLabel, null, option.label), !multiple && isSelected && /*#__PURE__*/_react["default"].createElement(OptionSelectedIndicator, null, _Icons["default"].selected))));
|
|
61
|
+
};
|
|
62
|
+
|
|
63
|
+
var OptionItem = _styledComponents["default"].li(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n padding: 0 0.5rem;\n box-shadow: inset 0 0 0 2px transparent;\n ", "\n ", ";\n line-height: 1.715em;\n cursor: pointer;\n\n &:hover {\n ", ";\n }\n &:active {\n ", ";\n }\n"])), function (props) {
|
|
64
|
+
return props.visualFocused && "box-shadow: inset 0 0 0 2px ".concat(props.theme.focusListOptionBorderColor, ";");
|
|
65
|
+
}, function (props) {
|
|
66
|
+
return props.selected && "background-color: ".concat(props.theme.selectedListOptionBackgroundColor);
|
|
67
|
+
}, function (props) {
|
|
68
|
+
return props.selected ? "background-color: ".concat(props.theme.selectedHoverListOptionBackgroundColor, ";") : "background-color: ".concat(props.theme.unselectedHoverListOptionBackgroundColor, ";");
|
|
69
|
+
}, function (props) {
|
|
70
|
+
return props.selected ? "background-color: ".concat(props.theme.selectedActiveListOptionBackgroundColor, ";") : "background-color: ".concat(props.theme.unselectedActiveListOptionBackgroundColor, ";");
|
|
71
|
+
});
|
|
72
|
+
|
|
73
|
+
var StyledOption = _styledComponents["default"].span(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n padding: 0.25rem 0.5rem 0.188rem 0;\n min-height: 24px;\n ", "\n ", ";\n"])), function (props) {
|
|
74
|
+
return props.grouped && props.multiple && "padding-left: 16px;";
|
|
75
|
+
}, function (props) {
|
|
76
|
+
return props.last || props.visualFocused || props.selected ? "border-bottom: 1px solid transparent" : "border-bottom: 1px solid ".concat(props.theme.listOptionDividerColor);
|
|
77
|
+
});
|
|
78
|
+
|
|
79
|
+
var OptionIcon = _styledComponents["default"].span(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n padding: 0.125rem;\n margin-left: ", ";\n color: ", ";\n\n svg,\n img {\n height: 20px;\n width: 20px;\n }\n"])), function (props) {
|
|
80
|
+
return props.grouped && !props.multiple ? "16px" : "8px";
|
|
81
|
+
}, function (props) {
|
|
82
|
+
return props.theme.listOptionIconColor;
|
|
83
|
+
});
|
|
84
|
+
|
|
85
|
+
var OptionContent = _styledComponents["default"].span(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n justify-content: space-between;\n gap: 0.25rem;\n width: 100%;\n overflow: hidden;\n margin-left: ", ";\n"])), function (props) {
|
|
86
|
+
return props.grouped && !props.multiple && !props.hasIcon ? "16px" : "8px";
|
|
87
|
+
});
|
|
88
|
+
|
|
89
|
+
var OptionLabel = _styledComponents["default"].span(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n"])));
|
|
90
|
+
|
|
91
|
+
var OptionSelectedIndicator = _styledComponents["default"].span(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n color: ", ";\n\n svg {\n width: 16px;\n height: 16px;\n }\n"])), function (props) {
|
|
92
|
+
return props.theme.selectedListOptionIconColor;
|
|
93
|
+
});
|
|
94
|
+
|
|
95
|
+
var _default = /*#__PURE__*/_react["default"].memo(Option);
|
|
96
|
+
|
|
97
|
+
exports["default"] = _default;
|