@dxc-technology/halstack-react 0.0.0-a5074e7 → 0.0.0-a5b9b2c

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.
Files changed (97) hide show
  1. package/HalstackContext.js +90 -50
  2. package/accordion/Accordion.js +7 -13
  3. package/accordion/Accordion.stories.tsx +102 -13
  4. package/alert/Alert.stories.tsx +28 -0
  5. package/box/Box.stories.tsx +15 -0
  6. package/button/Button.js +11 -13
  7. package/button/Button.stories.tsx +150 -8
  8. package/checkbox/Checkbox.d.ts +2 -2
  9. package/checkbox/Checkbox.js +4 -3
  10. package/checkbox/Checkbox.stories.tsx +52 -0
  11. package/checkbox/types.d.ts +4 -0
  12. package/chip/Chip.js +16 -22
  13. package/chip/Chip.stories.tsx +96 -9
  14. package/common/variables.js +259 -249
  15. package/date-input/Calendar.d.ts +4 -0
  16. package/date-input/Calendar.js +258 -0
  17. package/date-input/DateInput.js +134 -237
  18. package/date-input/DateInput.stories.tsx +199 -33
  19. package/date-input/DateInput.test.js +494 -138
  20. package/date-input/DatePicker.d.ts +4 -0
  21. package/date-input/DatePicker.js +146 -0
  22. package/date-input/Icons.d.ts +6 -0
  23. package/date-input/Icons.js +75 -0
  24. package/date-input/YearPicker.d.ts +4 -0
  25. package/date-input/YearPicker.js +126 -0
  26. package/date-input/types.d.ts +51 -0
  27. package/dialog/Dialog.js +1 -3
  28. package/dialog/Dialog.stories.tsx +42 -20
  29. package/dropdown/Dropdown.js +35 -35
  30. package/dropdown/Dropdown.stories.tsx +210 -84
  31. package/dropdown/Dropdown.test.js +17 -22
  32. package/dropdown/DropdownMenu.js +8 -18
  33. package/dropdown/DropdownMenuItem.js +4 -15
  34. package/file-input/FileInput.d.ts +2 -2
  35. package/file-input/FileInput.js +25 -45
  36. package/file-input/FileInput.stories.tsx +96 -17
  37. package/file-input/FileInput.test.js +12 -12
  38. package/file-input/FileItem.d.ts +2 -12
  39. package/file-input/FileItem.js +28 -41
  40. package/file-input/types.d.ts +17 -0
  41. package/footer/Footer.stories.tsx +91 -0
  42. package/header/Header.js +18 -20
  43. package/header/Header.stories.tsx +149 -6
  44. package/link/Link.js +1 -1
  45. package/link/Link.stories.tsx +60 -0
  46. package/number-input/NumberInput.test.js +5 -6
  47. package/package.json +7 -12
  48. package/paginator/Icons.d.ts +5 -0
  49. package/paginator/Icons.js +16 -28
  50. package/paginator/Paginator.js +5 -11
  51. package/paginator/Paginator.stories.tsx +24 -0
  52. package/paginator/Paginator.test.js +17 -10
  53. package/progress-bar/ProgressBar.js +4 -4
  54. package/progress-bar/ProgressBar.stories.jsx +35 -2
  55. package/quick-nav/QuickNav.stories.tsx +14 -0
  56. package/radio-group/RadioGroup.stories.tsx +131 -18
  57. package/resultsetTable/Icons.d.ts +7 -0
  58. package/resultsetTable/Icons.js +51 -0
  59. package/resultsetTable/ResultsetTable.js +48 -105
  60. package/resultsetTable/ResultsetTable.stories.tsx +50 -25
  61. package/resultsetTable/ResultsetTable.test.js +40 -63
  62. package/resultsetTable/types.d.ts +2 -2
  63. package/select/Listbox.d.ts +1 -1
  64. package/select/Listbox.js +5 -34
  65. package/select/Option.js +11 -24
  66. package/select/Select.js +43 -24
  67. package/select/Select.stories.tsx +494 -150
  68. package/select/Select.test.js +17 -22
  69. package/select/types.d.ts +2 -2
  70. package/sidenav/Sidenav.js +8 -10
  71. package/sidenav/Sidenav.stories.tsx +148 -46
  72. package/slider/Slider.d.ts +2 -2
  73. package/slider/Slider.js +9 -8
  74. package/slider/Slider.stories.tsx +57 -0
  75. package/slider/types.d.ts +4 -0
  76. package/spinner/Spinner.js +2 -2
  77. package/spinner/Spinner.stories.jsx +27 -1
  78. package/switch/Switch.d.ts +3 -3
  79. package/switch/Switch.js +5 -4
  80. package/switch/Switch.stories.tsx +33 -0
  81. package/switch/types.d.ts +6 -1
  82. package/table/Table.stories.jsx +80 -1
  83. package/table/Table.test.js +1 -1
  84. package/tabs/Tab.js +3 -5
  85. package/tabs/Tabs.js +3 -3
  86. package/tabs/Tabs.stories.tsx +45 -5
  87. package/tabs-nav/NavTabs.stories.tsx +8 -6
  88. package/tabs-nav/Tab.js +5 -7
  89. package/tag/Tag.stories.tsx +14 -1
  90. package/text-input/Suggestion.js +32 -5
  91. package/text-input/TextInput.js +7 -11
  92. package/text-input/TextInput.stories.tsx +92 -4
  93. package/text-input/TextInput.test.js +587 -634
  94. package/textarea/Textarea.stories.jsx +60 -1
  95. package/toggle-group/ToggleGroup.stories.tsx +42 -0
  96. package/wizard/Wizard.stories.tsx +20 -0
  97. package/common/RequiredComponent.js +0 -32
@@ -63,6 +63,28 @@ var downArrowIcon = /*#__PURE__*/_react["default"].createElement("svg", {
63
63
  fill: "none"
64
64
  }));
65
65
 
66
+ var useWidth = function useWidth(target) {
67
+ var _useState = (0, _react.useState)(0),
68
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
69
+ width = _useState2[0],
70
+ setWidth = _useState2[1];
71
+
72
+ (0, _react.useEffect)(function () {
73
+ if (target != null) {
74
+ setWidth(target.getBoundingClientRect().width);
75
+ var triggerObserver = new ResizeObserver(function (entries) {
76
+ var rect = entries[0].target.getBoundingClientRect();
77
+ setWidth(rect === null || rect === void 0 ? void 0 : rect.width);
78
+ });
79
+ triggerObserver.observe(target);
80
+ return function () {
81
+ triggerObserver.unobserve(target);
82
+ };
83
+ }
84
+ }, [target]);
85
+ return width;
86
+ };
87
+
66
88
  var DxcDropdown = function DxcDropdown(_ref) {
67
89
  var options = _ref.options,
68
90
  _ref$optionsIconPosit = _ref.optionsIconPosition,
@@ -85,21 +107,16 @@ var DxcDropdown = function DxcDropdown(_ref) {
85
107
  _ref$tabIndex = _ref.tabIndex,
86
108
  tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
87
109
 
88
- var _useState = (0, _react.useState)("trigger-".concat((0, _uuid.v4)())),
89
- _useState2 = (0, _slicedToArray2["default"])(_useState, 1),
90
- triggerId = _useState2[0];
110
+ var _useState3 = (0, _react.useState)("trigger-".concat((0, _uuid.v4)())),
111
+ _useState4 = (0, _slicedToArray2["default"])(_useState3, 1),
112
+ triggerId = _useState4[0];
91
113
 
92
114
  var menuId = "menu-".concat(triggerId);
93
115
 
94
- var _useState3 = (0, _react.useState)(false),
95
- _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
96
- isOpen = _useState4[0],
97
- changeIsOpen = _useState4[1];
98
-
99
- var _useState5 = (0, _react.useState)(null),
116
+ var _useState5 = (0, _react.useState)(false),
100
117
  _useState6 = (0, _slicedToArray2["default"])(_useState5, 2),
101
- menuStyles = _useState6[0],
102
- setMenuStyles = _useState6[1];
118
+ isOpen = _useState6[0],
119
+ changeIsOpen = _useState6[1];
103
120
 
104
121
  var _useState7 = (0, _react.useState)(0),
105
122
  _useState8 = (0, _slicedToArray2["default"])(_useState7, 2),
@@ -109,6 +126,7 @@ var DxcDropdown = function DxcDropdown(_ref) {
109
126
  var colorsTheme = (0, _useTheme["default"])();
110
127
  var triggerRef = (0, _react.useRef)(null);
111
128
  var menuRef = (0, _react.useRef)(null);
129
+ var width = useWidth(triggerRef.current);
112
130
 
113
131
  var handleOnOpenMenu = function handleOnOpenMenu() {
114
132
  changeIsOpen(true);
@@ -226,23 +244,6 @@ var DxcDropdown = function DxcDropdown(_ref) {
226
244
  inline: "start"
227
245
  });
228
246
  }, [visualFocusIndex]);
229
-
230
- var handleMenuResize = function handleMenuResize() {
231
- var _triggerRef$current4;
232
-
233
- var rect = triggerRef === null || triggerRef === void 0 ? void 0 : (_triggerRef$current4 = triggerRef.current) === null || _triggerRef$current4 === void 0 ? void 0 : _triggerRef$current4.getBoundingClientRect();
234
- setMenuStyles({
235
- width: rect === null || rect === void 0 ? void 0 : rect.width
236
- });
237
- };
238
-
239
- (0, _react.useEffect)(function () {
240
- handleMenuResize();
241
- window.addEventListener("resize", handleMenuResize);
242
- return function () {
243
- window.removeEventListener("resize", handleMenuResize);
244
- };
245
- }, []);
246
247
  return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
247
248
  theme: colorsTheme.dropdown
248
249
  }, /*#__PURE__*/_react["default"].createElement(DropdownContainer, {
@@ -257,7 +258,6 @@ var DxcDropdown = function DxcDropdown(_ref) {
257
258
  asChild: true,
258
259
  type: undefined
259
260
  }, /*#__PURE__*/_react["default"].createElement(DropdownTrigger, {
260
- opened: isOpen,
261
261
  onClick: handleTriggerOnClick,
262
262
  onKeyDown: handleTriggerOnKeyDown,
263
263
  onBlur: function onBlur(event) {
@@ -274,8 +274,6 @@ var DxcDropdown = function DxcDropdown(_ref) {
274
274
  tabIndex: tabIndex,
275
275
  ref: triggerRef
276
276
  }, /*#__PURE__*/_react["default"].createElement(DropdownTriggerContent, null, label && iconPosition === "after" && /*#__PURE__*/_react["default"].createElement(DropdownTriggerLabel, null, label), icon && /*#__PURE__*/_react["default"].createElement(DropdownTriggerIcon, {
277
- label: label,
278
- iconPosition: iconPosition,
279
277
  disabled: disabled,
280
278
  role: typeof icon === "string" ? undefined : "img"
281
279
  }, typeof icon === "string" ? /*#__PURE__*/_react["default"].createElement("img", {
@@ -293,7 +291,9 @@ var DxcDropdown = function DxcDropdown(_ref) {
293
291
  visualFocusIndex: visualFocusIndex,
294
292
  menuItemOnClick: handleMenuItemOnClick,
295
293
  onKeyDown: handleMenuOnKeyDown,
296
- styles: menuStyles,
294
+ styles: {
295
+ width: width
296
+ },
297
297
  ref: menuRef
298
298
  })))));
299
299
  };
@@ -368,12 +368,12 @@ var DropdownTriggerLabel = _styledComponents["default"].span(_templateObject4 ||
368
368
  return props.theme.buttonFontWeight;
369
369
  });
370
370
 
371
- var DropdownTriggerIcon = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n width: ", ";\n height: ", ";\n color: ", ";\n\n img,\n svg {\n height: 100%;\n width: 100%;\n }\n"])), function (props) {
372
- return props.theme.buttonIconSize;
371
+ var DropdownTriggerIcon = _styledComponents["default"].span(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n color: ", ";\n\n img,\n svg {\n width: ", ";\n height: ", ";\n }\n"])), function (props) {
372
+ return props.disabled ? props.theme.disabledColor : props.theme.buttonIconColor;
373
373
  }, function (props) {
374
374
  return props.theme.buttonIconSize;
375
375
  }, function (props) {
376
- return props.disabled ? props.theme.disabledColor : props.theme.buttonIconColor;
376
+ return props.theme.buttonIconSize;
377
377
  });
378
378
 
379
379
  var CaretIcon = _styledComponents["default"].span(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n color: ", ";\n\n svg {\n width: ", ";\n height: ", ";\n }\n"])), function (props) {
@@ -4,10 +4,11 @@ import DxcDropdown from "./Dropdown";
4
4
  import Title from "../../.storybook/components/Title";
5
5
  import ExampleContainer from "../../.storybook/components/ExampleContainer";
6
6
  import DropdownMenu from "./DropdownMenu";
7
- import DxcCheckbox from "../checkbox/Checkbox";
8
- import DxcTextInput from "../text-input/TextInput";
9
7
  import { Option } from "./types";
10
-
8
+ import useTheme from "../useTheme";
9
+ import DxcFlex from "../flex/Flex";
10
+ import { HalstackProvider } from "../HalstackContext";
11
+ import { ThemeProvider } from "styled-components";
11
12
 
12
13
  export default {
13
14
  title: "Dropdown",
@@ -20,20 +21,14 @@ const hamburguerIcon = (
20
21
  </svg>
21
22
  );
22
23
  const iconSVG = (
23
- <svg viewBox="0 0 24 24" fill="currentColor">
24
+ <svg viewBox="0 0 24 24" height="24" width="24" fill="currentColor">
24
25
  <path d="M0 0h24v24H0z" fill="none" />
25
26
  <path d="M12 21.35l-1.45-1.32C5.4 15.36 2 12.28 2 8.5 2 5.42 4.42 3 7.5 3c1.74 0 3.41.81 4.5 2.09C13.09 3.81 14.76 3 16.5 3 19.58 3 22 5.42 22 8.5c0 3.78-3.4 6.86-8.55 11.54L12 21.35z" />
26
27
  </svg>
27
28
  );
28
29
  const iconSVGLarge = (
29
- <svg enableBackground="new 0 0 24 24" height="48" viewBox="0 0 24 24" width="48" fill="currentColor">
30
- <g>
31
- <path d="M0,0h24v24H0V0z" fill="none" />
32
- <path d="M0,0h24v24H0V0z" fill="none" />
33
- </g>
34
- <g>
35
- <path d="M12,17.27L18.18,21l-1.64-7.03L22,9.24l-7.19-0.61L12,2L9.19,8.63L2,9.24l5.46,4.73L5.82,21L12,17.27z" />
36
- </g>
30
+ <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 48 48" height="48" width="48">
31
+ <path d="M11 44q-1.2 0-2.1-.9Q8 42.2 8 41V15q0-1.2.9-2.1.9-.9 2.1-.9h5.5v-.5q0-3.15 2.175-5.325Q20.85 4 24 4q3.15 0 5.325 2.175Q31.5 8.35 31.5 11.5v.5H37q1.2 0 2.1.9.9.9.9 2.1v26q0 1.2-.9 2.1-.9.9-2.1.9Zm0-3h26V15h-5.5v4.5q0 .65-.425 1.075Q30.65 21 30 21q-.65 0-1.075-.425-.425-.425-.425-1.075V15h-9v4.5q0 .65-.425 1.075Q18.65 21 18 21q-.65 0-1.075-.425-.425-.425-.425-1.075V15H11v26Zm8.5-29h9v-.5q0-1.9-1.3-3.2Q25.9 7 24 7q-1.9 0-3.2 1.3-1.3 1.3-1.3 3.2ZM11 41V15v26Z" />
37
32
  </svg>
38
33
  );
39
34
  const iconUrl = "https://iconape.com/wp-content/files/yd/367773/svg/logo-linkedin-logo-icon-png-svg.png";
@@ -60,6 +55,18 @@ const defaultOptions: Option[] = [
60
55
  value: "5",
61
56
  label: "Aliexpress",
62
57
  },
58
+ {
59
+ value: "6",
60
+ label: "Etsy",
61
+ },
62
+ {
63
+ value: "7",
64
+ label: "Alibaba",
65
+ },
66
+ {
67
+ value: "8",
68
+ label: "Gearbest shop",
69
+ },
63
70
  ];
64
71
  const options: Option[] = [
65
72
  {
@@ -85,7 +92,15 @@ const optionWithIcon: Option[] = [
85
92
 
86
93
  const optionsIcon: any = options.map((op, i) => ({ ...op, icon: icons[i] }));
87
94
 
88
- export const Chromatic = () => (
95
+ const opinionatedTheme = {
96
+ dropdown: {
97
+ baseColor: "#ffffff",
98
+ fontColor: "#000000",
99
+ optionFontColor: "#000000",
100
+ },
101
+ };
102
+
103
+ const Dropdown = () => (
89
104
  <>
90
105
  <ExampleContainer>
91
106
  <Title title="Default" theme="light" level={4} />
@@ -134,9 +149,18 @@ export const Chromatic = () => (
134
149
  <DxcDropdown options={options} onSelectOption={(value) => {}} icon={hamburguerIcon} caretHidden />
135
150
  </ExampleContainer>
136
151
  <ExampleContainer>
137
- <Title title="Large icon" theme="light" level={4} />
152
+ <Title title="Large icon (SVG)" theme="light" level={4} />
138
153
  <DxcDropdown label="Large icon" options={options} onSelectOption={(value) => {}} icon={iconSVGLarge} />
139
154
  </ExampleContainer>
155
+ <ExampleContainer>
156
+ <Title title="Large icon (image)" theme="light" level={4} />
157
+ <DxcDropdown
158
+ label="Large icon"
159
+ options={options}
160
+ onSelectOption={(value) => {}}
161
+ icon="https://upload.wikimedia.org/wikipedia/commons/thumb/b/b2/Hamburger_icon.svg/2048px-Hamburger_icon.svg.png"
162
+ />
163
+ </ExampleContainer>
140
164
  <ExampleContainer>
141
165
  <Title title="Disabled with icon" theme="light" level={4} />
142
166
  <DxcDropdown
@@ -219,94 +243,196 @@ export const Chromatic = () => (
219
243
  size="fillParent"
220
244
  />
221
245
  </ExampleContainer>
246
+ <ExampleContainer expanded>
247
+ <Title title="Opened menu" theme="light" level={4} />
248
+ <DxcDropdown label="Label" options={options} onSelectOption={(value) => {}} margin={{ top: "xxlarge" }} />
249
+ </ExampleContainer>
222
250
  </>
223
251
  );
224
252
 
225
- const DropdownListStates = () => (
253
+ const DropdownListStates = () => {
254
+ const colorsTheme: any = useTheme();
255
+
256
+ return (
257
+ <>
258
+ <Title title="Dropdown Menu" theme="light" level={2} />
259
+ <ExampleContainer>
260
+ <Title
261
+ title="List dialog uses a Radix Popover to appear over elements with a certain z-index"
262
+ theme="light"
263
+ level={3}
264
+ />
265
+ <div
266
+ style={{
267
+ position: "relative",
268
+ display: "flex",
269
+ flexDirection: "column",
270
+ gap: "20px",
271
+ height: "150px",
272
+ width: "min-content",
273
+ marginBottom: "100px",
274
+ padding: "20px",
275
+ border: "1px solid black",
276
+ borderRadius: "4px",
277
+ overflow: "auto",
278
+ zIndex: "1300",
279
+ }}
280
+ >
281
+ <DxcDropdown
282
+ label="Select a platform"
283
+ options={defaultOptions}
284
+ onSelectOption={(option) => {}}
285
+ size="medium"
286
+ />
287
+ <button style={{ zIndex: "1", width: "100px" }}>Submit</button>
288
+ </div>
289
+ </ExampleContainer>
290
+ <ThemeProvider theme={colorsTheme.dropdown}>
291
+ <Title title="Option states" theme="light" level={3} />
292
+ <ExampleContainer pseudoState="pseudo-hover">
293
+ <Title title="Hovered option" theme="light" level={4} />
294
+ <DropdownMenu
295
+ id="x"
296
+ dropdownTriggerId="dtx"
297
+ iconsPosition="before"
298
+ visualFocusIndex={-1}
299
+ menuItemOnClick={(value) => {}}
300
+ onKeyDown={(e) => {}}
301
+ options={optionWithIcon}
302
+ styles={{ width: 240 }}
303
+ />
304
+ </ExampleContainer>
305
+ <ExampleContainer pseudoState="pseudo-active">
306
+ <Title title="Active option" theme="light" level={4} />
307
+ <DropdownMenu
308
+ id="x"
309
+ dropdownTriggerId="dtx"
310
+ iconsPosition="before"
311
+ visualFocusIndex={-1}
312
+ menuItemOnClick={(value) => {}}
313
+ onKeyDown={(e) => {}}
314
+ options={optionWithIcon}
315
+ styles={{ width: 240 }}
316
+ />
317
+ </ExampleContainer>
318
+ <ExampleContainer>
319
+ <Title title="Focused option" theme="light" level={4} />
320
+ <DropdownMenu
321
+ id="x"
322
+ dropdownTriggerId="dtx"
323
+ iconsPosition="before"
324
+ visualFocusIndex={0}
325
+ menuItemOnClick={(value) => {}}
326
+ onKeyDown={(e) => {}}
327
+ options={options}
328
+ styles={{ width: 240 }}
329
+ />
330
+ </ExampleContainer>
331
+ <Title title="Icons" theme="light" level={3} />
332
+ <ExampleContainer>
333
+ <Title title="Before" theme="light" level={4} />
334
+ <DropdownMenu
335
+ id="x"
336
+ dropdownTriggerId="dtx"
337
+ iconsPosition="before"
338
+ visualFocusIndex={-1}
339
+ menuItemOnClick={(value) => {}}
340
+ onKeyDown={(e) => {}}
341
+ options={optionsIcon}
342
+ styles={{ width: 240 }}
343
+ />
344
+ <Title title="After" theme="light" level={4} />
345
+ <DropdownMenu
346
+ id="x"
347
+ dropdownTriggerId="dtx"
348
+ iconsPosition="after"
349
+ visualFocusIndex={-1}
350
+ menuItemOnClick={(value) => {}}
351
+ onKeyDown={(e) => {}}
352
+ options={optionsIcon}
353
+ styles={{ width: 240 }}
354
+ />
355
+ </ExampleContainer>
356
+ </ThemeProvider>
357
+ </>
358
+ );
359
+ };
360
+
361
+ const DropdownRightAlignment = () => (
362
+ <ExampleContainer expanded>
363
+ <Title title="Dropdown collisions on the right boundary (right)" theme="light" level={4} />
364
+ <DxcFlex justifyContent="flex-end">
365
+ <DxcDropdown label="Label" options={options} onSelectOption={(value) => {}} />
366
+ </DxcFlex>
367
+ </ExampleContainer>
368
+ );
369
+
370
+ const DropdownCenterAlignment = () => (
371
+ <ExampleContainer expanded>
372
+ <Title title="Dropdown collisions on the right boundary (centered)" theme="light" level={4} />
373
+ <DxcFlex justifyContent="flex-end">
374
+ <DxcDropdown label="Label" options={defaultOptions} onSelectOption={(value) => {}} margin="small" />
375
+ </DxcFlex>
376
+ </ExampleContainer>
377
+ );
378
+
379
+ export const Chromatic = Dropdown.bind({});
380
+ Chromatic.play = async ({ canvasElement }) => {
381
+ const canvas = within(canvasElement);
382
+ const buttonList = canvas.getAllByRole("button");
383
+ await userEvent.click(buttonList[buttonList.length - 1]);
384
+ };
385
+
386
+ export const OpinionatedTheme = () => (
226
387
  <>
227
- <Title title="Dropdown Menu" theme="light" level={2} />
228
- <Title title="Default with opened menu" theme="light" level={3} />
388
+ <Title title="Opinionated theme" theme="light" level={2} />
229
389
  <ExampleContainer>
230
- <div style={{ display: "flex", gap: "30px", flexDirection: "column", marginBottom: "80px" }}>
231
- <DxcDropdown label="Select a platform" options={defaultOptions} onSelectOption={(option) => {}} size="medium" />
232
- <DxcTextInput label="Your name" onChange={() => {}} />
233
- <DxcCheckbox
234
- label="You understand the selection and give your consent"
235
- onChange={() => {}}
236
- labelPosition="after"
237
- />
238
- </div>
390
+ <Title title="Default" theme="light" level={4} />
391
+ <HalstackProvider theme={opinionatedTheme}>
392
+ <DxcDropdown label="Default" options={options} onSelectOption={(value) => {}} icon={iconSVG} />
393
+ </HalstackProvider>
239
394
  </ExampleContainer>
240
- <Title title="Option states" theme="light" level={3} />
241
395
  <ExampleContainer pseudoState="pseudo-hover">
242
- <Title title="Hovered option" theme="light" level={4} />
243
- <DropdownMenu
244
- id="x"
245
- dropdownId="dX"
246
- iconsPosition="before"
247
- visualFocusIndex={-1}
248
- optionOnClick={(option) => {}}
249
- onKeyDown={(e) => {}}
250
- options={optionWithIcon}
251
- styles={{ width: 240 }}
252
- />
396
+ <Title title="Hovered" theme="light" level={4} />
397
+ <HalstackProvider theme={opinionatedTheme}>
398
+ <DxcDropdown label="Hovered" options={options} onSelectOption={(value) => {}} icon={iconSVG} />
399
+ </HalstackProvider>
253
400
  </ExampleContainer>
254
401
  <ExampleContainer pseudoState="pseudo-active">
255
- <Title title="Active option" theme="light" level={4} />
256
- <DropdownMenu
257
- id="x"
258
- dropdownId="dX"
259
- iconsPosition="before"
260
- visualFocusIndex={-1}
261
- optionOnClick={(option) => {}}
262
- onKeyDown={(e) => {}}
263
- options={optionWithIcon}
264
- styles={{ width: 240 }}
265
- />
402
+ <Title title="Actived" theme="light" level={4} />
403
+ <HalstackProvider theme={opinionatedTheme}>
404
+ <DxcDropdown label="Actived" options={options} onSelectOption={(value) => {}} icon={iconSVG} />
405
+ </HalstackProvider>
266
406
  </ExampleContainer>
267
- <ExampleContainer>
268
- <Title title="Focused option" theme="light" level={4} />
269
- <DropdownMenu
270
- id="x"
271
- dropdownId="dX"
272
- iconsPosition="before"
273
- visualFocusIndex={0}
274
- optionOnClick={(option) => {}}
275
- onKeyDown={(e) => {}}
276
- options={options}
277
- styles={{ width: 240 }}
278
- />
407
+ <ExampleContainer pseudoState="pseudo-focus">
408
+ <Title title="Focused" theme="light" level={4} />
409
+ <HalstackProvider theme={opinionatedTheme}>
410
+ <DxcDropdown label="Focused" options={options} onSelectOption={(value) => {}} icon={iconSVG} />
411
+ </HalstackProvider>
279
412
  </ExampleContainer>
280
- <Title title="Icons" theme="light" level={3} />
281
413
  <ExampleContainer>
282
- <Title title="Before" theme="light" level={4} />
283
- <DropdownMenu
284
- id="x"
285
- dropdownId="dX"
286
- iconsPosition="before"
287
- visualFocusIndex={-1}
288
- optionOnClick={(option) => {}}
289
- onKeyDown={(e) => {}}
290
- options={optionsIcon}
291
- styles={{ width: 240 }}
292
- />
293
- <Title title="After" theme="light" level={4} />
294
- <DropdownMenu
295
- id="x"
296
- dropdownId="dX"
297
- iconsPosition="after"
298
- visualFocusIndex={-1}
299
- optionOnClick={(option) => {}}
300
- onKeyDown={(e) => {}}
301
- options={optionsIcon}
302
- styles={{ width: 240 }}
303
- />
414
+ <Title title="Disabled" theme="light" level={4} />
415
+ <HalstackProvider theme={opinionatedTheme}>
416
+ <DxcDropdown label="Disabled" options={options} onSelectOption={(value) => {}} icon={iconSVG} disabled />
417
+ </HalstackProvider>
304
418
  </ExampleContainer>
305
419
  </>
306
420
  );
307
421
 
308
422
  export const DropdownMenuStates = DropdownListStates.bind({});
309
423
  DropdownMenuStates.play = async ({ canvasElement }) => {
424
+ const canvas = within(canvasElement);
425
+ await userEvent.click(canvas.getAllByRole("button")[0]);
426
+ };
427
+
428
+ export const DropdownMenuAlignedRight = DropdownRightAlignment.bind({});
429
+ DropdownMenuAlignedRight.play = async ({ canvasElement }) => {
430
+ const canvas = within(canvasElement);
431
+ await userEvent.click(canvas.getByRole("button"));
432
+ };
433
+
434
+ export const DropdownMenuAlignedCenter = DropdownCenterAlignment.bind({});
435
+ DropdownMenuAlignedCenter.play = async ({ canvasElement }) => {
310
436
  const canvas = within(canvasElement);
311
437
  await userEvent.click(canvas.getByRole("button"));
312
438
  };
@@ -15,42 +15,37 @@ var _Dropdown = _interopRequireDefault(require("./Dropdown"));
15
15
  var _userEvent = _interopRequireDefault(require("@testing-library/user-event"));
16
16
 
17
17
  global.globalThis = global;
18
+ global.DOMRect = {
19
+ fromRect: function fromRect() {
20
+ return {
21
+ top: 0,
22
+ left: 0,
23
+ bottom: 0,
24
+ right: 0,
25
+ width: 0,
26
+ height: 0
27
+ };
28
+ }
29
+ };
18
30
 
19
31
  global.ResizeObserver = /*#__PURE__*/function () {
20
- function ResizeObserver(cb) {
32
+ function ResizeObserver() {
21
33
  (0, _classCallCheck2["default"])(this, ResizeObserver);
22
- this.cb = cb;
23
34
  }
24
35
 
25
36
  (0, _createClass2["default"])(ResizeObserver, [{
26
37
  key: "observe",
27
- value: function observe() {
28
- this.cb([{
29
- borderBoxSize: {
30
- inlineSize: 0,
31
- blockSize: 0
32
- }
33
- }]);
34
- }
38
+ value: function observe() {}
35
39
  }, {
36
40
  key: "unobserve",
37
41
  value: function unobserve() {}
42
+ }, {
43
+ key: "disconnect",
44
+ value: function disconnect() {}
38
45
  }]);
39
46
  return ResizeObserver;
40
47
  }();
41
48
 
42
- global.DOMRect = {
43
- fromRect: function fromRect() {
44
- return {
45
- top: 0,
46
- left: 0,
47
- bottom: 0,
48
- right: 0,
49
- width: 0,
50
- height: 0
51
- };
52
- }
53
- };
54
49
  var options = [{
55
50
  value: "1",
56
51
  label: "Amazon"
@@ -2,8 +2,6 @@
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
4
 
5
- var _typeof = require("@babel/runtime/helpers/typeof");
6
-
7
5
  Object.defineProperty(exports, "__esModule", {
8
6
  value: true
9
7
  });
@@ -13,18 +11,12 @@ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/hel
13
11
 
14
12
  var _react = _interopRequireDefault(require("react"));
15
13
 
16
- var _styledComponents = _interopRequireWildcard(require("styled-components"));
17
-
18
- var _useTheme = _interopRequireDefault(require("../useTheme"));
14
+ var _styledComponents = _interopRequireDefault(require("styled-components"));
19
15
 
20
16
  var _DropdownMenuItem = _interopRequireDefault(require("./DropdownMenuItem"));
21
17
 
22
18
  var _templateObject;
23
19
 
24
- 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); }
25
-
26
- 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; }
27
-
28
20
  var DropdownMenu = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
29
21
  var id = _ref.id,
30
22
  dropdownTriggerId = _ref.dropdownTriggerId,
@@ -34,12 +26,10 @@ var DropdownMenu = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref
34
26
  onKeyDown = _ref.onKeyDown,
35
27
  options = _ref.options,
36
28
  styles = _ref.styles;
37
- var colorsTheme = (0, _useTheme["default"])();
38
- return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
39
- theme: colorsTheme.dropdown
40
- }, /*#__PURE__*/_react["default"].createElement(DropdownMenuContainer, {
29
+ return /*#__PURE__*/_react["default"].createElement(DropdownMenuContainer, {
41
30
  onMouseDown: function onMouseDown(event) {
42
- // Prevent the onBlur event from closing menu when clicking on the menu since it is implemented with a Portal and the menu is not a child of the container
31
+ // Prevent the onBlur event from closing menu when clicking on the menu since
32
+ // it is implemented with a Portal and the menu is not a direct child of the container
43
33
  event.preventDefault();
44
34
  },
45
35
  onKeyDown: onKeyDown,
@@ -49,8 +39,8 @@ var DropdownMenu = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref
49
39
  "aria-orientation": "vertical",
50
40
  "aria-activedescendant": "option-".concat(visualFocusIndex),
51
41
  tabIndex: -1,
52
- style: styles,
53
- ref: ref
42
+ ref: ref,
43
+ style: styles
54
44
  }, options.map(function (option, index) {
55
45
  return /*#__PURE__*/_react["default"].createElement(_DropdownMenuItem["default"], {
56
46
  id: "option-".concat(index),
@@ -60,10 +50,10 @@ var DropdownMenu = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref
60
50
  onClick: menuItemOnClick,
61
51
  option: option
62
52
  });
63
- })));
53
+ }));
64
54
  });
65
55
 
66
- var DropdownMenuContainer = _styledComponents["default"].ul(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n box-sizing: border-box;\n max-height: 230px;\n overflow-y: auto;\n padding: 0;\n margin: 0;\n background-color: ", ";\n border-width: ", ";\n border-style: ", ";\n border-color: ", ";\n border-radius: ", ";\n border-top-right-radius: 0;\n border-top-left-radius: 0;\n box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);\n outline: none;\n"])), function (props) {
56
+ var DropdownMenuContainer = _styledComponents["default"].ul(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n box-sizing: border-box;\n max-height: 230px;\n min-width: min-content;\n overflow-y: auto;\n padding: 0;\n margin: 0;\n background-color: ", ";\n border-width: ", ";\n border-style: ", ";\n border-color: ", ";\n border-radius: ", ";\n border-top-right-radius: 0;\n border-top-left-radius: 0;\n box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);\n outline: none;\n"])), function (props) {
67
57
  return props.theme.optionBackgroundColor;
68
58
  }, function (props) {
69
59
  return props.theme.borderThickness;