@dxc-technology/halstack-react 0.0.0-b3de035 → 0.0.0-b3e2de9

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 (577) hide show
  1. package/BackgroundColorContext.d.ts +1 -0
  2. package/BackgroundColorContext.js +30 -0
  3. package/HalstackContext.d.ts +1249 -0
  4. package/HalstackContext.js +310 -0
  5. package/README.md +28 -47
  6. package/accordion/Accordion.accessibility.test.js +71 -0
  7. package/accordion/Accordion.d.ts +4 -0
  8. package/accordion/Accordion.js +169 -0
  9. package/accordion/Accordion.stories.tsx +251 -0
  10. package/accordion/Accordion.test.js +56 -0
  11. package/accordion/types.d.ts +57 -0
  12. package/accordion/types.js +5 -0
  13. package/accordion-group/AccordionGroup.accessibility.test.js +88 -0
  14. package/accordion-group/AccordionGroup.d.ts +7 -0
  15. package/accordion-group/AccordionGroup.js +101 -0
  16. package/accordion-group/AccordionGroup.stories.tsx +252 -0
  17. package/accordion-group/AccordionGroup.test.js +98 -0
  18. package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
  19. package/accordion-group/AccordionGroupAccordion.js +31 -0
  20. package/accordion-group/AccordionGroupContext.d.ts +3 -0
  21. package/accordion-group/AccordionGroupContext.js +8 -0
  22. package/accordion-group/types.d.ts +67 -0
  23. package/accordion-group/types.js +5 -0
  24. package/action-icon/ActionIcon.accessibility.test.js +63 -0
  25. package/action-icon/ActionIcon.d.ts +4 -0
  26. package/action-icon/ActionIcon.js +48 -0
  27. package/action-icon/ActionIcon.stories.tsx +41 -0
  28. package/action-icon/ActionIcon.test.js +64 -0
  29. package/action-icon/types.d.ts +26 -0
  30. package/action-icon/types.js +5 -0
  31. package/alert/Alert.accessibility.test.js +95 -0
  32. package/alert/Alert.d.ts +4 -0
  33. package/alert/Alert.js +200 -0
  34. package/alert/Alert.stories.tsx +198 -0
  35. package/alert/Alert.test.js +75 -0
  36. package/alert/types.d.ts +49 -0
  37. package/alert/types.js +5 -0
  38. package/badge/Badge.accessibility.test.js +129 -0
  39. package/badge/Badge.d.ts +4 -0
  40. package/badge/Badge.js +159 -0
  41. package/badge/Badge.stories.tsx +210 -0
  42. package/badge/Badge.test.js +30 -0
  43. package/badge/types.d.ts +54 -0
  44. package/badge/types.js +5 -0
  45. package/bleed/Bleed.d.ts +3 -0
  46. package/bleed/Bleed.js +43 -0
  47. package/bleed/Bleed.stories.tsx +342 -0
  48. package/bleed/types.d.ts +37 -0
  49. package/bleed/types.js +5 -0
  50. package/box/Box.accessibility.test.js +33 -0
  51. package/box/Box.d.ts +4 -0
  52. package/box/Box.js +75 -0
  53. package/box/Box.stories.tsx +119 -0
  54. package/box/Box.test.js +13 -0
  55. package/box/types.d.ts +32 -0
  56. package/box/types.js +5 -0
  57. package/bulleted-list/BulletedList.accessibility.test.js +107 -0
  58. package/bulleted-list/BulletedList.d.ts +7 -0
  59. package/bulleted-list/BulletedList.js +92 -0
  60. package/bulleted-list/BulletedList.stories.tsx +115 -0
  61. package/bulleted-list/types.d.ts +38 -0
  62. package/bulleted-list/types.js +5 -0
  63. package/button/Button.accessibility.test.js +127 -0
  64. package/button/Button.d.ts +4 -0
  65. package/button/Button.js +121 -0
  66. package/button/Button.stories.tsx +325 -0
  67. package/button/Button.test.js +38 -0
  68. package/button/types.d.ts +57 -0
  69. package/button/types.js +5 -0
  70. package/card/Card.accessibility.test.js +36 -0
  71. package/card/Card.d.ts +4 -0
  72. package/card/Card.js +120 -0
  73. package/card/Card.stories.tsx +171 -0
  74. package/card/Card.test.js +39 -0
  75. package/card/types.d.ts +62 -0
  76. package/card/types.js +5 -0
  77. package/checkbox/Checkbox.accessibility.test.js +87 -0
  78. package/checkbox/Checkbox.d.ts +4 -0
  79. package/checkbox/Checkbox.js +215 -0
  80. package/checkbox/Checkbox.stories.tsx +222 -0
  81. package/checkbox/Checkbox.test.js +199 -0
  82. package/checkbox/types.d.ts +72 -0
  83. package/checkbox/types.js +5 -0
  84. package/chip/Chip.accessibility.test.js +67 -0
  85. package/chip/Chip.d.ts +4 -0
  86. package/chip/Chip.js +124 -0
  87. package/chip/Chip.stories.tsx +195 -0
  88. package/chip/Chip.test.js +41 -0
  89. package/chip/types.d.ts +45 -0
  90. package/chip/types.js +5 -0
  91. package/common/coreTokens.d.ts +237 -0
  92. package/common/coreTokens.js +184 -0
  93. package/common/utils.d.ts +1 -0
  94. package/{dist/common → common}/utils.js +6 -12
  95. package/common/variables.d.ts +1395 -0
  96. package/common/variables.js +1267 -0
  97. package/container/Container.d.ts +4 -0
  98. package/container/Container.js +194 -0
  99. package/container/Container.stories.tsx +214 -0
  100. package/container/types.d.ts +74 -0
  101. package/container/types.js +5 -0
  102. package/contextual-menu/ContextualMenu.accessibility.test.js +86 -0
  103. package/contextual-menu/ContextualMenu.d.ts +7 -0
  104. package/contextual-menu/ContextualMenu.js +71 -0
  105. package/contextual-menu/ContextualMenu.stories.tsx +182 -0
  106. package/contextual-menu/ContextualMenu.test.js +71 -0
  107. package/contextual-menu/MenuItemAction.d.ts +4 -0
  108. package/contextual-menu/MenuItemAction.js +46 -0
  109. package/contextual-menu/types.d.ts +22 -0
  110. package/contextual-menu/types.js +5 -0
  111. package/date-input/Calendar.d.ts +4 -0
  112. package/date-input/Calendar.js +214 -0
  113. package/date-input/DateInput.accessibility.test.js +216 -0
  114. package/date-input/DateInput.d.ts +4 -0
  115. package/date-input/DateInput.js +223 -0
  116. package/date-input/DateInput.stories.tsx +285 -0
  117. package/date-input/DateInput.test.js +808 -0
  118. package/date-input/DatePicker.d.ts +4 -0
  119. package/date-input/DatePicker.js +115 -0
  120. package/date-input/Icons.d.ts +6 -0
  121. package/date-input/Icons.js +58 -0
  122. package/date-input/YearPicker.d.ts +4 -0
  123. package/date-input/YearPicker.js +100 -0
  124. package/date-input/types.d.ts +164 -0
  125. package/date-input/types.js +5 -0
  126. package/dialog/Dialog.accessibility.test.js +69 -0
  127. package/dialog/Dialog.d.ts +4 -0
  128. package/dialog/Dialog.js +104 -0
  129. package/dialog/Dialog.stories.tsx +365 -0
  130. package/dialog/Dialog.test.js +307 -0
  131. package/dialog/types.d.ts +36 -0
  132. package/dialog/types.js +5 -0
  133. package/divider/Divider.accessibility.test.js +33 -0
  134. package/divider/Divider.d.ts +4 -0
  135. package/divider/Divider.js +36 -0
  136. package/divider/Divider.stories.tsx +223 -0
  137. package/divider/Divider.test.js +38 -0
  138. package/divider/types.d.ts +21 -0
  139. package/divider/types.js +5 -0
  140. package/dropdown/Dropdown.accessibility.test.js +180 -0
  141. package/dropdown/Dropdown.d.ts +4 -0
  142. package/dropdown/Dropdown.js +319 -0
  143. package/dropdown/Dropdown.stories.tsx +427 -0
  144. package/dropdown/Dropdown.test.js +599 -0
  145. package/dropdown/DropdownMenu.d.ts +4 -0
  146. package/dropdown/DropdownMenu.js +63 -0
  147. package/dropdown/DropdownMenuItem.d.ts +4 -0
  148. package/dropdown/DropdownMenuItem.js +70 -0
  149. package/dropdown/types.d.ts +96 -0
  150. package/dropdown/types.js +5 -0
  151. package/file-input/FileInput.accessibility.test.js +160 -0
  152. package/file-input/FileInput.d.ts +4 -0
  153. package/file-input/FileInput.js +479 -0
  154. package/file-input/FileInput.stories.tsx +618 -0
  155. package/file-input/FileInput.test.js +459 -0
  156. package/file-input/FileItem.d.ts +4 -0
  157. package/file-input/FileItem.js +135 -0
  158. package/file-input/types.d.ts +129 -0
  159. package/file-input/types.js +5 -0
  160. package/flex/Flex.d.ts +4 -0
  161. package/flex/Flex.js +57 -0
  162. package/flex/Flex.stories.tsx +112 -0
  163. package/flex/types.d.ts +97 -0
  164. package/flex/types.js +5 -0
  165. package/footer/Footer.accessibility.test.js +117 -0
  166. package/footer/Footer.d.ts +4 -0
  167. package/footer/Footer.js +138 -0
  168. package/footer/Footer.stories.tsx +170 -0
  169. package/footer/Footer.test.js +85 -0
  170. package/footer/Icons.d.ts +3 -0
  171. package/footer/Icons.js +136 -0
  172. package/footer/types.d.ts +64 -0
  173. package/footer/types.js +5 -0
  174. package/grid/Grid.d.ts +7 -0
  175. package/grid/Grid.js +76 -0
  176. package/grid/Grid.stories.tsx +219 -0
  177. package/grid/types.d.ts +115 -0
  178. package/grid/types.js +5 -0
  179. package/header/Header.accessibility.test.js +84 -0
  180. package/header/Header.d.ts +8 -0
  181. package/header/Header.js +220 -0
  182. package/header/Header.stories.tsx +251 -0
  183. package/header/Header.test.js +66 -0
  184. package/header/Icons.d.ts +2 -0
  185. package/{dist/header → header}/Icons.js +9 -39
  186. package/header/types.d.ts +33 -0
  187. package/header/types.js +5 -0
  188. package/heading/Heading.accessibility.test.js +33 -0
  189. package/heading/Heading.d.ts +4 -0
  190. package/{dist/heading → heading}/Heading.js +31 -124
  191. package/heading/Heading.stories.tsx +54 -0
  192. package/heading/Heading.test.js +169 -0
  193. package/heading/types.d.ts +33 -0
  194. package/heading/types.js +5 -0
  195. package/icon/Icon.accessibility.test.js +30 -0
  196. package/icon/Icon.d.ts +4 -0
  197. package/icon/Icon.js +33 -0
  198. package/icon/Icon.stories.tsx +28 -0
  199. package/icon/types.d.ts +4 -0
  200. package/icon/types.js +5 -0
  201. package/image/Image.accessibility.test.js +56 -0
  202. package/image/Image.d.ts +4 -0
  203. package/image/Image.js +70 -0
  204. package/image/Image.stories.tsx +129 -0
  205. package/image/types.d.ts +72 -0
  206. package/image/types.js +5 -0
  207. package/inset/Inset.d.ts +3 -0
  208. package/inset/Inset.js +43 -0
  209. package/inset/Inset.stories.tsx +230 -0
  210. package/inset/types.d.ts +37 -0
  211. package/inset/types.js +5 -0
  212. package/layout/ApplicationLayout.d.ts +20 -0
  213. package/layout/ApplicationLayout.js +134 -0
  214. package/layout/ApplicationLayout.stories.tsx +162 -0
  215. package/layout/Icons.d.ts +8 -0
  216. package/layout/Icons.js +56 -0
  217. package/layout/types.d.ts +41 -0
  218. package/layout/types.js +5 -0
  219. package/link/Link.accessibility.test.js +112 -0
  220. package/link/Link.d.ts +4 -0
  221. package/link/Link.js +117 -0
  222. package/link/Link.stories.tsx +253 -0
  223. package/link/Link.test.js +63 -0
  224. package/link/types.d.ts +54 -0
  225. package/link/types.js +5 -0
  226. package/main.d.ts +49 -0
  227. package/{dist/main.js → main.js} +135 -137
  228. package/nav-tabs/NavTabs.accessibility.test.js +52 -0
  229. package/nav-tabs/NavTabs.d.ts +7 -0
  230. package/nav-tabs/NavTabs.js +93 -0
  231. package/nav-tabs/NavTabs.stories.tsx +276 -0
  232. package/nav-tabs/NavTabs.test.js +76 -0
  233. package/nav-tabs/NavTabsContext.d.ts +3 -0
  234. package/nav-tabs/NavTabsContext.js +8 -0
  235. package/nav-tabs/Tab.d.ts +4 -0
  236. package/nav-tabs/Tab.js +118 -0
  237. package/nav-tabs/types.d.ts +52 -0
  238. package/nav-tabs/types.js +5 -0
  239. package/number-input/NumberInput.accessibility.test.js +228 -0
  240. package/number-input/NumberInput.d.ts +4 -0
  241. package/number-input/NumberInput.js +86 -0
  242. package/number-input/NumberInput.stories.tsx +131 -0
  243. package/number-input/NumberInput.test.js +989 -0
  244. package/number-input/NumberInputContext.d.ts +3 -0
  245. package/number-input/NumberInputContext.js +8 -0
  246. package/number-input/types.d.ts +136 -0
  247. package/number-input/types.js +5 -0
  248. package/package.json +62 -50
  249. package/paginator/Icons.d.ts +5 -0
  250. package/paginator/Icons.js +40 -0
  251. package/paginator/Paginator.accessibility.test.js +79 -0
  252. package/paginator/Paginator.d.ts +4 -0
  253. package/paginator/Paginator.js +135 -0
  254. package/paginator/Paginator.stories.tsx +87 -0
  255. package/paginator/Paginator.test.js +335 -0
  256. package/paginator/types.d.ts +38 -0
  257. package/paginator/types.js +5 -0
  258. package/paragraph/Paragraph.accessibility.test.js +28 -0
  259. package/paragraph/Paragraph.d.ts +5 -0
  260. package/paragraph/Paragraph.js +22 -0
  261. package/paragraph/Paragraph.stories.tsx +27 -0
  262. package/password-input/Icons.d.ts +6 -0
  263. package/password-input/Icons.js +35 -0
  264. package/password-input/PasswordInput.accessibility.test.js +153 -0
  265. package/password-input/PasswordInput.d.ts +4 -0
  266. package/password-input/PasswordInput.js +97 -0
  267. package/password-input/PasswordInput.stories.tsx +99 -0
  268. package/password-input/PasswordInput.test.js +198 -0
  269. package/password-input/types.d.ts +111 -0
  270. package/password-input/types.js +5 -0
  271. package/progress-bar/ProgressBar.accessibility.test.js +35 -0
  272. package/progress-bar/ProgressBar.d.ts +4 -0
  273. package/progress-bar/ProgressBar.js +144 -0
  274. package/progress-bar/ProgressBar.stories.tsx +93 -0
  275. package/progress-bar/ProgressBar.test.js +93 -0
  276. package/progress-bar/types.d.ts +37 -0
  277. package/progress-bar/types.js +5 -0
  278. package/quick-nav/QuickNav.accessibility.test.js +57 -0
  279. package/quick-nav/QuickNav.d.ts +4 -0
  280. package/quick-nav/QuickNav.js +94 -0
  281. package/quick-nav/QuickNav.stories.tsx +356 -0
  282. package/quick-nav/types.d.ts +21 -0
  283. package/quick-nav/types.js +5 -0
  284. package/radio-group/Radio.d.ts +4 -0
  285. package/radio-group/Radio.js +124 -0
  286. package/radio-group/RadioGroup.accessibility.test.js +97 -0
  287. package/radio-group/RadioGroup.d.ts +4 -0
  288. package/radio-group/RadioGroup.js +235 -0
  289. package/radio-group/RadioGroup.stories.tsx +214 -0
  290. package/radio-group/RadioGroup.test.js +756 -0
  291. package/radio-group/types.d.ts +114 -0
  292. package/radio-group/types.js +5 -0
  293. package/resultset-table/Icons.d.ts +7 -0
  294. package/resultset-table/Icons.js +47 -0
  295. package/resultset-table/ResultsetTable.accessibility.test.js +274 -0
  296. package/resultset-table/ResultsetTable.d.ts +7 -0
  297. package/resultset-table/ResultsetTable.js +170 -0
  298. package/resultset-table/ResultsetTable.stories.tsx +401 -0
  299. package/resultset-table/ResultsetTable.test.js +381 -0
  300. package/resultset-table/types.d.ts +100 -0
  301. package/resultset-table/types.js +5 -0
  302. package/select/Icons.d.ts +10 -0
  303. package/select/Icons.js +89 -0
  304. package/select/Listbox.d.ts +4 -0
  305. package/select/Listbox.js +143 -0
  306. package/select/Option.d.ts +4 -0
  307. package/select/Option.js +87 -0
  308. package/select/Select.accessibility.test.js +217 -0
  309. package/select/Select.d.ts +4 -0
  310. package/select/Select.js +590 -0
  311. package/select/Select.stories.tsx +970 -0
  312. package/select/Select.test.js +2370 -0
  313. package/select/types.d.ts +209 -0
  314. package/select/types.js +5 -0
  315. package/sidenav/Icons.d.ts +7 -0
  316. package/sidenav/Icons.js +47 -0
  317. package/sidenav/Sidenav.accessibility.test.js +59 -0
  318. package/sidenav/Sidenav.d.ts +10 -0
  319. package/sidenav/Sidenav.js +197 -0
  320. package/sidenav/Sidenav.stories.tsx +281 -0
  321. package/sidenav/Sidenav.test.js +37 -0
  322. package/sidenav/SidenavContext.d.ts +5 -0
  323. package/sidenav/SidenavContext.js +13 -0
  324. package/sidenav/types.d.ts +76 -0
  325. package/sidenav/types.js +5 -0
  326. package/slider/Slider.accessibility.test.js +104 -0
  327. package/slider/Slider.d.ts +4 -0
  328. package/slider/Slider.js +285 -0
  329. package/slider/Slider.test.js +254 -0
  330. package/slider/types.d.ts +86 -0
  331. package/slider/types.js +5 -0
  332. package/spinner/Spinner.accessibility.test.js +96 -0
  333. package/spinner/Spinner.d.ts +4 -0
  334. package/spinner/Spinner.js +206 -0
  335. package/spinner/Spinner.stories.tsx +129 -0
  336. package/spinner/Spinner.test.js +55 -0
  337. package/spinner/types.d.ts +32 -0
  338. package/spinner/types.js +5 -0
  339. package/status-light/StatusLight.accessibility.test.js +157 -0
  340. package/status-light/StatusLight.d.ts +4 -0
  341. package/status-light/StatusLight.js +51 -0
  342. package/status-light/StatusLight.stories.tsx +74 -0
  343. package/status-light/StatusLight.test.js +25 -0
  344. package/status-light/types.d.ts +17 -0
  345. package/status-light/types.js +5 -0
  346. package/switch/Switch.accessibility.test.js +89 -0
  347. package/switch/Switch.d.ts +4 -0
  348. package/switch/Switch.js +214 -0
  349. package/switch/Switch.stories.tsx +137 -0
  350. package/switch/Switch.test.js +180 -0
  351. package/switch/types.d.ts +66 -0
  352. package/switch/types.js +5 -0
  353. package/table/DropdownTheme.js +62 -0
  354. package/table/Table.accessibility.test.js +82 -0
  355. package/table/Table.d.ts +8 -0
  356. package/table/Table.js +161 -0
  357. package/table/Table.stories.tsx +651 -0
  358. package/table/Table.test.js +113 -0
  359. package/table/types.d.ts +49 -0
  360. package/table/types.js +5 -0
  361. package/tabs/Tab.d.ts +4 -0
  362. package/tabs/Tab.js +116 -0
  363. package/tabs/Tabs.accessibility.test.js +56 -0
  364. package/tabs/Tabs.d.ts +4 -0
  365. package/tabs/Tabs.js +384 -0
  366. package/tabs/Tabs.stories.tsx +226 -0
  367. package/tabs/Tabs.test.js +294 -0
  368. package/tabs/types.d.ts +92 -0
  369. package/tabs/types.js +5 -0
  370. package/tag/Tag.accessibility.test.js +69 -0
  371. package/tag/Tag.d.ts +4 -0
  372. package/tag/Tag.js +151 -0
  373. package/tag/Tag.stories.tsx +155 -0
  374. package/tag/Tag.test.js +49 -0
  375. package/tag/types.d.ts +69 -0
  376. package/tag/types.js +5 -0
  377. package/text-input/Suggestion.d.ts +4 -0
  378. package/text-input/Suggestion.js +67 -0
  379. package/text-input/Suggestions.d.ts +4 -0
  380. package/text-input/Suggestions.js +86 -0
  381. package/text-input/TextInput.accessibility.test.js +321 -0
  382. package/text-input/TextInput.d.ts +4 -0
  383. package/text-input/TextInput.js +567 -0
  384. package/text-input/TextInput.stories.tsx +465 -0
  385. package/text-input/TextInput.test.js +1756 -0
  386. package/text-input/types.d.ts +205 -0
  387. package/text-input/types.js +5 -0
  388. package/textarea/Textarea.accessibility.test.js +155 -0
  389. package/textarea/Textarea.d.ts +4 -0
  390. package/textarea/Textarea.js +234 -0
  391. package/textarea/Textarea.stories.tsx +174 -0
  392. package/textarea/Textarea.test.js +406 -0
  393. package/textarea/types.d.ts +141 -0
  394. package/textarea/types.js +5 -0
  395. package/toggle-group/ToggleGroup.accessibility.test.js +107 -0
  396. package/toggle-group/ToggleGroup.d.ts +4 -0
  397. package/toggle-group/ToggleGroup.js +201 -0
  398. package/toggle-group/ToggleGroup.stories.tsx +218 -0
  399. package/toggle-group/ToggleGroup.test.js +137 -0
  400. package/toggle-group/types.d.ts +114 -0
  401. package/toggle-group/types.js +5 -0
  402. package/typography/Typography.accessibility.test.js +339 -0
  403. package/typography/Typography.d.ts +4 -0
  404. package/typography/Typography.js +23 -0
  405. package/typography/Typography.stories.tsx +198 -0
  406. package/typography/types.d.ts +18 -0
  407. package/typography/types.js +5 -0
  408. package/useTheme.d.ts +1148 -0
  409. package/{dist/useTheme.js → useTheme.js} +4 -11
  410. package/useTranslatedLabels.d.ts +85 -0
  411. package/useTranslatedLabels.js +14 -0
  412. package/utils/BaseTypography.d.ts +21 -0
  413. package/utils/BaseTypography.js +94 -0
  414. package/utils/FocusLock.d.ts +13 -0
  415. package/utils/FocusLock.js +124 -0
  416. package/wizard/Wizard.accessibility.test.js +55 -0
  417. package/wizard/Wizard.d.ts +4 -0
  418. package/wizard/Wizard.js +250 -0
  419. package/wizard/Wizard.stories.tsx +253 -0
  420. package/wizard/Wizard.test.js +114 -0
  421. package/wizard/types.d.ts +64 -0
  422. package/wizard/types.js +5 -0
  423. package/babel.config.js +0 -8
  424. package/dist/BackgroundColorContext.js +0 -46
  425. package/dist/ThemeContext.js +0 -250
  426. package/dist/V3Select/V3Select.js +0 -549
  427. package/dist/V3Select/index.d.ts +0 -27
  428. package/dist/V3Textarea/V3Textarea.js +0 -264
  429. package/dist/V3Textarea/index.d.ts +0 -27
  430. package/dist/accordion/Accordion.js +0 -353
  431. package/dist/accordion/index.d.ts +0 -28
  432. package/dist/accordion-group/AccordionGroup.js +0 -186
  433. package/dist/accordion-group/index.d.ts +0 -16
  434. package/dist/alert/Alert.js +0 -403
  435. package/dist/alert/index.d.ts +0 -51
  436. package/dist/badge/Badge.js +0 -63
  437. package/dist/box/Box.js +0 -156
  438. package/dist/box/index.d.ts +0 -25
  439. package/dist/button/Button.js +0 -238
  440. package/dist/button/index.d.ts +0 -24
  441. package/dist/card/Card.js +0 -254
  442. package/dist/card/index.d.ts +0 -22
  443. package/dist/checkbox/Checkbox.js +0 -299
  444. package/dist/checkbox/index.d.ts +0 -24
  445. package/dist/chip/Chip.js +0 -265
  446. package/dist/chip/index.d.ts +0 -22
  447. package/dist/common/OpenSans.css +0 -81
  448. package/dist/common/RequiredComponent.js +0 -40
  449. package/dist/common/fonts/OpenSans-Bold.ttf +0 -0
  450. package/dist/common/fonts/OpenSans-BoldItalic.ttf +0 -0
  451. package/dist/common/fonts/OpenSans-ExtraBold.ttf +0 -0
  452. package/dist/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  453. package/dist/common/fonts/OpenSans-Italic.ttf +0 -0
  454. package/dist/common/fonts/OpenSans-Light.ttf +0 -0
  455. package/dist/common/fonts/OpenSans-LightItalic.ttf +0 -0
  456. package/dist/common/fonts/OpenSans-Regular.ttf +0 -0
  457. package/dist/common/fonts/OpenSans-SemiBold.ttf +0 -0
  458. package/dist/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  459. package/dist/common/variables.js +0 -1574
  460. package/dist/date/Date.js +0 -379
  461. package/dist/date/index.d.ts +0 -27
  462. package/dist/date-input/DateInput.js +0 -400
  463. package/dist/date-input/index.d.ts +0 -95
  464. package/dist/dialog/Dialog.js +0 -218
  465. package/dist/dialog/index.d.ts +0 -18
  466. package/dist/dropdown/Dropdown.js +0 -544
  467. package/dist/dropdown/index.d.ts +0 -26
  468. package/dist/file-input/FileInput.js +0 -644
  469. package/dist/file-input/FileItem.js +0 -287
  470. package/dist/file-input/index.d.ts +0 -81
  471. package/dist/footer/Footer.js +0 -421
  472. package/dist/footer/Icons.js +0 -77
  473. package/dist/footer/index.d.ts +0 -25
  474. package/dist/header/Header.js +0 -470
  475. package/dist/header/index.d.ts +0 -25
  476. package/dist/heading/index.d.ts +0 -17
  477. package/dist/input-text/Icons.js +0 -22
  478. package/dist/input-text/InputText.js +0 -705
  479. package/dist/input-text/index.d.ts +0 -36
  480. package/dist/layout/ApplicationLayout.js +0 -327
  481. package/dist/layout/Icons.js +0 -55
  482. package/dist/link/Link.js +0 -237
  483. package/dist/link/index.d.ts +0 -23
  484. package/dist/main.d.ts +0 -40
  485. package/dist/number-input/NumberInput.js +0 -136
  486. package/dist/number-input/NumberInputContext.js +0 -16
  487. package/dist/number-input/index.d.ts +0 -113
  488. package/dist/paginator/Icons.js +0 -66
  489. package/dist/paginator/Paginator.js +0 -283
  490. package/dist/paginator/index.d.ts +0 -20
  491. package/dist/password-input/PasswordInput.js +0 -203
  492. package/dist/password-input/index.d.ts +0 -94
  493. package/dist/progress-bar/ProgressBar.js +0 -242
  494. package/dist/progress-bar/index.d.ts +0 -18
  495. package/dist/radio/Radio.js +0 -209
  496. package/dist/radio/index.d.ts +0 -23
  497. package/dist/resultsetTable/ResultsetTable.js +0 -358
  498. package/dist/resultsetTable/index.d.ts +0 -19
  499. package/dist/select/Select.js +0 -1069
  500. package/dist/select/index.d.ts +0 -53
  501. package/dist/sidenav/Sidenav.js +0 -179
  502. package/dist/sidenav/index.d.ts +0 -13
  503. package/dist/slider/Slider.js +0 -404
  504. package/dist/slider/index.d.ts +0 -29
  505. package/dist/spinner/Spinner.js +0 -381
  506. package/dist/spinner/index.d.ts +0 -17
  507. package/dist/switch/Switch.js +0 -222
  508. package/dist/switch/index.d.ts +0 -24
  509. package/dist/table/Table.js +0 -132
  510. package/dist/table/index.d.ts +0 -13
  511. package/dist/tabs/Tabs.js +0 -343
  512. package/dist/tabs/index.d.ts +0 -19
  513. package/dist/tag/Tag.js +0 -282
  514. package/dist/tag/index.d.ts +0 -24
  515. package/dist/text-input/TextInput.js +0 -974
  516. package/dist/text-input/index.d.ts +0 -135
  517. package/dist/textarea/Textarea.js +0 -369
  518. package/dist/textarea/index.d.ts +0 -117
  519. package/dist/toggle/Toggle.js +0 -220
  520. package/dist/toggle/index.d.ts +0 -21
  521. package/dist/toggle-group/ToggleGroup.js +0 -327
  522. package/dist/toggle-group/index.d.ts +0 -21
  523. package/dist/upload/Upload.js +0 -205
  524. package/dist/upload/buttons-upload/ButtonsUpload.js +0 -135
  525. package/dist/upload/buttons-upload/Icons.js +0 -40
  526. package/dist/upload/dragAndDropArea/DragAndDropArea.js +0 -329
  527. package/dist/upload/dragAndDropArea/Icons.js +0 -39
  528. package/dist/upload/file-upload/FileToUpload.js +0 -189
  529. package/dist/upload/file-upload/Icons.js +0 -66
  530. package/dist/upload/files-upload/FilesToUpload.js +0 -123
  531. package/dist/upload/index.d.ts +0 -15
  532. package/dist/upload/transaction/Icons.js +0 -160
  533. package/dist/upload/transaction/Transaction.js +0 -148
  534. package/dist/upload/transactions/Transactions.js +0 -138
  535. package/dist/wizard/Icons.js +0 -65
  536. package/dist/wizard/Wizard.js +0 -405
  537. package/dist/wizard/index.d.ts +0 -18
  538. package/test/Accordion.test.js +0 -33
  539. package/test/AccordionGroup.test.js +0 -125
  540. package/test/Alert.test.js +0 -53
  541. package/test/Box.test.js +0 -10
  542. package/test/Button.test.js +0 -18
  543. package/test/Card.test.js +0 -30
  544. package/test/Checkbox.test.js +0 -45
  545. package/test/Chip.test.js +0 -25
  546. package/test/Date.test.js +0 -395
  547. package/test/DateInput.test.js +0 -242
  548. package/test/Dialog.test.js +0 -23
  549. package/test/Dropdown.test.js +0 -145
  550. package/test/FileInput.test.js +0 -201
  551. package/test/Footer.test.js +0 -94
  552. package/test/Header.test.js +0 -34
  553. package/test/Heading.test.js +0 -83
  554. package/test/InputText.test.js +0 -248
  555. package/test/Link.test.js +0 -43
  556. package/test/NumberInput.test.js +0 -259
  557. package/test/Paginator.test.js +0 -177
  558. package/test/PasswordInput.test.js +0 -83
  559. package/test/ProgressBar.test.js +0 -35
  560. package/test/Radio.test.js +0 -37
  561. package/test/ResultsetTable.test.js +0 -329
  562. package/test/Sidenav.test.js +0 -45
  563. package/test/Slider.test.js +0 -74
  564. package/test/Spinner.test.js +0 -32
  565. package/test/Switch.test.js +0 -45
  566. package/test/Table.test.js +0 -36
  567. package/test/Tabs.test.js +0 -109
  568. package/test/Tag.test.js +0 -32
  569. package/test/TextInput.test.js +0 -732
  570. package/test/Textarea.test.js +0 -193
  571. package/test/ToggleGroup.test.js +0 -85
  572. package/test/Upload.test.js +0 -60
  573. package/test/V3Select.test.js +0 -212
  574. package/test/V3TextArea.test.js +0 -51
  575. package/test/Wizard.test.js +0 -130
  576. package/test/mocks/pngMock.js +0 -1
  577. package/test/mocks/svgMock.js +0 -1
@@ -0,0 +1,171 @@
1
+ import React from "react";
2
+ import Title from "../../.storybook/components/Title";
3
+ import ExampleContainer from "../../.storybook/components/ExampleContainer";
4
+ import DxcCard from "./Card";
5
+ import { userEvent, within } from "@storybook/testing-library";
6
+
7
+ export default {
8
+ title: "Card",
9
+ component: DxcCard,
10
+ };
11
+
12
+ const Card = () => (
13
+ <>
14
+ <Title title="Default" theme="light" level={4} />
15
+ <ExampleContainer>
16
+ <DxcCard>Default</DxcCard>
17
+ </ExampleContainer>
18
+ <Title title="Not outlined" theme="light" level={4} />
19
+ <ExampleContainer>
20
+ <DxcCard outlined={false}>Not outlined</DxcCard>
21
+ </ExampleContainer>
22
+ <Title title="Default with link" theme="light" level={4} />
23
+ <ExampleContainer>
24
+ <DxcCard linkHref="https://www.dxc.com">Default with link</DxcCard>
25
+ </ExampleContainer>
26
+ <Title title="Focused default with link" theme="light" level={4} />
27
+ <ExampleContainer>
28
+ <DxcCard linkHref="https://www.dxc.com">Focused default with link</DxcCard>
29
+ </ExampleContainer>
30
+ <Title title="Hovered default with link" theme="light" level={4} />
31
+ <ExampleContainer>
32
+ <DxcCard linkHref="https://www.dxc.com">Hovered default with link</DxcCard>
33
+ </ExampleContainer>
34
+ <Title title="Default with action" theme="light" level={4} />
35
+ <ExampleContainer>
36
+ <DxcCard onClick={() => {}}>Default with action</DxcCard>
37
+ </ExampleContainer>
38
+ <Title title="Default with image" theme="light" level={4} />
39
+ <ExampleContainer>
40
+ <DxcCard imageSrc="https://picsum.photos/id/1022/200/300">Default</DxcCard>
41
+ </ExampleContainer>
42
+ <Title title="Default image with background color" theme="light" level={4} />
43
+ <ExampleContainer>
44
+ <DxcCard imageSrc="https://picsum.photos/id/1022/200/300" imageBgColor="yellow">
45
+ Background color
46
+ </DxcCard>
47
+ </ExampleContainer>
48
+ <Title title="Default image with position after" theme="light" level={4} />
49
+ <ExampleContainer>
50
+ <DxcCard imageSrc="https://picsum.photos/id/1022/200/300" imagePosition="after">
51
+ Position after
52
+ </DxcCard>
53
+ </ExampleContainer>
54
+ <Title title="Image cover" theme="light" level={4} />
55
+ <ExampleContainer>
56
+ <DxcCard imageSrc="https://picsum.photos/id/1022/200/300" imageCover>
57
+ Image cover
58
+ </DxcCard>
59
+ </ExampleContainer>
60
+ <Title title="Image cover with position after" theme="light" level={4} />
61
+ <ExampleContainer>
62
+ <DxcCard imageSrc="https://picsum.photos/id/1022/200/300" imageCover imagePosition="after">
63
+ Image cover with position after
64
+ </DxcCard>
65
+ </ExampleContainer>
66
+ <Title title="Image padding" theme="light" level={2} />
67
+ <ExampleContainer>
68
+ <Title title="Xxsmall" theme="light" level={4} />
69
+ <DxcCard imageSrc="https://picsum.photos/id/1022/200/300" imagePadding="xxsmall" imageCover>
70
+ Xxsmall
71
+ </DxcCard>
72
+ </ExampleContainer>
73
+ <ExampleContainer>
74
+ <Title title="Xsmall" theme="light" level={4} />
75
+ <DxcCard imageSrc="https://picsum.photos/id/1022/200/300" imagePadding="xsmall" imageCover>
76
+ Xsmall
77
+ </DxcCard>
78
+ </ExampleContainer>
79
+ <ExampleContainer>
80
+ <Title title="Small" theme="light" level={4} />
81
+ <DxcCard imageSrc="https://picsum.photos/id/1022/200/300" imagePadding="small" imageCover>
82
+ Small
83
+ </DxcCard>
84
+ </ExampleContainer>
85
+ <ExampleContainer>
86
+ <Title title="Medium" theme="light" level={4} />
87
+ <DxcCard imageSrc="https://picsum.photos/id/1022/200/300" imagePadding="medium" imageCover>
88
+ Medium
89
+ </DxcCard>
90
+ </ExampleContainer>
91
+ <ExampleContainer>
92
+ <Title title="Large" theme="light" level={4} />
93
+ <DxcCard imageSrc="https://picsum.photos/id/1022/200/300" imagePadding="large" imageCover>
94
+ Large
95
+ </DxcCard>
96
+ </ExampleContainer>
97
+ <ExampleContainer>
98
+ <Title title="Xlarge" theme="light" level={4} />
99
+ <DxcCard imageSrc="https://picsum.photos/id/1022/200/300" imagePadding="xlarge" imageCover>
100
+ Xlarge
101
+ </DxcCard>
102
+ </ExampleContainer>
103
+ <ExampleContainer>
104
+ <Title title="Xxlarge" theme="light" level={4} />
105
+ <DxcCard imageSrc="https://picsum.photos/id/1022/200/300" imagePadding="xxlarge" imageCover>
106
+ Xxlarge
107
+ </DxcCard>
108
+ </ExampleContainer>
109
+ <Title title="Margin" theme="light" level={2} />
110
+ <ExampleContainer>
111
+ <Title title="Xxsmall" theme="light" level={4} />
112
+ <DxcCard margin="xxsmall">Xxsmall</DxcCard>
113
+ </ExampleContainer>
114
+ <ExampleContainer>
115
+ <Title title="Xsmall" theme="light" level={4} />
116
+ <DxcCard margin="xsmall">Xsmall</DxcCard>
117
+ </ExampleContainer>
118
+ <ExampleContainer>
119
+ <Title title="Small" theme="light" level={4} />
120
+ <DxcCard margin="small">Small</DxcCard>
121
+ </ExampleContainer>
122
+ <ExampleContainer>
123
+ <Title title="Medium" theme="light" level={4} />
124
+ <DxcCard margin="medium">Medium</DxcCard>
125
+ </ExampleContainer>
126
+ <ExampleContainer>
127
+ <Title title="Large" theme="light" level={4} />
128
+ <DxcCard margin="large">Large</DxcCard>
129
+ </ExampleContainer>
130
+ <ExampleContainer>
131
+ <Title title="Xlarge" theme="light" level={4} />
132
+ <DxcCard margin="xlarge">Xlarge</DxcCard>
133
+ </ExampleContainer>
134
+ <ExampleContainer>
135
+ <Title title="Xxlarge" theme="light" level={4} />
136
+ <DxcCard margin="xxlarge">Xxlarge</DxcCard>
137
+ </ExampleContainer>
138
+ </>
139
+ );
140
+
141
+ const actionCard = () => (
142
+ <>
143
+ <ExampleContainer>
144
+ <Title title="Focused default with action" theme="light" level={4} />
145
+ <DxcCard onClick={() => {}}>Focused default with action</DxcCard>
146
+ </ExampleContainer>
147
+ <ExampleContainer expanded>
148
+ <Title title="Hovered default with action" theme="light" level={4} />
149
+ <DxcCard onClick={() => {}}>Hovered default with action</DxcCard>
150
+ </ExampleContainer>
151
+ </>
152
+ );
153
+
154
+ const linkStates = async (focusCard, hoverCard) => {
155
+ await focusCard.focus();
156
+ await userEvent.hover(hoverCard);
157
+ };
158
+
159
+ export const ActionCardStates = actionCard.bind({});
160
+ ActionCardStates.play = async ({ canvasElement }) => {
161
+ const canvas = within(canvasElement);
162
+ await userEvent.tab();
163
+ await userEvent.hover(canvas.getAllByText("Hovered default with action")[1]);
164
+ };
165
+
166
+ export const Chromatic = Card.bind({});
167
+ Chromatic.play = async ({ canvasElement }) => {
168
+ const canvas = within(canvasElement);
169
+ const linkCards = canvas.getAllByRole("link");
170
+ await linkStates(linkCards[1], linkCards[2]);
171
+ };
@@ -0,0 +1,39 @@
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 _Card = _interopRequireDefault(require("./Card.tsx"));
7
+ describe("Card component tests", function () {
8
+ test("Card renders with correct content", function () {
9
+ var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Card["default"], null, "test-card")),
10
+ getByText = _render.getByText;
11
+ expect(getByText("test-card")).toBeTruthy();
12
+ });
13
+ test("Card renders with correct href", function () {
14
+ var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Card["default"], {
15
+ linkHref: "/testPage"
16
+ }, "test-card")),
17
+ getByRole = _render2.getByRole;
18
+ var card = getByRole("link");
19
+ expect(card.getAttribute("href")).toEqual("/testPage");
20
+ });
21
+ test("Card renders with correct image", function () {
22
+ var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Card["default"], {
23
+ imageSrc: "/testImage"
24
+ }, "test-card")),
25
+ getByRole = _render3.getByRole;
26
+ var card = getByRole("img");
27
+ expect(card.getAttribute("src")).toEqual("/testImage");
28
+ });
29
+ test("OnClick function is called", function () {
30
+ var onClick = jest.fn();
31
+ var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Card["default"], {
32
+ onClick: onClick
33
+ }, "test-card")),
34
+ getByText = _render4.getByText;
35
+ var card = getByText("test-card");
36
+ _react2.fireEvent.click(card);
37
+ expect(onClick).toHaveBeenCalled();
38
+ });
39
+ });
@@ -0,0 +1,62 @@
1
+ /// <reference types="react" />
2
+ type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
+ type Size = {
4
+ top?: Space;
5
+ bottom?: Space;
6
+ left?: Space;
7
+ right?: Space;
8
+ };
9
+ type Props = {
10
+ /**
11
+ * URL of the image that will be placed in the card component.
12
+ * In case of omission, the image container will not appear and
13
+ * the content will occupy its space.
14
+ */
15
+ imageSrc?: string;
16
+ /**
17
+ * Color of the image background.
18
+ */
19
+ imageBgColor?: string;
20
+ /**
21
+ * Size of the padding to be applied to the image section of the
22
+ * component. You can pass an object with 'top', 'bottom', 'left'
23
+ * and 'right' properties in order to specify different padding sizes.
24
+ */
25
+ imagePadding?: Space | Size;
26
+ /**
27
+ * Whether the image should appear in relation to the content.
28
+ */
29
+ imagePosition?: "before" | "after";
30
+ /**
31
+ * If defined, the tag will be displayed as an anchor, using this prop
32
+ * as "href". Component will show some visual feedback on hover.
33
+ */
34
+ linkHref?: string;
35
+ /**
36
+ * This function will be called when the user clicks the card. Component
37
+ * will show some visual feedback on hover.
38
+ */
39
+ onClick?: () => void;
40
+ /**
41
+ * Whether the image must cover the whole image area of the card.
42
+ */
43
+ imageCover?: boolean;
44
+ /**
45
+ * Size of the margin to be applied to the component ('xxsmall' | 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge' | 'xxlarge').
46
+ * You can pass an object with 'top', 'bottom', 'left' and 'right' properties in order to specify different margin sizes.
47
+ */
48
+ margin?: Space | Size;
49
+ /**
50
+ * Value of the tabindex attribute applied when the component is clickable.
51
+ */
52
+ tabIndex?: number;
53
+ /**
54
+ * Determines whether or not the component should have an outline.
55
+ */
56
+ outlined?: boolean;
57
+ /**
58
+ * Custom content that will be placed inside the component.
59
+ */
60
+ children?: React.ReactNode;
61
+ };
62
+ export default Props;
package/card/types.js ADDED
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
@@ -0,0 +1,87 @@
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 _jestAxe = require("jest-axe");
9
+ var _Checkbox = _interopRequireDefault(require("./Checkbox.tsx"));
10
+ describe("Checkbox component accessibility tests", function () {
11
+ it("Should not have basic accessibility issues", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
12
+ var _render, container, results;
13
+ return _regenerator["default"].wrap(function _callee$(_context) {
14
+ while (1) switch (_context.prev = _context.next) {
15
+ case 0:
16
+ _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
17
+ label: "Checkbox",
18
+ labelPosition: "after",
19
+ name: "name",
20
+ size: "fitContent",
21
+ value: "checkboxValue",
22
+ margin: "small",
23
+ defaultChecked: true,
24
+ optional: true
25
+ })), container = _render.container;
26
+ _context.next = 3;
27
+ return (0, _jestAxe.axe)(container);
28
+ case 3:
29
+ results = _context.sent;
30
+ expect(results).toHaveNoViolations();
31
+ case 5:
32
+ case "end":
33
+ return _context.stop();
34
+ }
35
+ }, _callee);
36
+ })));
37
+ it("Should not have basic accessibility issues for read-only mode", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2() {
38
+ var _render2, container, results;
39
+ return _regenerator["default"].wrap(function _callee2$(_context2) {
40
+ while (1) switch (_context2.prev = _context2.next) {
41
+ case 0:
42
+ _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
43
+ label: "Checkbox",
44
+ labelPosition: "after",
45
+ name: "name",
46
+ size: "fitContent",
47
+ value: "checkboxValue",
48
+ margin: "small",
49
+ readOnly: true
50
+ })), container = _render2.container;
51
+ _context2.next = 3;
52
+ return (0, _jestAxe.axe)(container);
53
+ case 3:
54
+ results = _context2.sent;
55
+ expect(results).toHaveNoViolations();
56
+ case 5:
57
+ case "end":
58
+ return _context2.stop();
59
+ }
60
+ }, _callee2);
61
+ })));
62
+ it("Should not have basic accessibility issues for disabled mode", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee3() {
63
+ var _render3, container, results;
64
+ return _regenerator["default"].wrap(function _callee3$(_context3) {
65
+ while (1) switch (_context3.prev = _context3.next) {
66
+ case 0:
67
+ _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
68
+ label: "Checkbox",
69
+ labelPosition: "after",
70
+ name: "name",
71
+ size: "fitContent",
72
+ value: "checkboxValue",
73
+ margin: "small",
74
+ disabled: true
75
+ })), container = _render3.container;
76
+ _context3.next = 3;
77
+ return (0, _jestAxe.axe)(container);
78
+ case 3:
79
+ results = _context3.sent;
80
+ expect(results).toHaveNoViolations();
81
+ case 5:
82
+ case "end":
83
+ return _context3.stop();
84
+ }
85
+ }, _callee3);
86
+ })));
87
+ });
@@ -0,0 +1,4 @@
1
+ import React from "react";
2
+ import CheckboxPropsType from "./types";
3
+ declare const DxcCheckbox: React.ForwardRefExoticComponent<CheckboxPropsType & React.RefAttributes<HTMLDivElement>>;
4
+ export default DxcCheckbox;
@@ -0,0 +1,215 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _typeof3 = require("@babel/runtime/helpers/typeof");
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports["default"] = void 0;
9
+ var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
10
+ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
11
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
12
+ var _react = _interopRequireWildcard(require("react"));
13
+ var _styledComponents = _interopRequireWildcard(require("styled-components"));
14
+ var _variables = require("../common/variables");
15
+ var _utils = require("../common/utils");
16
+ var _uuid = require("uuid");
17
+ var _useTheme = _interopRequireDefault(require("../useTheme"));
18
+ var _useTranslatedLabels = _interopRequireDefault(require("../useTranslatedLabels"));
19
+ var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5;
20
+ 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); }
21
+ 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 && Object.prototype.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; }
22
+ var checkedIcon = /*#__PURE__*/_react["default"].createElement("svg", {
23
+ fill: "currentColor",
24
+ focusable: "false",
25
+ "aria-hidden": "true",
26
+ viewBox: "0 0 24 24"
27
+ }, /*#__PURE__*/_react["default"].createElement("path", {
28
+ d: "M19 3H5c-1.11 0-2 .9-2 2v14c0 1.1.89 2 2 2h14c1.11 0 2-.9 2-2V5c0-1.1-.89-2-2-2zm-9 14-5-5 1.41-1.41L10 14.17l7.59-7.59L19 8l-9 9z"
29
+ }));
30
+ var DxcCheckbox = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
31
+ var checked = _ref.checked,
32
+ _ref$defaultChecked = _ref.defaultChecked,
33
+ defaultChecked = _ref$defaultChecked === void 0 ? false : _ref$defaultChecked,
34
+ value = _ref.value,
35
+ _ref$label = _ref.label,
36
+ label = _ref$label === void 0 ? "" : _ref$label,
37
+ _ref$labelPosition = _ref.labelPosition,
38
+ labelPosition = _ref$labelPosition === void 0 ? "before" : _ref$labelPosition,
39
+ _ref$name = _ref.name,
40
+ name = _ref$name === void 0 ? "" : _ref$name,
41
+ _ref$disabled = _ref.disabled,
42
+ disabled = _ref$disabled === void 0 ? false : _ref$disabled,
43
+ _ref$optional = _ref.optional,
44
+ optional = _ref$optional === void 0 ? false : _ref$optional,
45
+ _ref$readOnly = _ref.readOnly,
46
+ readOnly = _ref$readOnly === void 0 ? false : _ref$readOnly,
47
+ onChange = _ref.onChange,
48
+ margin = _ref.margin,
49
+ _ref$size = _ref.size,
50
+ size = _ref$size === void 0 ? "fitContent" : _ref$size,
51
+ _ref$tabIndex = _ref.tabIndex,
52
+ tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
53
+ var _useState = (0, _react.useState)("label-checkbox-".concat((0, _uuid.v4)())),
54
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 1),
55
+ labelId = _useState2[0];
56
+ var _useState3 = (0, _react.useState)(defaultChecked),
57
+ _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
58
+ innerChecked = _useState4[0],
59
+ setInnerChecked = _useState4[1];
60
+ var checkboxRef = (0, _react.useRef)(null);
61
+ var colorsTheme = (0, _useTheme["default"])();
62
+ var translatedLabels = (0, _useTranslatedLabels["default"])();
63
+ var handleCheckboxChange = function handleCheckboxChange() {
64
+ if (!disabled && !readOnly) {
65
+ var _checkboxRef$current;
66
+ document.activeElement !== (checkboxRef === null || checkboxRef === void 0 ? void 0 : checkboxRef.current) && (checkboxRef === null || checkboxRef === void 0 ? void 0 : (_checkboxRef$current = checkboxRef.current) === null || _checkboxRef$current === void 0 ? void 0 : _checkboxRef$current.focus());
67
+ var newChecked = checked !== null && checked !== void 0 ? checked : innerChecked;
68
+ checked !== null && checked !== void 0 ? checked : setInnerChecked(function (innerChecked) {
69
+ return !innerChecked;
70
+ });
71
+ onChange === null || onChange === void 0 ? void 0 : onChange(!newChecked);
72
+ }
73
+ };
74
+ var handleKeyboard = function handleKeyboard(event) {
75
+ switch (event.key) {
76
+ case " ":
77
+ event.preventDefault();
78
+ handleCheckboxChange();
79
+ }
80
+ };
81
+ return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
82
+ theme: colorsTheme.checkbox
83
+ }, /*#__PURE__*/_react["default"].createElement(MainContainer, {
84
+ disabled: disabled,
85
+ readOnly: readOnly,
86
+ onClick: handleCheckboxChange,
87
+ margin: margin,
88
+ size: size,
89
+ checked: checked !== null && checked !== void 0 ? checked : innerChecked,
90
+ ref: ref
91
+ }, label && /*#__PURE__*/_react["default"].createElement(LabelContainer, {
92
+ id: labelId,
93
+ disabled: disabled,
94
+ labelPosition: labelPosition
95
+ }, label, optional && " ".concat(translatedLabels.formFields.optionalLabel)), /*#__PURE__*/_react["default"].createElement(ValueInput, {
96
+ type: "checkbox",
97
+ checked: checked !== null && checked !== void 0 ? checked : innerChecked,
98
+ name: name,
99
+ "aria-hidden": "true",
100
+ value: value,
101
+ disabled: disabled,
102
+ readOnly: true
103
+ }), /*#__PURE__*/_react["default"].createElement(CheckboxContainer, null, /*#__PURE__*/_react["default"].createElement(Checkbox, {
104
+ onKeyDown: handleKeyboard,
105
+ role: "checkbox",
106
+ tabIndex: disabled ? -1 : tabIndex,
107
+ "aria-checked": checked !== null && checked !== void 0 ? checked : innerChecked,
108
+ "aria-disabled": disabled,
109
+ "aria-readonly": readOnly,
110
+ "aria-required": !disabled && !optional,
111
+ "aria-labelledby": labelId,
112
+ checked: checked !== null && checked !== void 0 ? checked : innerChecked,
113
+ disabled: disabled,
114
+ readOnly: readOnly,
115
+ ref: checkboxRef
116
+ }, (checked !== null && checked !== void 0 ? checked : innerChecked) && checkedIcon))));
117
+ });
118
+ var sizes = {
119
+ small: "120px",
120
+ medium: "240px",
121
+ large: "480px",
122
+ fillParent: "100%",
123
+ fitContent: "fit-content"
124
+ };
125
+ var calculateWidth = function calculateWidth(margin, size) {
126
+ return size === "fillParent" ? "calc(".concat(sizes[size], " - ").concat((0, _utils.getMargin)(margin, "left"), " - ").concat((0, _utils.getMargin)(margin, "right"), ")") : sizes[size];
127
+ };
128
+ var getDisabledColor = function getDisabledColor(theme, element) {
129
+ switch (element) {
130
+ case "check":
131
+ return theme.disabledCheckColor;
132
+ case "background":
133
+ return theme.disabledBackgroundColorChecked;
134
+ case "border":
135
+ return theme.disabledBorderColor;
136
+ case "label":
137
+ return theme.disabledFontColor;
138
+ }
139
+ };
140
+ var getReadOnlyColor = function getReadOnlyColor(theme, element) {
141
+ switch (element) {
142
+ case "check":
143
+ return theme.readOnlyCheckColor;
144
+ case "background":
145
+ return theme.readOnlyBackgroundColorChecked;
146
+ case "hoverBackground":
147
+ return theme.hoverReadOnlyBackgroundColorChecked;
148
+ case "border":
149
+ return theme.readOnlyBorderColor;
150
+ case "hoverBorder":
151
+ return theme.hoverReadOnlyBorderColor;
152
+ }
153
+ };
154
+ var getEnabledColor = function getEnabledColor(theme, element) {
155
+ switch (element) {
156
+ case "check":
157
+ return theme.checkColor;
158
+ case "background":
159
+ return theme.backgroundColorChecked;
160
+ case "hoverBackground":
161
+ return theme.hoverBackgroundColorChecked;
162
+ case "border":
163
+ return theme.borderColor;
164
+ case "hoverBorder":
165
+ return theme.hoverBorderColor;
166
+ case "label":
167
+ return theme.fontColor;
168
+ }
169
+ };
170
+ var LabelContainer = _styledComponents["default"].span(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n order: ", ";\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n"])), function (props) {
171
+ return props.labelPosition === "before" ? 0 : 1;
172
+ }, function (props) {
173
+ return props.disabled ? getDisabledColor(props.theme, "label") : getEnabledColor(props.theme, "label");
174
+ }, function (props) {
175
+ return props.theme.fontFamily;
176
+ }, function (props) {
177
+ return props.theme.fontSize;
178
+ }, function (props) {
179
+ return props.theme.fontWeight;
180
+ });
181
+ var ValueInput = _styledComponents["default"].input(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: none;\n"])));
182
+ var CheckboxContainer = _styledComponents["default"].span(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n justify-content: center;\n height: 24px;\n width: 24px;\n"])));
183
+ var Checkbox = _styledComponents["default"].span(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n position: relative;\n box-sizing: border-box;\n display: flex;\n align-items: center;\n justify-content: center;\n height: 18px;\n width: 18px;\n border: 2px solid\n ", ";\n border-radius: 2px;\n background-color: ", ";\n color: ", ";\n\n &:focus {\n outline: 2px solid ", ";\n outline-offset: 2px;\n }\n svg {\n position: absolute;\n width: 22px;\n height: 22px;\n }\n ", "\n"])), function (props) {
184
+ return props.disabled ? getDisabledColor(props.theme, "border") : props.readOnly ? getReadOnlyColor(props.theme, "border") : getEnabledColor(props.theme, "border");
185
+ }, function (props) {
186
+ return props.checked ? props.disabled ? getDisabledColor(props.theme, "check") : props.readOnly ? getReadOnlyColor(props.theme, "check") : getEnabledColor(props.theme, "check") : "transparent";
187
+ }, function (props) {
188
+ return props.disabled ? getDisabledColor(props.theme, "background") : props.readOnly ? getReadOnlyColor(props.theme, "background") : getEnabledColor(props.theme, "background");
189
+ }, function (props) {
190
+ return props.theme.focusColor;
191
+ }, function (props) {
192
+ return props.disabled && "pointer-events: none;";
193
+ });
194
+ var MainContainer = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n align-items: center;\n gap: ", ";\n width: ", ";\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n cursor: ", ";\n\n &:hover ", " {\n border: 2px solid\n ", ";\n color: ", ";\n }\n"])), function (props) {
195
+ return props.theme.checkLabelSpacing;
196
+ }, function (props) {
197
+ return calculateWidth(props.margin, props.size);
198
+ }, function (props) {
199
+ return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
200
+ }, function (props) {
201
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.top ? _variables.spaces[props.margin.top] : "";
202
+ }, function (props) {
203
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.right ? _variables.spaces[props.margin.right] : "";
204
+ }, function (props) {
205
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.bottom ? _variables.spaces[props.margin.bottom] : "";
206
+ }, function (props) {
207
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.left ? _variables.spaces[props.margin.left] : "";
208
+ }, function (props) {
209
+ return props.disabled ? "not-allowed" : props.readOnly ? "default" : "pointer";
210
+ }, Checkbox, function (props) {
211
+ if (!props.disabled) return props.readOnly ? getReadOnlyColor(props.theme, "hoverBorder") : getEnabledColor(props.theme, "hoverBorder");
212
+ }, function (props) {
213
+ if (!props.disabled) return props.readOnly ? getReadOnlyColor(props.theme, "hoverBackground") : getEnabledColor(props.theme, "hoverBackground");
214
+ });
215
+ var _default = exports["default"] = DxcCheckbox;