@dxc-technology/halstack-react 0.0.0-9b45027 → 0.0.0-9c20370

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 (308) hide show
  1. package/BackgroundColorContext.d.ts +2 -2
  2. package/BackgroundColorContext.js +1 -1
  3. package/HalstackContext.d.ts +1336 -0
  4. package/HalstackContext.js +335 -0
  5. package/accordion/Accordion.d.ts +1 -1
  6. package/accordion/Accordion.js +110 -146
  7. package/accordion/Accordion.stories.tsx +108 -118
  8. package/accordion/Accordion.test.js +71 -0
  9. package/accordion/types.d.ts +7 -18
  10. package/accordion-group/AccordionGroup.d.ts +5 -4
  11. package/accordion-group/AccordionGroup.js +34 -76
  12. package/accordion-group/AccordionGroup.stories.tsx +94 -67
  13. package/accordion-group/AccordionGroup.test.js +116 -0
  14. package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
  15. package/accordion-group/AccordionGroupAccordion.js +43 -0
  16. package/accordion-group/types.d.ts +13 -18
  17. package/alert/Alert.js +9 -10
  18. package/alert/Alert.stories.tsx +28 -0
  19. package/alert/Alert.test.js +92 -0
  20. package/badge/Badge.d.ts +4 -0
  21. package/badge/Badge.js +5 -3
  22. package/badge/types.d.ts +5 -0
  23. package/bleed/Bleed.d.ts +2 -2
  24. package/bleed/Bleed.js +1 -34
  25. package/bleed/Bleed.stories.tsx +95 -95
  26. package/bleed/types.d.ts +25 -1
  27. package/box/Box.d.ts +1 -1
  28. package/box/Box.js +19 -48
  29. package/box/Box.stories.tsx +38 -51
  30. package/box/Box.test.js +18 -0
  31. package/box/types.d.ts +0 -11
  32. package/bulleted-list/BulletedList.d.ts +7 -0
  33. package/bulleted-list/BulletedList.js +125 -0
  34. package/bulleted-list/BulletedList.stories.tsx +206 -0
  35. package/bulleted-list/types.d.ts +38 -0
  36. package/bulleted-list/types.js +5 -0
  37. package/button/Button.d.ts +1 -1
  38. package/button/Button.js +44 -71
  39. package/button/Button.stories.tsx +159 -8
  40. package/button/Button.test.js +46 -0
  41. package/button/types.d.ts +9 -5
  42. package/card/Card.d.ts +1 -1
  43. package/card/Card.js +37 -58
  44. package/card/Card.stories.tsx +12 -42
  45. package/card/Card.test.js +50 -0
  46. package/card/types.d.ts +1 -6
  47. package/checkbox/Checkbox.d.ts +2 -2
  48. package/checkbox/Checkbox.js +107 -110
  49. package/checkbox/Checkbox.stories.tsx +198 -130
  50. package/checkbox/Checkbox.test.js +155 -0
  51. package/checkbox/types.d.ts +11 -3
  52. package/chip/Chip.d.ts +1 -1
  53. package/chip/Chip.js +36 -95
  54. package/chip/Chip.stories.tsx +123 -30
  55. package/chip/Chip.test.js +54 -0
  56. package/chip/types.d.ts +5 -13
  57. package/common/OpenSans.css +68 -80
  58. package/common/coreTokens.d.ts +146 -0
  59. package/common/coreTokens.js +167 -0
  60. package/common/utils.d.ts +1 -0
  61. package/common/utils.js +4 -4
  62. package/common/variables.d.ts +1482 -0
  63. package/common/variables.js +1097 -1348
  64. package/date-input/Calendar.d.ts +4 -0
  65. package/date-input/Calendar.js +258 -0
  66. package/date-input/DateInput.js +169 -258
  67. package/date-input/DateInput.stories.tsx +199 -33
  68. package/date-input/DateInput.test.js +835 -0
  69. package/date-input/DatePicker.d.ts +4 -0
  70. package/date-input/DatePicker.js +146 -0
  71. package/date-input/Icons.d.ts +6 -0
  72. package/date-input/Icons.js +75 -0
  73. package/date-input/YearPicker.d.ts +4 -0
  74. package/date-input/YearPicker.js +126 -0
  75. package/date-input/types.d.ts +67 -9
  76. package/dialog/Dialog.d.ts +1 -1
  77. package/dialog/Dialog.js +68 -103
  78. package/dialog/Dialog.stories.tsx +154 -171
  79. package/dialog/Dialog.test.js +369 -0
  80. package/dialog/types.d.ts +0 -12
  81. package/dropdown/Dropdown.d.ts +1 -1
  82. package/dropdown/Dropdown.js +248 -277
  83. package/dropdown/Dropdown.stories.tsx +255 -64
  84. package/dropdown/Dropdown.test.js +586 -0
  85. package/dropdown/DropdownMenu.d.ts +4 -0
  86. package/dropdown/DropdownMenu.js +74 -0
  87. package/dropdown/DropdownMenuItem.d.ts +4 -0
  88. package/dropdown/DropdownMenuItem.js +79 -0
  89. package/dropdown/types.d.ts +27 -16
  90. package/file-input/FileInput.d.ts +2 -2
  91. package/file-input/FileInput.js +180 -223
  92. package/file-input/FileInput.stories.tsx +122 -11
  93. package/file-input/FileInput.test.js +457 -0
  94. package/file-input/FileItem.d.ts +4 -14
  95. package/file-input/FileItem.js +44 -66
  96. package/file-input/types.d.ts +18 -1
  97. package/flex/Flex.d.ts +4 -0
  98. package/flex/Flex.js +71 -0
  99. package/flex/Flex.stories.tsx +112 -0
  100. package/flex/types.d.ts +97 -0
  101. package/flex/types.js +5 -0
  102. package/footer/Footer.d.ts +1 -1
  103. package/footer/Footer.js +49 -144
  104. package/footer/Footer.stories.tsx +37 -16
  105. package/footer/Footer.test.js +99 -0
  106. package/footer/Icons.js +1 -1
  107. package/footer/types.d.ts +11 -12
  108. package/grid/Grid.d.ts +7 -0
  109. package/grid/Grid.js +91 -0
  110. package/grid/Grid.stories.tsx +219 -0
  111. package/grid/types.d.ts +115 -0
  112. package/grid/types.js +5 -0
  113. package/header/Header.d.ts +4 -3
  114. package/header/Header.js +102 -150
  115. package/header/Header.stories.tsx +152 -63
  116. package/header/Header.test.js +79 -0
  117. package/header/Icons.js +2 -2
  118. package/header/types.d.ts +0 -13
  119. package/heading/Heading.js +1 -1
  120. package/heading/Heading.test.js +186 -0
  121. package/inset/Inset.js +1 -34
  122. package/inset/Inset.stories.tsx +37 -36
  123. package/inset/types.d.ts +25 -1
  124. package/layout/ApplicationLayout.d.ts +16 -6
  125. package/layout/ApplicationLayout.js +78 -129
  126. package/layout/ApplicationLayout.stories.tsx +84 -93
  127. package/layout/Icons.d.ts +5 -0
  128. package/layout/Icons.js +13 -2
  129. package/layout/SidenavContext.d.ts +5 -0
  130. package/layout/SidenavContext.js +19 -0
  131. package/layout/types.d.ts +19 -35
  132. package/link/Link.d.ts +3 -2
  133. package/link/Link.js +63 -88
  134. package/link/Link.stories.tsx +159 -52
  135. package/link/Link.test.js +81 -0
  136. package/link/types.d.ts +7 -27
  137. package/main.d.ts +12 -15
  138. package/main.js +57 -75
  139. package/nav-tabs/NavTabs.d.ts +8 -0
  140. package/nav-tabs/NavTabs.js +122 -0
  141. package/nav-tabs/NavTabs.stories.tsx +274 -0
  142. package/nav-tabs/NavTabs.test.js +82 -0
  143. package/nav-tabs/Tab.d.ts +4 -0
  144. package/nav-tabs/Tab.js +146 -0
  145. package/nav-tabs/types.d.ts +52 -0
  146. package/nav-tabs/types.js +5 -0
  147. package/number-input/NumberInput.js +11 -18
  148. package/number-input/NumberInput.stories.tsx +5 -5
  149. package/number-input/NumberInput.test.js +542 -0
  150. package/number-input/types.d.ts +17 -10
  151. package/package.json +20 -23
  152. package/paginator/Icons.d.ts +5 -0
  153. package/paginator/Icons.js +16 -28
  154. package/paginator/Paginator.js +20 -49
  155. package/paginator/Paginator.stories.tsx +24 -0
  156. package/paginator/Paginator.test.js +318 -0
  157. package/paragraph/Paragraph.d.ts +5 -0
  158. package/paragraph/Paragraph.js +38 -0
  159. package/paragraph/Paragraph.stories.tsx +44 -0
  160. package/password-input/PasswordInput.js +7 -4
  161. package/password-input/PasswordInput.test.js +181 -0
  162. package/password-input/types.d.ts +14 -11
  163. package/progress-bar/ProgressBar.js +61 -55
  164. package/progress-bar/ProgressBar.stories.jsx +47 -12
  165. package/progress-bar/ProgressBar.test.js +110 -0
  166. package/quick-nav/QuickNav.d.ts +4 -0
  167. package/quick-nav/QuickNav.js +117 -0
  168. package/quick-nav/QuickNav.stories.tsx +356 -0
  169. package/quick-nav/types.d.ts +21 -0
  170. package/quick-nav/types.js +5 -0
  171. package/radio-group/Radio.d.ts +1 -1
  172. package/radio-group/Radio.js +60 -34
  173. package/radio-group/RadioGroup.js +81 -68
  174. package/radio-group/RadioGroup.stories.tsx +171 -36
  175. package/radio-group/RadioGroup.test.js +722 -0
  176. package/radio-group/types.d.ts +81 -3
  177. package/resultsetTable/Icons.d.ts +7 -0
  178. package/resultsetTable/Icons.js +51 -0
  179. package/resultsetTable/ResultsetTable.js +50 -106
  180. package/resultsetTable/ResultsetTable.stories.tsx +50 -25
  181. package/resultsetTable/ResultsetTable.test.js +325 -0
  182. package/resultsetTable/types.d.ts +1 -1
  183. package/select/Icons.d.ts +10 -0
  184. package/select/Icons.js +93 -0
  185. package/select/Listbox.d.ts +4 -0
  186. package/select/Listbox.js +169 -0
  187. package/select/Option.d.ts +4 -0
  188. package/select/Option.js +97 -0
  189. package/select/Select.js +189 -386
  190. package/select/Select.stories.tsx +600 -201
  191. package/select/Select.test.js +2228 -0
  192. package/select/types.d.ts +53 -13
  193. package/sidenav/Icons.d.ts +7 -0
  194. package/sidenav/Icons.js +51 -0
  195. package/sidenav/Sidenav.d.ts +6 -5
  196. package/sidenav/Sidenav.js +146 -44
  197. package/sidenav/Sidenav.stories.tsx +251 -151
  198. package/sidenav/Sidenav.test.js +44 -0
  199. package/sidenav/types.d.ts +52 -26
  200. package/slider/Slider.d.ts +2 -2
  201. package/slider/Slider.js +123 -98
  202. package/slider/Slider.stories.tsx +72 -9
  203. package/slider/Slider.test.js +250 -0
  204. package/slider/types.d.ts +8 -0
  205. package/spinner/Spinner.js +18 -24
  206. package/spinner/Spinner.stories.jsx +53 -27
  207. package/spinner/Spinner.test.js +64 -0
  208. package/switch/Switch.d.ts +2 -2
  209. package/switch/Switch.js +152 -69
  210. package/switch/Switch.stories.tsx +53 -42
  211. package/switch/Switch.test.js +225 -0
  212. package/switch/types.d.ts +10 -2
  213. package/table/Table.js +3 -3
  214. package/table/Table.stories.jsx +80 -1
  215. package/table/Table.test.js +26 -0
  216. package/tabs/Tab.d.ts +4 -0
  217. package/tabs/Tab.js +132 -0
  218. package/tabs/Tabs.d.ts +1 -1
  219. package/tabs/Tabs.js +360 -112
  220. package/tabs/Tabs.stories.tsx +119 -13
  221. package/tabs/Tabs.test.js +350 -0
  222. package/tabs/types.d.ts +17 -3
  223. package/tag/Tag.d.ts +1 -1
  224. package/tag/Tag.js +24 -36
  225. package/tag/Tag.stories.tsx +37 -27
  226. package/tag/Tag.test.js +60 -0
  227. package/tag/types.d.ts +23 -14
  228. package/text-input/Icons.d.ts +8 -0
  229. package/text-input/Icons.js +60 -0
  230. package/text-input/Suggestion.d.ts +4 -0
  231. package/text-input/Suggestion.js +84 -0
  232. package/text-input/Suggestions.d.ts +4 -0
  233. package/text-input/Suggestions.js +134 -0
  234. package/text-input/TextInput.js +225 -346
  235. package/text-input/TextInput.stories.tsx +310 -197
  236. package/text-input/TextInput.test.js +1723 -0
  237. package/text-input/types.d.ts +50 -12
  238. package/textarea/Textarea.js +22 -30
  239. package/textarea/Textarea.stories.jsx +93 -13
  240. package/textarea/Textarea.test.js +435 -0
  241. package/textarea/types.d.ts +18 -11
  242. package/toggle-group/ToggleGroup.d.ts +2 -2
  243. package/toggle-group/ToggleGroup.js +12 -8
  244. package/toggle-group/ToggleGroup.stories.tsx +46 -4
  245. package/toggle-group/ToggleGroup.test.js +156 -0
  246. package/toggle-group/types.d.ts +10 -2
  247. package/typography/Typography.d.ts +4 -0
  248. package/typography/Typography.js +32 -0
  249. package/typography/Typography.stories.tsx +198 -0
  250. package/typography/types.d.ts +18 -0
  251. package/typography/types.js +5 -0
  252. package/useTheme.d.ts +1234 -1
  253. package/useTheme.js +3 -3
  254. package/useTranslatedLabels.d.ts +85 -0
  255. package/useTranslatedLabels.js +20 -0
  256. package/utils/BaseTypography.d.ts +21 -0
  257. package/utils/BaseTypography.js +108 -0
  258. package/utils/FocusLock.d.ts +13 -0
  259. package/utils/FocusLock.js +138 -0
  260. package/wizard/Wizard.d.ts +1 -1
  261. package/wizard/Wizard.js +59 -55
  262. package/wizard/Wizard.stories.tsx +48 -19
  263. package/wizard/Wizard.test.js +141 -0
  264. package/wizard/types.d.ts +8 -4
  265. package/ThemeContext.d.ts +0 -15
  266. package/ThemeContext.js +0 -243
  267. package/V3Select/V3Select.js +0 -455
  268. package/V3Select/index.d.ts +0 -27
  269. package/V3Textarea/V3Textarea.js +0 -260
  270. package/V3Textarea/index.d.ts +0 -27
  271. package/card/ice-cream.jpg +0 -0
  272. package/common/RequiredComponent.js +0 -32
  273. package/date/Date.js +0 -373
  274. package/date/index.d.ts +0 -27
  275. package/input-text/Icons.js +0 -22
  276. package/input-text/InputText.js +0 -611
  277. package/input-text/index.d.ts +0 -36
  278. package/list/List.d.ts +0 -8
  279. package/list/List.js +0 -47
  280. package/list/List.stories.tsx +0 -95
  281. package/radio/Radio.d.ts +0 -4
  282. package/radio/Radio.js +0 -174
  283. package/radio/Radio.stories.tsx +0 -192
  284. package/radio/types.d.ts +0 -54
  285. package/row/Row.d.ts +0 -11
  286. package/row/Row.js +0 -127
  287. package/row/Row.stories.tsx +0 -239
  288. package/stack/Stack.d.ts +0 -10
  289. package/stack/Stack.js +0 -97
  290. package/stack/Stack.stories.tsx +0 -166
  291. package/text/Text.d.ts +0 -7
  292. package/text/Text.js +0 -30
  293. package/text/Text.stories.tsx +0 -19
  294. package/toggle/Toggle.js +0 -186
  295. package/toggle/index.d.ts +0 -21
  296. package/upload/Upload.js +0 -201
  297. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  298. package/upload/buttons-upload/Icons.js +0 -40
  299. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  300. package/upload/dragAndDropArea/Icons.js +0 -39
  301. package/upload/file-upload/FileToUpload.js +0 -115
  302. package/upload/file-upload/Icons.js +0 -66
  303. package/upload/files-upload/FilesToUpload.js +0 -109
  304. package/upload/index.d.ts +0 -15
  305. package/upload/transaction/Icons.js +0 -160
  306. package/upload/transaction/Transaction.js +0 -104
  307. package/upload/transactions/Transactions.js +0 -94
  308. /package/{radio → badge}/types.js +0 -0
@@ -3,36 +3,72 @@ import { userEvent, within } from "@storybook/testing-library";
3
3
  import DxcDropdown from "./Dropdown";
4
4
  import Title from "../../.storybook/components/Title";
5
5
  import ExampleContainer from "../../.storybook/components/ExampleContainer";
6
+ import DropdownMenu from "./DropdownMenu";
7
+ import { Option } from "./types";
8
+ import useTheme from "../useTheme";
9
+ import DxcFlex from "../flex/Flex";
10
+ import { HalstackProvider } from "../HalstackContext";
11
+ import { ThemeProvider } from "styled-components";
6
12
 
7
13
  export default {
8
14
  title: "Dropdown",
9
15
  component: DxcDropdown,
10
16
  };
11
17
 
12
- const iconSVG = () => {
13
- return (
14
- <svg viewBox="0 0 24 24" fill="currentColor">
15
- <path d="M0 0h24v24H0z" fill="none" />
16
- <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" />
17
- </svg>
18
- );
19
- };
20
-
21
- const iconSVGLarge = () => {
22
- return (
23
- <svg enable-background="new 0 0 24 24" height="48px" viewBox="0 0 24 24" width="48px" fill="currentColor">
24
- <g>
25
- <path d="M0,0h24v24H0V0z" fill="none" />
26
- <path d="M0,0h24v24H0V0z" fill="none" />
27
- </g>
28
- <g>
29
- <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" />
30
- </g>
31
- </svg>
32
- );
33
- };
18
+ const hamburguerIcon = (
19
+ <svg xmlns="http://www.w3.org/2000/svg" height="20" width="20">
20
+ <path d="M3 14.5V13h14v1.5Zm0-3.75v-1.5h14v1.5ZM3 7V5.5h14V7Z" />
21
+ </svg>
22
+ );
23
+ const iconSVG = (
24
+ <svg viewBox="0 0 24 24" height="24" width="24" fill="currentColor">
25
+ <path d="M0 0h24v24H0z" fill="none" />
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" />
27
+ </svg>
28
+ );
29
+ const iconSVGLarge = (
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" />
32
+ </svg>
33
+ );
34
+ const iconUrl = "https://iconape.com/wp-content/files/yd/367773/svg/logo-linkedin-logo-icon-png-svg.png";
35
+ const icons = [iconSVG, iconSVGLarge, iconUrl];
34
36
 
35
- const options: any = [
37
+ const defaultOptions: Option[] = [
38
+ {
39
+ value: "1",
40
+ label: "Amazon",
41
+ },
42
+ {
43
+ value: "2",
44
+ label: "Ebay",
45
+ },
46
+ {
47
+ value: "3",
48
+ label: "Apple",
49
+ },
50
+ {
51
+ value: "4",
52
+ label: "Wallapop",
53
+ },
54
+ {
55
+ value: "5",
56
+ label: "Aliexpress",
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
+ },
70
+ ];
71
+ const options: Option[] = [
36
72
  {
37
73
  value: "1",
38
74
  label: "Amazon with a very long text",
@@ -46,17 +82,25 @@ const options: any = [
46
82
  label: "Apple",
47
83
  },
48
84
  ];
49
-
50
- const option: any = [
85
+ const optionWithIcon: Option[] = [
51
86
  {
52
87
  value: "1",
53
88
  label: "Ebay",
89
+ icon: iconUrl,
54
90
  },
55
91
  ];
56
92
 
57
- const optionsIcon: any = options.map((op, i) => ({ ...op, icon: i === 1 ? iconSVGLarge : iconSVG }));
93
+ const optionsIcon: any = options.map((op, i) => ({ ...op, icon: icons[i] }));
58
94
 
59
- export const Chromatic = () => (
95
+ const opinionatedTheme = {
96
+ dropdown: {
97
+ baseColor: "#ffffff",
98
+ fontColor: "#000000",
99
+ optionFontColor: "#000000",
100
+ },
101
+ };
102
+
103
+ const Dropdown = () => (
60
104
  <>
61
105
  <ExampleContainer>
62
106
  <Title title="Default" theme="light" level={4} />
@@ -66,7 +110,7 @@ export const Chromatic = () => (
66
110
  <Title title="Hovered" theme="light" level={4} />
67
111
  <DxcDropdown label="Hovered" options={options} onSelectOption={(value) => {}} />
68
112
  </ExampleContainer>
69
- <ExampleContainer pseudoState="pseudo-focus-visible">
113
+ <ExampleContainer pseudoState="pseudo-focus">
70
114
  <Title title="Focused" theme="light" level={4} />
71
115
  <DxcDropdown label="Focused" options={options} onSelectOption={(value) => {}} />
72
116
  </ExampleContainer>
@@ -92,7 +136,7 @@ export const Chromatic = () => (
92
136
  label="Icon after"
93
137
  options={options}
94
138
  onSelectOption={(value) => {}}
95
- icon={iconSVG}
139
+ icon="https://iconape.com/wp-content/files/yd/367773/svg/logo-linkedin-logo-icon-png-svg.png"
96
140
  iconPosition="after"
97
141
  />
98
142
  </ExampleContainer>
@@ -101,9 +145,22 @@ export const Chromatic = () => (
101
145
  <DxcDropdown options={options} onSelectOption={(value) => {}} icon={iconSVG} />
102
146
  </ExampleContainer>
103
147
  <ExampleContainer>
104
- <Title title="Large icon" theme="light" level={4} />
148
+ <Title title="Only icon without caret" theme="light" level={4} />
149
+ <DxcDropdown options={options} onSelectOption={(value) => {}} icon={hamburguerIcon} caretHidden />
150
+ </ExampleContainer>
151
+ <ExampleContainer>
152
+ <Title title="Large icon (SVG)" theme="light" level={4} />
105
153
  <DxcDropdown label="Large icon" options={options} onSelectOption={(value) => {}} icon={iconSVGLarge} />
106
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>
107
164
  <ExampleContainer>
108
165
  <Title title="Disabled with icon" theme="light" level={4} />
109
166
  <DxcDropdown
@@ -186,62 +243,196 @@ export const Chromatic = () => (
186
243
  size="fillParent"
187
244
  />
188
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>
189
250
  </>
190
251
  );
191
252
 
192
- const DropdownWithOptions = () => (
193
- <ExampleContainer expanded>
194
- <Title title="Options" theme="light" level={4} />
195
- <DxcDropdown label="Options with icon" options={optionsIcon} onSelectOption={(value) => {}} />
196
- </ExampleContainer>
197
- );
253
+ const DropdownListStates = () => {
254
+ const colorsTheme: any = useTheme();
198
255
 
199
- const DropdownHoverOption = () => (
200
- <ExampleContainer pseudoState="pseudo-hover" expanded>
201
- <Title title="Hovered option" theme="light" level={4} />
202
- <DxcDropdown label="Hovered options" options={option} onSelectOption={(value) => {}} />
203
- </ExampleContainer>
204
- );
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
+ };
205
360
 
206
- const DropdownActiveOption = () => (
207
- <ExampleContainer pseudoState="pseudo-active" expanded>
208
- <Title title="Actived option" theme="light" level={4} />
209
- <DxcDropdown label="Actived options" options={option} onSelectOption={(value) => {}} />
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>
210
367
  </ExampleContainer>
211
368
  );
212
369
 
213
- const DropdownWithOptionsIconAfter = () => (
370
+ const DropdownCenterAlignment = () => (
214
371
  <ExampleContainer expanded>
215
- <Title title="Icon after options" theme="light" level={4} />
216
- <DxcDropdown
217
- label="Icon after options"
218
- options={optionsIcon}
219
- onSelectOption={(value) => {}}
220
- optionsIconPosition="after"
221
- />
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>
222
376
  </ExampleContainer>
223
377
  );
224
378
 
225
- export const DropdownOptions = DropdownWithOptions.bind({});
226
- DropdownOptions.play = async ({ canvasElement }) => {
379
+ export const Chromatic = Dropdown.bind({});
380
+ Chromatic.play = async ({ canvasElement }) => {
227
381
  const canvas = within(canvasElement);
228
- await userEvent.click(canvas.getByRole("button"));
382
+ const buttonList = canvas.getAllByRole("button");
383
+ await userEvent.click(buttonList[buttonList.length - 1]);
229
384
  };
230
385
 
231
- export const DropdownHoveredOption = DropdownHoverOption.bind({});
232
- DropdownHoveredOption.play = async ({ canvasElement }) => {
386
+ export const OpinionatedTheme = () => (
387
+ <>
388
+ <Title title="Opinionated theme" theme="light" level={2} />
389
+ <ExampleContainer>
390
+ <Title title="Default" theme="light" level={4} />
391
+ <HalstackProvider theme={opinionatedTheme}>
392
+ <DxcDropdown label="Default" options={options} onSelectOption={(value) => {}} icon={iconSVG} />
393
+ </HalstackProvider>
394
+ </ExampleContainer>
395
+ <ExampleContainer pseudoState="pseudo-hover">
396
+ <Title title="Hovered" theme="light" level={4} />
397
+ <HalstackProvider theme={opinionatedTheme}>
398
+ <DxcDropdown label="Hovered" options={options} onSelectOption={(value) => {}} icon={iconSVG} />
399
+ </HalstackProvider>
400
+ </ExampleContainer>
401
+ <ExampleContainer pseudoState="pseudo-active">
402
+ <Title title="Actived" theme="light" level={4} />
403
+ <HalstackProvider theme={opinionatedTheme}>
404
+ <DxcDropdown label="Actived" options={options} onSelectOption={(value) => {}} icon={iconSVG} />
405
+ </HalstackProvider>
406
+ </ExampleContainer>
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>
412
+ </ExampleContainer>
413
+ <ExampleContainer>
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>
418
+ </ExampleContainer>
419
+ </>
420
+ );
421
+
422
+ export const DropdownMenuStates = DropdownListStates.bind({});
423
+ DropdownMenuStates.play = async ({ canvasElement }) => {
233
424
  const canvas = within(canvasElement);
234
- await userEvent.click(canvas.getByRole("button"));
425
+ await userEvent.click(canvas.getAllByRole("button")[0]);
235
426
  };
236
427
 
237
- export const DropdownActivedOption = DropdownActiveOption.bind({});
238
- DropdownActivedOption.play = async ({ canvasElement }) => {
428
+ export const DropdownMenuAlignedRight = DropdownRightAlignment.bind({});
429
+ DropdownMenuAlignedRight.play = async ({ canvasElement }) => {
239
430
  const canvas = within(canvasElement);
240
431
  await userEvent.click(canvas.getByRole("button"));
241
432
  };
242
433
 
243
- export const DropdownOptionsIconAfter = DropdownWithOptionsIconAfter.bind({});
244
- DropdownOptionsIconAfter.play = async ({ canvasElement }) => {
434
+ export const DropdownMenuAlignedCenter = DropdownCenterAlignment.bind({});
435
+ DropdownMenuAlignedCenter.play = async ({ canvasElement }) => {
245
436
  const canvas = within(canvasElement);
246
437
  await userEvent.click(canvas.getByRole("button"));
247
438
  };