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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (443) hide show
  1. package/BackgroundColorContext.d.ts +1 -10
  2. package/BackgroundColorContext.js +5 -22
  3. package/HalstackContext.d.ts +1246 -0
  4. package/HalstackContext.js +310 -0
  5. package/README.md +47 -0
  6. package/accordion/Accordion.accessibility.test.js +71 -0
  7. package/accordion/Accordion.d.ts +1 -1
  8. package/accordion/Accordion.js +105 -181
  9. package/accordion/Accordion.stories.tsx +83 -149
  10. package/accordion/Accordion.test.js +56 -0
  11. package/accordion/types.d.ts +10 -17
  12. package/accordion-group/AccordionGroup.accessibility.test.js +88 -0
  13. package/accordion-group/AccordionGroup.d.ts +3 -3
  14. package/accordion-group/AccordionGroup.js +38 -107
  15. package/accordion-group/AccordionGroup.stories.tsx +95 -68
  16. package/accordion-group/AccordionGroup.test.js +98 -0
  17. package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
  18. package/accordion-group/AccordionGroupAccordion.js +31 -0
  19. package/accordion-group/AccordionGroupContext.d.ts +3 -0
  20. package/accordion-group/AccordionGroupContext.js +8 -0
  21. package/accordion-group/types.d.ts +16 -17
  22. package/action-icon/ActionIcon.accessibility.test.js +63 -0
  23. package/action-icon/ActionIcon.d.ts +4 -0
  24. package/action-icon/ActionIcon.js +48 -0
  25. package/action-icon/ActionIcon.stories.tsx +41 -0
  26. package/action-icon/ActionIcon.test.js +64 -0
  27. package/action-icon/types.d.ts +26 -0
  28. package/alert/Alert.accessibility.test.js +95 -0
  29. package/alert/Alert.js +40 -127
  30. package/alert/Alert.stories.tsx +28 -0
  31. package/alert/Alert.test.js +75 -0
  32. package/alert/types.d.ts +5 -5
  33. package/badge/Badge.accessibility.test.js +129 -0
  34. package/badge/Badge.d.ts +4 -0
  35. package/badge/Badge.js +142 -40
  36. package/badge/Badge.stories.tsx +210 -0
  37. package/badge/Badge.test.js +30 -0
  38. package/badge/types.d.ts +54 -0
  39. package/bleed/Bleed.js +14 -55
  40. package/bleed/Bleed.stories.tsx +95 -95
  41. package/bleed/types.d.ts +26 -2
  42. package/box/Box.accessibility.test.js +33 -0
  43. package/box/Box.d.ts +1 -1
  44. package/box/Box.js +30 -81
  45. package/box/Box.stories.tsx +38 -51
  46. package/box/Box.test.js +13 -0
  47. package/box/types.d.ts +3 -14
  48. package/breadcrumbs/Breadcrumbs.accessibility.test.d.ts +1 -0
  49. package/breadcrumbs/Breadcrumbs.accessibility.test.js +96 -0
  50. package/breadcrumbs/Breadcrumbs.d.ts +4 -0
  51. package/breadcrumbs/Breadcrumbs.js +79 -0
  52. package/breadcrumbs/Breadcrumbs.stories.tsx +194 -0
  53. package/breadcrumbs/Breadcrumbs.test.d.ts +1 -0
  54. package/breadcrumbs/Breadcrumbs.test.js +169 -0
  55. package/breadcrumbs/Item.d.ts +4 -0
  56. package/breadcrumbs/Item.js +52 -0
  57. package/breadcrumbs/dropdownTheme.d.ts +53 -0
  58. package/breadcrumbs/dropdownTheme.js +62 -0
  59. package/breadcrumbs/types.d.ts +16 -0
  60. package/bulleted-list/BulletedList.accessibility.test.js +119 -0
  61. package/bulleted-list/BulletedList.d.ts +7 -0
  62. package/bulleted-list/BulletedList.js +92 -0
  63. package/bulleted-list/BulletedList.stories.tsx +115 -0
  64. package/bulleted-list/types.d.ts +38 -0
  65. package/button/Button.accessibility.test.js +127 -0
  66. package/button/Button.d.ts +1 -1
  67. package/button/Button.js +63 -113
  68. package/button/Button.stories.tsx +151 -100
  69. package/button/Button.test.js +38 -0
  70. package/button/types.d.ts +12 -8
  71. package/card/Card.accessibility.test.js +36 -0
  72. package/card/Card.d.ts +1 -1
  73. package/card/Card.js +59 -102
  74. package/card/Card.stories.tsx +12 -42
  75. package/card/Card.test.js +39 -0
  76. package/card/types.d.ts +6 -11
  77. package/checkbox/Checkbox.accessibility.test.js +87 -0
  78. package/checkbox/Checkbox.d.ts +2 -2
  79. package/checkbox/Checkbox.js +143 -181
  80. package/checkbox/Checkbox.stories.tsx +166 -136
  81. package/checkbox/Checkbox.test.js +199 -0
  82. package/checkbox/types.d.ts +18 -6
  83. package/chip/Chip.accessibility.test.js +67 -0
  84. package/chip/Chip.js +45 -80
  85. package/chip/Chip.stories.tsx +107 -27
  86. package/chip/Chip.test.js +41 -0
  87. package/chip/types.d.ts +4 -4
  88. package/common/coreTokens.d.ts +237 -0
  89. package/common/coreTokens.js +184 -0
  90. package/common/utils.d.ts +1 -0
  91. package/common/utils.js +6 -12
  92. package/common/variables.d.ts +1392 -0
  93. package/common/variables.js +1080 -1427
  94. package/container/Container.d.ts +4 -0
  95. package/container/Container.js +194 -0
  96. package/container/Container.stories.tsx +214 -0
  97. package/container/types.d.ts +74 -0
  98. package/contextual-menu/ContextualMenu.accessibility.test.js +97 -0
  99. package/contextual-menu/ContextualMenu.d.ts +5 -0
  100. package/contextual-menu/ContextualMenu.js +88 -0
  101. package/contextual-menu/ContextualMenu.stories.tsx +232 -0
  102. package/contextual-menu/ContextualMenu.test.js +205 -0
  103. package/contextual-menu/GroupItem.d.ts +4 -0
  104. package/contextual-menu/GroupItem.js +67 -0
  105. package/contextual-menu/ItemAction.d.ts +4 -0
  106. package/contextual-menu/ItemAction.js +51 -0
  107. package/contextual-menu/MenuItem.d.ts +4 -0
  108. package/contextual-menu/MenuItem.js +29 -0
  109. package/contextual-menu/SingleItem.d.ts +4 -0
  110. package/contextual-menu/SingleItem.js +38 -0
  111. package/contextual-menu/types.d.ts +58 -0
  112. package/date-input/Calendar.d.ts +4 -0
  113. package/date-input/Calendar.js +214 -0
  114. package/date-input/DateInput.accessibility.test.js +228 -0
  115. package/date-input/DateInput.js +170 -306
  116. package/date-input/DateInput.stories.tsx +210 -56
  117. package/date-input/DateInput.test.js +808 -0
  118. package/date-input/DatePicker.d.ts +4 -0
  119. package/date-input/DatePicker.js +121 -0
  120. package/date-input/YearPicker.d.ts +4 -0
  121. package/date-input/YearPicker.js +100 -0
  122. package/date-input/types.d.ts +86 -22
  123. package/dialog/Dialog.accessibility.test.js +69 -0
  124. package/dialog/Dialog.d.ts +1 -1
  125. package/dialog/Dialog.js +56 -129
  126. package/dialog/Dialog.stories.tsx +326 -167
  127. package/dialog/Dialog.test.js +307 -0
  128. package/dialog/types.d.ts +18 -25
  129. package/divider/Divider.accessibility.test.js +33 -0
  130. package/divider/Divider.d.ts +4 -0
  131. package/divider/Divider.js +36 -0
  132. package/divider/Divider.stories.tsx +223 -0
  133. package/divider/Divider.test.js +38 -0
  134. package/divider/types.d.ts +21 -0
  135. package/divider/types.js +5 -0
  136. package/dropdown/Dropdown.accessibility.test.js +180 -0
  137. package/dropdown/Dropdown.d.ts +1 -1
  138. package/dropdown/Dropdown.js +233 -307
  139. package/dropdown/Dropdown.stories.tsx +235 -57
  140. package/dropdown/Dropdown.test.js +599 -0
  141. package/dropdown/DropdownMenu.d.ts +4 -0
  142. package/dropdown/DropdownMenu.js +63 -0
  143. package/dropdown/DropdownMenuItem.d.ts +4 -0
  144. package/dropdown/DropdownMenuItem.js +71 -0
  145. package/dropdown/types.d.ts +35 -19
  146. package/file-input/FileInput.accessibility.test.js +160 -0
  147. package/file-input/FileInput.d.ts +2 -2
  148. package/file-input/FileInput.js +246 -393
  149. package/file-input/FileInput.stories.tsx +123 -12
  150. package/file-input/FileInput.test.js +382 -0
  151. package/file-input/FileItem.d.ts +4 -14
  152. package/file-input/FileItem.js +61 -120
  153. package/file-input/types.d.ts +25 -8
  154. package/flex/Flex.d.ts +4 -0
  155. package/flex/Flex.js +57 -0
  156. package/flex/Flex.stories.tsx +112 -0
  157. package/flex/types.d.ts +97 -0
  158. package/flex/types.js +5 -0
  159. package/footer/Footer.accessibility.test.js +125 -0
  160. package/footer/Footer.d.ts +1 -1
  161. package/footer/Footer.js +73 -191
  162. package/footer/Footer.stories.tsx +99 -21
  163. package/footer/Footer.test.js +85 -0
  164. package/footer/Icons.d.ts +3 -2
  165. package/footer/Icons.js +54 -23
  166. package/footer/types.d.ts +26 -27
  167. package/grid/Grid.d.ts +7 -0
  168. package/grid/Grid.js +76 -0
  169. package/grid/Grid.stories.tsx +219 -0
  170. package/grid/types.d.ts +115 -0
  171. package/grid/types.js +5 -0
  172. package/header/Header.accessibility.test.js +93 -0
  173. package/header/Header.d.ts +4 -3
  174. package/header/Header.js +104 -218
  175. package/header/Header.stories.tsx +168 -63
  176. package/header/Header.test.js +66 -0
  177. package/header/Icons.d.ts +2 -2
  178. package/header/Icons.js +5 -15
  179. package/header/types.d.ts +7 -21
  180. package/heading/Heading.accessibility.test.js +33 -0
  181. package/heading/Heading.js +10 -32
  182. package/heading/Heading.test.js +169 -0
  183. package/heading/types.d.ts +7 -7
  184. package/icon/Icon.accessibility.test.js +30 -0
  185. package/icon/Icon.d.ts +4 -0
  186. package/icon/Icon.js +33 -0
  187. package/icon/Icon.stories.tsx +28 -0
  188. package/icon/types.d.ts +4 -0
  189. package/icon/types.js +5 -0
  190. package/image/Image.accessibility.test.js +56 -0
  191. package/image/Image.d.ts +4 -0
  192. package/image/Image.js +70 -0
  193. package/image/Image.stories.tsx +129 -0
  194. package/image/types.d.ts +72 -0
  195. package/image/types.js +5 -0
  196. package/inset/Inset.js +14 -55
  197. package/inset/Inset.stories.tsx +37 -36
  198. package/inset/types.d.ts +26 -2
  199. package/layout/ApplicationLayout.d.ts +16 -6
  200. package/layout/ApplicationLayout.js +88 -182
  201. package/layout/ApplicationLayout.stories.tsx +85 -94
  202. package/layout/Icons.d.ts +7 -0
  203. package/layout/Icons.js +41 -48
  204. package/layout/types.d.ts +19 -35
  205. package/link/Link.accessibility.test.js +108 -0
  206. package/link/Link.d.ts +3 -2
  207. package/link/Link.js +65 -101
  208. package/link/Link.stories.tsx +157 -55
  209. package/link/Link.test.js +63 -0
  210. package/link/types.d.ts +15 -31
  211. package/main.d.ts +19 -18
  212. package/main.js +84 -123
  213. package/nav-tabs/NavTabs.accessibility.test.js +44 -0
  214. package/nav-tabs/NavTabs.d.ts +7 -0
  215. package/nav-tabs/NavTabs.js +93 -0
  216. package/nav-tabs/NavTabs.stories.tsx +279 -0
  217. package/nav-tabs/NavTabs.test.js +77 -0
  218. package/nav-tabs/NavTabsContext.d.ts +3 -0
  219. package/nav-tabs/NavTabsContext.js +8 -0
  220. package/nav-tabs/Tab.d.ts +4 -0
  221. package/nav-tabs/Tab.js +117 -0
  222. package/nav-tabs/types.d.ts +52 -0
  223. package/nav-tabs/types.js +5 -0
  224. package/number-input/NumberInput.accessibility.test.js +228 -0
  225. package/number-input/NumberInput.js +47 -44
  226. package/number-input/NumberInput.stories.tsx +44 -28
  227. package/number-input/NumberInput.test.js +989 -0
  228. package/number-input/NumberInputContext.d.ts +3 -4
  229. package/number-input/NumberInputContext.js +3 -14
  230. package/number-input/types.d.ts +34 -15
  231. package/package.json +54 -53
  232. package/paginator/Paginator.accessibility.test.js +79 -0
  233. package/paginator/Paginator.js +46 -100
  234. package/paginator/Paginator.stories.tsx +24 -0
  235. package/paginator/Paginator.test.js +335 -0
  236. package/paginator/types.d.ts +3 -3
  237. package/paragraph/Paragraph.accessibility.test.js +28 -0
  238. package/paragraph/Paragraph.d.ts +5 -0
  239. package/paragraph/Paragraph.js +22 -0
  240. package/paragraph/Paragraph.stories.tsx +27 -0
  241. package/password-input/PasswordInput.accessibility.test.js +153 -0
  242. package/password-input/PasswordInput.js +58 -124
  243. package/password-input/PasswordInput.stories.tsx +1 -33
  244. package/password-input/PasswordInput.test.js +198 -0
  245. package/password-input/types.d.ts +21 -17
  246. package/progress-bar/ProgressBar.accessibility.test.js +35 -0
  247. package/progress-bar/ProgressBar.js +68 -92
  248. package/progress-bar/ProgressBar.stories.tsx +93 -0
  249. package/progress-bar/ProgressBar.test.js +93 -0
  250. package/progress-bar/types.d.ts +3 -3
  251. package/quick-nav/QuickNav.accessibility.test.js +57 -0
  252. package/quick-nav/QuickNav.d.ts +4 -0
  253. package/quick-nav/QuickNav.js +94 -0
  254. package/quick-nav/QuickNav.stories.tsx +356 -0
  255. package/quick-nav/types.d.ts +21 -0
  256. package/quick-nav/types.js +5 -0
  257. package/radio-group/Radio.d.ts +1 -1
  258. package/radio-group/Radio.js +64 -80
  259. package/radio-group/RadioGroup.accessibility.test.js +97 -0
  260. package/radio-group/RadioGroup.js +102 -139
  261. package/radio-group/RadioGroup.stories.tsx +171 -36
  262. package/radio-group/RadioGroup.test.js +691 -183
  263. package/radio-group/types.d.ts +89 -11
  264. package/resultset-table/Icons.d.ts +7 -0
  265. package/resultset-table/Icons.js +47 -0
  266. package/resultset-table/ResultsetTable.accessibility.test.js +285 -0
  267. package/resultset-table/ResultsetTable.d.ts +7 -0
  268. package/resultset-table/ResultsetTable.js +171 -0
  269. package/{resultsetTable → resultset-table}/ResultsetTable.stories.tsx +168 -30
  270. package/resultset-table/ResultsetTable.test.js +381 -0
  271. package/{resultsetTable → resultset-table}/types.d.ts +44 -11
  272. package/resultset-table/types.js +5 -0
  273. package/select/Listbox.d.ts +4 -0
  274. package/select/Listbox.js +155 -0
  275. package/select/Option.d.ts +4 -0
  276. package/select/Option.js +89 -0
  277. package/select/Select.accessibility.test.js +228 -0
  278. package/select/Select.js +243 -504
  279. package/select/Select.stories.tsx +602 -255
  280. package/select/Select.test.js +2265 -0
  281. package/select/types.d.ts +65 -26
  282. package/sidenav/Sidenav.accessibility.test.js +59 -0
  283. package/sidenav/Sidenav.d.ts +6 -5
  284. package/sidenav/Sidenav.js +136 -71
  285. package/sidenav/Sidenav.stories.tsx +246 -151
  286. package/sidenav/Sidenav.test.js +37 -0
  287. package/sidenav/SidenavContext.d.ts +5 -0
  288. package/sidenav/SidenavContext.js +13 -0
  289. package/sidenav/types.d.ts +52 -26
  290. package/slider/Slider.accessibility.test.js +104 -0
  291. package/slider/Slider.d.ts +2 -2
  292. package/slider/Slider.js +149 -180
  293. package/slider/Slider.test.js +254 -0
  294. package/slider/types.d.ts +11 -3
  295. package/spinner/Spinner.accessibility.test.js +96 -0
  296. package/spinner/Spinner.js +34 -74
  297. package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +53 -27
  298. package/spinner/Spinner.test.js +55 -0
  299. package/spinner/types.d.ts +3 -3
  300. package/status-light/StatusLight.accessibility.test.js +157 -0
  301. package/status-light/StatusLight.d.ts +4 -0
  302. package/status-light/StatusLight.js +51 -0
  303. package/status-light/StatusLight.stories.tsx +74 -0
  304. package/status-light/StatusLight.test.js +25 -0
  305. package/status-light/types.d.ts +17 -0
  306. package/status-light/types.js +5 -0
  307. package/switch/Switch.accessibility.test.js +98 -0
  308. package/switch/Switch.d.ts +2 -2
  309. package/switch/Switch.js +149 -114
  310. package/switch/Switch.stories.tsx +56 -67
  311. package/switch/Switch.test.js +180 -0
  312. package/switch/types.d.ts +13 -5
  313. package/table/DropdownTheme.js +62 -0
  314. package/table/Table.accessibility.test.js +93 -0
  315. package/table/Table.d.ts +6 -2
  316. package/table/Table.js +78 -35
  317. package/table/Table.stories.tsx +663 -0
  318. package/table/Table.test.js +113 -0
  319. package/table/types.d.ts +34 -6
  320. package/tabs/Tab.d.ts +4 -0
  321. package/tabs/Tab.js +117 -0
  322. package/tabs/Tabs.accessibility.test.js +56 -0
  323. package/tabs/Tabs.d.ts +1 -1
  324. package/tabs/Tabs.js +305 -145
  325. package/tabs/Tabs.stories.tsx +124 -14
  326. package/tabs/Tabs.test.js +276 -0
  327. package/tabs/types.d.ts +31 -17
  328. package/tag/Tag.accessibility.test.js +69 -0
  329. package/tag/Tag.js +42 -79
  330. package/tag/Tag.stories.tsx +24 -10
  331. package/tag/Tag.test.js +41 -0
  332. package/tag/types.d.ts +9 -9
  333. package/text-input/Suggestion.d.ts +4 -0
  334. package/text-input/Suggestion.js +67 -0
  335. package/text-input/Suggestions.d.ts +4 -0
  336. package/text-input/Suggestions.js +94 -0
  337. package/text-input/TextInput.accessibility.test.js +321 -0
  338. package/text-input/TextInput.js +334 -557
  339. package/text-input/TextInput.stories.tsx +291 -273
  340. package/text-input/TextInput.test.js +1756 -0
  341. package/text-input/types.d.ts +70 -24
  342. package/textarea/Textarea.accessibility.test.js +155 -0
  343. package/textarea/Textarea.js +86 -135
  344. package/textarea/Textarea.stories.tsx +174 -0
  345. package/textarea/Textarea.test.js +406 -0
  346. package/textarea/types.d.ts +27 -16
  347. package/toggle-group/ToggleGroup.accessibility.test.js +107 -0
  348. package/toggle-group/ToggleGroup.d.ts +2 -2
  349. package/toggle-group/ToggleGroup.js +94 -106
  350. package/toggle-group/ToggleGroup.stories.tsx +56 -11
  351. package/toggle-group/ToggleGroup.test.js +137 -0
  352. package/toggle-group/types.d.ts +36 -19
  353. package/typography/Typography.accessibility.test.js +339 -0
  354. package/typography/Typography.d.ts +4 -0
  355. package/typography/Typography.js +23 -0
  356. package/typography/Typography.stories.tsx +198 -0
  357. package/typography/types.d.ts +18 -0
  358. package/typography/types.js +5 -0
  359. package/useTheme.d.ts +1144 -1
  360. package/useTheme.js +4 -11
  361. package/useTranslatedLabels.d.ts +85 -0
  362. package/useTranslatedLabels.js +14 -0
  363. package/utils/BaseTypography.d.ts +21 -0
  364. package/utils/BaseTypography.js +94 -0
  365. package/utils/FocusLock.d.ts +13 -0
  366. package/utils/FocusLock.js +124 -0
  367. package/wizard/Wizard.accessibility.test.js +55 -0
  368. package/wizard/Wizard.d.ts +1 -1
  369. package/wizard/Wizard.js +78 -120
  370. package/wizard/Wizard.stories.tsx +67 -19
  371. package/wizard/Wizard.test.js +114 -0
  372. package/wizard/types.d.ts +14 -10
  373. package/ThemeContext.d.ts +0 -15
  374. package/ThemeContext.js +0 -243
  375. package/V3Select/V3Select.js +0 -455
  376. package/V3Select/index.d.ts +0 -27
  377. package/V3Textarea/V3Textarea.js +0 -260
  378. package/V3Textarea/index.d.ts +0 -27
  379. package/card/ice-cream.jpg +0 -0
  380. package/common/OpenSans.css +0 -81
  381. package/common/RequiredComponent.js +0 -32
  382. package/common/fonts/OpenSans-Bold.ttf +0 -0
  383. package/common/fonts/OpenSans-BoldItalic.ttf +0 -0
  384. package/common/fonts/OpenSans-ExtraBold.ttf +0 -0
  385. package/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  386. package/common/fonts/OpenSans-Italic.ttf +0 -0
  387. package/common/fonts/OpenSans-Light.ttf +0 -0
  388. package/common/fonts/OpenSans-LightItalic.ttf +0 -0
  389. package/common/fonts/OpenSans-Regular.ttf +0 -0
  390. package/common/fonts/OpenSans-SemiBold.ttf +0 -0
  391. package/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  392. package/date/Date.js +0 -373
  393. package/date/index.d.ts +0 -27
  394. package/input-text/Icons.js +0 -22
  395. package/input-text/InputText.js +0 -611
  396. package/input-text/index.d.ts +0 -36
  397. package/list/List.d.ts +0 -4
  398. package/list/List.js +0 -47
  399. package/list/List.stories.tsx +0 -95
  400. package/list/types.d.ts +0 -7
  401. package/number-input/numberInputContextTypes.d.ts +0 -19
  402. package/paginator/Icons.js +0 -66
  403. package/progress-bar/ProgressBar.stories.jsx +0 -58
  404. package/radio/Radio.d.ts +0 -4
  405. package/radio/Radio.js +0 -174
  406. package/radio/Radio.stories.tsx +0 -192
  407. package/radio/types.d.ts +0 -54
  408. package/resultsetTable/ResultsetTable.d.ts +0 -4
  409. package/resultsetTable/ResultsetTable.js +0 -254
  410. package/row/Row.d.ts +0 -3
  411. package/row/Row.js +0 -127
  412. package/row/Row.stories.tsx +0 -237
  413. package/row/types.d.ts +0 -10
  414. package/slider/Slider.stories.tsx +0 -177
  415. package/stack/Stack.d.ts +0 -3
  416. package/stack/Stack.js +0 -97
  417. package/stack/Stack.stories.tsx +0 -164
  418. package/stack/types.d.ts +0 -9
  419. package/table/Table.stories.jsx +0 -277
  420. package/text/Text.d.ts +0 -7
  421. package/text/Text.js +0 -30
  422. package/text/Text.stories.tsx +0 -19
  423. package/textarea/Textarea.stories.jsx +0 -136
  424. package/toggle/Toggle.js +0 -186
  425. package/toggle/index.d.ts +0 -21
  426. package/upload/Upload.js +0 -201
  427. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  428. package/upload/buttons-upload/Icons.js +0 -40
  429. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  430. package/upload/dragAndDropArea/Icons.js +0 -39
  431. package/upload/file-upload/FileToUpload.js +0 -115
  432. package/upload/file-upload/Icons.js +0 -66
  433. package/upload/files-upload/FilesToUpload.js +0 -109
  434. package/upload/index.d.ts +0 -15
  435. package/upload/transaction/Icons.js +0 -160
  436. package/upload/transaction/Transaction.js +0 -104
  437. package/upload/transactions/Transactions.js +0 -94
  438. /package/{list → action-icon}/types.js +0 -0
  439. /package/{radio → badge}/types.js +0 -0
  440. /package/{resultsetTable → breadcrumbs}/types.js +0 -0
  441. /package/{row → bulleted-list}/types.js +0 -0
  442. /package/{stack → container}/types.js +0 -0
  443. /package/{number-input/numberInputContextTypes.js → contextual-menu/types.js} +0 -0
@@ -2,67 +2,84 @@ import React from "react";
2
2
  import DxcSpinner from "./Spinner";
3
3
  import Title from "../../.storybook/components/Title";
4
4
  import ExampleContainer from "../../.storybook/components/ExampleContainer";
5
+ import { HalstackProvider } from "../HalstackContext";
5
6
 
6
7
  export default {
7
8
  title: "Spinner",
8
9
  component: DxcSpinner,
9
10
  };
10
11
 
12
+ const opinionatedTheme = {
13
+ spinner: {
14
+ accentColor: "#5f249f",
15
+ baseColor: "#ffffff",
16
+ fontColor: "#000000",
17
+ overlayColor: "#a46ede",
18
+ overlayFontColor: "#ffffff",
19
+ },
20
+ };
21
+
11
22
  export const Chromatic = () => (
12
23
  <>
13
24
  <ExampleContainer>
14
25
  <Title title="With label" theme="light" level={4} />
15
- <DxcSpinner label="Label" value="50"></DxcSpinner>
26
+ <DxcSpinner label="Label" value={50}></DxcSpinner>
16
27
  <Title title="With value label" theme="light" level={4} />
17
- <DxcSpinner value="50" showValue></DxcSpinner>
28
+ <DxcSpinner value={50} showValue></DxcSpinner>
18
29
  <Title title="With label and value label" theme="light" level={4} />
19
- <DxcSpinner label="Label" value="50" showValue></DxcSpinner>
30
+ <DxcSpinner label="Label" value={50} showValue></DxcSpinner>
20
31
  <Title title="With 100%" theme="light" level={4} />
21
- <DxcSpinner label="Label" value="100" showValue></DxcSpinner>
32
+ <DxcSpinner label="Label" value={100} showValue></DxcSpinner>
22
33
  </ExampleContainer>
23
34
  <Title title="Modes" theme="light" level={2} />
24
35
  <ExampleContainer>
25
36
  <Title title="Mode large" theme="light" level={4} />
26
- <DxcSpinner mode="large" value="50"></DxcSpinner>
37
+ <DxcSpinner mode="large" value={50}></DxcSpinner>
27
38
  <Title title="Mode small" theme="light" level={4} />
28
- <DxcSpinner mode="small" value="50"></DxcSpinner>
39
+ <DxcSpinner mode="small" value={50}></DxcSpinner>
29
40
  <Title title="Mode small with 100%" theme="light" level={4} />
30
- <DxcSpinner mode="small" value="100" showValue></DxcSpinner>
41
+ <DxcSpinner mode="small" value={100} showValue></DxcSpinner>
31
42
  </ExampleContainer>
32
43
  <Title title="Margins with large mode" theme="light" level={2} />
33
44
  <ExampleContainer>
34
45
  <Title title="Xxsmall margin" theme="light" level={4} />
35
- <DxcSpinner margin="xxsmall" value="75"></DxcSpinner>
46
+ <DxcSpinner margin="xxsmall" value={75}></DxcSpinner>
36
47
  <Title title="Xsmall margin" theme="light" level={4} />
37
- <DxcSpinner margin="xsmall" value="75"></DxcSpinner>
48
+ <DxcSpinner margin="xsmall" value={75}></DxcSpinner>
38
49
  <Title title="Small margin" theme="light" level={4} />
39
- <DxcSpinner margin="small" value="75"></DxcSpinner>
50
+ <DxcSpinner margin="small" value={75}></DxcSpinner>
40
51
  <Title title="Medium margin" theme="light" level={4} />
41
- <DxcSpinner margin="medium" value="75"></DxcSpinner>
52
+ <DxcSpinner margin="medium" value={75}></DxcSpinner>
42
53
  <Title title="Large margin" theme="light" level={4} />
43
- <DxcSpinner margin="large" value="75"></DxcSpinner>
54
+ <DxcSpinner margin="large" value={75}></DxcSpinner>
44
55
  <Title title="Xlarge margin" theme="light" level={4} />
45
- <DxcSpinner margin="xlarge" value="75"></DxcSpinner>
56
+ <DxcSpinner margin="xlarge" value={75}></DxcSpinner>
46
57
  <Title title="Xxlarge margin" theme="light" level={4} />
47
- <DxcSpinner margin="xxlarge" value="75"></DxcSpinner>
58
+ <DxcSpinner margin="xxlarge" value={75}></DxcSpinner>
48
59
  </ExampleContainer>
49
60
  <Title title="Margins with small mode" theme="light" level={2} />
50
61
  <ExampleContainer>
51
62
  <Title title="Xxsmall margin" theme="light" level={4} />
52
- <DxcSpinner margin="xxsmall" mode="small" value="75"></DxcSpinner>
63
+ <DxcSpinner margin="xxsmall" mode="small" value={75}></DxcSpinner>
53
64
  <Title title="Xsmall margin" theme="light" level={4} />
54
- <DxcSpinner margin="xsmall" mode="small" value="75"></DxcSpinner>
65
+ <DxcSpinner margin="xsmall" mode="small" value={75}></DxcSpinner>
55
66
  <Title title="Small margin" theme="light" level={4} />
56
- <DxcSpinner margin="small" mode="small" value="75"></DxcSpinner>
67
+ <DxcSpinner margin="small" mode="small" value={75}></DxcSpinner>
57
68
  <Title title="Medium margin" theme="light" level={4} />
58
- <DxcSpinner margin="medium" mode="small" value="75"></DxcSpinner>
69
+ <DxcSpinner margin="medium" mode="small" value={75}></DxcSpinner>
59
70
  <Title title="Large margin" theme="light" level={4} />
60
- <DxcSpinner margin="large" mode="small" value="75"></DxcSpinner>
71
+ <DxcSpinner margin="large" mode="small" value={75}></DxcSpinner>
61
72
  <Title title="Xlarge margin" theme="light" level={4} />
62
- <DxcSpinner margin="xlarge" mode="small" value="75"></DxcSpinner>
73
+ <DxcSpinner margin="xlarge" mode="small" value={75}></DxcSpinner>
63
74
  <Title title="Xxlarge margin" theme="light" level={4} />
64
- <DxcSpinner margin="xxlarge" mode="small" value="75"></DxcSpinner>
65
- <hr />
75
+ <DxcSpinner margin="xxlarge" mode="small" value={75}></DxcSpinner>
76
+ </ExampleContainer>
77
+ <Title title="Opinionated theme" theme="light" level={2} />
78
+ <ExampleContainer>
79
+ <Title title="With label and value label" theme="light" level={4} />
80
+ <HalstackProvider theme={opinionatedTheme}>
81
+ <DxcSpinner label="Label" value={50} showValue></DxcSpinner>
82
+ </HalstackProvider>
66
83
  </ExampleContainer>
67
84
  </>
68
85
  );
@@ -70,34 +87,43 @@ export const Chromatic = () => (
70
87
  export const SpinnerOverlay = () => (
71
88
  <ExampleContainer>
72
89
  <Title title="Mode overlay" theme="light" level={4} />
73
- <DxcSpinner mode="overlay" value="25"></DxcSpinner>
90
+ <DxcSpinner mode="overlay" value={25}></DxcSpinner>
74
91
  </ExampleContainer>
75
92
  );
76
93
 
77
94
  export const SpinnerOverlayWith100 = () => (
78
95
  <ExampleContainer>
79
96
  <Title title="Mode overlay" theme="light" level={4} />
80
- <DxcSpinner mode="overlay" value="100"></DxcSpinner>
97
+ <DxcSpinner mode="overlay" value={100}></DxcSpinner>
81
98
  </ExampleContainer>
82
99
  );
83
100
 
84
101
  export const SpinnerOverlayWithLabel = () => (
85
102
  <ExampleContainer>
86
103
  <Title title="Mode overlay" theme="light" level={4} />
87
- <DxcSpinner mode="overlay" value="50" label="Label"></DxcSpinner>
104
+ <DxcSpinner mode="overlay" value={50} label="Label"></DxcSpinner>
88
105
  </ExampleContainer>
89
106
  );
90
107
 
91
108
  export const SpinnerOverlayWithValue = () => (
92
109
  <ExampleContainer>
93
110
  <Title title="Mode overlay" theme="light" level={4} />
94
- <DxcSpinner mode="overlay" value="50" showValue></DxcSpinner>
111
+ <DxcSpinner mode="overlay" value={50} showValue></DxcSpinner>
95
112
  </ExampleContainer>
96
113
  );
97
114
 
98
115
  export const SpinnerOverlayWithValueAndLabel = () => (
99
116
  <ExampleContainer>
100
117
  <Title title="Mode overlay" theme="light" level={4} />
101
- <DxcSpinner mode="overlay" label="Label" value="50" showValue></DxcSpinner>
118
+ <DxcSpinner mode="overlay" label="Label" value={50} showValue></DxcSpinner>
119
+ </ExampleContainer>
120
+ );
121
+
122
+ export const SpinnerOverlayWithValueAndLabelOpinionated = () => (
123
+ <ExampleContainer>
124
+ <HalstackProvider theme={opinionatedTheme}>
125
+ <Title title="Mode overlay" theme="light" level={4} />
126
+ <DxcSpinner mode="overlay" label="Label" value={50} showValue></DxcSpinner>
127
+ </HalstackProvider>
102
128
  </ExampleContainer>
103
129
  );
@@ -0,0 +1,55 @@
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 _Spinner = _interopRequireDefault(require("./Spinner.tsx"));
7
+ describe("Spinner component tests", function () {
8
+ test("Spinner renders with correct label", function () {
9
+ var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Spinner["default"], {
10
+ label: "test-loading"
11
+ })),
12
+ getByText = _render.getByText;
13
+ expect(getByText("test-loading")).toBeTruthy();
14
+ });
15
+ test("Spinner shows value correctly", function () {
16
+ var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Spinner["default"], {
17
+ label: "test-loading",
18
+ value: 75,
19
+ showValue: true
20
+ })),
21
+ getByText = _render2.getByText;
22
+ expect(getByText("75%")).toBeTruthy();
23
+ });
24
+ test("Small spinner hides value and label correctly", function () {
25
+ var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Spinner["default"], {
26
+ mode: "small",
27
+ label: "test-loading",
28
+ value: 75,
29
+ showValue: true
30
+ })),
31
+ queryByText = _render3.queryByText;
32
+ expect(queryByText("test-loading")).toBeFalsy();
33
+ expect(queryByText("75%")).toBeFalsy();
34
+ });
35
+ test("Overlay spinner shows value and label correctly", function () {
36
+ var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Spinner["default"], {
37
+ mode: "overlay",
38
+ label: "test-loading",
39
+ value: 75,
40
+ showValue: true
41
+ })),
42
+ getByText = _render4.getByText;
43
+ expect(getByText("test-loading")).toBeTruthy();
44
+ expect(getByText("75%")).toBeTruthy();
45
+ });
46
+ test("Get spinner by role", function () {
47
+ var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Spinner["default"], {
48
+ label: "test-loading",
49
+ value: 75,
50
+ showValue: true
51
+ })),
52
+ getByRole = _render5.getByRole;
53
+ expect(getByRole("progressbar")).toBeTruthy();
54
+ });
55
+ });
@@ -1,11 +1,11 @@
1
- declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
2
- declare type Margin = {
1
+ type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
2
+ type Margin = {
3
3
  top?: Space;
4
4
  bottom?: Space;
5
5
  left?: Space;
6
6
  right?: Space;
7
7
  };
8
- declare type Props = {
8
+ type Props = {
9
9
  /**
10
10
  * Text to be placed inside the spinner.
11
11
  */
@@ -0,0 +1,157 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
5
+ var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
6
+ var _react = _interopRequireDefault(require("react"));
7
+ var _react2 = require("@testing-library/react");
8
+ var _axeHelper = require("../../test/accessibility/axe-helper.js");
9
+ var _StatusLight = _interopRequireDefault(require("./StatusLight.tsx"));
10
+ var _Flex = _interopRequireDefault(require("../flex/Flex.tsx"));
11
+ describe("StatusLight component accessibility tests", function () {
12
+ it("Should not have basic accessibility issues for default mode", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
13
+ var _render, container, results;
14
+ return _regenerator["default"].wrap(function _callee$(_context) {
15
+ while (1) switch (_context.prev = _context.next) {
16
+ case 0:
17
+ _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Flex["default"], null, /*#__PURE__*/_react["default"].createElement(_StatusLight["default"], {
18
+ label: "Status Light Test",
19
+ mode: "default",
20
+ size: "large"
21
+ }), /*#__PURE__*/_react["default"].createElement(_StatusLight["default"], {
22
+ label: "Status Light Test",
23
+ mode: "default",
24
+ size: "medium"
25
+ }), /*#__PURE__*/_react["default"].createElement(_StatusLight["default"], {
26
+ label: "Status Light Test",
27
+ mode: "default",
28
+ size: "small"
29
+ }))), container = _render.container;
30
+ _context.next = 3;
31
+ return (0, _axeHelper.axe)(container);
32
+ case 3:
33
+ results = _context.sent;
34
+ expect(results).toHaveNoViolations();
35
+ case 5:
36
+ case "end":
37
+ return _context.stop();
38
+ }
39
+ }, _callee);
40
+ })));
41
+ it("Should not have basic accessibility issues for error mode", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2() {
42
+ var _render2, container, results;
43
+ return _regenerator["default"].wrap(function _callee2$(_context2) {
44
+ while (1) switch (_context2.prev = _context2.next) {
45
+ case 0:
46
+ _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Flex["default"], null, /*#__PURE__*/_react["default"].createElement(_StatusLight["default"], {
47
+ label: "Status Light Test",
48
+ mode: "error",
49
+ size: "large"
50
+ }), /*#__PURE__*/_react["default"].createElement(_StatusLight["default"], {
51
+ label: "Status Light Test",
52
+ mode: "error",
53
+ size: "medium"
54
+ }), /*#__PURE__*/_react["default"].createElement(_StatusLight["default"], {
55
+ label: "Status Light Test",
56
+ mode: "error",
57
+ size: "small"
58
+ }))), container = _render2.container;
59
+ _context2.next = 3;
60
+ return (0, _axeHelper.axe)(container);
61
+ case 3:
62
+ results = _context2.sent;
63
+ expect(results).toHaveNoViolations();
64
+ case 5:
65
+ case "end":
66
+ return _context2.stop();
67
+ }
68
+ }, _callee2);
69
+ })));
70
+ it("Should not have basic accessibility issues for info mode", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee3() {
71
+ var _render3, container, results;
72
+ return _regenerator["default"].wrap(function _callee3$(_context3) {
73
+ while (1) switch (_context3.prev = _context3.next) {
74
+ case 0:
75
+ _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Flex["default"], null, /*#__PURE__*/_react["default"].createElement(_StatusLight["default"], {
76
+ label: "Status Light Test",
77
+ mode: "info",
78
+ size: "large"
79
+ }), /*#__PURE__*/_react["default"].createElement(_StatusLight["default"], {
80
+ label: "Status Light Test",
81
+ mode: "info",
82
+ size: "medium"
83
+ }), /*#__PURE__*/_react["default"].createElement(_StatusLight["default"], {
84
+ label: "Status Light Test",
85
+ mode: "info",
86
+ size: "small"
87
+ }))), container = _render3.container;
88
+ _context3.next = 3;
89
+ return (0, _axeHelper.axe)(container);
90
+ case 3:
91
+ results = _context3.sent;
92
+ expect(results).toHaveNoViolations();
93
+ case 5:
94
+ case "end":
95
+ return _context3.stop();
96
+ }
97
+ }, _callee3);
98
+ })));
99
+ it("Should not have basic accessibility issues for success mode", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee4() {
100
+ var _render4, container, results;
101
+ return _regenerator["default"].wrap(function _callee4$(_context4) {
102
+ while (1) switch (_context4.prev = _context4.next) {
103
+ case 0:
104
+ _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Flex["default"], null, /*#__PURE__*/_react["default"].createElement(_StatusLight["default"], {
105
+ label: "Status Light Test",
106
+ mode: "success",
107
+ size: "large"
108
+ }), /*#__PURE__*/_react["default"].createElement(_StatusLight["default"], {
109
+ label: "Status Light Test",
110
+ mode: "success",
111
+ size: "medium"
112
+ }), /*#__PURE__*/_react["default"].createElement(_StatusLight["default"], {
113
+ label: "Status Light Test",
114
+ mode: "success",
115
+ size: "small"
116
+ }))), container = _render4.container;
117
+ _context4.next = 3;
118
+ return (0, _axeHelper.axe)(container);
119
+ case 3:
120
+ results = _context4.sent;
121
+ expect(results).toHaveNoViolations();
122
+ case 5:
123
+ case "end":
124
+ return _context4.stop();
125
+ }
126
+ }, _callee4);
127
+ })));
128
+ it("Should not have basic accessibility issues for warning mode", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee5() {
129
+ var _render5, container, results;
130
+ return _regenerator["default"].wrap(function _callee5$(_context5) {
131
+ while (1) switch (_context5.prev = _context5.next) {
132
+ case 0:
133
+ _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Flex["default"], null, /*#__PURE__*/_react["default"].createElement(_StatusLight["default"], {
134
+ label: "Status Light Test",
135
+ mode: "warning",
136
+ size: "large"
137
+ }), /*#__PURE__*/_react["default"].createElement(_StatusLight["default"], {
138
+ label: "Status Light Test",
139
+ mode: "warning",
140
+ size: "medium"
141
+ }), /*#__PURE__*/_react["default"].createElement(_StatusLight["default"], {
142
+ label: "Status Light Test",
143
+ mode: "warning",
144
+ size: "small"
145
+ }))), container = _render5.container;
146
+ _context5.next = 3;
147
+ return (0, _axeHelper.axe)(container);
148
+ case 3:
149
+ results = _context5.sent;
150
+ expect(results).toHaveNoViolations();
151
+ case 5:
152
+ case "end":
153
+ return _context5.stop();
154
+ }
155
+ }, _callee5);
156
+ })));
157
+ });
@@ -0,0 +1,4 @@
1
+ /// <reference types="react" />
2
+ import StatusLightPropsType from "./types";
3
+ declare const DxcStatusLight: ({ mode, label, size }: StatusLightPropsType) => JSX.Element;
4
+ export default DxcStatusLight;
@@ -0,0 +1,51 @@
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 _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
9
+ var _react = _interopRequireDefault(require("react"));
10
+ var _styledComponents = _interopRequireDefault(require("styled-components"));
11
+ var _coreTokens = _interopRequireDefault(require("../common/coreTokens"));
12
+ var _templateObject, _templateObject2, _templateObject3;
13
+ var DxcStatusLight = function DxcStatusLight(_ref) {
14
+ var _ref$mode = _ref.mode,
15
+ mode = _ref$mode === void 0 ? "default" : _ref$mode,
16
+ label = _ref.label,
17
+ _ref$size = _ref.size,
18
+ size = _ref$size === void 0 ? "medium" : _ref$size;
19
+ return /*#__PURE__*/_react["default"].createElement(StatusLightContainer, {
20
+ size: size,
21
+ "aria-label": "".concat(mode, ": ").concat(label),
22
+ "data-testid": "status_light-container"
23
+ }, /*#__PURE__*/_react["default"].createElement(StatusDot, {
24
+ mode: mode,
25
+ size: size,
26
+ "aria-hidden": "true",
27
+ "data-testid": "status-dot"
28
+ }), /*#__PURE__*/_react["default"].createElement(StatusLabel, {
29
+ mode: mode,
30
+ size: size
31
+ }, label));
32
+ };
33
+ var StatusLightContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n align-items: center;\n gap: ", ";\n"])), _coreTokens["default"].spacing_8);
34
+ var StatusDot = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n width: ", ";\n height: ", ";\n border-radius: 50%;\n background-color: ", ";\n"])), function (_ref2) {
35
+ var size = _ref2.size;
36
+ return size === "small" && _coreTokens["default"].type_scale_01 || size === "medium" && _coreTokens["default"].type_scale_02 || size === "large" && _coreTokens["default"].type_scale_03 || _coreTokens["default"].type_scale_02;
37
+ }, function (_ref3) {
38
+ var size = _ref3.size;
39
+ return size === "small" && _coreTokens["default"].type_scale_01 || size === "medium" && _coreTokens["default"].type_scale_02 || size === "large" && _coreTokens["default"].type_scale_03 || _coreTokens["default"].type_scale_02;
40
+ }, function (_ref4) {
41
+ var mode = _ref4.mode;
42
+ return mode === "default" && _coreTokens["default"].color_grey_700 || mode === "error" && _coreTokens["default"].color_red_700 || mode === "info" && _coreTokens["default"].color_blue_700 || mode === "success" && _coreTokens["default"].color_green_700 || mode === "warning" && _coreTokens["default"].color_orange_700 || _coreTokens["default"].color_grey_700;
43
+ });
44
+ var StatusLabel = _styledComponents["default"].span(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n font-size: ", ";\n font-family: ", ";\n font-style: ", ";\n font-weight: ", ";\n color: ", ";\n text-align: center;\n text-overflow: ellipsis;\n overflow: hidden;\n white-space: nowrap;\n"])), function (_ref5) {
45
+ var size = _ref5.size;
46
+ return size === "small" && _coreTokens["default"].type_scale_01 || size === "medium" && _coreTokens["default"].type_scale_02 || size === "large" && _coreTokens["default"].type_scale_03 || _coreTokens["default"].type_scale_02;
47
+ }, _coreTokens["default"].type_sans, _coreTokens["default"].type_normal, _coreTokens["default"].type_semibold, function (_ref6) {
48
+ var mode = _ref6.mode;
49
+ return mode === "default" && _coreTokens["default"].color_grey_700 || mode === "error" && _coreTokens["default"].color_red_700 || mode === "info" && _coreTokens["default"].color_blue_700 || mode === "success" && _coreTokens["default"].color_green_700 || mode === "warning" && _coreTokens["default"].color_orange_700 || _coreTokens["default"].color_grey_700;
50
+ });
51
+ var _default = exports["default"] = DxcStatusLight;
@@ -0,0 +1,74 @@
1
+ import React from "react";
2
+ import Title from "../../.storybook/components/Title";
3
+ import ExampleContainer from "../../.storybook/components/ExampleContainer";
4
+ import DxcStatusLight from "./StatusLight";
5
+
6
+ export default {
7
+ title: "Status Light",
8
+ component: DxcStatusLight,
9
+ };
10
+
11
+ export const Chromatic = () => (
12
+ <>
13
+ <ExampleContainer>
14
+ <Title title="Default light small" theme="light" level={4} />
15
+ <DxcStatusLight label="StatusLight" size="small" />
16
+ </ExampleContainer>
17
+ <ExampleContainer>
18
+ <Title title="Default light medium" theme="light" level={4} />
19
+ <DxcStatusLight label="StatusLight" />
20
+ </ExampleContainer>
21
+ <ExampleContainer>
22
+ <Title title="Default light large" theme="light" level={4} />
23
+ <DxcStatusLight label="StatusLight" size="large" />
24
+ </ExampleContainer>
25
+ <ExampleContainer>
26
+ <Title title="Info light small" theme="light" level={4} />
27
+ <DxcStatusLight label="StatusLight" mode="info" size="small" />
28
+ </ExampleContainer>
29
+ <ExampleContainer>
30
+ <Title title="Info light medium" theme="light" level={4} />
31
+ <DxcStatusLight label="StatusLight" mode="info" />
32
+ </ExampleContainer>
33
+ <ExampleContainer>
34
+ <Title title="Info light large" theme="light" level={4} />
35
+ <DxcStatusLight label="StatusLight" mode="info" size="large" />
36
+ </ExampleContainer>
37
+ <ExampleContainer>
38
+ <Title title="Success light small" theme="light" level={4} />
39
+ <DxcStatusLight label="StatusLight" mode="success" size="small" />
40
+ </ExampleContainer>
41
+ <ExampleContainer>
42
+ <Title title="Success lights medium" theme="light" level={4} />
43
+ <DxcStatusLight label="StatusLight" mode="success" />
44
+ </ExampleContainer>
45
+ <ExampleContainer>
46
+ <Title title="Success lights large" theme="light" level={4} />
47
+ <DxcStatusLight label="StatusLight" mode="success" size="large" />
48
+ </ExampleContainer>
49
+ <ExampleContainer>
50
+ <Title title="Warning light small" theme="light" level={4} />
51
+ <DxcStatusLight label="StatusLight" mode="warning" size="small" />
52
+ </ExampleContainer>
53
+ <ExampleContainer>
54
+ <Title title="Warning light medium" theme="light" level={4} />
55
+ <DxcStatusLight label="StatusLight" mode="warning" />
56
+ </ExampleContainer>
57
+ <ExampleContainer>
58
+ <Title title="Warning light large" theme="light" level={4} />
59
+ <DxcStatusLight label="StatusLight" mode="warning" size="large" />
60
+ </ExampleContainer>
61
+ <ExampleContainer>
62
+ <Title title="Error light small" theme="light" level={4} />
63
+ <DxcStatusLight label="StatusLight" mode="error" size="small" />
64
+ </ExampleContainer>
65
+ <ExampleContainer>
66
+ <Title title="Error lights medium" theme="light" level={4} />
67
+ <DxcStatusLight label="StatusLight" mode="error" />
68
+ </ExampleContainer>
69
+ <ExampleContainer>
70
+ <Title title="Error lights large" theme="light" level={4} />
71
+ <DxcStatusLight label="StatusLight" mode="error" size="large" />
72
+ </ExampleContainer>
73
+ </>
74
+ );
@@ -0,0 +1,25 @@
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 _StatusLight = _interopRequireDefault(require("./StatusLight.tsx"));
7
+ describe("StatusLight component tests", function () {
8
+ test("StatusLight renders with correct label", function () {
9
+ var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_StatusLight["default"], {
10
+ label: "Status Light Test"
11
+ })),
12
+ getByText = _render.getByText;
13
+ expect(getByText("Status Light Test")).toBeTruthy();
14
+ });
15
+ test("StatusLight applies accessibility attributes", function () {
16
+ var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_StatusLight["default"], {
17
+ label: "Status Light Test"
18
+ })),
19
+ getByTestId = _render2.getByTestId;
20
+ var statusLightContainer = getByTestId("status_light-container");
21
+ var statusDot = getByTestId("status-dot");
22
+ expect(statusLightContainer.getAttribute("aria-label")).toBe("default: Status Light Test");
23
+ expect(statusDot.getAttribute("aria-hidden")).toBe("true");
24
+ });
25
+ });
@@ -0,0 +1,17 @@
1
+ type Mode = "default" | "info" | "success" | "warning" | "error";
2
+ type Size = "small" | "medium" | "large";
3
+ type Props = {
4
+ /**
5
+ * It will define the color of the light based on its semantic meaning.
6
+ */
7
+ mode?: Mode;
8
+ /**
9
+ * An auxiliar text that will add some context to the status.
10
+ */
11
+ label: string;
12
+ /**
13
+ * Size of the component. Should be defined based on its importance and/or available space.
14
+ */
15
+ size?: Size;
16
+ };
17
+ export default Props;
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });