@dxc-technology/halstack-react 0.0.0-b0ab1e3 → 0.0.0-b0ec7b9

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 (527) hide show
  1. package/BackgroundColorContext.d.ts +1 -10
  2. package/BackgroundColorContext.js +5 -22
  3. package/HalstackContext.d.ts +1276 -6
  4. package/HalstackContext.js +191 -114
  5. package/README.md +47 -0
  6. package/accordion/Accordion.accessibility.test.d.ts +1 -0
  7. package/accordion/Accordion.accessibility.test.js +71 -0
  8. package/accordion/Accordion.d.ts +1 -1
  9. package/accordion/Accordion.js +101 -159
  10. package/accordion/Accordion.stories.tsx +82 -148
  11. package/accordion/Accordion.test.d.ts +1 -0
  12. package/accordion/Accordion.test.js +24 -40
  13. package/accordion/types.d.ts +6 -17
  14. package/accordion-group/AccordionGroup.accessibility.test.d.ts +1 -0
  15. package/accordion-group/AccordionGroup.accessibility.test.js +82 -0
  16. package/accordion-group/AccordionGroup.d.ts +2 -2
  17. package/accordion-group/AccordionGroup.js +31 -98
  18. package/accordion-group/AccordionGroup.stories.tsx +94 -67
  19. package/accordion-group/AccordionGroup.test.d.ts +1 -0
  20. package/accordion-group/AccordionGroup.test.js +49 -106
  21. package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
  22. package/accordion-group/AccordionGroupAccordion.js +31 -0
  23. package/accordion-group/AccordionGroupContext.d.ts +3 -0
  24. package/accordion-group/AccordionGroupContext.js +8 -0
  25. package/accordion-group/types.d.ts +12 -17
  26. package/action-icon/ActionIcon.accessibility.test.d.ts +1 -0
  27. package/action-icon/ActionIcon.accessibility.test.js +63 -0
  28. package/action-icon/ActionIcon.d.ts +4 -0
  29. package/action-icon/ActionIcon.js +48 -0
  30. package/action-icon/ActionIcon.stories.tsx +41 -0
  31. package/action-icon/ActionIcon.test.d.ts +1 -0
  32. package/action-icon/ActionIcon.test.js +64 -0
  33. package/action-icon/types.d.ts +26 -0
  34. package/alert/Alert.accessibility.test.d.ts +1 -0
  35. package/alert/Alert.accessibility.test.js +95 -0
  36. package/alert/Alert.js +40 -127
  37. package/alert/Alert.stories.tsx +28 -0
  38. package/alert/Alert.test.d.ts +1 -0
  39. package/alert/Alert.test.js +28 -45
  40. package/alert/types.d.ts +5 -5
  41. package/badge/Badge.accessibility.test.d.ts +1 -0
  42. package/badge/Badge.accessibility.test.js +129 -0
  43. package/badge/Badge.d.ts +1 -1
  44. package/badge/Badge.js +142 -40
  45. package/badge/Badge.stories.tsx +210 -0
  46. package/badge/Badge.test.d.ts +1 -0
  47. package/badge/Badge.test.js +30 -0
  48. package/badge/types.d.ts +52 -2
  49. package/bar-chart/BarChart.d.ts +4 -0
  50. package/bar-chart/BarChart.js +152 -0
  51. package/bar-chart/BarChart.stories.tsx +281 -0
  52. package/bar-chart/BarChart.test.d.ts +1 -0
  53. package/bar-chart/BarChart.test.js +194 -0
  54. package/bar-chart/theme.d.ts +3 -0
  55. package/bar-chart/theme.js +31 -0
  56. package/bar-chart/types.d.ts +118 -0
  57. package/bleed/Bleed.js +14 -55
  58. package/bleed/Bleed.stories.tsx +95 -96
  59. package/bleed/types.d.ts +2 -2
  60. package/box/Box.accessibility.test.d.ts +1 -0
  61. package/box/Box.accessibility.test.js +33 -0
  62. package/box/Box.d.ts +1 -1
  63. package/box/Box.js +30 -81
  64. package/box/Box.stories.tsx +38 -51
  65. package/box/Box.test.d.ts +1 -0
  66. package/box/Box.test.js +1 -6
  67. package/box/types.d.ts +3 -14
  68. package/breadcrumbs/Breadcrumbs.accessibility.test.d.ts +1 -0
  69. package/breadcrumbs/Breadcrumbs.accessibility.test.js +96 -0
  70. package/breadcrumbs/Breadcrumbs.d.ts +4 -0
  71. package/breadcrumbs/Breadcrumbs.js +79 -0
  72. package/breadcrumbs/Breadcrumbs.stories.tsx +194 -0
  73. package/breadcrumbs/Breadcrumbs.test.d.ts +1 -0
  74. package/breadcrumbs/Breadcrumbs.test.js +168 -0
  75. package/breadcrumbs/Item.d.ts +4 -0
  76. package/breadcrumbs/Item.js +52 -0
  77. package/breadcrumbs/dropdownTheme.d.ts +53 -0
  78. package/breadcrumbs/dropdownTheme.js +62 -0
  79. package/breadcrumbs/types.d.ts +40 -0
  80. package/bulleted-list/BulletedList.accessibility.test.d.ts +1 -0
  81. package/bulleted-list/BulletedList.accessibility.test.js +119 -0
  82. package/bulleted-list/BulletedList.d.ts +7 -0
  83. package/bulleted-list/BulletedList.js +92 -0
  84. package/bulleted-list/BulletedList.stories.tsx +115 -0
  85. package/bulleted-list/types.d.ts +38 -0
  86. package/button/Button.accessibility.test.d.ts +1 -0
  87. package/button/Button.accessibility.test.js +127 -0
  88. package/button/Button.d.ts +1 -1
  89. package/button/Button.js +64 -115
  90. package/button/Button.stories.tsx +151 -100
  91. package/button/Button.test.d.ts +1 -0
  92. package/button/Button.test.js +19 -16
  93. package/button/types.d.ts +12 -8
  94. package/card/Card.accessibility.test.d.ts +1 -0
  95. package/card/Card.accessibility.test.js +36 -0
  96. package/card/Card.d.ts +1 -1
  97. package/card/Card.js +65 -107
  98. package/card/Card.stories.tsx +13 -43
  99. package/card/Card.test.d.ts +1 -0
  100. package/card/Card.test.js +10 -21
  101. package/card/types.d.ts +6 -11
  102. package/checkbox/Checkbox.accessibility.test.d.ts +1 -0
  103. package/checkbox/Checkbox.accessibility.test.js +87 -0
  104. package/checkbox/Checkbox.d.ts +2 -2
  105. package/checkbox/Checkbox.js +140 -182
  106. package/checkbox/Checkbox.stories.tsx +128 -94
  107. package/checkbox/Checkbox.test.d.ts +1 -0
  108. package/checkbox/Checkbox.test.js +159 -38
  109. package/checkbox/types.d.ts +11 -3
  110. package/chip/Chip.accessibility.test.d.ts +1 -0
  111. package/chip/Chip.accessibility.test.js +67 -0
  112. package/chip/Chip.js +45 -80
  113. package/chip/Chip.stories.tsx +103 -27
  114. package/chip/Chip.test.d.ts +1 -0
  115. package/chip/Chip.test.js +17 -32
  116. package/chip/types.d.ts +4 -4
  117. package/common/coreTokens.d.ts +236 -0
  118. package/common/coreTokens.js +183 -0
  119. package/common/utils.d.ts +1 -0
  120. package/common/utils.js +6 -12
  121. package/common/variables.d.ts +1432 -0
  122. package/common/variables.js +1110 -1184
  123. package/container/Container.d.ts +4 -0
  124. package/container/Container.js +194 -0
  125. package/container/Container.stories.tsx +214 -0
  126. package/container/types.d.ts +176 -0
  127. package/contextual-menu/ContextualMenu.accessibility.test.d.ts +1 -0
  128. package/contextual-menu/ContextualMenu.accessibility.test.js +98 -0
  129. package/contextual-menu/ContextualMenu.d.ts +5 -0
  130. package/contextual-menu/ContextualMenu.js +136 -0
  131. package/contextual-menu/ContextualMenu.stories.tsx +231 -0
  132. package/contextual-menu/ContextualMenu.test.d.ts +1 -0
  133. package/contextual-menu/ContextualMenu.test.js +247 -0
  134. package/contextual-menu/GroupItem.d.ts +4 -0
  135. package/contextual-menu/GroupItem.js +67 -0
  136. package/contextual-menu/ItemAction.d.ts +4 -0
  137. package/contextual-menu/ItemAction.js +88 -0
  138. package/contextual-menu/MenuItem.d.ts +4 -0
  139. package/contextual-menu/MenuItem.js +29 -0
  140. package/contextual-menu/SingleItem.d.ts +4 -0
  141. package/contextual-menu/SingleItem.js +38 -0
  142. package/contextual-menu/types.d.ts +65 -0
  143. package/date-input/Calendar.d.ts +4 -0
  144. package/date-input/Calendar.js +230 -0
  145. package/date-input/DateInput.accessibility.test.d.ts +1 -0
  146. package/date-input/DateInput.accessibility.test.js +229 -0
  147. package/date-input/DateInput.js +158 -299
  148. package/date-input/DateInput.stories.tsx +210 -57
  149. package/date-input/DateInput.test.d.ts +1 -0
  150. package/date-input/DateInput.test.js +699 -370
  151. package/date-input/DatePicker.d.ts +4 -0
  152. package/date-input/DatePicker.js +121 -0
  153. package/date-input/YearPicker.d.ts +4 -0
  154. package/date-input/YearPicker.js +105 -0
  155. package/date-input/types.d.ts +72 -15
  156. package/dialog/Dialog.accessibility.test.d.ts +1 -0
  157. package/dialog/Dialog.accessibility.test.js +69 -0
  158. package/dialog/Dialog.d.ts +1 -1
  159. package/dialog/Dialog.js +61 -106
  160. package/dialog/Dialog.stories.tsx +324 -167
  161. package/dialog/Dialog.test.d.ts +1 -0
  162. package/dialog/Dialog.test.js +349 -19
  163. package/dialog/types.d.ts +18 -25
  164. package/divider/Divider.accessibility.test.d.ts +1 -0
  165. package/divider/Divider.accessibility.test.js +33 -0
  166. package/divider/Divider.d.ts +4 -0
  167. package/divider/Divider.js +36 -0
  168. package/divider/Divider.stories.tsx +224 -0
  169. package/divider/Divider.test.d.ts +1 -0
  170. package/divider/Divider.test.js +38 -0
  171. package/divider/types.d.ts +21 -0
  172. package/divider/types.js +5 -0
  173. package/dropdown/Dropdown.accessibility.test.d.ts +1 -0
  174. package/dropdown/Dropdown.accessibility.test.js +183 -0
  175. package/dropdown/Dropdown.d.ts +1 -1
  176. package/dropdown/Dropdown.js +213 -303
  177. package/dropdown/Dropdown.stories.tsx +236 -58
  178. package/dropdown/Dropdown.test.d.ts +1 -0
  179. package/dropdown/Dropdown.test.js +603 -164
  180. package/dropdown/DropdownMenu.d.ts +4 -0
  181. package/dropdown/DropdownMenu.js +63 -0
  182. package/dropdown/DropdownMenuItem.d.ts +4 -0
  183. package/dropdown/DropdownMenuItem.js +71 -0
  184. package/dropdown/types.d.ts +35 -19
  185. package/file-input/FileInput.accessibility.test.d.ts +1 -0
  186. package/file-input/FileInput.accessibility.test.js +167 -0
  187. package/file-input/FileInput.d.ts +2 -2
  188. package/file-input/FileInput.js +243 -395
  189. package/file-input/FileInput.stories.tsx +123 -12
  190. package/file-input/FileInput.test.d.ts +1 -0
  191. package/file-input/FileInput.test.js +314 -367
  192. package/file-input/FileItem.d.ts +4 -14
  193. package/file-input/FileItem.js +61 -120
  194. package/file-input/types.d.ts +24 -11
  195. package/flex/Flex.d.ts +4 -0
  196. package/flex/Flex.js +57 -0
  197. package/flex/Flex.stories.tsx +112 -0
  198. package/flex/types.d.ts +97 -0
  199. package/flex/types.js +5 -0
  200. package/footer/Footer.accessibility.test.d.ts +1 -0
  201. package/footer/Footer.accessibility.test.js +125 -0
  202. package/footer/Footer.d.ts +1 -1
  203. package/footer/Footer.js +75 -118
  204. package/footer/Footer.stories.tsx +99 -21
  205. package/footer/Footer.test.d.ts +1 -0
  206. package/footer/Footer.test.js +32 -56
  207. package/footer/Icons.d.ts +3 -2
  208. package/footer/Icons.js +54 -23
  209. package/footer/types.d.ts +26 -27
  210. package/grid/Grid.d.ts +7 -0
  211. package/grid/Grid.js +76 -0
  212. package/grid/Grid.stories.tsx +221 -0
  213. package/grid/types.d.ts +115 -0
  214. package/grid/types.js +5 -0
  215. package/header/Header.accessibility.test.d.ts +1 -0
  216. package/header/Header.accessibility.test.js +94 -0
  217. package/header/Header.d.ts +4 -3
  218. package/header/Header.js +95 -185
  219. package/header/Header.stories.tsx +134 -39
  220. package/header/Header.test.d.ts +1 -0
  221. package/header/Header.test.js +12 -25
  222. package/header/Icons.d.ts +2 -2
  223. package/header/Icons.js +5 -15
  224. package/header/types.d.ts +7 -21
  225. package/heading/Heading.accessibility.test.d.ts +1 -0
  226. package/heading/Heading.accessibility.test.js +33 -0
  227. package/heading/Heading.js +10 -32
  228. package/heading/Heading.test.d.ts +1 -0
  229. package/heading/Heading.test.js +64 -94
  230. package/heading/types.d.ts +7 -7
  231. package/icon/Icon.accessibility.test.d.ts +1 -0
  232. package/icon/Icon.accessibility.test.js +30 -0
  233. package/icon/Icon.d.ts +4 -0
  234. package/icon/Icon.js +33 -0
  235. package/icon/Icon.stories.tsx +28 -0
  236. package/icon/types.d.ts +4 -0
  237. package/icon/types.js +5 -0
  238. package/image/Image.accessibility.test.d.ts +1 -0
  239. package/image/Image.accessibility.test.js +56 -0
  240. package/image/Image.d.ts +4 -0
  241. package/image/Image.js +70 -0
  242. package/image/Image.stories.tsx +129 -0
  243. package/image/types.d.ts +72 -0
  244. package/image/types.js +5 -0
  245. package/inset/Inset.js +14 -55
  246. package/inset/Inset.stories.tsx +37 -36
  247. package/inset/types.d.ts +2 -2
  248. package/layout/ApplicationLayout.d.ts +16 -6
  249. package/layout/ApplicationLayout.js +86 -167
  250. package/layout/ApplicationLayout.stories.tsx +85 -94
  251. package/layout/Icons.d.ts +7 -0
  252. package/layout/Icons.js +41 -48
  253. package/layout/types.d.ts +19 -35
  254. package/link/Link.accessibility.test.d.ts +1 -0
  255. package/link/Link.accessibility.test.js +108 -0
  256. package/link/Link.d.ts +3 -2
  257. package/link/Link.js +65 -97
  258. package/link/Link.stories.tsx +157 -55
  259. package/link/Link.test.d.ts +1 -0
  260. package/link/Link.test.js +24 -52
  261. package/link/types.d.ts +15 -31
  262. package/main.d.ts +17 -13
  263. package/main.js +85 -101
  264. package/nav-tabs/NavTabs.accessibility.test.d.ts +1 -0
  265. package/nav-tabs/NavTabs.accessibility.test.js +44 -0
  266. package/nav-tabs/NavTabs.d.ts +7 -0
  267. package/nav-tabs/NavTabs.js +108 -0
  268. package/nav-tabs/NavTabs.stories.tsx +294 -0
  269. package/nav-tabs/NavTabs.test.d.ts +1 -0
  270. package/nav-tabs/NavTabs.test.js +77 -0
  271. package/nav-tabs/NavTabsContext.d.ts +3 -0
  272. package/nav-tabs/NavTabsContext.js +8 -0
  273. package/nav-tabs/Tab.d.ts +4 -0
  274. package/nav-tabs/Tab.js +117 -0
  275. package/nav-tabs/types.d.ts +52 -0
  276. package/nav-tabs/types.js +5 -0
  277. package/number-input/NumberInput.accessibility.test.d.ts +1 -0
  278. package/number-input/NumberInput.accessibility.test.js +227 -0
  279. package/number-input/NumberInput.js +50 -37
  280. package/number-input/NumberInput.stories.tsx +37 -26
  281. package/number-input/NumberInput.test.d.ts +1 -0
  282. package/number-input/NumberInput.test.js +858 -376
  283. package/number-input/NumberInputContext.d.ts +3 -4
  284. package/number-input/NumberInputContext.js +3 -14
  285. package/number-input/types.d.ts +18 -6
  286. package/package.json +57 -52
  287. package/paginator/Paginator.accessibility.test.d.ts +1 -0
  288. package/paginator/Paginator.accessibility.test.js +78 -0
  289. package/paginator/Paginator.js +46 -100
  290. package/paginator/Paginator.stories.tsx +24 -0
  291. package/paginator/Paginator.test.d.ts +1 -0
  292. package/paginator/Paginator.test.js +278 -210
  293. package/paginator/types.d.ts +3 -3
  294. package/paragraph/Paragraph.accessibility.test.d.ts +1 -0
  295. package/paragraph/Paragraph.accessibility.test.js +28 -0
  296. package/paragraph/Paragraph.d.ts +5 -0
  297. package/paragraph/Paragraph.js +22 -0
  298. package/paragraph/Paragraph.stories.tsx +27 -0
  299. package/password-input/PasswordInput.accessibility.test.d.ts +1 -0
  300. package/password-input/PasswordInput.accessibility.test.js +152 -0
  301. package/password-input/PasswordInput.js +62 -125
  302. package/password-input/PasswordInput.stories.tsx +11 -34
  303. package/password-input/PasswordInput.test.d.ts +1 -0
  304. package/password-input/PasswordInput.test.js +158 -142
  305. package/password-input/types.d.ts +9 -8
  306. package/progress-bar/ProgressBar.accessibility.test.d.ts +1 -0
  307. package/progress-bar/ProgressBar.accessibility.test.js +35 -0
  308. package/progress-bar/ProgressBar.js +68 -92
  309. package/progress-bar/ProgressBar.stories.tsx +93 -0
  310. package/progress-bar/ProgressBar.test.d.ts +1 -0
  311. package/progress-bar/ProgressBar.test.js +71 -43
  312. package/progress-bar/types.d.ts +3 -3
  313. package/quick-nav/QuickNav.accessibility.test.d.ts +1 -0
  314. package/quick-nav/QuickNav.accessibility.test.js +57 -0
  315. package/quick-nav/QuickNav.js +71 -41
  316. package/quick-nav/QuickNav.stories.tsx +146 -27
  317. package/quick-nav/types.d.ts +10 -10
  318. package/radio-group/Radio.d.ts +1 -1
  319. package/radio-group/Radio.js +59 -79
  320. package/radio-group/RadioGroup.accessibility.test.d.ts +1 -0
  321. package/radio-group/RadioGroup.accessibility.test.js +97 -0
  322. package/radio-group/RadioGroup.js +74 -121
  323. package/radio-group/RadioGroup.stories.tsx +132 -18
  324. package/radio-group/RadioGroup.test.d.ts +1 -0
  325. package/radio-group/RadioGroup.test.js +518 -459
  326. package/radio-group/types.d.ts +10 -10
  327. package/resultset-table/Icons.d.ts +7 -0
  328. package/resultset-table/Icons.js +47 -0
  329. package/resultset-table/ResultsetTable.accessibility.test.d.ts +1 -0
  330. package/resultset-table/ResultsetTable.accessibility.test.js +284 -0
  331. package/resultset-table/ResultsetTable.d.ts +7 -0
  332. package/resultset-table/ResultsetTable.js +198 -0
  333. package/{resultsetTable → resultset-table}/ResultsetTable.stories.tsx +169 -31
  334. package/resultset-table/ResultsetTable.test.d.ts +1 -0
  335. package/resultset-table/ResultsetTable.test.js +450 -0
  336. package/{resultsetTable → resultset-table}/types.d.ts +47 -13
  337. package/resultset-table/types.js +5 -0
  338. package/select/Listbox.d.ts +3 -3
  339. package/select/Listbox.js +73 -74
  340. package/select/Option.d.ts +3 -3
  341. package/select/Option.js +42 -59
  342. package/select/Select.accessibility.test.d.ts +1 -0
  343. package/select/Select.accessibility.test.js +227 -0
  344. package/select/Select.js +188 -360
  345. package/select/Select.stories.tsx +533 -187
  346. package/select/Select.test.d.ts +1 -0
  347. package/select/Select.test.js +1929 -1818
  348. package/select/selectUtils.d.ts +41 -0
  349. package/select/selectUtils.js +129 -0
  350. package/select/types.d.ts +17 -21
  351. package/sidenav/Sidenav.accessibility.test.d.ts +1 -0
  352. package/sidenav/Sidenav.accessibility.test.js +59 -0
  353. package/sidenav/Sidenav.d.ts +6 -5
  354. package/sidenav/Sidenav.js +136 -71
  355. package/sidenav/Sidenav.stories.tsx +246 -151
  356. package/sidenav/Sidenav.test.d.ts +1 -0
  357. package/sidenav/Sidenav.test.js +25 -44
  358. package/sidenav/SidenavContext.d.ts +5 -0
  359. package/sidenav/SidenavContext.js +13 -0
  360. package/sidenav/types.d.ts +52 -26
  361. package/slider/Slider.accessibility.test.d.ts +1 -0
  362. package/slider/Slider.accessibility.test.js +103 -0
  363. package/slider/Slider.d.ts +2 -2
  364. package/slider/Slider.js +146 -181
  365. package/slider/Slider.stories.tsx +64 -61
  366. package/slider/Slider.test.d.ts +1 -0
  367. package/slider/Slider.test.js +194 -88
  368. package/slider/types.d.ts +7 -3
  369. package/spinner/Spinner.accessibility.test.d.ts +1 -0
  370. package/spinner/Spinner.accessibility.test.js +96 -0
  371. package/spinner/Spinner.d.ts +1 -1
  372. package/spinner/Spinner.js +50 -109
  373. package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +53 -27
  374. package/spinner/Spinner.test.d.ts +1 -0
  375. package/spinner/Spinner.test.js +25 -34
  376. package/spinner/types.d.ts +3 -3
  377. package/status-light/StatusLight.accessibility.test.d.ts +1 -0
  378. package/status-light/StatusLight.accessibility.test.js +157 -0
  379. package/status-light/StatusLight.d.ts +4 -0
  380. package/status-light/StatusLight.js +51 -0
  381. package/status-light/StatusLight.stories.tsx +74 -0
  382. package/status-light/StatusLight.test.d.ts +1 -0
  383. package/status-light/StatusLight.test.js +25 -0
  384. package/status-light/types.d.ts +17 -0
  385. package/status-light/types.js +5 -0
  386. package/switch/Switch.accessibility.test.d.ts +1 -0
  387. package/switch/Switch.accessibility.test.js +98 -0
  388. package/switch/Switch.d.ts +2 -2
  389. package/switch/Switch.js +147 -128
  390. package/switch/Switch.stories.tsx +49 -60
  391. package/switch/Switch.test.d.ts +1 -0
  392. package/switch/Switch.test.js +137 -55
  393. package/switch/types.d.ts +7 -3
  394. package/table/DropdownTheme.js +62 -0
  395. package/table/Table.accessibility.test.d.ts +1 -0
  396. package/table/Table.accessibility.test.js +92 -0
  397. package/table/Table.d.ts +6 -2
  398. package/table/Table.js +78 -35
  399. package/table/Table.stories.tsx +663 -0
  400. package/table/Table.test.d.ts +1 -0
  401. package/table/Table.test.js +92 -7
  402. package/table/types.d.ts +34 -6
  403. package/tabs/Tab.d.ts +4 -0
  404. package/tabs/Tab.js +117 -0
  405. package/tabs/Tabs.accessibility.test.d.ts +1 -0
  406. package/tabs/Tabs.accessibility.test.js +56 -0
  407. package/tabs/Tabs.js +303 -141
  408. package/tabs/Tabs.stories.tsx +124 -12
  409. package/tabs/Tabs.test.d.ts +1 -0
  410. package/tabs/Tabs.test.js +212 -76
  411. package/tabs/types.d.ts +30 -20
  412. package/tag/Tag.accessibility.test.d.ts +1 -0
  413. package/tag/Tag.accessibility.test.js +69 -0
  414. package/tag/Tag.js +35 -67
  415. package/tag/Tag.stories.tsx +19 -9
  416. package/tag/Tag.test.d.ts +1 -0
  417. package/tag/Tag.test.js +17 -36
  418. package/tag/types.d.ts +9 -9
  419. package/text-input/Suggestion.d.ts +4 -0
  420. package/text-input/Suggestion.js +67 -0
  421. package/text-input/Suggestions.d.ts +4 -0
  422. package/text-input/Suggestions.js +94 -0
  423. package/text-input/TextInput.accessibility.test.d.ts +1 -0
  424. package/text-input/TextInput.accessibility.test.js +320 -0
  425. package/text-input/TextInput.js +313 -557
  426. package/text-input/TextInput.stories.tsx +278 -275
  427. package/text-input/TextInput.test.d.ts +1 -0
  428. package/text-input/TextInput.test.js +1418 -1375
  429. package/text-input/types.d.ts +53 -14
  430. package/textarea/Textarea.accessibility.test.d.ts +1 -0
  431. package/textarea/Textarea.accessibility.test.js +155 -0
  432. package/textarea/Textarea.js +76 -127
  433. package/textarea/Textarea.stories.tsx +174 -0
  434. package/textarea/Textarea.test.d.ts +1 -0
  435. package/textarea/Textarea.test.js +151 -182
  436. package/textarea/types.d.ts +10 -6
  437. package/toggle-group/ToggleGroup.accessibility.test.d.ts +1 -0
  438. package/toggle-group/ToggleGroup.accessibility.test.js +107 -0
  439. package/toggle-group/ToggleGroup.d.ts +2 -2
  440. package/toggle-group/ToggleGroup.js +92 -108
  441. package/toggle-group/ToggleGroup.stories.tsx +53 -8
  442. package/toggle-group/ToggleGroup.test.d.ts +1 -0
  443. package/toggle-group/ToggleGroup.test.js +68 -87
  444. package/toggle-group/types.d.ts +28 -19
  445. package/tooltip/Tooltip.accessibility.test.d.ts +1 -0
  446. package/tooltip/Tooltip.accessibility.test.js +144 -0
  447. package/tooltip/Tooltip.d.ts +4 -0
  448. package/tooltip/Tooltip.js +50 -0
  449. package/tooltip/Tooltip.stories.tsx +111 -0
  450. package/tooltip/Tooltip.test.d.ts +1 -0
  451. package/tooltip/Tooltip.test.js +112 -0
  452. package/tooltip/types.d.ts +16 -0
  453. package/tooltip/types.js +5 -0
  454. package/typography/Typography.accessibility.test.d.ts +1 -0
  455. package/typography/Typography.accessibility.test.js +339 -0
  456. package/typography/Typography.d.ts +4 -0
  457. package/typography/Typography.js +23 -0
  458. package/typography/Typography.stories.tsx +196 -0
  459. package/typography/Typography.test.js +23 -0
  460. package/typography/types.d.ts +18 -0
  461. package/typography/types.js +5 -0
  462. package/useTheme.d.ts +1167 -1
  463. package/useTheme.js +2 -9
  464. package/useTranslatedLabels.d.ts +96 -0
  465. package/useTranslatedLabels.js +14 -0
  466. package/utils/BaseTypography.d.ts +21 -0
  467. package/utils/BaseTypography.js +98 -0
  468. package/utils/FocusLock.d.ts +13 -0
  469. package/utils/FocusLock.js +125 -0
  470. package/utils/useWidth.d.ts +2 -0
  471. package/utils/useWidth.js +30 -0
  472. package/wizard/Wizard.accessibility.test.d.ts +1 -0
  473. package/wizard/Wizard.accessibility.test.js +55 -0
  474. package/wizard/Wizard.js +59 -110
  475. package/wizard/Wizard.stories.tsx +60 -2
  476. package/wizard/Wizard.test.d.ts +1 -0
  477. package/wizard/Wizard.test.js +53 -80
  478. package/wizard/types.d.ts +9 -9
  479. package/card/ice-cream.jpg +0 -0
  480. package/common/OpenSans.css +0 -81
  481. package/common/RequiredComponent.js +0 -32
  482. package/common/fonts/OpenSans-Bold.ttf +0 -0
  483. package/common/fonts/OpenSans-BoldItalic.ttf +0 -0
  484. package/common/fonts/OpenSans-ExtraBold.ttf +0 -0
  485. package/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  486. package/common/fonts/OpenSans-Italic.ttf +0 -0
  487. package/common/fonts/OpenSans-Light.ttf +0 -0
  488. package/common/fonts/OpenSans-LightItalic.ttf +0 -0
  489. package/common/fonts/OpenSans-Regular.ttf +0 -0
  490. package/common/fonts/OpenSans-SemiBold.ttf +0 -0
  491. package/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  492. package/list/List.d.ts +0 -4
  493. package/list/List.js +0 -47
  494. package/list/List.stories.tsx +0 -95
  495. package/list/types.d.ts +0 -7
  496. package/number-input/numberInputContextTypes.d.ts +0 -19
  497. package/paginator/Icons.js +0 -66
  498. package/progress-bar/ProgressBar.stories.jsx +0 -58
  499. package/radio/Radio.d.ts +0 -4
  500. package/radio/Radio.js +0 -173
  501. package/radio/Radio.stories.tsx +0 -192
  502. package/radio/Radio.test.js +0 -71
  503. package/radio/types.d.ts +0 -54
  504. package/resultsetTable/ResultsetTable.d.ts +0 -4
  505. package/resultsetTable/ResultsetTable.js +0 -254
  506. package/resultsetTable/ResultsetTable.test.js +0 -306
  507. package/row/Row.d.ts +0 -3
  508. package/row/Row.js +0 -127
  509. package/row/Row.stories.tsx +0 -237
  510. package/row/types.d.ts +0 -28
  511. package/select/Icons.d.ts +0 -10
  512. package/select/Icons.js +0 -93
  513. package/stack/Stack.d.ts +0 -3
  514. package/stack/Stack.js +0 -97
  515. package/stack/Stack.stories.tsx +0 -164
  516. package/stack/types.d.ts +0 -24
  517. package/table/Table.stories.jsx +0 -277
  518. package/text/Text.d.ts +0 -7
  519. package/text/Text.js +0 -30
  520. package/text/Text.stories.tsx +0 -19
  521. package/textarea/Textarea.stories.jsx +0 -157
  522. /package/{list → action-icon}/types.js +0 -0
  523. /package/{radio → bar-chart}/types.js +0 -0
  524. /package/{resultsetTable → breadcrumbs}/types.js +0 -0
  525. /package/{row → bulleted-list}/types.js +0 -0
  526. /package/{stack → container}/types.js +0 -0
  527. /package/{number-input/numberInputContextTypes.js → contextual-menu/types.js} +0 -0
@@ -0,0 +1,4 @@
1
+ import React from "react";
2
+ import ContainerPropsType from "./types";
3
+ declare const DxcContainer: ({ display, width, height, overflow, ...props }: ContainerPropsType) => React.JSX.Element;
4
+ export default DxcContainer;
@@ -0,0 +1,194 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports["default"] = void 0;
8
+ var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
9
+ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
10
+ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
11
+ var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
12
+ var _react = _interopRequireDefault(require("react"));
13
+ var _styledComponents = _interopRequireDefault(require("styled-components"));
14
+ var _coreTokens = require("../common/coreTokens");
15
+ var _templateObject;
16
+ var _excluded = ["display", "width", "height", "overflow"];
17
+ /**
18
+ * This values correspond to the spaces defined in the design system
19
+ * https://developer.dxc.com/halstack/next/principles/spacing/#component-spacing-tokens
20
+ */
21
+ var spaces = {
22
+ xxsmall: "4px",
23
+ xsmall: "8px",
24
+ small: "12px",
25
+ medium: "16px",
26
+ large: "24px",
27
+ xlarge: "32px",
28
+ xxlarge: "48px"
29
+ };
30
+ var DxcContainer = function DxcContainer(_ref) {
31
+ var display = _ref.display,
32
+ width = _ref.width,
33
+ height = _ref.height,
34
+ overflow = _ref.overflow,
35
+ props = (0, _objectWithoutProperties2["default"])(_ref, _excluded);
36
+ return /*#__PURE__*/_react["default"].createElement(Container, (0, _extends2["default"])({
37
+ $display: display,
38
+ $width: width,
39
+ $height: height,
40
+ $overflow: overflow
41
+ }, props));
42
+ };
43
+ var getBorderStyles = function getBorderStyles(direction, borderProperties) {
44
+ var _borderProperties$wid, _borderProperties$sty, _getCoreColorToken;
45
+ return "border-".concat(direction, ": ").concat((_borderProperties$wid = borderProperties === null || borderProperties === void 0 ? void 0 : borderProperties.width) !== null && _borderProperties$wid !== void 0 ? _borderProperties$wid : "", " ").concat((_borderProperties$sty = borderProperties === null || borderProperties === void 0 ? void 0 : borderProperties.style) !== null && _borderProperties$sty !== void 0 ? _borderProperties$sty : "", " ").concat((_getCoreColorToken = (0, _coreTokens.getCoreColorToken)(borderProperties === null || borderProperties === void 0 ? void 0 : borderProperties.color)) !== null && _getCoreColorToken !== void 0 ? _getCoreColorToken : "", ";");
46
+ };
47
+ var Container = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n box-sizing: ", ";\n display: ", ";\n width: ", ";\n height: ", ";\n max-width: ", ";\n max-height: ", ";\n min-width: ", ";\n min-height: ", ";\n position: ", ";\n top: ", ";\n right: ", ";\n bottom: ", ";\n left: ", ";\n float: ", ";\n z-index: ", ";\n box-shadow: ", ";\n\n background-attachment: ", ";\n background-clip: ", ";\n background-color: ", ";\n background-image: ", ";\n background-origin: ", ";\n background-position: ", ";\n background-repeat: ", ";\n background-size: ", ";\n\n border-radius: ", ";\n border-width: ", ";\n border-style: ", ";\n border-color: ", ";\n\n ", ";\n\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n\n outline: ", ";\n outline-offset: ", ";\n\n overflow: ", ";\n overflow-x: ", ";\n overflow-y: ", ";\n\n padding: ", ";\n padding-top: ", ";\n padding-right: ", ";\n padding-bottom: ", ";\n padding-left: ", ";\n"])), function (_ref2) {
48
+ var boxSizing = _ref2.boxSizing;
49
+ return boxSizing;
50
+ }, function (_ref3) {
51
+ var $display = _ref3.$display;
52
+ return $display;
53
+ }, function (_ref4) {
54
+ var $width = _ref4.$width;
55
+ return $width;
56
+ }, function (_ref5) {
57
+ var $height = _ref5.$height;
58
+ return $height;
59
+ }, function (_ref6) {
60
+ var maxWidth = _ref6.maxWidth;
61
+ return maxWidth;
62
+ }, function (_ref7) {
63
+ var maxHeight = _ref7.maxHeight;
64
+ return maxHeight;
65
+ }, function (_ref8) {
66
+ var minWidth = _ref8.minWidth;
67
+ return minWidth;
68
+ }, function (_ref9) {
69
+ var minHeight = _ref9.minHeight;
70
+ return minHeight;
71
+ }, function (_ref10) {
72
+ var position = _ref10.position;
73
+ return position;
74
+ }, function (_ref11) {
75
+ var inset = _ref11.inset;
76
+ return inset === null || inset === void 0 ? void 0 : inset.top;
77
+ }, function (_ref12) {
78
+ var inset = _ref12.inset;
79
+ return inset === null || inset === void 0 ? void 0 : inset.right;
80
+ }, function (_ref13) {
81
+ var inset = _ref13.inset;
82
+ return inset === null || inset === void 0 ? void 0 : inset.bottom;
83
+ }, function (_ref14) {
84
+ var inset = _ref14.inset;
85
+ return inset === null || inset === void 0 ? void 0 : inset.left;
86
+ }, function (_ref15) {
87
+ var _float = _ref15["float"];
88
+ return _float;
89
+ }, function (_ref16) {
90
+ var zIndex = _ref16.zIndex;
91
+ return zIndex;
92
+ }, function (_ref17) {
93
+ var boxShadow = _ref17.boxShadow;
94
+ return boxShadow;
95
+ }, function (_ref18) {
96
+ var background = _ref18.background;
97
+ return background === null || background === void 0 ? void 0 : background.attachment;
98
+ }, function (_ref19) {
99
+ var background = _ref19.background;
100
+ return background === null || background === void 0 ? void 0 : background.clip;
101
+ }, function (_ref20) {
102
+ var background = _ref20.background;
103
+ return (0, _coreTokens.getCoreColorToken)(background === null || background === void 0 ? void 0 : background.color);
104
+ }, function (_ref21) {
105
+ var background = _ref21.background;
106
+ return background === null || background === void 0 ? void 0 : background.image;
107
+ }, function (_ref22) {
108
+ var background = _ref22.background;
109
+ return background === null || background === void 0 ? void 0 : background.origin;
110
+ }, function (_ref23) {
111
+ var background = _ref23.background;
112
+ return background === null || background === void 0 ? void 0 : background.position;
113
+ }, function (_ref24) {
114
+ var background = _ref24.background;
115
+ return background === null || background === void 0 ? void 0 : background.repeat;
116
+ }, function (_ref25) {
117
+ var background = _ref25.background;
118
+ return background === null || background === void 0 ? void 0 : background.size;
119
+ }, function (_ref26) {
120
+ var borderRadius = _ref26.borderRadius;
121
+ return borderRadius;
122
+ }, function (_ref27) {
123
+ var border = _ref27.border;
124
+ return border && "width" in border ? "".concat(border === null || border === void 0 ? void 0 : border.width) : "";
125
+ }, function (_ref28) {
126
+ var border = _ref28.border;
127
+ return border && "style" in border ? "".concat(border === null || border === void 0 ? void 0 : border.style) : "";
128
+ }, function (_ref29) {
129
+ var border = _ref29.border;
130
+ return border && "color" in border ? "".concat((0, _coreTokens.getCoreColorToken)(border === null || border === void 0 ? void 0 : border.color)) : "";
131
+ }, function (_ref30) {
132
+ var border = _ref30.border;
133
+ if (border != null) {
134
+ var styles = "";
135
+ switch (true) {
136
+ case "top" in border:
137
+ styles += getBorderStyles("top", border.top);
138
+ case "right" in border:
139
+ styles += getBorderStyles("right", border.right);
140
+ case "left" in border:
141
+ styles += getBorderStyles("left", border.left);
142
+ case "bottom" in border:
143
+ styles += getBorderStyles("bottom", border.bottom);
144
+ }
145
+ return styles;
146
+ }
147
+ }, function (_ref31) {
148
+ var margin = _ref31.margin;
149
+ return typeof margin === "string" ? spaces[margin] : "";
150
+ }, function (_ref32) {
151
+ var margin = _ref32.margin;
152
+ return (0, _typeof2["default"])(margin) === "object" ? spaces[margin.top] : "";
153
+ }, function (_ref33) {
154
+ var margin = _ref33.margin;
155
+ return (0, _typeof2["default"])(margin) === "object" ? spaces[margin.right] : "";
156
+ }, function (_ref34) {
157
+ var margin = _ref34.margin;
158
+ return (0, _typeof2["default"])(margin) === "object" ? spaces[margin.bottom] : "";
159
+ }, function (_ref35) {
160
+ var margin = _ref35.margin;
161
+ return (0, _typeof2["default"])(margin) === "object" ? spaces[margin.left] : "";
162
+ }, function (_ref36) {
163
+ var _outline$width, _outline$style, _getCoreColorToken2;
164
+ var outline = _ref36.outline;
165
+ return "".concat((_outline$width = outline === null || outline === void 0 ? void 0 : outline.width) !== null && _outline$width !== void 0 ? _outline$width : "", " ").concat((_outline$style = outline === null || outline === void 0 ? void 0 : outline.style) !== null && _outline$style !== void 0 ? _outline$style : "", " ").concat((_getCoreColorToken2 = (0, _coreTokens.getCoreColorToken)(outline === null || outline === void 0 ? void 0 : outline.color)) !== null && _getCoreColorToken2 !== void 0 ? _getCoreColorToken2 : "");
166
+ }, function (_ref37) {
167
+ var outline = _ref37.outline;
168
+ return outline === null || outline === void 0 ? void 0 : outline.offset;
169
+ }, function (_ref38) {
170
+ var $overflow = _ref38.$overflow;
171
+ return typeof $overflow === "string" ? $overflow : "";
172
+ }, function (_ref39) {
173
+ var $overflow = _ref39.$overflow;
174
+ return (0, _typeof2["default"])($overflow) === "object" ? "".concat($overflow === null || $overflow === void 0 ? void 0 : $overflow.x) : "";
175
+ }, function (_ref40) {
176
+ var $overflow = _ref40.$overflow;
177
+ return (0, _typeof2["default"])($overflow) === "object" ? "".concat($overflow === null || $overflow === void 0 ? void 0 : $overflow.y) : "";
178
+ }, function (_ref41) {
179
+ var padding = _ref41.padding;
180
+ return typeof padding === "string" ? spaces[padding] : "";
181
+ }, function (_ref42) {
182
+ var padding = _ref42.padding;
183
+ return (0, _typeof2["default"])(padding) === "object" ? spaces[padding.top] : "";
184
+ }, function (_ref43) {
185
+ var padding = _ref43.padding;
186
+ return (0, _typeof2["default"])(padding) === "object" ? spaces[padding.right] : "";
187
+ }, function (_ref44) {
188
+ var padding = _ref44.padding;
189
+ return (0, _typeof2["default"])(padding) === "object" ? spaces[padding.bottom] : "";
190
+ }, function (_ref45) {
191
+ var padding = _ref45.padding;
192
+ return (0, _typeof2["default"])(padding) === "object" ? spaces[padding.left] : "";
193
+ });
194
+ var _default = exports["default"] = DxcContainer;
@@ -0,0 +1,214 @@
1
+ import React from "react";
2
+ import Title from "../../.storybook/components/Title";
3
+ import ExampleContainer from "../../.storybook/components/ExampleContainer";
4
+ import DxcContainer from "./Container";
5
+ import DxcParagraph from "../paragraph/Paragraph";
6
+ import DxcTypography from "../typography/Typography";
7
+
8
+ export default {
9
+ title: "Container",
10
+ component: DxcContainer,
11
+ };
12
+
13
+ export const Chromatic = () => (
14
+ <>
15
+ <Title title="Box sizing border box" level={4} />
16
+ <ExampleContainer>
17
+ <DxcContainer
18
+ boxSizing="border-box"
19
+ width="200px"
20
+ height="200px"
21
+ background={{ color: "color_purple_400" }}
22
+ border={{
23
+ top: {
24
+ width: "2px",
25
+ color: "color_blue_600",
26
+ style: "solid",
27
+ },
28
+ bottom: {
29
+ width: "thick",
30
+ color: "color_purple_600",
31
+ style: "solid",
32
+ },
33
+ }}
34
+ borderRadius="0 0 0.25rem 0.25rem"
35
+ padding="medium"
36
+ margin="large"
37
+ >
38
+ <b>Example text</b>
39
+ </DxcContainer>
40
+ </ExampleContainer>
41
+ <Title title="Background image" level={4} />
42
+ <ExampleContainer>
43
+ <DxcContainer
44
+ background={{
45
+ image: "url(https://www.laecuaciondigital.com/wp-content/uploads/2023/10/DXC-Technology.png)",
46
+ position: "50%",
47
+ }}
48
+ width="500px"
49
+ height="500px"
50
+ >
51
+ <p>Example text</p>
52
+ </DxcContainer>
53
+ </ExampleContainer>
54
+ <Title title="Positioning of boxes" level={4} />
55
+ <ExampleContainer>
56
+ <DxcContainer
57
+ position="relative"
58
+ width="fit-content"
59
+ border={{ color: "color_purple_400", width: "2px", style: "dashed" }}
60
+ borderRadius="0.25rem"
61
+ margin={{ bottom: "xxlarge" }}
62
+ >
63
+ <DxcContainer display="inline-block" background={{ color: "color_purple_400" }} width="50px" height="50px">
64
+ <b>1</b>
65
+ </DxcContainer>
66
+ <DxcContainer display="inline-block" background={{ color: "color_purple_400" }} width="50px" height="50px">
67
+ <b>2</b>
68
+ </DxcContainer>
69
+ <DxcContainer
70
+ display="inline-block"
71
+ position="absolute"
72
+ inset={{ top: "25px", left: "0" }}
73
+ background={{ color: "color_blue_500" }}
74
+ width="50px"
75
+ height="50px"
76
+ zIndex={1}
77
+ >
78
+ <b>3</b>
79
+ </DxcContainer>
80
+ </DxcContainer>
81
+ </ExampleContainer>
82
+ <Title title="Margin collapse" level={4} />
83
+ <ExampleContainer>
84
+ <DxcContainer
85
+ width="fit-content"
86
+ border={{ color: "color_purple_400", width: "2px", style: "dashed" }}
87
+ borderRadius="0.25rem"
88
+ >
89
+ <DxcContainer
90
+ background={{ color: "color_purple_400" }}
91
+ width="50px"
92
+ height="50px"
93
+ margin={{ bottom: "medium" }}
94
+ >
95
+ <b>1</b>
96
+ </DxcContainer>
97
+ <DxcContainer background={{ color: "color_purple_400" }} width="50px" height="50px" margin={{ top: "large" }}>
98
+ <b>2</b>
99
+ </DxcContainer>
100
+ </DxcContainer>
101
+ </ExampleContainer>
102
+ <Title title="Overflow" level={4} />
103
+ <ExampleContainer>
104
+ <DxcContainer overflow={{ x: "auto" }} maxHeight="100px" width="fit-content">
105
+ <DxcContainer
106
+ border={{ width: "1px", style: "solid", color: "color_black" }}
107
+ background={{ color: "color_purple_400" }}
108
+ width="50px"
109
+ height="50px"
110
+ >
111
+ <b tabIndex={0}>1</b>
112
+ </DxcContainer>
113
+ <DxcContainer
114
+ border={{ width: "1px", style: "solid", color: "color_black" }}
115
+ background={{ color: "color_purple_400" }}
116
+ width="50px"
117
+ height="50px"
118
+ >
119
+ <b tabIndex={0}>2</b>
120
+ </DxcContainer>
121
+ <DxcContainer
122
+ border={{ width: "1px", style: "solid", color: "color_black" }}
123
+ background={{ color: "color_purple_400" }}
124
+ width="50px"
125
+ height="50px"
126
+ >
127
+ <b tabIndex={0}>3</b>
128
+ </DxcContainer>
129
+ </DxcContainer>
130
+ </ExampleContainer>
131
+ <Title title="Float" level={4} />
132
+ <ExampleContainer>
133
+ <DxcContainer padding="medium" border={{ width: "1px", style: "solid", color: "color_black" }}>
134
+ <DxcContainer float="right" background={{ color: "color_purple_400" }} width="100px" height="100px">
135
+ <b>Floating text</b>
136
+ </DxcContainer>
137
+ <p style={{ margin: 0 }}>
138
+ Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nulla facilisis, sapien vitae aliquam lacinia, nisl
139
+ quam tincidunt ligula, eget aliquam eros quam quis nunc. Donec euismod, nisl eget ultricies aliquam, nisl
140
+ velit aliquam nunc, quis aliquam nisl nunc vel nisl. Donec euismod, nisl eget ultricies aliquam, nisl velit
141
+ aliquam nunc, quis aliquam nisl nunc vel nisl. Donec euismod, nisl eget ultricies aliquam, nisl velit aliquam
142
+ nunc, quis aliquam nisl nunc vel nisl. Donec euismod, nisl eget ultricies aliquam, nisl velit aliquam nunc,
143
+ quis aliquam nisl nunc vel nisl. Donec euismod, nisl eget ultricies aliquam, nisl velit aliquam nunc, quis
144
+ aliquam nisl nunc vel nisl. Donec euismod, nisl eget ultricies aliquam, nisl velit aliquam nunc, quis aliquam
145
+ nisl nunc vel nisl. Donec euismod, nisl eget ultricies aliquam, nisl velit aliquam nunc, quis aliquam nisl.
146
+ </p>
147
+ </DxcContainer>
148
+ </ExampleContainer>
149
+ <Title title="Box shadow and opacity" level={4} />
150
+ <ExampleContainer>
151
+ <DxcContainer
152
+ padding="medium"
153
+ outline={{ width: "1px", style: "solid", color: "color_black" }}
154
+ boxShadow="10px 5px 5px #fe0123"
155
+ >
156
+ <p style={{ margin: 0 }}>
157
+ Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nulla facilisis, sapien vitae aliquam lacinia, nisl
158
+ quam tincidunt ligula, eget aliquam eros quam quis nunc. Donec euismod, nisl eget ultricies aliquam, nisl
159
+ velit aliquam nunc, quis aliquam nisl nunc vel nisl. Donec euismod, nisl eget ultricies aliquam, nisl velit
160
+ aliquam nunc, quis aliquam nisl nunc vel nisl. Donec euismod, nisl eget ultricies aliquam, nisl velit aliquam
161
+ nunc, quis aliquam nisl nunc vel nisl. Donec euismod, nisl eget ultricies aliquam, nisl velit aliquam nunc,
162
+ quis aliquam nisl nunc vel nisl. Donec euismod, nisl eget ultricies aliquam, nisl velit aliquam nunc, quis
163
+ aliquam nisl nunc vel nisl. Donec euismod, nisl eget ultricies aliquam, nisl velit aliquam nunc, quis aliquam
164
+ nisl.
165
+ </p>
166
+ </DxcContainer>
167
+ </ExampleContainer>
168
+ <Title title="Building a listbox component" level={4} />
169
+ <ExampleContainer>
170
+ <Listbox suggestions={["Option 1", "Option 2", "Option 3", "Option 4", "Option 5"]} />
171
+ </ExampleContainer>
172
+ <Title title="Border and outline" level={4} />
173
+ <ExampleContainer>
174
+ <DxcContainer
175
+ outline={{ color: "color_blue_400", style: "solid", offset: "2px" }}
176
+ border={{ top: { style: "solid" } }}
177
+ >
178
+ Example text
179
+ </DxcContainer>
180
+ </ExampleContainer>
181
+ </>
182
+ );
183
+
184
+ const Listbox = ({ suggestions = [] }: { suggestions: string[] }): JSX.Element => (
185
+ <DxcContainer
186
+ boxSizing="border-box"
187
+ boxShadow="0 4px 6px -1px rgba(0, 0, 0, 0.1)"
188
+ border={{ width: "1px", style: "solid", color: "color_grey_400" }}
189
+ borderRadius="0.25rem"
190
+ background={{ color: "color_white" }}
191
+ padding={{ top: "xxsmall", bottom: "xxsmall" }}
192
+ maxHeight="304px"
193
+ width="250px"
194
+ overflow={{ x: "hidden", y: "auto" }}
195
+ >
196
+ {suggestions.map((suggestion, index) => (
197
+ <DxcContainer padding={{ left: "xsmall", right: "xsmall" }}>
198
+ <DxcContainer
199
+ border={
200
+ index !== suggestions.length - 1
201
+ ? { bottom: { width: "1px", style: "solid", color: "color_grey_200" } }
202
+ : undefined
203
+ }
204
+ padding={{ top: "xxsmall", bottom: "xxsmall", left: "xxsmall", right: "xxsmall" }}
205
+ overflow="hidden"
206
+ >
207
+ <DxcTypography whiteSpace="nowrap" textOverflow="ellipsis" lineHeight="1.715em">
208
+ {suggestion}
209
+ </DxcTypography>
210
+ </DxcContainer>
211
+ </DxcContainer>
212
+ ))}
213
+ </DxcContainer>
214
+ );
@@ -0,0 +1,176 @@
1
+ /// <reference types="react" />
2
+ import { CoreColorTokens } from "../common/coreTokens";
3
+ type SpacingValues = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
4
+ type Space = SpacingValues | {
5
+ top?: SpacingValues;
6
+ right?: SpacingValues;
7
+ bottom?: SpacingValues;
8
+ left?: SpacingValues;
9
+ };
10
+ type Inset = {
11
+ top?: string;
12
+ right?: string;
13
+ bottom?: string;
14
+ left?: string;
15
+ };
16
+ type Background = {
17
+ attachment?: string;
18
+ clip?: string;
19
+ color?: CoreColorTokens;
20
+ image?: string;
21
+ origin?: string;
22
+ position?: string;
23
+ repeat?: string;
24
+ size?: string;
25
+ };
26
+ export type BorderProperties = {
27
+ width?: string;
28
+ style?: "none" | "dotted" | "dashed" | "solid" | "double" | "groove" | "ridge" | "inset" | "outset";
29
+ color?: CoreColorTokens;
30
+ };
31
+ type Border = BorderProperties | {
32
+ top?: BorderProperties;
33
+ right?: BorderProperties;
34
+ bottom?: BorderProperties;
35
+ left?: BorderProperties;
36
+ };
37
+ type Outline = BorderProperties & {
38
+ offset?: string;
39
+ };
40
+ type OverflowValues = "visible" | "hidden" | "clip" | "scroll" | "auto";
41
+ type Overflow = OverflowValues | {
42
+ x?: OverflowValues;
43
+ y?: OverflowValues;
44
+ };
45
+ type Props = {
46
+ /**
47
+ * Based on the CSS property background allows configuring all properties related to the background of a container.
48
+ *
49
+ * See MDN: https://developer.mozilla.org/en-US/docs/Web/CSS/background
50
+ */
51
+ background?: Background;
52
+ /**
53
+ * Based on the CSS property border allows configuring all properties related to the border of a container.
54
+ */
55
+ border?: Border;
56
+ /**
57
+ * Sets the border-radius CSS property.
58
+ *
59
+ * See MDN: https://developer.mozilla.org/en-US/docs/Web/CSS/border-radius
60
+ */
61
+ borderRadius?: string;
62
+ /**
63
+ * Sets the box-shadow CSS property.
64
+ *
65
+ * See MDN: https://developer.mozilla.org/en-US/docs/Web/CSS/box-shadow
66
+ */
67
+ boxShadow?: string;
68
+ /**
69
+ * Sets the box-sizing CSS property.
70
+ *
71
+ * See MDN: https://developer.mozilla.org/en-US/docs/Web/CSS/box-sizing
72
+ */
73
+ boxSizing?: "border-box" | "content-box";
74
+ /**
75
+ * Custom content inside the container.
76
+ */
77
+ children: React.ReactNode;
78
+ /**
79
+ * Sets the display CSS property.
80
+ * The set of values is limited to the ones related to the outer display type.
81
+ * If you want to apply any pattern from the inner box and how the children are laid out,
82
+ * we recommend you to use the Flex and Grid components.
83
+ *
84
+ * See MDN: https://developer.mozilla.org/en-US/docs/Web/CSS/display
85
+ */
86
+ display?: "block" | "inline-block" | "inline" | "none";
87
+ /**
88
+ * Sets the float CSS property.
89
+ *
90
+ * See MDN: https://developer.mozilla.org/en-US/docs/Web/CSS/float
91
+ */
92
+ float?: "left" | "right" | "none";
93
+ /**
94
+ * Sets the height CSS property.
95
+ *
96
+ * See MDN: https://developer.mozilla.org/en-US/docs/Web/CSS/height
97
+ */
98
+ height?: string;
99
+ /**
100
+ * Based on the CSS property inset this prop is a shorthand that corresponds
101
+ * to the top, right, bottom, and/or left properties.
102
+ */
103
+ inset?: Inset;
104
+ /**
105
+ * Size of the margin to be applied to the component.
106
+ * You can pass an object with 'top', 'bottom', 'left' and 'right' properties
107
+ * in order to specify different margin sizes.
108
+ */
109
+ margin?: Space;
110
+ /**
111
+ * Sets the max-height CSS property.
112
+ *
113
+ * See MDN: https://developer.mozilla.org/en-US/docs/Web/CSS/max-height
114
+ */
115
+ maxWidth?: string;
116
+ /**
117
+ * Sets the max-width CSS property.
118
+ *
119
+ * See MDN: https://developer.mozilla.org/en-US/docs/Web/CSS/max-width
120
+ */
121
+ maxHeight?: string;
122
+ /**
123
+ * Sets the min-height CSS property.
124
+ *
125
+ * See MDN: https://developer.mozilla.org/en-US/docs/Web/CSS/min-height
126
+ */
127
+ minWidth?: string;
128
+ /**
129
+ * Sets the min-width CSS property.
130
+ *
131
+ * See MDN: https://developer.mozilla.org/en-US/docs/Web/CSS/min-width
132
+ */
133
+ minHeight?: string;
134
+ /**
135
+ * Based on the CSS property outline allows configuring all properties related
136
+ * to the outline of a container.
137
+ */
138
+ outline?: Outline;
139
+ /**
140
+ * Sets the overflow CSS property.
141
+ *
142
+ * See MDN: https://developer.mozilla.org/en-US/docs/Web/CSS/overflow
143
+ */
144
+ overflow?: Overflow;
145
+ /**
146
+ * Size of the margin to be applied to the component.
147
+ * You can pass an object with 'top', 'bottom', 'left' and 'right' properties
148
+ * in order to specify different margin sizes.
149
+ */
150
+ padding?: Space;
151
+ /**
152
+ * Sets the position CSS property.
153
+ *
154
+ * See MDN: https://developer.mozilla.org/en-US/docs/Web/CSS/position
155
+ */
156
+ position?: "static" | "relative" | "absolute" | "fixed" | "sticky";
157
+ /**
158
+ * Sets the width CSS property.
159
+ *
160
+ * See MDN: https://developer.mozilla.org/en-US/docs/Web/CSS/width
161
+ */
162
+ width?: string;
163
+ /**
164
+ * Sets the z-index CSS property.
165
+ *
166
+ * See MDN: https://developer.mozilla.org/en-US/docs/Web/CSS/z-index
167
+ */
168
+ zIndex?: "auto" | number;
169
+ };
170
+ export type StyledProps = Omit<Props, "display" | "width" | "height" | "opacity" | "overflow"> & {
171
+ $display?: "block" | "inline-block" | "inline" | "none";
172
+ $width?: string;
173
+ $height?: string;
174
+ $overflow?: Overflow;
175
+ };
176
+ export default Props;