@dxc-technology/halstack-react 0.0.0-9df62c5 → 0.0.0-9e54008

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 (516) hide show
  1. package/BackgroundColorContext.d.ts +10 -0
  2. package/BackgroundColorContext.js +47 -0
  3. package/HalstackContext.d.ts +1336 -0
  4. package/HalstackContext.js +335 -0
  5. package/accordion/Accordion.d.ts +4 -0
  6. package/accordion/Accordion.js +222 -0
  7. package/accordion/Accordion.stories.tsx +297 -0
  8. package/accordion/Accordion.test.js +71 -0
  9. package/accordion/types.d.ts +57 -0
  10. package/accordion/types.js +5 -0
  11. package/accordion-group/AccordionGroup.d.ts +8 -0
  12. package/accordion-group/AccordionGroup.js +128 -0
  13. package/accordion-group/AccordionGroup.stories.tsx +252 -0
  14. package/accordion-group/AccordionGroup.test.js +116 -0
  15. package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
  16. package/accordion-group/AccordionGroupAccordion.js +43 -0
  17. package/accordion-group/types.d.ts +67 -0
  18. package/accordion-group/types.js +5 -0
  19. package/alert/Alert.d.ts +4 -0
  20. package/alert/Alert.js +289 -0
  21. package/alert/Alert.stories.tsx +198 -0
  22. package/alert/Alert.test.js +92 -0
  23. package/alert/types.d.ts +49 -0
  24. package/alert/types.js +5 -0
  25. package/badge/Badge.d.ts +4 -0
  26. package/badge/Badge.js +61 -0
  27. package/badge/types.d.ts +5 -0
  28. package/badge/types.js +5 -0
  29. package/bleed/Bleed.d.ts +3 -0
  30. package/bleed/Bleed.js +51 -0
  31. package/bleed/Bleed.stories.tsx +342 -0
  32. package/bleed/types.d.ts +37 -0
  33. package/bleed/types.js +5 -0
  34. package/box/Box.d.ts +4 -0
  35. package/box/Box.js +97 -0
  36. package/box/Box.stories.tsx +119 -0
  37. package/box/Box.test.js +18 -0
  38. package/box/types.d.ts +32 -0
  39. package/box/types.js +5 -0
  40. package/bulleted-list/BulletedList.d.ts +7 -0
  41. package/bulleted-list/BulletedList.js +125 -0
  42. package/bulleted-list/BulletedList.stories.tsx +206 -0
  43. package/bulleted-list/types.d.ts +38 -0
  44. package/bulleted-list/types.js +5 -0
  45. package/button/Button.d.ts +4 -0
  46. package/button/Button.js +153 -0
  47. package/button/Button.stories.tsx +425 -0
  48. package/button/Button.test.js +35 -0
  49. package/button/types.d.ts +53 -0
  50. package/button/types.js +5 -0
  51. package/card/Card.d.ts +4 -0
  52. package/card/Card.js +143 -0
  53. package/card/Card.stories.tsx +171 -0
  54. package/card/Card.test.js +50 -0
  55. package/card/types.d.ts +62 -0
  56. package/card/types.js +5 -0
  57. package/checkbox/Checkbox.d.ts +4 -0
  58. package/checkbox/Checkbox.js +250 -0
  59. package/checkbox/Checkbox.stories.tsx +260 -0
  60. package/checkbox/Checkbox.test.js +155 -0
  61. package/checkbox/types.d.ts +68 -0
  62. package/checkbox/types.js +5 -0
  63. package/chip/Chip.d.ts +4 -0
  64. package/chip/Chip.js +140 -0
  65. package/chip/Chip.stories.tsx +214 -0
  66. package/chip/Chip.test.js +54 -0
  67. package/chip/types.d.ts +45 -0
  68. package/chip/types.js +5 -0
  69. package/common/OpenSans.css +69 -0
  70. package/common/coreTokens.d.ts +146 -0
  71. package/common/coreTokens.js +167 -0
  72. package/common/utils.d.ts +1 -0
  73. package/common/utils.js +22 -0
  74. package/common/variables.d.ts +1482 -0
  75. package/common/variables.js +1361 -0
  76. package/date-input/Calendar.d.ts +4 -0
  77. package/date-input/Calendar.js +258 -0
  78. package/date-input/DateInput.d.ts +4 -0
  79. package/date-input/DateInput.js +269 -0
  80. package/date-input/DateInput.stories.tsx +304 -0
  81. package/date-input/DateInput.test.js +835 -0
  82. package/date-input/DatePicker.d.ts +4 -0
  83. package/date-input/DatePicker.js +146 -0
  84. package/date-input/Icons.d.ts +6 -0
  85. package/date-input/Icons.js +75 -0
  86. package/date-input/YearPicker.d.ts +4 -0
  87. package/date-input/YearPicker.js +126 -0
  88. package/date-input/types.d.ts +158 -0
  89. package/date-input/types.js +5 -0
  90. package/dialog/Dialog.d.ts +4 -0
  91. package/dialog/Dialog.js +131 -0
  92. package/dialog/Dialog.stories.tsx +195 -0
  93. package/dialog/Dialog.test.js +369 -0
  94. package/dialog/types.d.ts +31 -0
  95. package/dialog/types.js +5 -0
  96. package/dropdown/Dropdown.d.ts +4 -0
  97. package/dropdown/Dropdown.js +388 -0
  98. package/dropdown/Dropdown.stories.tsx +438 -0
  99. package/dropdown/Dropdown.test.js +586 -0
  100. package/dropdown/DropdownMenu.d.ts +4 -0
  101. package/dropdown/DropdownMenu.js +74 -0
  102. package/dropdown/DropdownMenuItem.d.ts +4 -0
  103. package/dropdown/DropdownMenuItem.js +79 -0
  104. package/dropdown/types.d.ts +100 -0
  105. package/dropdown/types.js +5 -0
  106. package/file-input/FileInput.d.ts +4 -0
  107. package/file-input/FileInput.js +547 -0
  108. package/file-input/FileInput.stories.tsx +618 -0
  109. package/file-input/FileInput.test.js +457 -0
  110. package/file-input/FileItem.d.ts +4 -0
  111. package/file-input/FileItem.js +162 -0
  112. package/file-input/types.d.ts +129 -0
  113. package/file-input/types.js +5 -0
  114. package/flex/Flex.d.ts +4 -0
  115. package/flex/Flex.js +71 -0
  116. package/flex/Flex.stories.tsx +112 -0
  117. package/flex/types.d.ts +97 -0
  118. package/flex/types.js +5 -0
  119. package/footer/Footer.d.ts +4 -0
  120. package/footer/Footer.js +170 -0
  121. package/footer/Footer.stories.tsx +140 -0
  122. package/footer/Footer.test.js +97 -0
  123. package/footer/Icons.d.ts +2 -0
  124. package/footer/Icons.js +77 -0
  125. package/footer/types.d.ts +60 -0
  126. package/footer/types.js +5 -0
  127. package/grid/Grid.d.ts +7 -0
  128. package/grid/Grid.js +91 -0
  129. package/grid/Grid.stories.tsx +219 -0
  130. package/grid/types.d.ts +115 -0
  131. package/grid/types.js +5 -0
  132. package/header/Header.d.ts +8 -0
  133. package/header/Header.js +276 -0
  134. package/header/Header.stories.tsx +251 -0
  135. package/header/Header.test.js +79 -0
  136. package/header/Icons.d.ts +2 -0
  137. package/header/Icons.js +34 -0
  138. package/header/types.d.ts +34 -0
  139. package/header/types.js +5 -0
  140. package/heading/Heading.d.ts +4 -0
  141. package/heading/Heading.js +159 -0
  142. package/heading/Heading.stories.tsx +54 -0
  143. package/heading/Heading.test.js +186 -0
  144. package/heading/types.d.ts +33 -0
  145. package/heading/types.js +5 -0
  146. package/inset/Inset.d.ts +3 -0
  147. package/inset/Inset.js +51 -0
  148. package/inset/Inset.stories.tsx +230 -0
  149. package/inset/types.d.ts +37 -0
  150. package/inset/types.js +5 -0
  151. package/layout/ApplicationLayout.d.ts +20 -0
  152. package/layout/ApplicationLayout.js +171 -0
  153. package/layout/ApplicationLayout.stories.tsx +162 -0
  154. package/layout/Icons.d.ts +5 -0
  155. package/layout/Icons.js +66 -0
  156. package/layout/SidenavContext.d.ts +5 -0
  157. package/layout/SidenavContext.js +19 -0
  158. package/layout/types.d.ts +41 -0
  159. package/layout/types.js +5 -0
  160. package/link/Link.d.ts +4 -0
  161. package/link/Link.js +136 -0
  162. package/link/Link.stories.tsx +253 -0
  163. package/link/Link.test.js +81 -0
  164. package/link/types.d.ts +54 -0
  165. package/link/types.js +5 -0
  166. package/main.d.ts +45 -0
  167. package/{dist/main.js → main.js} +171 -73
  168. package/nav-tabs/NavTabs.d.ts +8 -0
  169. package/nav-tabs/NavTabs.js +122 -0
  170. package/nav-tabs/NavTabs.stories.tsx +274 -0
  171. package/nav-tabs/NavTabs.test.js +82 -0
  172. package/nav-tabs/Tab.d.ts +4 -0
  173. package/nav-tabs/Tab.js +146 -0
  174. package/nav-tabs/types.d.ts +52 -0
  175. package/nav-tabs/types.js +5 -0
  176. package/number-input/NumberInput.d.ts +4 -0
  177. package/number-input/NumberInput.js +76 -0
  178. package/number-input/NumberInput.stories.tsx +115 -0
  179. package/number-input/NumberInput.test.js +542 -0
  180. package/number-input/NumberInputContext.d.ts +4 -0
  181. package/{dist/ThemeContext.js → number-input/NumberInputContext.js} +6 -2
  182. package/number-input/numberInputContextTypes.d.ts +19 -0
  183. package/number-input/numberInputContextTypes.js +5 -0
  184. package/number-input/types.d.ts +124 -0
  185. package/number-input/types.js +5 -0
  186. package/package.json +49 -36
  187. package/paginator/Icons.d.ts +5 -0
  188. package/paginator/Icons.js +54 -0
  189. package/paginator/Paginator.d.ts +4 -0
  190. package/paginator/Paginator.js +163 -0
  191. package/paginator/Paginator.stories.tsx +87 -0
  192. package/paginator/Paginator.test.js +318 -0
  193. package/paginator/types.d.ts +38 -0
  194. package/paginator/types.js +5 -0
  195. package/paragraph/Paragraph.d.ts +5 -0
  196. package/paragraph/Paragraph.js +38 -0
  197. package/paragraph/Paragraph.stories.tsx +44 -0
  198. package/password-input/PasswordInput.d.ts +4 -0
  199. package/password-input/PasswordInput.js +166 -0
  200. package/password-input/PasswordInput.stories.tsx +131 -0
  201. package/password-input/PasswordInput.test.js +181 -0
  202. package/password-input/types.d.ts +110 -0
  203. package/password-input/types.js +5 -0
  204. package/progress-bar/ProgressBar.d.ts +4 -0
  205. package/progress-bar/ProgressBar.js +176 -0
  206. package/progress-bar/ProgressBar.stories.jsx +93 -0
  207. package/progress-bar/ProgressBar.test.js +110 -0
  208. package/progress-bar/types.d.ts +37 -0
  209. package/progress-bar/types.js +5 -0
  210. package/quick-nav/QuickNav.d.ts +4 -0
  211. package/quick-nav/QuickNav.js +117 -0
  212. package/quick-nav/QuickNav.stories.tsx +356 -0
  213. package/quick-nav/types.d.ts +21 -0
  214. package/quick-nav/types.js +5 -0
  215. package/radio-group/Radio.d.ts +4 -0
  216. package/radio-group/Radio.js +156 -0
  217. package/radio-group/RadioGroup.d.ts +4 -0
  218. package/radio-group/RadioGroup.js +281 -0
  219. package/radio-group/RadioGroup.stories.tsx +214 -0
  220. package/radio-group/RadioGroup.test.js +722 -0
  221. package/radio-group/types.d.ts +114 -0
  222. package/radio-group/types.js +5 -0
  223. package/resultsetTable/Icons.d.ts +7 -0
  224. package/resultsetTable/Icons.js +51 -0
  225. package/resultsetTable/ResultsetTable.d.ts +4 -0
  226. package/resultsetTable/ResultsetTable.js +195 -0
  227. package/resultsetTable/ResultsetTable.stories.tsx +300 -0
  228. package/resultsetTable/ResultsetTable.test.js +325 -0
  229. package/resultsetTable/types.d.ts +67 -0
  230. package/resultsetTable/types.js +5 -0
  231. package/select/Icons.d.ts +10 -0
  232. package/select/Icons.js +93 -0
  233. package/select/Listbox.d.ts +4 -0
  234. package/select/Listbox.js +169 -0
  235. package/select/Option.d.ts +4 -0
  236. package/select/Option.js +97 -0
  237. package/select/Select.d.ts +4 -0
  238. package/select/Select.js +666 -0
  239. package/select/Select.stories.tsx +971 -0
  240. package/select/Select.test.js +2228 -0
  241. package/select/types.d.ts +210 -0
  242. package/select/types.js +5 -0
  243. package/sidenav/Icons.d.ts +7 -0
  244. package/sidenav/Icons.js +51 -0
  245. package/sidenav/Sidenav.d.ts +10 -0
  246. package/sidenav/Sidenav.js +238 -0
  247. package/sidenav/Sidenav.stories.tsx +282 -0
  248. package/sidenav/Sidenav.test.js +44 -0
  249. package/sidenav/types.d.ts +76 -0
  250. package/sidenav/types.js +5 -0
  251. package/slider/Slider.d.ts +4 -0
  252. package/slider/Slider.js +342 -0
  253. package/slider/Slider.stories.tsx +240 -0
  254. package/slider/Slider.test.js +250 -0
  255. package/slider/types.d.ts +86 -0
  256. package/slider/types.js +5 -0
  257. package/spinner/Spinner.d.ts +4 -0
  258. package/spinner/Spinner.js +244 -0
  259. package/spinner/Spinner.stories.jsx +129 -0
  260. package/spinner/Spinner.test.js +64 -0
  261. package/spinner/types.d.ts +32 -0
  262. package/spinner/types.js +5 -0
  263. package/switch/Switch.d.ts +4 -0
  264. package/switch/Switch.js +262 -0
  265. package/switch/Switch.stories.tsx +171 -0
  266. package/switch/Switch.test.js +225 -0
  267. package/switch/types.d.ts +66 -0
  268. package/switch/types.js +5 -0
  269. package/table/Table.d.ts +4 -0
  270. package/table/Table.js +118 -0
  271. package/table/Table.stories.jsx +356 -0
  272. package/table/Table.test.js +26 -0
  273. package/table/types.d.ts +21 -0
  274. package/table/types.js +5 -0
  275. package/tabs/Tab.d.ts +4 -0
  276. package/tabs/Tab.js +132 -0
  277. package/tabs/Tabs.d.ts +4 -0
  278. package/tabs/Tabs.js +461 -0
  279. package/tabs/Tabs.stories.tsx +226 -0
  280. package/tabs/Tabs.test.js +350 -0
  281. package/tabs/types.d.ts +92 -0
  282. package/tabs/types.js +5 -0
  283. package/tag/Tag.d.ts +4 -0
  284. package/tag/Tag.js +181 -0
  285. package/tag/Tag.stories.tsx +155 -0
  286. package/tag/Tag.test.js +60 -0
  287. package/tag/types.d.ts +69 -0
  288. package/tag/types.js +5 -0
  289. package/text-input/Icons.d.ts +8 -0
  290. package/text-input/Icons.js +60 -0
  291. package/text-input/Suggestion.d.ts +4 -0
  292. package/text-input/Suggestion.js +84 -0
  293. package/text-input/Suggestions.d.ts +4 -0
  294. package/text-input/Suggestions.js +134 -0
  295. package/text-input/TextInput.d.ts +4 -0
  296. package/text-input/TextInput.js +673 -0
  297. package/text-input/TextInput.stories.tsx +569 -0
  298. package/text-input/TextInput.test.js +1723 -0
  299. package/text-input/types.d.ts +197 -0
  300. package/text-input/types.js +5 -0
  301. package/textarea/Textarea.d.ts +4 -0
  302. package/textarea/Textarea.js +276 -0
  303. package/textarea/Textarea.stories.jsx +216 -0
  304. package/textarea/Textarea.test.js +435 -0
  305. package/textarea/types.d.ts +137 -0
  306. package/textarea/types.js +5 -0
  307. package/toggle-group/ToggleGroup.d.ts +4 -0
  308. package/toggle-group/ToggleGroup.js +218 -0
  309. package/toggle-group/ToggleGroup.stories.tsx +215 -0
  310. package/toggle-group/ToggleGroup.test.js +156 -0
  311. package/toggle-group/types.d.ts +105 -0
  312. package/toggle-group/types.js +5 -0
  313. package/typography/Typography.d.ts +4 -0
  314. package/typography/Typography.js +32 -0
  315. package/typography/Typography.stories.tsx +198 -0
  316. package/typography/types.d.ts +18 -0
  317. package/typography/types.js +5 -0
  318. package/useTheme.d.ts +1235 -0
  319. package/useTheme.js +22 -0
  320. package/useTranslatedLabels.d.ts +85 -0
  321. package/useTranslatedLabels.js +20 -0
  322. package/utils/BaseTypography.d.ts +21 -0
  323. package/utils/BaseTypography.js +108 -0
  324. package/utils/FocusLock.d.ts +13 -0
  325. package/utils/FocusLock.js +138 -0
  326. package/wizard/Wizard.d.ts +4 -0
  327. package/wizard/Wizard.js +285 -0
  328. package/wizard/Wizard.stories.tsx +253 -0
  329. package/wizard/Wizard.test.js +141 -0
  330. package/wizard/types.d.ts +64 -0
  331. package/wizard/types.js +5 -0
  332. package/README.md +0 -66
  333. package/babel.config.js +0 -4
  334. package/dist/accordion/Accordion.js +0 -268
  335. package/dist/accordion/Accordion.stories.js +0 -207
  336. package/dist/accordion/readme.md +0 -96
  337. package/dist/alert/Alert.js +0 -304
  338. package/dist/alert/Alert.stories.js +0 -158
  339. package/dist/alert/close.svg +0 -4
  340. package/dist/alert/error.svg +0 -4
  341. package/dist/alert/info.svg +0 -4
  342. package/dist/alert/readme.md +0 -43
  343. package/dist/alert/success.svg +0 -4
  344. package/dist/alert/warning.svg +0 -4
  345. package/dist/box/Box.js +0 -148
  346. package/dist/button/Button.js +0 -202
  347. package/dist/button/Button.stories.js +0 -224
  348. package/dist/button/readme.md +0 -93
  349. package/dist/card/Card.js +0 -217
  350. package/dist/checkbox/Checkbox.js +0 -240
  351. package/dist/checkbox/Checkbox.stories.js +0 -144
  352. package/dist/checkbox/readme.md +0 -116
  353. package/dist/chip/Chip.js +0 -208
  354. package/dist/common/OpenSans.css +0 -81
  355. package/dist/common/RequiredComponent.js +0 -46
  356. package/dist/common/services/example-service.js +0 -10
  357. package/dist/common/services/example-service.test.js +0 -12
  358. package/dist/common/utils.js +0 -42
  359. package/dist/common/variables.js +0 -434
  360. package/dist/date/Date.js +0 -356
  361. package/dist/date/Date.stories.js +0 -205
  362. package/dist/date/calendar.svg +0 -1
  363. package/dist/date/calendar_dark.svg +0 -1
  364. package/dist/date/readme.md +0 -73
  365. package/dist/dialog/Dialog.js +0 -197
  366. package/dist/dialog/Dialog.stories.js +0 -217
  367. package/dist/dialog/readme.md +0 -32
  368. package/dist/dropdown/Dropdown.js +0 -449
  369. package/dist/dropdown/Dropdown.stories.js +0 -249
  370. package/dist/dropdown/baseline-arrow_drop_down.svg +0 -1
  371. package/dist/dropdown/baseline-arrow_drop_down_wh.svg +0 -4
  372. package/dist/dropdown/baseline-arrow_drop_up.svg +0 -1
  373. package/dist/dropdown/baseline-arrow_drop_up_wh.svg +0 -4
  374. package/dist/dropdown/readme.md +0 -69
  375. package/dist/footer/Footer.js +0 -371
  376. package/dist/footer/Footer.stories.js +0 -94
  377. package/dist/footer/dxc_logo_wht.png +0 -0
  378. package/dist/footer/readme.md +0 -41
  379. package/dist/header/Header.js +0 -373
  380. package/dist/header/Header.stories.js +0 -176
  381. package/dist/header/close_icon.svg +0 -1
  382. package/dist/header/dxc_logo_black.png +0 -0
  383. package/dist/header/dxc_logo_blk_rgb.svg +0 -6
  384. package/dist/header/dxc_logo_white.png +0 -0
  385. package/dist/header/hamb_menu_black.svg +0 -1
  386. package/dist/header/hamb_menu_white.svg +0 -1
  387. package/dist/header/readme.md +0 -33
  388. package/dist/heading/Heading.js +0 -153
  389. package/dist/input-text/InputText.js +0 -570
  390. package/dist/input-text/InputText.stories.js +0 -209
  391. package/dist/input-text/error.svg +0 -1
  392. package/dist/input-text/readme.md +0 -91
  393. package/dist/layout/ApplicationLayout.js +0 -335
  394. package/dist/layout/facebook.svg +0 -45
  395. package/dist/layout/linkedin.svg +0 -50
  396. package/dist/layout/twitter.svg +0 -53
  397. package/dist/link/Link.js +0 -189
  398. package/dist/link/readme.md +0 -51
  399. package/dist/paginator/Paginator.js +0 -196
  400. package/dist/paginator/images/next.svg +0 -3
  401. package/dist/paginator/images/nextPage.svg +0 -3
  402. package/dist/paginator/images/previous.svg +0 -3
  403. package/dist/paginator/images/previousPage.svg +0 -3
  404. package/dist/paginator/readme.md +0 -50
  405. package/dist/progress-bar/ProgressBar.js +0 -185
  406. package/dist/progress-bar/ProgressBar.stories.js +0 -280
  407. package/dist/progress-bar/readme.md +0 -63
  408. package/dist/radio/Radio.js +0 -195
  409. package/dist/radio/Radio.stories.js +0 -166
  410. package/dist/radio/readme.md +0 -70
  411. package/dist/resultsetTable/ResultsetTable.js +0 -333
  412. package/dist/resultsetTable/arrow_downward-24px_wht.svg +0 -1
  413. package/dist/resultsetTable/arrow_upward-24px_wht.svg +0 -1
  414. package/dist/resultsetTable/unfold_more-24px_wht.svg +0 -1
  415. package/dist/select/Select.js +0 -473
  416. package/dist/select/Select.stories.js +0 -235
  417. package/dist/select/readme.md +0 -72
  418. package/dist/sidenav/Sidenav.js +0 -128
  419. package/dist/slider/Slider.js +0 -266
  420. package/dist/slider/Slider.stories.js +0 -241
  421. package/dist/slider/readme.md +0 -64
  422. package/dist/spinner/Spinner.js +0 -193
  423. package/dist/spinner/Spinner.stories.js +0 -183
  424. package/dist/spinner/readme.md +0 -65
  425. package/dist/switch/Switch.js +0 -199
  426. package/dist/switch/Switch.stories.js +0 -134
  427. package/dist/switch/readme.md +0 -133
  428. package/dist/table/Table.js +0 -105
  429. package/dist/tabs/Tabs.js +0 -172
  430. package/dist/tabs/Tabs.stories.js +0 -130
  431. package/dist/tabs/readme.md +0 -78
  432. package/dist/tabs-for-sections/TabsForSections.js +0 -92
  433. package/dist/tabs-for-sections/readme.md +0 -78
  434. package/dist/tag/Tag.js +0 -249
  435. package/dist/textarea/Textarea.js +0 -227
  436. package/dist/toggle/Toggle.js +0 -223
  437. package/dist/toggle/Toggle.stories.js +0 -297
  438. package/dist/toggle/readme.md +0 -80
  439. package/dist/toggle-group/ToggleGroup.js +0 -214
  440. package/dist/toggle-group/readme.md +0 -82
  441. package/dist/upload/Upload.js +0 -200
  442. package/dist/upload/Upload.stories.js +0 -72
  443. package/dist/upload/buttons-upload/ButtonsUpload.js +0 -122
  444. package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
  445. package/dist/upload/buttons-upload/upload-button.svg +0 -1
  446. package/dist/upload/dragAndDropArea/DragAndDropArea.js +0 -279
  447. package/dist/upload/dragAndDropArea/upload_drop.svg +0 -4
  448. package/dist/upload/dragAndDropArea/upload_file.svg +0 -4
  449. package/dist/upload/file-upload/FileToUpload.js +0 -158
  450. package/dist/upload/file-upload/audio-icon.svg +0 -4
  451. package/dist/upload/file-upload/close.svg +0 -4
  452. package/dist/upload/file-upload/file-icon.svg +0 -4
  453. package/dist/upload/file-upload/video-icon.svg +0 -4
  454. package/dist/upload/files-upload/FilesToUpload.js +0 -123
  455. package/dist/upload/readme.md +0 -37
  456. package/dist/upload/transaction/Transaction.js +0 -155
  457. package/dist/upload/transaction/audio-icon-err.svg +0 -4
  458. package/dist/upload/transaction/audio-icon.svg +0 -4
  459. package/dist/upload/transaction/error-icon.svg +0 -4
  460. package/dist/upload/transaction/file-icon-err.svg +0 -4
  461. package/dist/upload/transaction/file-icon.svg +0 -4
  462. package/dist/upload/transaction/image-icon-err.svg +0 -4
  463. package/dist/upload/transaction/image-icon.svg +0 -4
  464. package/dist/upload/transaction/success-icon.svg +0 -4
  465. package/dist/upload/transaction/video-icon-err.svg +0 -4
  466. package/dist/upload/transaction/video-icon.svg +0 -4
  467. package/dist/upload/transactions/Transactions.js +0 -120
  468. package/dist/wizard/Wizard.js +0 -327
  469. package/dist/wizard/invalid_icon.svg +0 -6
  470. package/dist/wizard/valid_icon.svg +0 -6
  471. package/dist/wizard/validation-wrong.svg +0 -6
  472. package/test/Accordion.test.js +0 -33
  473. package/test/Alert.test.js +0 -53
  474. package/test/Box.test.js +0 -10
  475. package/test/Button.test.js +0 -18
  476. package/test/Card.test.js +0 -30
  477. package/test/Checkbox.test.js +0 -45
  478. package/test/Chip.test.js +0 -25
  479. package/test/Date.test.js +0 -393
  480. package/test/Dialog.test.js +0 -23
  481. package/test/Dropdown.test.js +0 -130
  482. package/test/Footer.test.js +0 -99
  483. package/test/Header.test.js +0 -39
  484. package/test/Heading.test.js +0 -35
  485. package/test/InputText.test.js +0 -236
  486. package/test/Link.test.js +0 -33
  487. package/test/Paginator.test.js +0 -165
  488. package/test/ProgressBar.test.js +0 -35
  489. package/test/Radio.test.js +0 -37
  490. package/test/ResultsetTable.test.js +0 -282
  491. package/test/Select.test.js +0 -191
  492. package/test/Sidenav.test.js +0 -45
  493. package/test/Slider.test.js +0 -82
  494. package/test/Spinner.test.js +0 -27
  495. package/test/Switch.test.js +0 -45
  496. package/test/Table.test.js +0 -36
  497. package/test/Tabs.test.js +0 -88
  498. package/test/TabsForSections.test.js +0 -34
  499. package/test/Tag.test.js +0 -32
  500. package/test/TextArea.test.js +0 -52
  501. package/test/Toggle.test.js +0 -43
  502. package/test/ToggleGroup.test.js +0 -81
  503. package/test/Upload.test.js +0 -60
  504. package/test/Wizard.test.js +0 -130
  505. package/test/mocks/pngMock.js +0 -1
  506. package/test/mocks/svgMock.js +0 -1
  507. /package/{dist/common → common}/fonts/OpenSans-Bold.ttf +0 -0
  508. /package/{dist/common → common}/fonts/OpenSans-BoldItalic.ttf +0 -0
  509. /package/{dist/common → common}/fonts/OpenSans-ExtraBold.ttf +0 -0
  510. /package/{dist/common → common}/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  511. /package/{dist/common → common}/fonts/OpenSans-Italic.ttf +0 -0
  512. /package/{dist/common → common}/fonts/OpenSans-Light.ttf +0 -0
  513. /package/{dist/common → common}/fonts/OpenSans-LightItalic.ttf +0 -0
  514. /package/{dist/common → common}/fonts/OpenSans-Regular.ttf +0 -0
  515. /package/{dist/common → common}/fonts/OpenSans-SemiBold.ttf +0 -0
  516. /package/{dist/common → common}/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
@@ -0,0 +1,438 @@
1
+ import React from "react";
2
+ import { userEvent, within } from "@storybook/testing-library";
3
+ import DxcDropdown from "./Dropdown";
4
+ import Title from "../../.storybook/components/Title";
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";
12
+
13
+ export default {
14
+ title: "Dropdown",
15
+ component: DxcDropdown,
16
+ };
17
+
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];
36
+
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[] = [
72
+ {
73
+ value: "1",
74
+ label: "Amazon with a very long text",
75
+ },
76
+ {
77
+ value: "2",
78
+ label: "Ebay",
79
+ },
80
+ {
81
+ value: "3",
82
+ label: "Apple",
83
+ },
84
+ ];
85
+ const optionWithIcon: Option[] = [
86
+ {
87
+ value: "1",
88
+ label: "Ebay",
89
+ icon: iconUrl,
90
+ },
91
+ ];
92
+
93
+ const optionsIcon: any = options.map((op, i) => ({ ...op, icon: icons[i] }));
94
+
95
+ const opinionatedTheme = {
96
+ dropdown: {
97
+ baseColor: "#ffffff",
98
+ fontColor: "#000000",
99
+ optionFontColor: "#000000",
100
+ },
101
+ };
102
+
103
+ const Dropdown = () => (
104
+ <>
105
+ <ExampleContainer>
106
+ <Title title="Default" theme="light" level={4} />
107
+ <DxcDropdown label="Default" options={options} onSelectOption={(value) => {}} />
108
+ </ExampleContainer>
109
+ <ExampleContainer pseudoState="pseudo-hover">
110
+ <Title title="Hovered" theme="light" level={4} />
111
+ <DxcDropdown label="Hovered" options={options} onSelectOption={(value) => {}} />
112
+ </ExampleContainer>
113
+ <ExampleContainer pseudoState="pseudo-focus">
114
+ <Title title="Focused" theme="light" level={4} />
115
+ <DxcDropdown label="Focused" options={options} onSelectOption={(value) => {}} />
116
+ </ExampleContainer>
117
+ <ExampleContainer pseudoState="pseudo-active">
118
+ <Title title="Actived" theme="light" level={4} />
119
+ <DxcDropdown label="Actived" options={options} onSelectOption={(value) => {}} />
120
+ </ExampleContainer>
121
+ <ExampleContainer>
122
+ <Title title="Disabled" theme="light" level={4} />
123
+ <DxcDropdown label="Disabled" options={options} onSelectOption={(value) => {}} disabled />
124
+ </ExampleContainer>
125
+ <ExampleContainer>
126
+ <Title title="Caret hidden" theme="light" level={4} />
127
+ <DxcDropdown label="Caret hidden" options={options} onSelectOption={(value) => {}} caretHidden />
128
+ </ExampleContainer>
129
+ <ExampleContainer>
130
+ <Title title="With icon before" theme="light" level={4} />
131
+ <DxcDropdown label="Icon before" options={options} onSelectOption={(value) => {}} icon={iconSVG} />
132
+ </ExampleContainer>
133
+ <ExampleContainer>
134
+ <Title title="With icon after" theme="light" level={4} />
135
+ <DxcDropdown
136
+ label="Icon after"
137
+ options={options}
138
+ onSelectOption={(value) => {}}
139
+ icon="https://iconape.com/wp-content/files/yd/367773/svg/logo-linkedin-logo-icon-png-svg.png"
140
+ iconPosition="after"
141
+ />
142
+ </ExampleContainer>
143
+ <ExampleContainer>
144
+ <Title title="Only icon" theme="light" level={4} />
145
+ <DxcDropdown options={options} onSelectOption={(value) => {}} icon={iconSVG} />
146
+ </ExampleContainer>
147
+ <ExampleContainer>
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} />
153
+ <DxcDropdown label="Large icon" options={options} onSelectOption={(value) => {}} icon={iconSVGLarge} />
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>
164
+ <ExampleContainer>
165
+ <Title title="Disabled with icon" theme="light" level={4} />
166
+ <DxcDropdown
167
+ label="Disabled with icon"
168
+ options={options}
169
+ onSelectOption={(value) => {}}
170
+ icon={iconSVG}
171
+ disabled
172
+ />
173
+ </ExampleContainer>
174
+ <ExampleContainer>
175
+ <Title title="Ellipsis" theme="light" level={4} />
176
+ <DxcDropdown
177
+ label="Very long text in dropdown button"
178
+ options={options}
179
+ onSelectOption={(value) => {}}
180
+ icon={iconSVG}
181
+ size="medium"
182
+ />
183
+ </ExampleContainer>
184
+ <Title title="Margins" theme="light" level={2} />
185
+ <ExampleContainer>
186
+ <Title title="Xxsmall" theme="light" level={4} />
187
+ <DxcDropdown label="Xxsmall" options={options} onSelectOption={(value) => {}} icon={iconSVG} margin="xxsmall" />
188
+ </ExampleContainer>
189
+ <ExampleContainer>
190
+ <Title title="Xsmall" theme="light" level={4} />
191
+ <DxcDropdown label="Xsmall" options={options} onSelectOption={(value) => {}} icon={iconSVG} margin="xsmall" />
192
+ </ExampleContainer>
193
+ <ExampleContainer>
194
+ <Title title="Small" theme="light" level={4} />
195
+ <DxcDropdown label="Small" options={options} onSelectOption={(value) => {}} icon={iconSVG} margin="small" />
196
+ </ExampleContainer>
197
+ <ExampleContainer>
198
+ <Title title="Medium" theme="light" level={4} />
199
+ <DxcDropdown label="Medium" options={options} onSelectOption={(value) => {}} icon={iconSVG} margin="medium" />
200
+ </ExampleContainer>
201
+ <ExampleContainer>
202
+ <Title title="Large" theme="light" level={4} />
203
+ <DxcDropdown label="Large" options={options} onSelectOption={(value) => {}} icon={iconSVG} margin="large" />
204
+ </ExampleContainer>
205
+ <ExampleContainer>
206
+ <Title title="Xlarge" theme="light" level={4} />
207
+ <DxcDropdown label="Xlarge" options={options} onSelectOption={(value) => {}} icon={iconSVG} margin="xlarge" />
208
+ </ExampleContainer>
209
+ <ExampleContainer>
210
+ <Title title="Xxlarge" theme="light" level={4} />
211
+ <DxcDropdown label="Xxlarge" options={options} onSelectOption={(value) => {}} icon={iconSVG} margin="xxlarge" />
212
+ </ExampleContainer>
213
+ <Title title="Sizes" theme="light" level={2} />
214
+ <ExampleContainer>
215
+ <Title title="Small" theme="light" level={4} />
216
+ <DxcDropdown label="Small" options={options} onSelectOption={(value) => {}} icon={iconSVG} size="small" />
217
+ </ExampleContainer>
218
+ <ExampleContainer>
219
+ <Title title="Medium" theme="light" level={4} />
220
+ <DxcDropdown label="Medium" options={options} onSelectOption={(value) => {}} icon={iconSVG} size="medium" />
221
+ </ExampleContainer>
222
+ <ExampleContainer>
223
+ <Title title="Large" theme="light" level={4} />
224
+ <DxcDropdown label="Large" options={options} onSelectOption={(value) => {}} icon={iconSVG} size="large" />
225
+ </ExampleContainer>
226
+ <ExampleContainer>
227
+ <Title title="FitContent" theme="light" level={4} />
228
+ <DxcDropdown
229
+ label="FitContent"
230
+ options={options}
231
+ onSelectOption={(value) => {}}
232
+ icon={iconSVG}
233
+ size="fitContent"
234
+ />
235
+ </ExampleContainer>
236
+ <ExampleContainer>
237
+ <Title title="FillParent" theme="light" level={4} />
238
+ <DxcDropdown
239
+ label="FillParent"
240
+ options={options}
241
+ onSelectOption={(value) => {}}
242
+ icon={iconSVG}
243
+ size="fillParent"
244
+ />
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>
250
+ </>
251
+ );
252
+
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 = () => (
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 }) => {
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 }) => {
436
+ const canvas = within(canvasElement);
437
+ await userEvent.click(canvas.getByRole("button"));
438
+ };