@dxc-technology/halstack-react 6.1.0 → 6.2.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/accordion/Accordion.js +122 -103
- package/accordion/Accordion.stories.tsx +1 -2
- package/accordion/Accordion.test.js +9 -10
- package/accordion/types.d.ts +3 -3
- package/accordion-group/AccordionGroup.js +1 -21
- package/accordion-group/AccordionGroup.stories.tsx +27 -1
- package/accordion-group/AccordionGroup.test.js +20 -45
- package/accordion-group/types.d.ts +8 -2
- package/alert/Alert.js +1 -1
- package/box/Box.js +1 -1
- package/checkbox/Checkbox.js +88 -95
- package/checkbox/Checkbox.test.js +93 -16
- package/checkbox/types.d.ts +2 -2
- package/common/variables.js +8 -4
- package/dropdown/Dropdown.js +1 -1
- package/footer/Footer.stories.tsx +8 -1
- package/header/Header.stories.tsx +4 -4
- package/layout/ApplicationLayout.stories.tsx +1 -0
- package/package.json +8 -8
- package/select/Listbox.js +0 -1
- package/slider/Slider.js +112 -91
- package/slider/Slider.stories.tsx +7 -1
- package/slider/Slider.test.js +87 -24
- package/slider/types.d.ts +2 -2
- package/switch/Switch.js +1 -1
- package/tabs/Tab.d.ts +4 -0
- package/tabs/Tab.js +135 -0
- package/tabs/Tabs.js +360 -104
- package/tabs/Tabs.stories.tsx +74 -0
- package/tabs/Tabs.test.js +217 -6
- package/tabs/types.d.ts +14 -4
- package/tag/Tag.js +1 -1
- package/text-input/Icons.d.ts +8 -0
- package/text-input/Icons.js +60 -0
- package/text-input/Suggestion.js +7 -5
- package/text-input/Suggestions.d.ts +4 -0
- package/text-input/Suggestions.js +134 -0
- package/text-input/TextInput.js +103 -201
- package/text-input/TextInput.stories.tsx +189 -181
- package/text-input/TextInput.test.js +163 -162
- package/text-input/types.d.ts +16 -2
package/tabs/Tabs.test.js
CHANGED
|
@@ -25,6 +25,23 @@ var sampleTabsWithBadge = [{
|
|
|
25
25
|
label: "Tab-3",
|
|
26
26
|
notificationNumber: "101"
|
|
27
27
|
}];
|
|
28
|
+
var sampleTabsMiddleDisabled = [{
|
|
29
|
+
label: "Tab-1"
|
|
30
|
+
}, {
|
|
31
|
+
label: "Tab-2",
|
|
32
|
+
isDisabled: true
|
|
33
|
+
}, {
|
|
34
|
+
label: "Tab-3"
|
|
35
|
+
}];
|
|
36
|
+
var sampleTabsLastTabNonDisabled = [{
|
|
37
|
+
label: "Tab-1",
|
|
38
|
+
isDisabled: true
|
|
39
|
+
}, {
|
|
40
|
+
label: "Tab-2",
|
|
41
|
+
isDisabled: true
|
|
42
|
+
}, {
|
|
43
|
+
label: "Tab-3"
|
|
44
|
+
}];
|
|
28
45
|
describe("Tabs component tests", function () {
|
|
29
46
|
test("Tabs render with correct labels", function () {
|
|
30
47
|
var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Tabs["default"], {
|
|
@@ -103,18 +120,26 @@ describe("Tabs component tests", function () {
|
|
|
103
120
|
tabs: sampleTabs,
|
|
104
121
|
onTabClick: onTabClick
|
|
105
122
|
})),
|
|
106
|
-
getByText = _render6.getByText
|
|
123
|
+
getByText = _render6.getByText,
|
|
124
|
+
getAllByRole = _render6.getAllByRole;
|
|
107
125
|
|
|
126
|
+
var tabs = getAllByRole("tab");
|
|
108
127
|
var tab1 = getByText("Tab-1");
|
|
109
128
|
var tab2 = getByText("Tab-2");
|
|
110
129
|
|
|
111
130
|
_react2.fireEvent.click(tab2);
|
|
112
131
|
|
|
113
132
|
expect(onTabClick).toHaveBeenCalledWith(1);
|
|
133
|
+
expect(tabs[0].getAttribute("aria-selected")).toBe("false");
|
|
134
|
+
expect(tabs[1].getAttribute("aria-selected")).toBe("true");
|
|
135
|
+
expect(tabs[2].getAttribute("aria-selected")).toBe("false");
|
|
114
136
|
|
|
115
137
|
_react2.fireEvent.click(tab1);
|
|
116
138
|
|
|
117
139
|
expect(onTabClick).toHaveBeenCalledWith(0);
|
|
140
|
+
expect(tabs[0].getAttribute("aria-selected")).toBe("true");
|
|
141
|
+
expect(tabs[1].getAttribute("aria-selected")).toBe("false");
|
|
142
|
+
expect(tabs[2].getAttribute("aria-selected")).toBe("false");
|
|
118
143
|
});
|
|
119
144
|
test("Controlled tabs", function () {
|
|
120
145
|
var onTabClick = jest.fn();
|
|
@@ -124,17 +149,203 @@ describe("Tabs component tests", function () {
|
|
|
124
149
|
onTabClick: onTabClick,
|
|
125
150
|
activeTabIndex: 0
|
|
126
151
|
})),
|
|
127
|
-
getByText = _render7.getByText
|
|
152
|
+
getByText = _render7.getByText,
|
|
153
|
+
getAllByRole = _render7.getAllByRole;
|
|
128
154
|
|
|
129
|
-
var
|
|
130
|
-
var tab3 = getByText("Tab-3");
|
|
155
|
+
var tabs = getAllByRole("tab");
|
|
131
156
|
|
|
132
|
-
_react2.fireEvent.click(
|
|
157
|
+
_react2.fireEvent.click(tabs[1]);
|
|
158
|
+
|
|
159
|
+
expect(onTabClick).toHaveBeenCalledWith(1);
|
|
160
|
+
expect(tabs[0].getAttribute("aria-selected")).toBe("true");
|
|
161
|
+
expect(tabs[1].getAttribute("aria-selected")).toBe("false");
|
|
162
|
+
expect(tabs[2].getAttribute("aria-selected")).toBe("false");
|
|
163
|
+
|
|
164
|
+
_react2.fireEvent.click(tabs[2]);
|
|
165
|
+
|
|
166
|
+
expect(onTabClick).toHaveBeenCalledWith(2);
|
|
167
|
+
expect(tabs[0].getAttribute("aria-selected")).toBe("true");
|
|
168
|
+
expect(tabs[1].getAttribute("aria-selected")).toBe("false");
|
|
169
|
+
expect(tabs[2].getAttribute("aria-selected")).toBe("false");
|
|
170
|
+
});
|
|
171
|
+
test("Uncontrolled tabs should have focus in the first non-disabled tab", function () {
|
|
172
|
+
var onTabClick = jest.fn();
|
|
173
|
+
|
|
174
|
+
var _render8 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Tabs["default"], {
|
|
175
|
+
tabs: sampleTabsLastTabNonDisabled,
|
|
176
|
+
onTabClick: onTabClick
|
|
177
|
+
})),
|
|
178
|
+
getAllByRole = _render8.getAllByRole;
|
|
179
|
+
|
|
180
|
+
var tabs = getAllByRole("tab");
|
|
181
|
+
expect(tabs[0].hasAttribute("disabled")).toBeTruthy();
|
|
182
|
+
expect(tabs[1].hasAttribute("disabled")).toBeTruthy();
|
|
183
|
+
expect(tabs[2].hasAttribute("disabled")).toBeFalsy();
|
|
184
|
+
expect(tabs[0].getAttribute("aria-selected")).toBe("false");
|
|
185
|
+
expect(tabs[1].getAttribute("aria-selected")).toBe("false");
|
|
186
|
+
expect(tabs[2].getAttribute("aria-selected")).toBe("true");
|
|
187
|
+
});
|
|
188
|
+
test("Controlled tabs with active index in disabled tab should not change focus to the first available tab", function () {
|
|
189
|
+
var onTabClick = jest.fn();
|
|
190
|
+
|
|
191
|
+
var _render9 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Tabs["default"], {
|
|
192
|
+
tabs: sampleTabsLastTabNonDisabled,
|
|
193
|
+
onTabClick: onTabClick,
|
|
194
|
+
activeTabIndex: 0
|
|
195
|
+
})),
|
|
196
|
+
getAllByRole = _render9.getAllByRole;
|
|
197
|
+
|
|
198
|
+
var tabs = getAllByRole("tab");
|
|
199
|
+
expect(tabs[0].getAttribute("aria-selected")).toBe("true");
|
|
200
|
+
expect(tabs[1].getAttribute("aria-selected")).toBe("false");
|
|
201
|
+
expect(tabs[2].getAttribute("aria-selected")).toBe("false");
|
|
202
|
+
expect(tabs[0].hasAttribute("disabled")).toBeTruthy();
|
|
203
|
+
expect(tabs[1].hasAttribute("disabled")).toBeTruthy();
|
|
204
|
+
expect(tabs[2].hasAttribute("disabled")).toBeFalsy();
|
|
205
|
+
|
|
206
|
+
_react2.fireEvent.click(tabs[2]);
|
|
207
|
+
|
|
208
|
+
expect(onTabClick).toHaveBeenCalledWith(2);
|
|
209
|
+
expect(tabs[0].getAttribute("aria-selected")).toBe("true");
|
|
210
|
+
expect(tabs[1].getAttribute("aria-selected")).toBe("false");
|
|
211
|
+
expect(tabs[2].getAttribute("aria-selected")).toBe("false");
|
|
212
|
+
expect(tabs[0].hasAttribute("disabled")).toBeTruthy();
|
|
213
|
+
expect(tabs[1].hasAttribute("disabled")).toBeTruthy();
|
|
214
|
+
expect(tabs[2].hasAttribute("disabled")).toBeFalsy();
|
|
215
|
+
});
|
|
216
|
+
test("Select tabs with keyboard event arrows", function () {
|
|
217
|
+
var onTabClick = jest.fn();
|
|
218
|
+
|
|
219
|
+
var _render10 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Tabs["default"], {
|
|
220
|
+
tabs: sampleTabs,
|
|
221
|
+
onTabClick: onTabClick
|
|
222
|
+
})),
|
|
223
|
+
getByText = _render10.getByText,
|
|
224
|
+
getByRole = _render10.getByRole,
|
|
225
|
+
getAllByRole = _render10.getAllByRole;
|
|
226
|
+
|
|
227
|
+
var tabList = getByRole("tablist");
|
|
228
|
+
var tab1 = getByText("Tab-1");
|
|
229
|
+
var tabs = getAllByRole("tab");
|
|
230
|
+
|
|
231
|
+
_react2.fireEvent.click(tab1);
|
|
232
|
+
|
|
233
|
+
expect(tabs[0].getAttribute("aria-selected")).toBe("true");
|
|
234
|
+
expect(tabs[1].getAttribute("aria-selected")).toBe("false");
|
|
235
|
+
expect(tabs[2].getAttribute("aria-selected")).toBe("false");
|
|
236
|
+
expect(onTabClick).toHaveBeenCalledWith(0);
|
|
133
237
|
|
|
238
|
+
_react2.fireEvent.keyDown(tabList, {
|
|
239
|
+
key: "ArrowRight"
|
|
240
|
+
});
|
|
241
|
+
|
|
242
|
+
_react2.fireEvent.keyDown(tabList, {
|
|
243
|
+
key: "Enter"
|
|
244
|
+
});
|
|
245
|
+
|
|
246
|
+
expect(tabs[0].getAttribute("aria-selected")).toBe("false");
|
|
247
|
+
expect(tabs[1].getAttribute("aria-selected")).toBe("true");
|
|
248
|
+
expect(tabs[2].getAttribute("aria-selected")).toBe("false");
|
|
134
249
|
expect(onTabClick).toHaveBeenCalledWith(1);
|
|
135
250
|
|
|
136
|
-
_react2.fireEvent.
|
|
251
|
+
_react2.fireEvent.keyDown(tabList, {
|
|
252
|
+
key: "ArrowRight"
|
|
253
|
+
});
|
|
254
|
+
|
|
255
|
+
_react2.fireEvent.keyDown(tabList, {
|
|
256
|
+
key: "Enter"
|
|
257
|
+
});
|
|
258
|
+
|
|
259
|
+
expect(tabs[0].getAttribute("aria-selected")).toBe("false");
|
|
260
|
+
expect(tabs[1].getAttribute("aria-selected")).toBe("false");
|
|
261
|
+
expect(tabs[2].getAttribute("aria-selected")).toBe("true");
|
|
262
|
+
expect(onTabClick).toHaveBeenCalledWith(2);
|
|
263
|
+
|
|
264
|
+
_react2.fireEvent.keyDown(tabList, {
|
|
265
|
+
key: "ArrowLeft"
|
|
266
|
+
});
|
|
267
|
+
|
|
268
|
+
_react2.fireEvent.keyDown(tabList, {
|
|
269
|
+
key: "Enter"
|
|
270
|
+
});
|
|
271
|
+
|
|
272
|
+
expect(tabs[0].getAttribute("aria-selected")).toBe("false");
|
|
273
|
+
expect(tabs[1].getAttribute("aria-selected")).toBe("true");
|
|
274
|
+
expect(tabs[2].getAttribute("aria-selected")).toBe("false");
|
|
275
|
+
expect(onTabClick).toHaveBeenCalledWith(1);
|
|
276
|
+
|
|
277
|
+
_react2.fireEvent.keyDown(tabList, {
|
|
278
|
+
key: "ArrowLeft"
|
|
279
|
+
});
|
|
280
|
+
|
|
281
|
+
_react2.fireEvent.keyDown(tabList, {
|
|
282
|
+
key: "Enter"
|
|
283
|
+
});
|
|
284
|
+
|
|
285
|
+
expect(tabs[0].getAttribute("aria-selected")).toBe("true");
|
|
286
|
+
expect(tabs[1].getAttribute("aria-selected")).toBe("false");
|
|
287
|
+
expect(tabs[2].getAttribute("aria-selected")).toBe("false");
|
|
288
|
+
expect(onTabClick).toHaveBeenCalledWith(0);
|
|
289
|
+
|
|
290
|
+
_react2.fireEvent.keyDown(tabList, {
|
|
291
|
+
key: "ArrowLeft"
|
|
292
|
+
});
|
|
137
293
|
|
|
294
|
+
_react2.fireEvent.keyDown(tabList, {
|
|
295
|
+
key: "Enter"
|
|
296
|
+
});
|
|
297
|
+
|
|
298
|
+
expect(tabs[0].getAttribute("aria-selected")).toBe("false");
|
|
299
|
+
expect(tabs[1].getAttribute("aria-selected")).toBe("false");
|
|
300
|
+
expect(tabs[2].getAttribute("aria-selected")).toBe("true");
|
|
301
|
+
expect(onTabClick).toHaveBeenCalledWith(2);
|
|
302
|
+
|
|
303
|
+
_react2.fireEvent.keyDown(tabList, {
|
|
304
|
+
key: "ArrowRight"
|
|
305
|
+
});
|
|
306
|
+
|
|
307
|
+
_react2.fireEvent.keyDown(tabList, {
|
|
308
|
+
key: "Enter"
|
|
309
|
+
});
|
|
310
|
+
|
|
311
|
+
expect(tabs[0].getAttribute("aria-selected")).toBe("true");
|
|
312
|
+
expect(tabs[1].getAttribute("aria-selected")).toBe("false");
|
|
313
|
+
expect(tabs[2].getAttribute("aria-selected")).toBe("false");
|
|
314
|
+
expect(onTabClick).toHaveBeenCalledWith(0);
|
|
315
|
+
});
|
|
316
|
+
test("Skip disabled tab with keyboard event arrows", function () {
|
|
317
|
+
var onTabClick = jest.fn();
|
|
318
|
+
|
|
319
|
+
var _render11 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Tabs["default"], {
|
|
320
|
+
tabs: sampleTabsMiddleDisabled,
|
|
321
|
+
onTabClick: onTabClick
|
|
322
|
+
})),
|
|
323
|
+
getByText = _render11.getByText,
|
|
324
|
+
getByRole = _render11.getByRole,
|
|
325
|
+
getAllByRole = _render11.getAllByRole;
|
|
326
|
+
|
|
327
|
+
var tabList = getByRole("tablist");
|
|
328
|
+
var tab1 = getByText("Tab-1");
|
|
329
|
+
var tabs = getAllByRole("tab");
|
|
330
|
+
|
|
331
|
+
_react2.fireEvent.click(tab1);
|
|
332
|
+
|
|
333
|
+
expect(tabs[0].getAttribute("aria-selected")).toBe("true");
|
|
334
|
+
expect(tabs[1].getAttribute("aria-selected")).toBe("false");
|
|
335
|
+
expect(tabs[2].getAttribute("aria-selected")).toBe("false");
|
|
336
|
+
expect(onTabClick).toHaveBeenCalledWith(0);
|
|
337
|
+
|
|
338
|
+
_react2.fireEvent.keyDown(tabList, {
|
|
339
|
+
key: "ArrowRight"
|
|
340
|
+
});
|
|
341
|
+
|
|
342
|
+
_react2.fireEvent.keyDown(tabList, {
|
|
343
|
+
key: " "
|
|
344
|
+
});
|
|
345
|
+
|
|
346
|
+
expect(tabs[0].getAttribute("aria-selected")).toBe("false");
|
|
347
|
+
expect(tabs[1].getAttribute("aria-selected")).toBe("false");
|
|
348
|
+
expect(tabs[2].getAttribute("aria-selected")).toBe("true");
|
|
138
349
|
expect(onTabClick).toHaveBeenCalledWith(2);
|
|
139
350
|
});
|
|
140
351
|
});
|
package/tabs/types.d.ts
CHANGED
|
@@ -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;
|
|
@@ -21,7 +21,7 @@ declare type TabCommonProps = {
|
|
|
21
21
|
*/
|
|
22
22
|
notificationNumber?: boolean | number;
|
|
23
23
|
};
|
|
24
|
-
declare type TabLabelProps = TabCommonProps & {
|
|
24
|
+
export declare type TabLabelProps = TabCommonProps & {
|
|
25
25
|
/**
|
|
26
26
|
* Tab label.
|
|
27
27
|
*/
|
|
@@ -31,7 +31,7 @@ declare type TabLabelProps = TabCommonProps & {
|
|
|
31
31
|
*/
|
|
32
32
|
icon?: string | SVG;
|
|
33
33
|
};
|
|
34
|
-
declare type TabIconProps = TabCommonProps & {
|
|
34
|
+
export declare type TabIconProps = TabCommonProps & {
|
|
35
35
|
/**
|
|
36
36
|
* Tab label.
|
|
37
37
|
*/
|
|
@@ -41,6 +41,16 @@ declare type TabIconProps = TabCommonProps & {
|
|
|
41
41
|
*/
|
|
42
42
|
icon: string | SVG;
|
|
43
43
|
};
|
|
44
|
+
export declare type TabProps = {
|
|
45
|
+
tab: TabLabelProps | TabIconProps;
|
|
46
|
+
active: boolean;
|
|
47
|
+
tabIndex: number;
|
|
48
|
+
hasLabelAndIcon: boolean;
|
|
49
|
+
iconPosition: "top" | "left";
|
|
50
|
+
onClick: () => void;
|
|
51
|
+
onMouseEnter: () => void;
|
|
52
|
+
onMouseLeave: () => void;
|
|
53
|
+
};
|
|
44
54
|
declare type Props = {
|
|
45
55
|
/**
|
|
46
56
|
* An array of objects representing the tabs.
|
package/tag/Tag.js
CHANGED
|
@@ -0,0 +1,60 @@
|
|
|
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 icons = {
|
|
13
|
+
error: /*#__PURE__*/_react["default"].createElement("svg", {
|
|
14
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
15
|
+
height: "24px",
|
|
16
|
+
viewBox: "0 0 24 24",
|
|
17
|
+
width: "24px",
|
|
18
|
+
fill: "currentColor"
|
|
19
|
+
}, /*#__PURE__*/_react["default"].createElement("path", {
|
|
20
|
+
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"
|
|
21
|
+
})),
|
|
22
|
+
clear: /*#__PURE__*/_react["default"].createElement("svg", {
|
|
23
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
24
|
+
width: "24",
|
|
25
|
+
height: "24",
|
|
26
|
+
viewBox: "0 0 24 24",
|
|
27
|
+
fill: "currentColor"
|
|
28
|
+
}, /*#__PURE__*/_react["default"].createElement("path", {
|
|
29
|
+
d: "M0 0h24v24H0V0z",
|
|
30
|
+
fill: "none"
|
|
31
|
+
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
32
|
+
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"
|
|
33
|
+
})),
|
|
34
|
+
increment: /*#__PURE__*/_react["default"].createElement("svg", {
|
|
35
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
36
|
+
height: "24px",
|
|
37
|
+
viewBox: "0 0 24 24",
|
|
38
|
+
width: "24px",
|
|
39
|
+
fill: "currentColor"
|
|
40
|
+
}, /*#__PURE__*/_react["default"].createElement("path", {
|
|
41
|
+
d: "M0 0h24v24H0z",
|
|
42
|
+
fill: "none"
|
|
43
|
+
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
44
|
+
d: "M19 13h-6v6h-2v-6H5v-2h6V5h2v6h6v2z"
|
|
45
|
+
})),
|
|
46
|
+
decrement: /*#__PURE__*/_react["default"].createElement("svg", {
|
|
47
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
48
|
+
height: "24px",
|
|
49
|
+
viewBox: "0 0 24 24",
|
|
50
|
+
width: "24px",
|
|
51
|
+
fill: "currentColor"
|
|
52
|
+
}, /*#__PURE__*/_react["default"].createElement("path", {
|
|
53
|
+
d: "M0 0h24v24H0z",
|
|
54
|
+
fill: "none"
|
|
55
|
+
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
56
|
+
d: "M19 13H5v-2h14v2z"
|
|
57
|
+
}))
|
|
58
|
+
};
|
|
59
|
+
var _default = icons;
|
|
60
|
+
exports["default"] = _default;
|
package/text-input/Suggestion.js
CHANGED
|
@@ -18,7 +18,7 @@ var _templateObject, _templateObject2;
|
|
|
18
18
|
var Suggestion = function Suggestion(_ref) {
|
|
19
19
|
var id = _ref.id,
|
|
20
20
|
value = _ref.value,
|
|
21
|
-
|
|
21
|
+
_onClick = _ref.onClick,
|
|
22
22
|
suggestion = _ref.suggestion,
|
|
23
23
|
isLast = _ref.isLast,
|
|
24
24
|
visuallyFocused = _ref.visuallyFocused,
|
|
@@ -28,17 +28,19 @@ var Suggestion = function Suggestion(_ref) {
|
|
|
28
28
|
var noMatchedWords = suggestion.replace(regEx, "");
|
|
29
29
|
return /*#__PURE__*/_react["default"].createElement(SuggestionContainer, {
|
|
30
30
|
id: id,
|
|
31
|
-
onClick: onClick
|
|
31
|
+
onClick: function onClick() {
|
|
32
|
+
_onClick(suggestion);
|
|
33
|
+
},
|
|
32
34
|
visuallyFocused: visuallyFocused,
|
|
33
35
|
role: "option",
|
|
34
|
-
"aria-selected": visuallyFocused ?
|
|
36
|
+
"aria-selected": visuallyFocused ? true : undefined
|
|
35
37
|
}, /*#__PURE__*/_react["default"].createElement(StyledSuggestion, {
|
|
36
38
|
last: isLast,
|
|
37
39
|
visuallyFocused: visuallyFocused
|
|
38
|
-
}, highlighted ?
|
|
40
|
+
}, highlighted ? /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement("strong", null, matchedWords), noMatchedWords) : suggestion));
|
|
39
41
|
};
|
|
40
42
|
|
|
41
|
-
var SuggestionContainer = _styledComponents["default"].li(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n padding: 0 0.5rem;\n line-height: 1.715em;\n cursor: pointer;\n
|
|
43
|
+
var SuggestionContainer = _styledComponents["default"].li(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n padding: 0 0.5rem;\n line-height: 1.715em;\n cursor: pointer;\n box-shadow: inset 0 0 0 2px\n ", ";\n\n &:hover {\n background-color: ", ";\n }\n &:active {\n background-color: ", ";\n }\n"])), function (props) {
|
|
42
44
|
return props.visuallyFocused ? props.theme.focusListOptionBorderColor : "transparent";
|
|
43
45
|
}, function (props) {
|
|
44
46
|
return props.theme.hoverListOptionBackgroundColor;
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { SuggestionsProps } from "./types";
|
|
3
|
+
declare const _default: React.MemoExoticComponent<({ id, value, suggestions, visualFocusIndex, highlightedSuggestions, searchHasErrors, isSearching, suggestionOnClick, getTextInputWidth, }: SuggestionsProps) => JSX.Element>;
|
|
4
|
+
export default _default;
|
|
@@ -0,0 +1,134 @@
|
|
|
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 _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
15
|
+
|
|
16
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
17
|
+
|
|
18
|
+
var _styledComponents = _interopRequireDefault(require("styled-components"));
|
|
19
|
+
|
|
20
|
+
var _useTranslatedLabels = _interopRequireDefault(require("../useTranslatedLabels"));
|
|
21
|
+
|
|
22
|
+
var _BackgroundColorContext = _interopRequireDefault(require("../BackgroundColorContext"));
|
|
23
|
+
|
|
24
|
+
var _Suggestion = _interopRequireDefault(require("./Suggestion"));
|
|
25
|
+
|
|
26
|
+
var _Icons = _interopRequireDefault(require("./Icons"));
|
|
27
|
+
|
|
28
|
+
var _templateObject, _templateObject2, _templateObject3, _templateObject4;
|
|
29
|
+
|
|
30
|
+
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); }
|
|
31
|
+
|
|
32
|
+
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; }
|
|
33
|
+
|
|
34
|
+
var Suggestions = function Suggestions(_ref) {
|
|
35
|
+
var id = _ref.id,
|
|
36
|
+
value = _ref.value,
|
|
37
|
+
suggestions = _ref.suggestions,
|
|
38
|
+
visualFocusIndex = _ref.visualFocusIndex,
|
|
39
|
+
highlightedSuggestions = _ref.highlightedSuggestions,
|
|
40
|
+
searchHasErrors = _ref.searchHasErrors,
|
|
41
|
+
isSearching = _ref.isSearching,
|
|
42
|
+
suggestionOnClick = _ref.suggestionOnClick,
|
|
43
|
+
getTextInputWidth = _ref.getTextInputWidth;
|
|
44
|
+
var translatedLabels = (0, _useTranslatedLabels["default"])();
|
|
45
|
+
var backgroundType = (0, _react.useContext)(_BackgroundColorContext["default"]);
|
|
46
|
+
var listboxRef = (0, _react.useRef)(null);
|
|
47
|
+
|
|
48
|
+
var _useState = (0, _react.useState)(null),
|
|
49
|
+
_useState2 = (0, _slicedToArray2["default"])(_useState, 2),
|
|
50
|
+
styles = _useState2[0],
|
|
51
|
+
setStyles = _useState2[1];
|
|
52
|
+
|
|
53
|
+
(0, _react.useLayoutEffect)(function () {
|
|
54
|
+
var _listboxRef$current, _visualFocusedOptionE;
|
|
55
|
+
|
|
56
|
+
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];
|
|
57
|
+
visualFocusedOptionEl === null || visualFocusedOptionEl === void 0 ? void 0 : (_visualFocusedOptionE = visualFocusedOptionEl.scrollIntoView) === null || _visualFocusedOptionE === void 0 ? void 0 : _visualFocusedOptionE.call(visualFocusedOptionEl, {
|
|
58
|
+
block: "nearest",
|
|
59
|
+
inline: "start"
|
|
60
|
+
});
|
|
61
|
+
}, [visualFocusIndex]);
|
|
62
|
+
|
|
63
|
+
var handleResize = function handleResize() {
|
|
64
|
+
setStyles({
|
|
65
|
+
width: getTextInputWidth()
|
|
66
|
+
});
|
|
67
|
+
};
|
|
68
|
+
|
|
69
|
+
(0, _react.useLayoutEffect)(function () {
|
|
70
|
+
handleResize();
|
|
71
|
+
}, [getTextInputWidth]);
|
|
72
|
+
(0, _react.useEffect)(function () {
|
|
73
|
+
window.addEventListener("resize", handleResize);
|
|
74
|
+
return function () {
|
|
75
|
+
window.removeEventListener("resize", handleResize);
|
|
76
|
+
};
|
|
77
|
+
}, [getTextInputWidth]);
|
|
78
|
+
return /*#__PURE__*/_react["default"].createElement(SuggestionsContainer, {
|
|
79
|
+
id: id,
|
|
80
|
+
error: searchHasErrors ? true : false,
|
|
81
|
+
onMouseDown: function onMouseDown(event) {
|
|
82
|
+
event.preventDefault();
|
|
83
|
+
},
|
|
84
|
+
ref: listboxRef,
|
|
85
|
+
role: "listbox",
|
|
86
|
+
backgroundType: backgroundType,
|
|
87
|
+
style: styles
|
|
88
|
+
}, !isSearching && !searchHasErrors && suggestions.length > 0 && suggestions.map(function (suggestion, index) {
|
|
89
|
+
return /*#__PURE__*/_react["default"].createElement(_Suggestion["default"], {
|
|
90
|
+
key: "suggestion-".concat(index),
|
|
91
|
+
id: "suggestion-".concat(index),
|
|
92
|
+
value: value,
|
|
93
|
+
onClick: suggestionOnClick,
|
|
94
|
+
suggestion: suggestion,
|
|
95
|
+
isLast: index === suggestions.length - 1,
|
|
96
|
+
visuallyFocused: visualFocusIndex === index,
|
|
97
|
+
highlighted: highlightedSuggestions
|
|
98
|
+
});
|
|
99
|
+
}), isSearching && /*#__PURE__*/_react["default"].createElement(SuggestionsSystemMessage, null, translatedLabels.textInput.searchingMessage), searchHasErrors && /*#__PURE__*/_react["default"].createElement(SuggestionsError, null, /*#__PURE__*/_react["default"].createElement(SuggestionsErrorIcon, {
|
|
100
|
+
backgroundType: backgroundType
|
|
101
|
+
}, _Icons["default"].error), translatedLabels.textInput.fetchingDataErrorMessage));
|
|
102
|
+
};
|
|
103
|
+
|
|
104
|
+
var SuggestionsContainer = _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 ", ";\n\n border-radius: 0.25rem;\n box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n"])), function (props) {
|
|
105
|
+
return props.error ? props.theme.errorListDialogBackgroundColor : props.theme.listDialogBackgroundColor;
|
|
106
|
+
}, function (props) {
|
|
107
|
+
return props.error ? props.backgroundType === "dark" ? props.theme.errorBorderColorOnDark : props.theme.errorListDialogBorderColor : props.theme.listDialogBorderColor;
|
|
108
|
+
}, function (props) {
|
|
109
|
+
return props.theme.listOptionFontColor;
|
|
110
|
+
}, function (props) {
|
|
111
|
+
return props.theme.fontFamily;
|
|
112
|
+
}, function (props) {
|
|
113
|
+
return props.theme.listOptionFontSize;
|
|
114
|
+
}, function (props) {
|
|
115
|
+
return props.theme.listOptionFontStyle;
|
|
116
|
+
}, function (props) {
|
|
117
|
+
return props.theme.listOptionFontWeight;
|
|
118
|
+
});
|
|
119
|
+
|
|
120
|
+
var SuggestionsSystemMessage = _styledComponents["default"].span(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n padding: 0.25rem 1rem;\n color: ", ";\n line-height: 1.715em;\n"])), function (props) {
|
|
121
|
+
return props.theme.systemMessageFontColor;
|
|
122
|
+
});
|
|
123
|
+
|
|
124
|
+
var SuggestionsErrorIcon = _styledComponents["default"].span(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-wrap: wrap;\n align-content: center;\n margin-right: 0.5rem;\n height: 18px;\n width: 18px;\n color: ", ";\n"])), function (props) {
|
|
125
|
+
return props.backgroundType === "dark" ? props.theme.errorIconColorOnDark : props.theme.errorIconColor;
|
|
126
|
+
});
|
|
127
|
+
|
|
128
|
+
var SuggestionsError = _styledComponents["default"].span(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n padding: 0.25rem 1rem;\n align-items: center;\n line-height: 1.715em;\n color: ", ";\n"])), function (props) {
|
|
129
|
+
return props.theme.errorListDialogFontColor;
|
|
130
|
+
});
|
|
131
|
+
|
|
132
|
+
var _default = /*#__PURE__*/_react["default"].memo(Suggestions);
|
|
133
|
+
|
|
134
|
+
exports["default"] = _default;
|