@dxc-technology/halstack-react 0.0.0-d30020b → 0.0.0-d3624d0

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 (443) hide show
  1. package/BackgroundColorContext.d.ts +1 -10
  2. package/BackgroundColorContext.js +5 -22
  3. package/HalstackContext.d.ts +1246 -0
  4. package/HalstackContext.js +310 -0
  5. package/README.md +47 -0
  6. package/accordion/Accordion.accessibility.test.js +71 -0
  7. package/accordion/Accordion.d.ts +1 -1
  8. package/accordion/Accordion.js +105 -181
  9. package/accordion/Accordion.stories.tsx +83 -149
  10. package/accordion/Accordion.test.js +56 -0
  11. package/accordion/types.d.ts +10 -17
  12. package/accordion-group/AccordionGroup.accessibility.test.js +88 -0
  13. package/accordion-group/AccordionGroup.d.ts +3 -3
  14. package/accordion-group/AccordionGroup.js +38 -107
  15. package/accordion-group/AccordionGroup.stories.tsx +95 -68
  16. package/accordion-group/AccordionGroup.test.js +98 -0
  17. package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
  18. package/accordion-group/AccordionGroupAccordion.js +31 -0
  19. package/accordion-group/AccordionGroupContext.d.ts +3 -0
  20. package/accordion-group/AccordionGroupContext.js +8 -0
  21. package/accordion-group/types.d.ts +16 -17
  22. package/action-icon/ActionIcon.accessibility.test.js +63 -0
  23. package/action-icon/ActionIcon.d.ts +4 -0
  24. package/action-icon/ActionIcon.js +48 -0
  25. package/action-icon/ActionIcon.stories.tsx +41 -0
  26. package/action-icon/ActionIcon.test.js +64 -0
  27. package/action-icon/types.d.ts +26 -0
  28. package/alert/Alert.accessibility.test.js +95 -0
  29. package/alert/Alert.js +40 -127
  30. package/alert/Alert.stories.tsx +28 -0
  31. package/alert/Alert.test.js +75 -0
  32. package/alert/types.d.ts +5 -5
  33. package/badge/Badge.accessibility.test.js +129 -0
  34. package/badge/Badge.d.ts +4 -0
  35. package/badge/Badge.js +142 -40
  36. package/badge/Badge.stories.tsx +210 -0
  37. package/badge/Badge.test.js +30 -0
  38. package/badge/types.d.ts +54 -0
  39. package/bleed/Bleed.js +14 -55
  40. package/bleed/Bleed.stories.tsx +95 -95
  41. package/bleed/types.d.ts +26 -2
  42. package/box/Box.accessibility.test.js +33 -0
  43. package/box/Box.d.ts +1 -1
  44. package/box/Box.js +30 -81
  45. package/box/Box.stories.tsx +38 -51
  46. package/box/Box.test.js +13 -0
  47. package/box/types.d.ts +3 -14
  48. package/breadcrumbs/Breadcrumbs.accessibility.test.d.ts +1 -0
  49. package/breadcrumbs/Breadcrumbs.accessibility.test.js +96 -0
  50. package/breadcrumbs/Breadcrumbs.d.ts +4 -0
  51. package/breadcrumbs/Breadcrumbs.js +79 -0
  52. package/breadcrumbs/Breadcrumbs.stories.tsx +194 -0
  53. package/breadcrumbs/Breadcrumbs.test.d.ts +1 -0
  54. package/breadcrumbs/Breadcrumbs.test.js +169 -0
  55. package/breadcrumbs/Item.d.ts +4 -0
  56. package/breadcrumbs/Item.js +52 -0
  57. package/breadcrumbs/dropdownTheme.d.ts +53 -0
  58. package/breadcrumbs/dropdownTheme.js +62 -0
  59. package/breadcrumbs/types.d.ts +16 -0
  60. package/bulleted-list/BulletedList.accessibility.test.js +119 -0
  61. package/bulleted-list/BulletedList.d.ts +7 -0
  62. package/bulleted-list/BulletedList.js +92 -0
  63. package/bulleted-list/BulletedList.stories.tsx +115 -0
  64. package/bulleted-list/types.d.ts +38 -0
  65. package/button/Button.accessibility.test.js +127 -0
  66. package/button/Button.d.ts +1 -1
  67. package/button/Button.js +63 -113
  68. package/button/Button.stories.tsx +151 -100
  69. package/button/Button.test.js +38 -0
  70. package/button/types.d.ts +12 -8
  71. package/card/Card.accessibility.test.js +36 -0
  72. package/card/Card.d.ts +1 -1
  73. package/card/Card.js +59 -102
  74. package/card/Card.stories.tsx +12 -42
  75. package/card/Card.test.js +39 -0
  76. package/card/types.d.ts +6 -11
  77. package/checkbox/Checkbox.accessibility.test.js +87 -0
  78. package/checkbox/Checkbox.d.ts +2 -2
  79. package/checkbox/Checkbox.js +143 -181
  80. package/checkbox/Checkbox.stories.tsx +166 -136
  81. package/checkbox/Checkbox.test.js +199 -0
  82. package/checkbox/types.d.ts +18 -6
  83. package/chip/Chip.accessibility.test.js +67 -0
  84. package/chip/Chip.js +45 -80
  85. package/chip/Chip.stories.tsx +107 -27
  86. package/chip/Chip.test.js +41 -0
  87. package/chip/types.d.ts +4 -4
  88. package/common/coreTokens.d.ts +237 -0
  89. package/common/coreTokens.js +184 -0
  90. package/common/utils.d.ts +1 -0
  91. package/common/utils.js +6 -12
  92. package/common/variables.d.ts +1392 -0
  93. package/common/variables.js +1080 -1427
  94. package/container/Container.d.ts +4 -0
  95. package/container/Container.js +194 -0
  96. package/container/Container.stories.tsx +214 -0
  97. package/container/types.d.ts +74 -0
  98. package/contextual-menu/ContextualMenu.accessibility.test.js +97 -0
  99. package/contextual-menu/ContextualMenu.d.ts +5 -0
  100. package/contextual-menu/ContextualMenu.js +88 -0
  101. package/contextual-menu/ContextualMenu.stories.tsx +232 -0
  102. package/contextual-menu/ContextualMenu.test.js +205 -0
  103. package/contextual-menu/GroupItem.d.ts +4 -0
  104. package/contextual-menu/GroupItem.js +67 -0
  105. package/contextual-menu/ItemAction.d.ts +4 -0
  106. package/contextual-menu/ItemAction.js +51 -0
  107. package/contextual-menu/MenuItem.d.ts +4 -0
  108. package/contextual-menu/MenuItem.js +29 -0
  109. package/contextual-menu/SingleItem.d.ts +4 -0
  110. package/contextual-menu/SingleItem.js +38 -0
  111. package/contextual-menu/types.d.ts +58 -0
  112. package/date-input/Calendar.d.ts +4 -0
  113. package/date-input/Calendar.js +214 -0
  114. package/date-input/DateInput.accessibility.test.js +228 -0
  115. package/date-input/DateInput.js +170 -306
  116. package/date-input/DateInput.stories.tsx +210 -56
  117. package/date-input/DateInput.test.js +808 -0
  118. package/date-input/DatePicker.d.ts +4 -0
  119. package/date-input/DatePicker.js +121 -0
  120. package/date-input/YearPicker.d.ts +4 -0
  121. package/date-input/YearPicker.js +100 -0
  122. package/date-input/types.d.ts +86 -22
  123. package/dialog/Dialog.accessibility.test.js +69 -0
  124. package/dialog/Dialog.d.ts +1 -1
  125. package/dialog/Dialog.js +56 -129
  126. package/dialog/Dialog.stories.tsx +326 -167
  127. package/dialog/Dialog.test.js +307 -0
  128. package/dialog/types.d.ts +18 -25
  129. package/divider/Divider.accessibility.test.js +33 -0
  130. package/divider/Divider.d.ts +4 -0
  131. package/divider/Divider.js +36 -0
  132. package/divider/Divider.stories.tsx +223 -0
  133. package/divider/Divider.test.js +38 -0
  134. package/divider/types.d.ts +21 -0
  135. package/divider/types.js +5 -0
  136. package/dropdown/Dropdown.accessibility.test.js +180 -0
  137. package/dropdown/Dropdown.d.ts +1 -1
  138. package/dropdown/Dropdown.js +233 -307
  139. package/dropdown/Dropdown.stories.tsx +235 -57
  140. package/dropdown/Dropdown.test.js +599 -0
  141. package/dropdown/DropdownMenu.d.ts +4 -0
  142. package/dropdown/DropdownMenu.js +63 -0
  143. package/dropdown/DropdownMenuItem.d.ts +4 -0
  144. package/dropdown/DropdownMenuItem.js +71 -0
  145. package/dropdown/types.d.ts +35 -19
  146. package/file-input/FileInput.accessibility.test.js +160 -0
  147. package/file-input/FileInput.d.ts +2 -2
  148. package/file-input/FileInput.js +246 -393
  149. package/file-input/FileInput.stories.tsx +123 -12
  150. package/file-input/FileInput.test.js +382 -0
  151. package/file-input/FileItem.d.ts +4 -14
  152. package/file-input/FileItem.js +61 -120
  153. package/file-input/types.d.ts +25 -8
  154. package/flex/Flex.d.ts +4 -0
  155. package/flex/Flex.js +57 -0
  156. package/flex/Flex.stories.tsx +112 -0
  157. package/flex/types.d.ts +97 -0
  158. package/flex/types.js +5 -0
  159. package/footer/Footer.accessibility.test.js +125 -0
  160. package/footer/Footer.d.ts +1 -1
  161. package/footer/Footer.js +73 -191
  162. package/footer/Footer.stories.tsx +99 -21
  163. package/footer/Footer.test.js +85 -0
  164. package/footer/Icons.d.ts +3 -2
  165. package/footer/Icons.js +54 -23
  166. package/footer/types.d.ts +26 -27
  167. package/grid/Grid.d.ts +7 -0
  168. package/grid/Grid.js +76 -0
  169. package/grid/Grid.stories.tsx +219 -0
  170. package/grid/types.d.ts +115 -0
  171. package/grid/types.js +5 -0
  172. package/header/Header.accessibility.test.js +93 -0
  173. package/header/Header.d.ts +4 -3
  174. package/header/Header.js +104 -218
  175. package/header/Header.stories.tsx +168 -63
  176. package/header/Header.test.js +66 -0
  177. package/header/Icons.d.ts +2 -2
  178. package/header/Icons.js +5 -15
  179. package/header/types.d.ts +7 -21
  180. package/heading/Heading.accessibility.test.js +33 -0
  181. package/heading/Heading.js +10 -32
  182. package/heading/Heading.test.js +169 -0
  183. package/heading/types.d.ts +7 -7
  184. package/icon/Icon.accessibility.test.js +30 -0
  185. package/icon/Icon.d.ts +4 -0
  186. package/icon/Icon.js +33 -0
  187. package/icon/Icon.stories.tsx +28 -0
  188. package/icon/types.d.ts +4 -0
  189. package/icon/types.js +5 -0
  190. package/image/Image.accessibility.test.js +56 -0
  191. package/image/Image.d.ts +4 -0
  192. package/image/Image.js +70 -0
  193. package/image/Image.stories.tsx +129 -0
  194. package/image/types.d.ts +72 -0
  195. package/image/types.js +5 -0
  196. package/inset/Inset.js +14 -55
  197. package/inset/Inset.stories.tsx +37 -36
  198. package/inset/types.d.ts +26 -2
  199. package/layout/ApplicationLayout.d.ts +16 -6
  200. package/layout/ApplicationLayout.js +88 -182
  201. package/layout/ApplicationLayout.stories.tsx +85 -94
  202. package/layout/Icons.d.ts +7 -0
  203. package/layout/Icons.js +41 -48
  204. package/layout/types.d.ts +19 -35
  205. package/link/Link.accessibility.test.js +108 -0
  206. package/link/Link.d.ts +3 -2
  207. package/link/Link.js +65 -101
  208. package/link/Link.stories.tsx +157 -55
  209. package/link/Link.test.js +63 -0
  210. package/link/types.d.ts +15 -31
  211. package/main.d.ts +19 -18
  212. package/main.js +84 -123
  213. package/nav-tabs/NavTabs.accessibility.test.js +44 -0
  214. package/nav-tabs/NavTabs.d.ts +7 -0
  215. package/nav-tabs/NavTabs.js +93 -0
  216. package/nav-tabs/NavTabs.stories.tsx +279 -0
  217. package/nav-tabs/NavTabs.test.js +77 -0
  218. package/nav-tabs/NavTabsContext.d.ts +3 -0
  219. package/nav-tabs/NavTabsContext.js +8 -0
  220. package/nav-tabs/Tab.d.ts +4 -0
  221. package/nav-tabs/Tab.js +117 -0
  222. package/nav-tabs/types.d.ts +52 -0
  223. package/nav-tabs/types.js +5 -0
  224. package/number-input/NumberInput.accessibility.test.js +228 -0
  225. package/number-input/NumberInput.js +47 -44
  226. package/number-input/NumberInput.stories.tsx +44 -28
  227. package/number-input/NumberInput.test.js +989 -0
  228. package/number-input/NumberInputContext.d.ts +3 -4
  229. package/number-input/NumberInputContext.js +3 -14
  230. package/number-input/types.d.ts +34 -15
  231. package/package.json +54 -53
  232. package/paginator/Paginator.accessibility.test.js +79 -0
  233. package/paginator/Paginator.js +46 -100
  234. package/paginator/Paginator.stories.tsx +24 -0
  235. package/paginator/Paginator.test.js +335 -0
  236. package/paginator/types.d.ts +3 -3
  237. package/paragraph/Paragraph.accessibility.test.js +28 -0
  238. package/paragraph/Paragraph.d.ts +5 -0
  239. package/paragraph/Paragraph.js +22 -0
  240. package/paragraph/Paragraph.stories.tsx +27 -0
  241. package/password-input/PasswordInput.accessibility.test.js +153 -0
  242. package/password-input/PasswordInput.js +58 -124
  243. package/password-input/PasswordInput.stories.tsx +1 -33
  244. package/password-input/PasswordInput.test.js +198 -0
  245. package/password-input/types.d.ts +21 -17
  246. package/progress-bar/ProgressBar.accessibility.test.js +35 -0
  247. package/progress-bar/ProgressBar.js +68 -92
  248. package/progress-bar/ProgressBar.stories.tsx +93 -0
  249. package/progress-bar/ProgressBar.test.js +93 -0
  250. package/progress-bar/types.d.ts +3 -3
  251. package/quick-nav/QuickNav.accessibility.test.js +57 -0
  252. package/quick-nav/QuickNav.d.ts +4 -0
  253. package/quick-nav/QuickNav.js +94 -0
  254. package/quick-nav/QuickNav.stories.tsx +356 -0
  255. package/quick-nav/types.d.ts +21 -0
  256. package/quick-nav/types.js +5 -0
  257. package/radio-group/Radio.d.ts +1 -1
  258. package/radio-group/Radio.js +64 -80
  259. package/radio-group/RadioGroup.accessibility.test.js +97 -0
  260. package/radio-group/RadioGroup.js +102 -139
  261. package/radio-group/RadioGroup.stories.tsx +171 -36
  262. package/radio-group/RadioGroup.test.js +691 -183
  263. package/radio-group/types.d.ts +89 -11
  264. package/resultset-table/Icons.d.ts +7 -0
  265. package/resultset-table/Icons.js +47 -0
  266. package/resultset-table/ResultsetTable.accessibility.test.js +285 -0
  267. package/resultset-table/ResultsetTable.d.ts +7 -0
  268. package/resultset-table/ResultsetTable.js +171 -0
  269. package/{resultsetTable → resultset-table}/ResultsetTable.stories.tsx +168 -30
  270. package/resultset-table/ResultsetTable.test.js +381 -0
  271. package/{resultsetTable → resultset-table}/types.d.ts +44 -11
  272. package/resultset-table/types.js +5 -0
  273. package/select/Listbox.d.ts +4 -0
  274. package/select/Listbox.js +155 -0
  275. package/select/Option.d.ts +4 -0
  276. package/select/Option.js +89 -0
  277. package/select/Select.accessibility.test.js +228 -0
  278. package/select/Select.js +243 -504
  279. package/select/Select.stories.tsx +602 -255
  280. package/select/Select.test.js +2265 -0
  281. package/select/types.d.ts +65 -26
  282. package/sidenav/Sidenav.accessibility.test.js +59 -0
  283. package/sidenav/Sidenav.d.ts +6 -5
  284. package/sidenav/Sidenav.js +136 -71
  285. package/sidenav/Sidenav.stories.tsx +246 -151
  286. package/sidenav/Sidenav.test.js +37 -0
  287. package/sidenav/SidenavContext.d.ts +5 -0
  288. package/sidenav/SidenavContext.js +13 -0
  289. package/sidenav/types.d.ts +52 -26
  290. package/slider/Slider.accessibility.test.js +104 -0
  291. package/slider/Slider.d.ts +2 -2
  292. package/slider/Slider.js +149 -180
  293. package/slider/Slider.test.js +254 -0
  294. package/slider/types.d.ts +11 -3
  295. package/spinner/Spinner.accessibility.test.js +96 -0
  296. package/spinner/Spinner.js +34 -74
  297. package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +53 -27
  298. package/spinner/Spinner.test.js +55 -0
  299. package/spinner/types.d.ts +3 -3
  300. package/status-light/StatusLight.accessibility.test.js +157 -0
  301. package/status-light/StatusLight.d.ts +4 -0
  302. package/status-light/StatusLight.js +51 -0
  303. package/status-light/StatusLight.stories.tsx +74 -0
  304. package/status-light/StatusLight.test.js +25 -0
  305. package/status-light/types.d.ts +17 -0
  306. package/status-light/types.js +5 -0
  307. package/switch/Switch.accessibility.test.js +98 -0
  308. package/switch/Switch.d.ts +2 -2
  309. package/switch/Switch.js +149 -114
  310. package/switch/Switch.stories.tsx +56 -67
  311. package/switch/Switch.test.js +180 -0
  312. package/switch/types.d.ts +13 -5
  313. package/table/DropdownTheme.js +62 -0
  314. package/table/Table.accessibility.test.js +93 -0
  315. package/table/Table.d.ts +6 -2
  316. package/table/Table.js +78 -35
  317. package/table/Table.stories.tsx +663 -0
  318. package/table/Table.test.js +113 -0
  319. package/table/types.d.ts +34 -6
  320. package/tabs/Tab.d.ts +4 -0
  321. package/tabs/Tab.js +117 -0
  322. package/tabs/Tabs.accessibility.test.js +56 -0
  323. package/tabs/Tabs.d.ts +1 -1
  324. package/tabs/Tabs.js +305 -145
  325. package/tabs/Tabs.stories.tsx +124 -14
  326. package/tabs/Tabs.test.js +276 -0
  327. package/tabs/types.d.ts +31 -17
  328. package/tag/Tag.accessibility.test.js +69 -0
  329. package/tag/Tag.js +42 -79
  330. package/tag/Tag.stories.tsx +24 -10
  331. package/tag/Tag.test.js +41 -0
  332. package/tag/types.d.ts +9 -9
  333. package/text-input/Suggestion.d.ts +4 -0
  334. package/text-input/Suggestion.js +67 -0
  335. package/text-input/Suggestions.d.ts +4 -0
  336. package/text-input/Suggestions.js +94 -0
  337. package/text-input/TextInput.accessibility.test.js +321 -0
  338. package/text-input/TextInput.js +334 -557
  339. package/text-input/TextInput.stories.tsx +291 -273
  340. package/text-input/TextInput.test.js +1756 -0
  341. package/text-input/types.d.ts +70 -24
  342. package/textarea/Textarea.accessibility.test.js +155 -0
  343. package/textarea/Textarea.js +86 -135
  344. package/textarea/Textarea.stories.tsx +174 -0
  345. package/textarea/Textarea.test.js +406 -0
  346. package/textarea/types.d.ts +27 -16
  347. package/toggle-group/ToggleGroup.accessibility.test.js +107 -0
  348. package/toggle-group/ToggleGroup.d.ts +2 -2
  349. package/toggle-group/ToggleGroup.js +94 -106
  350. package/toggle-group/ToggleGroup.stories.tsx +56 -11
  351. package/toggle-group/ToggleGroup.test.js +137 -0
  352. package/toggle-group/types.d.ts +36 -19
  353. package/typography/Typography.accessibility.test.js +339 -0
  354. package/typography/Typography.d.ts +4 -0
  355. package/typography/Typography.js +23 -0
  356. package/typography/Typography.stories.tsx +198 -0
  357. package/typography/types.d.ts +18 -0
  358. package/typography/types.js +5 -0
  359. package/useTheme.d.ts +1144 -1
  360. package/useTheme.js +4 -11
  361. package/useTranslatedLabels.d.ts +85 -0
  362. package/useTranslatedLabels.js +14 -0
  363. package/utils/BaseTypography.d.ts +21 -0
  364. package/utils/BaseTypography.js +94 -0
  365. package/utils/FocusLock.d.ts +13 -0
  366. package/utils/FocusLock.js +124 -0
  367. package/wizard/Wizard.accessibility.test.js +55 -0
  368. package/wizard/Wizard.d.ts +1 -1
  369. package/wizard/Wizard.js +78 -120
  370. package/wizard/Wizard.stories.tsx +67 -19
  371. package/wizard/Wizard.test.js +114 -0
  372. package/wizard/types.d.ts +14 -10
  373. package/ThemeContext.d.ts +0 -15
  374. package/ThemeContext.js +0 -243
  375. package/V3Select/V3Select.js +0 -455
  376. package/V3Select/index.d.ts +0 -27
  377. package/V3Textarea/V3Textarea.js +0 -260
  378. package/V3Textarea/index.d.ts +0 -27
  379. package/card/ice-cream.jpg +0 -0
  380. package/common/OpenSans.css +0 -81
  381. package/common/RequiredComponent.js +0 -32
  382. package/common/fonts/OpenSans-Bold.ttf +0 -0
  383. package/common/fonts/OpenSans-BoldItalic.ttf +0 -0
  384. package/common/fonts/OpenSans-ExtraBold.ttf +0 -0
  385. package/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  386. package/common/fonts/OpenSans-Italic.ttf +0 -0
  387. package/common/fonts/OpenSans-Light.ttf +0 -0
  388. package/common/fonts/OpenSans-LightItalic.ttf +0 -0
  389. package/common/fonts/OpenSans-Regular.ttf +0 -0
  390. package/common/fonts/OpenSans-SemiBold.ttf +0 -0
  391. package/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  392. package/date/Date.js +0 -373
  393. package/date/index.d.ts +0 -27
  394. package/input-text/Icons.js +0 -22
  395. package/input-text/InputText.js +0 -611
  396. package/input-text/index.d.ts +0 -36
  397. package/list/List.d.ts +0 -4
  398. package/list/List.js +0 -47
  399. package/list/List.stories.tsx +0 -95
  400. package/list/types.d.ts +0 -7
  401. package/number-input/numberInputContextTypes.d.ts +0 -19
  402. package/paginator/Icons.js +0 -66
  403. package/progress-bar/ProgressBar.stories.jsx +0 -58
  404. package/radio/Radio.d.ts +0 -4
  405. package/radio/Radio.js +0 -174
  406. package/radio/Radio.stories.tsx +0 -192
  407. package/radio/types.d.ts +0 -54
  408. package/resultsetTable/ResultsetTable.d.ts +0 -4
  409. package/resultsetTable/ResultsetTable.js +0 -254
  410. package/row/Row.d.ts +0 -3
  411. package/row/Row.js +0 -127
  412. package/row/Row.stories.tsx +0 -237
  413. package/row/types.d.ts +0 -10
  414. package/slider/Slider.stories.tsx +0 -177
  415. package/stack/Stack.d.ts +0 -3
  416. package/stack/Stack.js +0 -97
  417. package/stack/Stack.stories.tsx +0 -164
  418. package/stack/types.d.ts +0 -9
  419. package/table/Table.stories.jsx +0 -277
  420. package/text/Text.d.ts +0 -7
  421. package/text/Text.js +0 -30
  422. package/text/Text.stories.tsx +0 -19
  423. package/textarea/Textarea.stories.jsx +0 -136
  424. package/toggle/Toggle.js +0 -186
  425. package/toggle/index.d.ts +0 -21
  426. package/upload/Upload.js +0 -201
  427. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  428. package/upload/buttons-upload/Icons.js +0 -40
  429. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  430. package/upload/dragAndDropArea/Icons.js +0 -39
  431. package/upload/file-upload/FileToUpload.js +0 -115
  432. package/upload/file-upload/Icons.js +0 -66
  433. package/upload/files-upload/FilesToUpload.js +0 -109
  434. package/upload/index.d.ts +0 -15
  435. package/upload/transaction/Icons.js +0 -160
  436. package/upload/transaction/Transaction.js +0 -104
  437. package/upload/transactions/Transactions.js +0 -94
  438. /package/{list → action-icon}/types.js +0 -0
  439. /package/{radio → badge}/types.js +0 -0
  440. /package/{resultsetTable → breadcrumbs}/types.js +0 -0
  441. /package/{row → bulleted-list}/types.js +0 -0
  442. /package/{stack → container}/types.js +0 -0
  443. /package/{number-input/numberInputContextTypes.js → contextual-menu/types.js} +0 -0
@@ -0,0 +1,67 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
5
+ var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
6
+ var _react = _interopRequireDefault(require("react"));
7
+ var _react2 = require("@testing-library/react");
8
+ var _axeHelper = require("../../test/accessibility/axe-helper.js");
9
+ var _Chip = _interopRequireDefault(require("./Chip.tsx"));
10
+ var iconSVG = /*#__PURE__*/_react["default"].createElement("svg", {
11
+ version: "1.1",
12
+ x: "0px",
13
+ y: "0px",
14
+ width: "438.536px",
15
+ height: "438.536px",
16
+ viewBox: "0 0 438.536 438.536",
17
+ fill: "currentColor"
18
+ }, /*#__PURE__*/_react["default"].createElement("g", null, /*#__PURE__*/_react["default"].createElement("path", {
19
+ d: "M414.41,24.123C398.333,8.042,378.963,0,356.315,0H82.228C59.58,0,40.21,8.042,24.126,24.123\nC8.045,40.207,0.003,59.576,0.003,82.225v274.084c0,22.647,8.042,42.018,24.123,58.102c16.084,16.084,35.454,24.126,58.102,24.126\nh274.084c22.648,0,42.018-8.042,58.095-24.126c16.084-16.084,24.126-35.454,24.126-58.102V82.225\nC438.532,59.576,430.49,40.204,414.41,24.123z M373.155,225.548h-49.963V406.84h-74.802V225.548H210.99V163.02h37.401v-37.402\nc0-26.838,6.283-47.107,18.843-60.813c12.559-13.706,33.304-20.555,62.242-20.555h49.963v62.526h-31.401\nc-10.663,0-17.467,1.853-20.417,5.568c-2.949,3.711-4.428,10.23-4.428,19.558v31.119h56.534L373.155,225.548z"
20
+ })));
21
+ describe("Chip component accessibility tests", function () {
22
+ it("Should not have basic accessibility issues", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
23
+ var _render, container, results;
24
+ return _regenerator["default"].wrap(function _callee$(_context) {
25
+ while (1) switch (_context.prev = _context.next) {
26
+ case 0:
27
+ _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Chip["default"], {
28
+ margin: "small",
29
+ prefixIcon: iconSVG,
30
+ suffixIcon: iconSVG,
31
+ label: "Chip"
32
+ })), container = _render.container;
33
+ _context.next = 3;
34
+ return (0, _axeHelper.axe)(container);
35
+ case 3:
36
+ results = _context.sent;
37
+ expect(results).toHaveNoViolations();
38
+ case 5:
39
+ case "end":
40
+ return _context.stop();
41
+ }
42
+ }, _callee);
43
+ })));
44
+ it("Should not have basic accessibility issues for disabled mode", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2() {
45
+ var _render2, container, results;
46
+ return _regenerator["default"].wrap(function _callee2$(_context2) {
47
+ while (1) switch (_context2.prev = _context2.next) {
48
+ case 0:
49
+ _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Chip["default"], {
50
+ margin: "small",
51
+ prefixIcon: iconSVG,
52
+ suffixIcon: iconSVG,
53
+ label: "Chip",
54
+ disabled: true
55
+ })), container = _render2.container;
56
+ _context2.next = 3;
57
+ return (0, _axeHelper.axe)(container);
58
+ case 3:
59
+ results = _context2.sent;
60
+ expect(results).toHaveNoViolations();
61
+ case 5:
62
+ case "end":
63
+ return _context2.stop();
64
+ }
65
+ }, _callee2);
66
+ })));
67
+ });
package/chip/Chip.js CHANGED
@@ -1,94 +1,71 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
4
  var _typeof3 = require("@babel/runtime/helpers/typeof");
6
-
7
5
  Object.defineProperty(exports, "__esModule", {
8
6
  value: true
9
7
  });
10
8
  exports["default"] = void 0;
11
-
12
9
  var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
13
-
14
10
  var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
15
-
16
11
  var _react = _interopRequireDefault(require("react"));
17
-
18
12
  var _styledComponents = _interopRequireWildcard(require("styled-components"));
19
-
20
- var _variables = require("../common/variables.js");
21
-
22
- var _utils = require("../common/utils.js");
23
-
13
+ var _variables = require("../common/variables");
14
+ var _utils = require("../common/utils");
24
15
  var _useTheme = _interopRequireDefault(require("../useTheme"));
25
-
26
- var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5;
27
-
28
- 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); }
29
-
30
- function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof3(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; }
31
-
16
+ var _Icon = _interopRequireDefault(require("../icon/Icon"));
17
+ var _templateObject, _templateObject2, _templateObject3;
18
+ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
19
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof3(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
32
20
  var DxcChip = function DxcChip(_ref) {
33
21
  var label = _ref.label,
34
- suffixIcon = _ref.suffixIcon,
35
- prefixIcon = _ref.prefixIcon,
36
- onClickSuffix = _ref.onClickSuffix,
37
- onClickPrefix = _ref.onClickPrefix,
38
- disabled = _ref.disabled,
39
- margin = _ref.margin,
40
- _ref$tabIndex = _ref.tabIndex,
41
- tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
22
+ suffixIcon = _ref.suffixIcon,
23
+ prefixIcon = _ref.prefixIcon,
24
+ onClickSuffix = _ref.onClickSuffix,
25
+ onClickPrefix = _ref.onClickPrefix,
26
+ disabled = _ref.disabled,
27
+ margin = _ref.margin,
28
+ _ref$tabIndex = _ref.tabIndex,
29
+ tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
42
30
  var colorsTheme = (0, _useTheme["default"])();
43
31
  return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
44
32
  theme: colorsTheme.chip
45
- }, /*#__PURE__*/_react["default"].createElement(StyledDxcChip, {
33
+ }, /*#__PURE__*/_react["default"].createElement(Chip, {
46
34
  disabled: disabled,
47
35
  margin: margin
48
36
  }, prefixIcon && /*#__PURE__*/_react["default"].createElement(IconContainer, {
37
+ role: typeof onClickPrefix === "function" ? "button" : undefined,
38
+ "aria-label": typeof onClickPrefix === "function" ? "Prefix Action" : undefined,
49
39
  disabled: disabled,
50
- prefixIcon: true,
51
- label: label,
52
- mode: "prefix",
40
+ interactuable: typeof onClickPrefix === "function" && !disabled,
53
41
  tabIndex: typeof onClickPrefix === "function" && !disabled ? tabIndex : -1,
54
42
  onClick: function onClick() {
55
43
  return onClickPrefix && !disabled && onClickPrefix();
56
- },
57
- interactuable: typeof onClickPrefix === "function" && !disabled
58
- }, typeof prefixIcon === "string" ? /*#__PURE__*/_react["default"].createElement(PrefixIconContainer, {
59
- src: prefixIcon
60
- }) : prefixIcon), label && /*#__PURE__*/_react["default"].createElement(ChipTextContainer, {
44
+ }
45
+ }, typeof prefixIcon === "string" ? /*#__PURE__*/_react["default"].createElement(_Icon["default"], {
46
+ icon: prefixIcon
47
+ }) : prefixIcon), label && /*#__PURE__*/_react["default"].createElement(LabelContainer, {
61
48
  disabled: disabled
62
49
  }, label), suffixIcon && /*#__PURE__*/_react["default"].createElement(IconContainer, {
50
+ role: typeof onClickSuffix === "function" ? "button" : undefined,
51
+ "aria-label": typeof onClickSuffix === "function" ? "Suffix Action" : undefined,
63
52
  disabled: disabled,
64
- suffixIcon: true,
65
- mode: "suffix",
66
- label: label,
53
+ interactuable: typeof onClickSuffix === "function" && !disabled,
67
54
  tabIndex: typeof onClickSuffix === "function" && !disabled ? tabIndex : -1,
68
55
  onClick: function onClick() {
69
- return onClickSuffix && !disabled && onClickSuffix();
70
- },
71
- interactuable: typeof onClickSuffix === "function" && !disabled
72
- }, typeof suffixIcon === "string" ? /*#__PURE__*/_react["default"].createElement(SuffixIconContainer, {
73
- src: suffixIcon
56
+ return !disabled && (onClickSuffix === null || onClickSuffix === void 0 ? void 0 : onClickSuffix());
57
+ }
58
+ }, typeof suffixIcon === "string" ? /*#__PURE__*/_react["default"].createElement(_Icon["default"], {
59
+ icon: suffixIcon
74
60
  }) : suffixIcon)));
75
61
  };
76
-
77
- var getCursor = function getCursor(interactuable, disabled) {
78
- if (disabled) {
79
- return "cursor:not-allowed;";
80
- }
81
-
82
- if (interactuable) {
83
- return "cursor:pointer;";
84
- }
85
-
86
- return "cursor:default; outline:none;";
62
+ var calculateWidth = function calculateWidth(margin) {
63
+ return "calc(100% - ".concat((0, _utils.getMargin)(margin, "left"), " - ").concat((0, _utils.getMargin)(margin, "right"), ")");
87
64
  };
88
-
89
- var StyledDxcChip = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n align-items: center;\n min-height: 40px;\n max-width: ", ";\n background-color: ", ";\n border-radius: ", ";\n border-width: ", ";\n border-style: ", ";\n border-color: ", ";\n padding-top: ", ";\n padding-bottom: ", ";\n padding-left: ", ";\n padding-right: ", ";\n\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n cursor: ", ";\n"])), function (_ref2) {
90
- var margin = _ref2.margin;
91
- return "calc(100% - 40px - ".concat((0, _utils.getMargin)(margin, "left"), " - ").concat((0, _utils.getMargin)(margin, "right"), ")");
65
+ var Chip = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n box-sizing: border-box;\n display: inline-flex;\n align-items: center;\n gap: ", ";\n min-height: 40px;\n max-width: ", ";\n background-color: ", ";\n border-radius: ", ";\n border-width: ", ";\n border-style: ", ";\n border-color: ", ";\n\n padding-top: ", ";\n padding-bottom: ", ";\n padding-left: ", ";\n padding-right: ", ";\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n cursor: ", ";\n"])), function (props) {
66
+ return props.theme.iconSpacing;
67
+ }, function (props) {
68
+ return calculateWidth(props.margin);
92
69
  }, function (props) {
93
70
  return props.disabled && props.theme.disabledBackgroundColor || props.theme.backgroundColor;
94
71
  }, function (props) {
@@ -117,12 +94,11 @@ var StyledDxcChip = _styledComponents["default"].div(_templateObject || (_templa
117
94
  return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.bottom ? _variables.spaces[props.margin.bottom] : "";
118
95
  }, function (props) {
119
96
  return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.left ? _variables.spaces[props.margin.left] : "";
120
- }, function (_ref3) {
121
- var disabled = _ref3.disabled;
97
+ }, function (_ref2) {
98
+ var disabled = _ref2.disabled;
122
99
  return disabled && "not-allowed";
123
100
  });
124
-
125
- var ChipTextContainer = _styledComponents["default"].span(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n font-size: ", ";\n font-family: ", ";\n font-weight: ", ";\n font-style: ", ";\n color: ", ";\n cursor: ", ";\n text-overflow: ellipsis;\n white-space: nowrap;\n overflow: hidden;\n"])), function (props) {
101
+ var LabelContainer = _styledComponents["default"].span(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n font-size: ", ";\n font-family: ", ";\n font-weight: ", ";\n font-style: ", ";\n color: ", ";\n text-overflow: ellipsis;\n white-space: nowrap;\n overflow: hidden;\n"])), function (props) {
126
102
  return props.theme.fontSize;
127
103
  }, function (props) {
128
104
  return props.theme.fontFamily;
@@ -132,30 +108,19 @@ var ChipTextContainer = _styledComponents["default"].span(_templateObject2 || (_
132
108
  return props.theme.fontStyle;
133
109
  }, function (props) {
134
110
  return props.disabled ? props.theme.disabledFontColor : props.theme.fontColor;
135
- }, function (_ref4) {
136
- var disabled = _ref4.disabled;
137
- return disabled && "not-allowed" || "default";
138
111
  });
139
-
140
- var SuffixIconContainer = _styledComponents["default"].img(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])([""])));
141
-
142
- var PrefixIconContainer = _styledComponents["default"].img(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])([""])));
143
-
144
- var IconContainer = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n ", "\n ", "\n width: ", ";\n height: ", ";\n overflow: hidden;\n\n img,\n svg {\n height: 100%;\n width: 100%;\n }\n &:focus {\n outline-color: ", ";\n outline-width: 2px;\n ", "\n }\n"])), function (props) {
112
+ var IconContainer = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n border-radius: 0.25rem;\n color: ", ";\n ", "\n\n ", "\n\n font-size: ", ";\n svg {\n width: ", ";\n height: ", ";\n }\n"])), function (props) {
145
113
  return props.disabled ? props.theme.disabledIconColor : props.theme.iconColor;
114
+ }, function (_ref3) {
115
+ var interactuable = _ref3.interactuable;
116
+ return interactuable && "cursor: pointer;";
146
117
  }, function (props) {
147
- return props.prefixIcon ? "margin-right: ".concat((props.label || props.suffixIcon) && props.theme.iconSpacing || props.prefixIcon && "0", ";") : "margin-left: ".concat((props.label || props.prefixIcon) && props.theme.iconSpacing || props.prefixIcon && "0", ";");
148
- }, function (props) {
149
- return getCursor(props.interactuable, props.disabled);
118
+ return props.interactuable && "\n &:hover {\n color: ".concat(props.theme.hoverIconColor, ";\n }\n &:focus,\n &:focus-visible {\n outline: ").concat(props.theme.focusBorderThickness, " ").concat(props.theme.focusBorderStyle, " ").concat(props.theme.focusColor, ";\n }\n &:active {\n color: ").concat(props.theme.activeIconColor, ";\n }\n ");
150
119
  }, function (props) {
151
120
  return props.theme.iconSize;
152
121
  }, function (props) {
153
122
  return props.theme.iconSize;
154
123
  }, function (props) {
155
- return props.theme.focusColor;
156
- }, function (props) {
157
- return props.disabled && "outline: none;";
124
+ return props.theme.iconSize;
158
125
  });
159
-
160
- var _default = DxcChip;
161
- exports["default"] = _default;
126
+ var _default = exports["default"] = DxcChip;
@@ -3,6 +3,7 @@ import { userEvent, within } from "@storybook/testing-library";
3
3
  import DxcChip from "./Chip";
4
4
  import Title from "../../.storybook/components/Title";
5
5
  import ExampleContainer from "../../.storybook/components/ExampleContainer";
6
+ import { HalstackProvider } from "../HalstackContext";
6
7
 
7
8
  export default {
8
9
  title: "Chip",
@@ -10,12 +11,42 @@ export default {
10
11
  };
11
12
 
12
13
  const iconSVG = (
13
- <svg viewBox="0 0 24 24" fill="currentColor">
14
- <path d="M0 0h24v24H0z" fill="none" />
15
- <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" />
14
+ <svg
15
+ version="1.1"
16
+ x="0px"
17
+ y="0px"
18
+ width="438.536px"
19
+ height="438.536px"
20
+ viewBox="0 0 438.536 438.536"
21
+ fill="currentColor"
22
+ >
23
+ <g>
24
+ <path
25
+ d="M414.41,24.123C398.333,8.042,378.963,0,356.315,0H82.228C59.58,0,40.21,8.042,24.126,24.123
26
+ C8.045,40.207,0.003,59.576,0.003,82.225v274.084c0,22.647,8.042,42.018,24.123,58.102c16.084,16.084,35.454,24.126,58.102,24.126
27
+ h274.084c22.648,0,42.018-8.042,58.095-24.126c16.084-16.084,24.126-35.454,24.126-58.102V82.225
28
+ C438.532,59.576,430.49,40.204,414.41,24.123z M373.155,225.548h-49.963V406.84h-74.802V225.548H210.99V163.02h37.401v-37.402
29
+ c0-26.838,6.283-47.107,18.843-60.813c12.559-13.706,33.304-20.555,62.242-20.555h49.963v62.526h-31.401
30
+ c-10.663,0-17.467,1.853-20.417,5.568c-2.949,3.711-4.428,10.23-4.428,19.558v31.119h56.534L373.155,225.548z"
31
+ />
32
+ </g>
33
+ </svg>
34
+ );
35
+
36
+ const smallIconSVG = (
37
+ <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20" height="20" width="20">
38
+ <path d="m10 17-1.042-.938q-2.083-1.854-3.437-3.177-1.354-1.323-2.136-2.354Q2.604 9.5 2.302 8.646 2 7.792 2 6.896q0-1.854 1.271-3.125T6.396 2.5q1.021 0 1.979.438.958.437 1.625 1.229.667-.792 1.625-1.229.958-.438 1.979-.438 1.854 0 3.125 1.271T18 6.896q0 .896-.292 1.729-.291.833-1.073 1.854-.781 1.021-2.145 2.365-1.365 1.344-3.49 3.26Zm0-2.021q1.938-1.729 3.188-2.948 1.25-1.219 1.989-2.125.74-.906 1.031-1.614.292-.709.292-1.396 0-1.229-.833-2.063Q14.833 4 13.604 4q-.729 0-1.364.302-.636.302-1.094.844L10.417 6h-.834l-.729-.854q-.458-.542-1.114-.844Q7.083 4 6.396 4q-1.229 0-2.063.833-.833.834-.833 2.063 0 .687.271 1.364.271.678.989 1.573.719.896 1.98 2.125Q8 13.188 10 14.979Zm0-5.5Z" />
16
39
  </svg>
17
40
  );
18
41
 
42
+ const opinionatedTheme = {
43
+ chip: {
44
+ baseColor: "#e6e6e6",
45
+ fontColor: "#000000",
46
+ iconColor: "#4d4d4d",
47
+ },
48
+ };
49
+
19
50
  export const Chromatic = () => (
20
51
  <>
21
52
  <ExampleContainer>
@@ -23,46 +54,54 @@ export const Chromatic = () => (
23
54
  <DxcChip label="Default Chip" />
24
55
  </ExampleContainer>
25
56
  <ExampleContainer>
26
- <Title title="Chip with prefix" theme="light" level={4} />
27
- <DxcChip label="Chip with prefix" prefixIcon={iconSVG} />
57
+ <Title title="Chip with prefix SVG (small icon)" theme="light" level={4} />
58
+ <DxcChip label="Chip with prefix" prefixIcon={smallIconSVG} />
28
59
  </ExampleContainer>
29
60
  <ExampleContainer>
30
- <Title title="Chip with suffix" theme="light" level={4} />
61
+ <Title title="Chip with suffix SVG (large icon)" theme="light" level={4} />
31
62
  <DxcChip label="Chip with suffix" suffixIcon={iconSVG} />
32
63
  </ExampleContainer>
33
64
  <ExampleContainer>
34
- <Title title="Chip with prefix and suffix" theme="light" level={4} />
35
- <DxcChip label="Chip with prefix and suffix" prefixIcon={iconSVG} suffixIcon={iconSVG} />
65
+ <Title title="Chip with prefix (SVG) and suffix (URL)" theme="light" level={4} />
66
+ <DxcChip label="Chip with prefix and suffix" prefixIcon={iconSVG} suffixIcon="filled_check_circle" />
36
67
  </ExampleContainer>
37
68
  <ExampleContainer>
38
69
  <Title title="Disabled chip" theme="light" level={4} />
39
- <DxcChip label="Disabled" disabled prefixIcon={iconSVG} suffixIcon={iconSVG} />
70
+ <DxcChip label="Disabled" disabled prefixIcon={iconSVG} suffixIcon="filled_check_circle" />
40
71
  </ExampleContainer>
41
72
  <ExampleContainer>
42
73
  <Title title="Chip with ellipsis" theme="light" level={4} />
43
- <DxcChip label="With ellipsis asdfasdf asdf asdfasdf asdf asdfasdf asdfasdf asdf asdf adfasrfasf afsdg afgasfg asdf asdf asdf asdf asdf asdf asdf afdg asfg asdfg asdf asdf asdf asdfasdf asd fas df asd asdf asdf asdfasd fg ssssssssssss ssss" />
74
+ <div style={{ width: "200px" }}>
75
+ <DxcChip label="With ellipsis asdfasdf asdf asdfasdf asdf asdfasdf asdfasdf asdf asdf adfasrfasf afsdg afgasfg asdf asdf asdf asdf asdf asdf asdf afdg asfg asdfg asdf asdf asdf asdfasdf asd fas df asd asdf asdf asdfasd fg ssssssssssss ssss" />
76
+ </div>
44
77
  </ExampleContainer>
45
78
  <ExampleContainer>
46
79
  <Title title="Chip with ellipsis and suffix" theme="light" level={4} />
47
- <DxcChip
48
- suffixIcon={iconSVG}
49
- label="With ellipsis asdfasdf asdf asdfasdf asdf asdfasdf asdfasdf asdf asdf adfasrfasf afsdg afgasfg asdf asdf asdf asdf asdf asdf asdf afdg asfg asdfg asdf asdf asdf asdfasdf asd fas df asd asdf asdf asdfasd fgsss"
50
- />
80
+ <div style={{ width: "200px" }}>
81
+ <DxcChip
82
+ suffixIcon={iconSVG}
83
+ label="With ellipsis asdfasdf asdf asdfasdf asdf asdfasdf asdfasdf asdf asdf adfasrfasf afsdg afgasfg asdf asdf asdf asdf asdf asdf asdf afdg asfg asdfg asdf asdf asdf asdfasdf asd fas df asd asdf asdf asdfasd fgsss"
84
+ />
85
+ </div>
51
86
  </ExampleContainer>
52
87
  <ExampleContainer>
53
88
  <Title title="Chip with ellipsis and prefix" theme="light" level={4} />
54
- <DxcChip
55
- prefixIcon={iconSVG}
56
- label="With ellipsis asdfasdf asdf asdfasdf asdf asdfasdf asdfasdf asdf asdf adfasrfasf afsdg afgasfg asdf asdf asdf asdf asdf asdf asdf afdg asfg asdfg asdf asdf asdf asdfasdf asd fas df asd asdf asdf asdfasd fgsss"
57
- />
89
+ <div style={{ width: "200px" }}>
90
+ <DxcChip
91
+ prefixIcon={iconSVG}
92
+ label="With ellipsis asdfasdf asdf asdfasdf asdf asdfasdf asdfasdf asdf asdf adfasrfasf afsdg afgasfg asdf asdf asdf asdf asdf asdf asdf afdg asfg asdfg asdf asdf asdf asdfasdf asd fas df asd asdf asdf asdfasd fgsss"
93
+ />
94
+ </div>
58
95
  </ExampleContainer>
59
96
  <ExampleContainer>
60
97
  <Title title="Chip with ellipsis, suffix and prefix" theme="light" level={4} />
61
- <DxcChip
62
- prefixIcon={iconSVG}
63
- suffixIcon={iconSVG}
64
- label="With ellipsis asdfasdf asdf asdfasdf asdf asdfasdf asdfasdf asdf asdf adfasrfasf afsdg afgasfg asdf asdf asdf asdf asdf asdf asdf afdg asfg asdfg asdf asdf asdf asdfasdf asd fas df asd asdf asdf asdfasdf"
65
- />
98
+ <div style={{ width: "200px" }}>
99
+ <DxcChip
100
+ prefixIcon={iconSVG}
101
+ suffixIcon={iconSVG}
102
+ label="With ellipsis asdfasdf asdf asdfasdf asdf asdfasdf asdfasdf asdf asdf adfasrfasf afsdg afgasfg asdf asdf asdf asdf asdf asdf asdf afdg asfg asdfg asdf asdf asdf asdfasdf asd fas df asd asdf asdf asdfasdf"
103
+ />
104
+ </div>
66
105
  </ExampleContainer>
67
106
  <Title title="Margins" theme="light" level={2} />
68
107
  <ExampleContainer>
@@ -93,27 +132,68 @@ export const Chromatic = () => (
93
132
  <Title title="Xxlarge margin" theme="light" level={4} />
94
133
  <DxcChip label="xxlarge" margin="xxlarge" />
95
134
  </ExampleContainer>
135
+ <Title title="Opinionated theme" theme="light" level={2} />
136
+ <ExampleContainer>
137
+ <Title title="Chip with prefix and suffix" theme="light" level={4} />
138
+ <HalstackProvider theme={opinionatedTheme}>
139
+ <DxcChip label="Chip" prefixIcon={iconSVG} suffixIcon="filled_check_circle" />
140
+ </HalstackProvider>
141
+ </ExampleContainer>
142
+ <ExampleContainer>
143
+ <Title title="Chip with prefix and suffix" theme="light" level={4} />
144
+ <HalstackProvider theme={opinionatedTheme}>
145
+ <DxcChip label="Chip" disabled prefixIcon={iconSVG} suffixIcon="filled_check_circle" />
146
+ </HalstackProvider>
147
+ </ExampleContainer>
148
+ <ExampleContainer pseudoState="pseudo-hover">
149
+ <Title title="Hovered" theme="light" level={4} />
150
+ <HalstackProvider theme={opinionatedTheme}>
151
+ <DxcChip
152
+ label="Chip"
153
+ prefixIcon={iconSVG}
154
+ suffixIcon={iconSVG}
155
+ onClickPrefix={() => {}}
156
+ onClickSuffix={() => {}}
157
+ />
158
+ </HalstackProvider>
159
+ </ExampleContainer>
160
+ <ExampleContainer pseudoState="pseudo-active">
161
+ <Title title="Actived" theme="light" level={4} />
162
+ <HalstackProvider theme={opinionatedTheme}>
163
+ <DxcChip
164
+ label="Chip"
165
+ prefixIcon={iconSVG}
166
+ suffixIcon={iconSVG}
167
+ onClickPrefix={() => {}}
168
+ onClickSuffix={() => {}}
169
+ />
170
+ </HalstackProvider>
171
+ </ExampleContainer>
96
172
  </>
97
173
  );
98
174
  const ChipPrefixFocused = () => (
99
175
  <ExampleContainer>
100
176
  <Title title="Chip with prefix" theme="light" level={4} />
101
- <DxcChip label="Chip with prefix" prefixIcon={iconSVG} onClickPrefix={() => {}} />
177
+ <DxcChip
178
+ label="Chip with prefix"
179
+ prefixIcon={iconSVG}
180
+ onClickPrefix={() => {}}
181
+ />
102
182
  </ExampleContainer>
103
183
  );
104
184
  const ChipSuffixFocused = () => (
105
185
  <ExampleContainer>
106
186
  <Title title="Chip with suffix" theme="light" level={4} />
107
- <DxcChip label="Chip with suffix" suffixIcon={iconSVG} onClickSuffix={() => {}} />
187
+ <DxcChip label="Chip with suffix" suffixIcon="filled_delete" onClickSuffix={() => {}} />
108
188
  </ExampleContainer>
109
189
  );
110
190
 
111
191
  export const PrefixFocused = ChipPrefixFocused.bind({});
112
- PrefixFocused.play = async ({ canvasElement }) => {
192
+ PrefixFocused.play = async () => {
113
193
  await userEvent.tab();
114
194
  };
115
195
 
116
196
  export const SuffixFocused = ChipSuffixFocused.bind({});
117
- SuffixFocused.play = async ({ canvasElement }) => {
197
+ SuffixFocused.play = async () => {
118
198
  await userEvent.tab();
119
199
  };
@@ -0,0 +1,41 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _react = _interopRequireDefault(require("react"));
5
+ var _react2 = require("@testing-library/react");
6
+ var _Chip = _interopRequireDefault(require("./Chip.tsx"));
7
+ describe("Chip component tests", function () {
8
+ test("Chip renders with correct text", function () {
9
+ var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Chip["default"], {
10
+ label: "Chip"
11
+ })),
12
+ getByText = _render.getByText;
13
+ expect(getByText("Chip")).toBeTruthy();
14
+ });
15
+ test("Calls correct function when clicking on prefix icon", function () {
16
+ var onClick = jest.fn();
17
+ var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Chip["default"], {
18
+ label: "Chip",
19
+ prefixIcon: "nutrition",
20
+ onClickPrefix: onClick
21
+ })),
22
+ getByText = _render2.getByText,
23
+ getByRole = _render2.getByRole;
24
+ expect(getByText("Chip")).toBeTruthy();
25
+ _react2.fireEvent.click(getByRole("button"));
26
+ expect(onClick).toHaveBeenCalled();
27
+ });
28
+ test("Calls correct function when clicking on suffix icon", function () {
29
+ var onClick = jest.fn();
30
+ var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Chip["default"], {
31
+ label: "Chip",
32
+ suffixIcon: "nutrition",
33
+ onClickSuffix: onClick
34
+ })),
35
+ getByText = _render3.getByText,
36
+ getByRole = _render3.getByRole;
37
+ expect(getByText("Chip")).toBeTruthy();
38
+ _react2.fireEvent.click(getByRole("button"));
39
+ expect(onClick).toHaveBeenCalled();
40
+ });
41
+ });
package/chip/types.d.ts CHANGED
@@ -1,13 +1,13 @@
1
1
  /// <reference types="react" />
2
- declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
- declare type Margin = {
2
+ type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
+ type Margin = {
4
4
  top?: Space;
5
5
  bottom?: Space;
6
6
  left?: Space;
7
7
  right?: Space;
8
8
  };
9
- declare type SVG = React.SVGProps<SVGSVGElement>;
10
- declare type Props = {
9
+ type SVG = React.ReactNode & React.SVGProps<SVGSVGElement>;
10
+ type Props = {
11
11
  /**
12
12
  * Text to be placed on the chip.
13
13
  */