@dxc-technology/halstack-react 0.0.0-c291a0c → 0.0.0-c293b72

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 (396) hide show
  1. package/BackgroundColorContext.d.ts +1 -10
  2. package/BackgroundColorContext.js +5 -22
  3. package/HalstackContext.d.ts +1243 -6
  4. package/HalstackContext.js +126 -111
  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 +104 -161
  9. package/accordion/Accordion.stories.tsx +84 -140
  10. package/accordion/Accordion.test.js +25 -41
  11. package/accordion/types.d.ts +6 -17
  12. package/accordion-group/AccordionGroup.accessibility.test.js +88 -0
  13. package/accordion-group/AccordionGroup.d.ts +2 -2
  14. package/accordion-group/AccordionGroup.js +31 -98
  15. package/accordion-group/AccordionGroup.stories.tsx +94 -67
  16. package/accordion-group/AccordionGroup.test.js +52 -105
  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 +12 -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 +32 -125
  30. package/alert/Alert.stories.tsx +28 -0
  31. package/alert/Alert.test.js +29 -46
  32. package/alert/types.d.ts +5 -5
  33. package/badge/Badge.accessibility.test.js +129 -0
  34. package/badge/Badge.d.ts +1 -1
  35. package/badge/Badge.js +142 -42
  36. package/badge/Badge.stories.tsx +210 -0
  37. package/badge/Badge.test.js +30 -0
  38. package/badge/types.d.ts +52 -3
  39. package/bleed/Bleed.js +13 -21
  40. package/bleed/Bleed.stories.tsx +64 -63
  41. package/bleed/types.d.ts +2 -2
  42. package/box/Box.accessibility.test.js +33 -0
  43. package/box/Box.d.ts +1 -1
  44. package/box/Box.js +19 -60
  45. package/box/Box.stories.tsx +38 -51
  46. package/box/Box.test.js +2 -7
  47. package/box/types.d.ts +3 -14
  48. package/bulleted-list/BulletedList.accessibility.test.js +107 -0
  49. package/bulleted-list/BulletedList.d.ts +7 -0
  50. package/bulleted-list/BulletedList.js +92 -0
  51. package/bulleted-list/BulletedList.stories.tsx +115 -0
  52. package/bulleted-list/types.d.ts +38 -0
  53. package/button/Button.accessibility.test.js +127 -0
  54. package/button/Button.d.ts +1 -1
  55. package/button/Button.js +64 -117
  56. package/button/Button.stories.tsx +151 -100
  57. package/button/Button.test.js +20 -17
  58. package/button/types.d.ts +12 -8
  59. package/card/Card.accessibility.test.js +36 -0
  60. package/card/Card.d.ts +1 -1
  61. package/card/Card.js +48 -89
  62. package/card/Card.stories.tsx +12 -42
  63. package/card/Card.test.js +11 -22
  64. package/card/types.d.ts +6 -11
  65. package/checkbox/Checkbox.accessibility.test.js +87 -0
  66. package/checkbox/Checkbox.d.ts +2 -2
  67. package/checkbox/Checkbox.js +140 -182
  68. package/checkbox/Checkbox.stories.tsx +128 -94
  69. package/checkbox/Checkbox.test.js +160 -39
  70. package/checkbox/types.d.ts +11 -3
  71. package/chip/Chip.accessibility.test.js +67 -0
  72. package/chip/Chip.js +43 -80
  73. package/chip/Chip.stories.tsx +102 -26
  74. package/chip/Chip.test.js +18 -33
  75. package/chip/types.d.ts +4 -4
  76. package/common/coreTokens.d.ts +237 -0
  77. package/common/coreTokens.js +184 -0
  78. package/common/utils.d.ts +1 -0
  79. package/common/utils.js +6 -12
  80. package/common/variables.d.ts +1395 -0
  81. package/common/variables.js +942 -1145
  82. package/container/Container.d.ts +4 -0
  83. package/container/Container.js +194 -0
  84. package/container/Container.stories.tsx +214 -0
  85. package/container/types.d.ts +74 -0
  86. package/contextual-menu/ContextualMenu.accessibility.test.js +86 -0
  87. package/contextual-menu/ContextualMenu.d.ts +7 -0
  88. package/contextual-menu/ContextualMenu.js +71 -0
  89. package/contextual-menu/ContextualMenu.stories.tsx +182 -0
  90. package/contextual-menu/ContextualMenu.test.js +71 -0
  91. package/contextual-menu/MenuItemAction.d.ts +4 -0
  92. package/contextual-menu/MenuItemAction.js +46 -0
  93. package/contextual-menu/types.d.ts +22 -0
  94. package/date-input/Calendar.d.ts +4 -0
  95. package/date-input/Calendar.js +214 -0
  96. package/date-input/DateInput.accessibility.test.js +216 -0
  97. package/date-input/DateInput.js +149 -299
  98. package/date-input/DateInput.stories.tsx +203 -56
  99. package/date-input/DateInput.test.js +700 -371
  100. package/date-input/DatePicker.d.ts +4 -0
  101. package/date-input/DatePicker.js +121 -0
  102. package/date-input/YearPicker.d.ts +4 -0
  103. package/date-input/YearPicker.js +100 -0
  104. package/date-input/types.d.ts +72 -15
  105. package/dialog/Dialog.accessibility.test.js +69 -0
  106. package/dialog/Dialog.d.ts +1 -1
  107. package/dialog/Dialog.js +73 -107
  108. package/dialog/Dialog.stories.tsx +320 -167
  109. package/dialog/Dialog.test.js +287 -20
  110. package/dialog/types.d.ts +18 -25
  111. package/divider/Divider.accessibility.test.js +33 -0
  112. package/divider/Divider.d.ts +4 -0
  113. package/divider/Divider.js +36 -0
  114. package/divider/Divider.stories.tsx +223 -0
  115. package/divider/Divider.test.js +38 -0
  116. package/divider/types.d.ts +21 -0
  117. package/dropdown/Dropdown.accessibility.test.js +180 -0
  118. package/dropdown/Dropdown.d.ts +1 -1
  119. package/dropdown/Dropdown.js +231 -303
  120. package/dropdown/Dropdown.stories.tsx +235 -57
  121. package/dropdown/Dropdown.test.js +575 -165
  122. package/dropdown/DropdownMenu.d.ts +4 -0
  123. package/dropdown/DropdownMenu.js +63 -0
  124. package/dropdown/DropdownMenuItem.d.ts +4 -0
  125. package/dropdown/DropdownMenuItem.js +70 -0
  126. package/dropdown/types.d.ts +35 -19
  127. package/file-input/FileInput.accessibility.test.js +160 -0
  128. package/file-input/FileInput.d.ts +2 -2
  129. package/file-input/FileInput.js +241 -391
  130. package/file-input/FileInput.stories.tsx +123 -12
  131. package/file-input/FileInput.test.js +292 -367
  132. package/file-input/FileItem.d.ts +4 -14
  133. package/file-input/FileItem.js +52 -117
  134. package/file-input/types.d.ts +25 -8
  135. package/flex/Flex.d.ts +4 -0
  136. package/flex/Flex.js +57 -0
  137. package/flex/Flex.stories.tsx +112 -0
  138. package/flex/types.d.ts +97 -0
  139. package/footer/Footer.accessibility.test.js +117 -0
  140. package/footer/Footer.d.ts +1 -1
  141. package/footer/Footer.js +73 -118
  142. package/footer/Footer.stories.tsx +87 -21
  143. package/footer/Footer.test.js +33 -57
  144. package/footer/Icons.d.ts +3 -2
  145. package/footer/Icons.js +66 -7
  146. package/footer/types.d.ts +26 -27
  147. package/grid/Grid.d.ts +7 -0
  148. package/grid/Grid.js +76 -0
  149. package/grid/Grid.stories.tsx +219 -0
  150. package/grid/types.d.ts +115 -0
  151. package/header/Header.accessibility.test.js +84 -0
  152. package/header/Header.d.ts +4 -3
  153. package/header/Header.js +88 -182
  154. package/header/Header.stories.tsx +118 -39
  155. package/header/Header.test.js +13 -26
  156. package/header/Icons.d.ts +2 -2
  157. package/header/Icons.js +4 -9
  158. package/header/types.d.ts +7 -21
  159. package/heading/Heading.accessibility.test.js +33 -0
  160. package/heading/Heading.js +10 -32
  161. package/heading/Heading.test.js +71 -88
  162. package/heading/types.d.ts +7 -7
  163. package/icon/Icon.accessibility.test.js +30 -0
  164. package/icon/Icon.d.ts +4 -0
  165. package/icon/Icon.js +33 -0
  166. package/icon/Icon.stories.tsx +28 -0
  167. package/icon/types.d.ts +4 -0
  168. package/icon/types.js +5 -0
  169. package/image/Image.accessibility.test.js +56 -0
  170. package/image/Image.d.ts +4 -0
  171. package/image/Image.js +70 -0
  172. package/image/Image.stories.tsx +129 -0
  173. package/image/types.d.ts +72 -0
  174. package/image/types.js +5 -0
  175. package/inset/Inset.js +13 -21
  176. package/inset/Inset.stories.tsx +5 -4
  177. package/inset/types.d.ts +2 -2
  178. package/layout/ApplicationLayout.d.ts +15 -6
  179. package/layout/ApplicationLayout.js +51 -116
  180. package/layout/ApplicationLayout.stories.tsx +81 -45
  181. package/layout/Icons.d.ts +8 -5
  182. package/layout/Icons.js +49 -59
  183. package/layout/types.d.ts +21 -32
  184. package/link/Link.accessibility.test.js +112 -0
  185. package/link/Link.js +32 -51
  186. package/link/Link.stories.tsx +74 -7
  187. package/link/Link.test.js +24 -44
  188. package/link/types.d.ts +14 -14
  189. package/main.d.ts +14 -13
  190. package/main.js +59 -103
  191. package/nav-tabs/NavTabs.accessibility.test.js +44 -0
  192. package/nav-tabs/NavTabs.d.ts +7 -0
  193. package/{tabs-nav → nav-tabs}/NavTabs.js +30 -62
  194. package/nav-tabs/NavTabs.stories.tsx +279 -0
  195. package/{tabs-nav → nav-tabs}/NavTabs.test.js +39 -46
  196. package/nav-tabs/NavTabsContext.d.ts +3 -0
  197. package/nav-tabs/NavTabsContext.js +8 -0
  198. package/nav-tabs/Tab.js +117 -0
  199. package/{tabs-nav → nav-tabs}/types.d.ts +15 -16
  200. package/nav-tabs/types.js +5 -0
  201. package/number-input/NumberInput.accessibility.test.js +228 -0
  202. package/number-input/NumberInput.js +46 -36
  203. package/number-input/NumberInput.stories.tsx +42 -26
  204. package/number-input/NumberInput.test.js +860 -377
  205. package/number-input/NumberInputContext.d.ts +3 -4
  206. package/number-input/NumberInputContext.js +3 -14
  207. package/number-input/types.d.ts +17 -5
  208. package/package.json +49 -52
  209. package/paginator/Icons.d.ts +5 -0
  210. package/paginator/Icons.js +21 -47
  211. package/paginator/Paginator.accessibility.test.js +79 -0
  212. package/paginator/Paginator.js +23 -59
  213. package/paginator/Paginator.stories.tsx +24 -0
  214. package/paginator/Paginator.test.js +253 -226
  215. package/paginator/types.d.ts +3 -3
  216. package/paragraph/Paragraph.accessibility.test.js +28 -0
  217. package/paragraph/Paragraph.d.ts +5 -0
  218. package/paragraph/Paragraph.js +22 -0
  219. package/paragraph/Paragraph.stories.tsx +27 -0
  220. package/password-input/PasswordInput.accessibility.test.js +153 -0
  221. package/password-input/PasswordInput.js +56 -126
  222. package/password-input/PasswordInput.stories.tsx +1 -33
  223. package/password-input/PasswordInput.test.js +160 -142
  224. package/password-input/types.d.ts +8 -7
  225. package/progress-bar/ProgressBar.accessibility.test.js +35 -0
  226. package/progress-bar/ProgressBar.js +65 -91
  227. package/progress-bar/{ProgressBar.stories.jsx → ProgressBar.stories.tsx} +39 -4
  228. package/progress-bar/ProgressBar.test.js +72 -44
  229. package/progress-bar/types.d.ts +3 -3
  230. package/quick-nav/QuickNav.accessibility.test.js +57 -0
  231. package/quick-nav/QuickNav.js +27 -45
  232. package/quick-nav/QuickNav.stories.tsx +146 -27
  233. package/quick-nav/types.d.ts +10 -10
  234. package/radio-group/Radio.d.ts +1 -1
  235. package/radio-group/Radio.js +59 -76
  236. package/radio-group/RadioGroup.accessibility.test.js +97 -0
  237. package/radio-group/RadioGroup.js +67 -114
  238. package/radio-group/RadioGroup.stories.tsx +132 -18
  239. package/radio-group/RadioGroup.test.js +518 -457
  240. package/radio-group/types.d.ts +10 -10
  241. package/resultset-table/Icons.d.ts +7 -0
  242. package/resultset-table/Icons.js +47 -0
  243. package/resultset-table/ResultsetTable.accessibility.test.js +274 -0
  244. package/resultset-table/ResultsetTable.d.ts +7 -0
  245. package/resultset-table/ResultsetTable.js +170 -0
  246. package/{resultsetTable → resultset-table}/ResultsetTable.stories.tsx +156 -30
  247. package/resultset-table/ResultsetTable.test.js +381 -0
  248. package/{resultsetTable → resultset-table}/types.d.ts +44 -11
  249. package/resultset-table/types.js +5 -0
  250. package/select/Listbox.js +22 -52
  251. package/select/Option.js +33 -55
  252. package/select/Select.accessibility.test.js +217 -0
  253. package/select/Select.js +146 -208
  254. package/select/Select.stories.tsx +484 -203
  255. package/select/Select.test.js +1928 -1814
  256. package/select/types.d.ts +17 -20
  257. package/sidenav/Sidenav.accessibility.test.js +59 -0
  258. package/sidenav/Sidenav.d.ts +6 -5
  259. package/sidenav/Sidenav.js +132 -78
  260. package/sidenav/Sidenav.stories.tsx +246 -151
  261. package/sidenav/Sidenav.test.js +26 -45
  262. package/{layout → sidenav}/SidenavContext.d.ts +1 -1
  263. package/{layout → sidenav}/SidenavContext.js +3 -9
  264. package/sidenav/types.d.ts +52 -26
  265. package/slider/Slider.accessibility.test.js +104 -0
  266. package/slider/Slider.d.ts +2 -2
  267. package/slider/Slider.js +148 -181
  268. package/slider/Slider.test.js +185 -81
  269. package/slider/types.d.ts +7 -3
  270. package/spinner/Spinner.accessibility.test.js +96 -0
  271. package/spinner/Spinner.js +31 -75
  272. package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +53 -27
  273. package/spinner/Spinner.test.js +26 -35
  274. package/spinner/types.d.ts +3 -3
  275. package/status-light/StatusLight.accessibility.test.js +157 -0
  276. package/status-light/StatusLight.d.ts +4 -0
  277. package/status-light/StatusLight.js +51 -0
  278. package/status-light/StatusLight.stories.tsx +74 -0
  279. package/status-light/StatusLight.test.js +25 -0
  280. package/status-light/types.d.ts +17 -0
  281. package/status-light/types.js +5 -0
  282. package/switch/Switch.accessibility.test.js +89 -0
  283. package/switch/Switch.d.ts +2 -2
  284. package/switch/Switch.js +145 -126
  285. package/switch/Switch.stories.tsx +37 -60
  286. package/switch/Switch.test.js +138 -56
  287. package/switch/types.d.ts +7 -3
  288. package/table/DropdownTheme.js +62 -0
  289. package/table/Table.accessibility.test.js +82 -0
  290. package/table/Table.d.ts +6 -2
  291. package/table/Table.js +78 -35
  292. package/table/Table.stories.tsx +651 -0
  293. package/table/Table.test.js +95 -8
  294. package/table/types.d.ts +34 -6
  295. package/tabs/Tab.d.ts +4 -0
  296. package/tabs/Tab.js +117 -0
  297. package/tabs/Tabs.accessibility.test.js +56 -0
  298. package/tabs/Tabs.js +303 -141
  299. package/tabs/Tabs.stories.tsx +118 -6
  300. package/tabs/Tabs.test.js +213 -77
  301. package/tabs/types.d.ts +30 -20
  302. package/tag/Tag.accessibility.test.js +69 -0
  303. package/tag/Tag.js +35 -67
  304. package/tag/Tag.stories.tsx +18 -8
  305. package/tag/Tag.test.js +18 -37
  306. package/tag/types.d.ts +9 -9
  307. package/text-input/Suggestion.js +40 -28
  308. package/text-input/Suggestions.d.ts +4 -0
  309. package/text-input/Suggestions.js +86 -0
  310. package/text-input/TextInput.accessibility.test.js +321 -0
  311. package/text-input/TextInput.js +311 -514
  312. package/text-input/TextInput.stories.tsx +266 -275
  313. package/text-input/TextInput.test.js +1419 -1375
  314. package/text-input/types.d.ts +43 -16
  315. package/textarea/Textarea.accessibility.test.js +155 -0
  316. package/textarea/Textarea.js +70 -113
  317. package/textarea/Textarea.stories.tsx +174 -0
  318. package/textarea/Textarea.test.js +152 -183
  319. package/textarea/types.d.ts +9 -5
  320. package/toggle-group/ToggleGroup.accessibility.test.js +107 -0
  321. package/toggle-group/ToggleGroup.d.ts +2 -2
  322. package/toggle-group/ToggleGroup.js +94 -107
  323. package/toggle-group/ToggleGroup.stories.tsx +52 -7
  324. package/toggle-group/ToggleGroup.test.js +69 -88
  325. package/toggle-group/types.d.ts +28 -19
  326. package/typography/Typography.accessibility.test.js +339 -0
  327. package/typography/Typography.d.ts +4 -0
  328. package/typography/Typography.js +23 -0
  329. package/typography/Typography.stories.tsx +198 -0
  330. package/typography/types.d.ts +18 -0
  331. package/typography/types.js +5 -0
  332. package/useTheme.d.ts +1147 -1
  333. package/useTheme.js +2 -9
  334. package/useTranslatedLabels.d.ts +84 -1
  335. package/useTranslatedLabels.js +1 -7
  336. package/utils/BaseTypography.d.ts +21 -0
  337. package/utils/BaseTypography.js +94 -0
  338. package/utils/FocusLock.d.ts +13 -0
  339. package/utils/FocusLock.js +124 -0
  340. package/wizard/Wizard.accessibility.test.js +55 -0
  341. package/wizard/Wizard.js +34 -79
  342. package/wizard/Wizard.stories.tsx +59 -1
  343. package/wizard/Wizard.test.js +54 -81
  344. package/wizard/types.d.ts +9 -9
  345. package/card/ice-cream.jpg +0 -0
  346. package/common/OpenSans.css +0 -81
  347. package/common/RequiredComponent.js +0 -32
  348. package/common/fonts/OpenSans-Bold.ttf +0 -0
  349. package/common/fonts/OpenSans-BoldItalic.ttf +0 -0
  350. package/common/fonts/OpenSans-ExtraBold.ttf +0 -0
  351. package/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  352. package/common/fonts/OpenSans-Italic.ttf +0 -0
  353. package/common/fonts/OpenSans-Light.ttf +0 -0
  354. package/common/fonts/OpenSans-LightItalic.ttf +0 -0
  355. package/common/fonts/OpenSans-Regular.ttf +0 -0
  356. package/common/fonts/OpenSans-SemiBold.ttf +0 -0
  357. package/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  358. package/inline/Inline.d.ts +0 -4
  359. package/inline/Inline.js +0 -54
  360. package/inline/Inline.stories.tsx +0 -264
  361. package/inline/types.d.ts +0 -32
  362. package/list/List.d.ts +0 -4
  363. package/list/List.js +0 -47
  364. package/list/List.stories.tsx +0 -89
  365. package/list/types.d.ts +0 -7
  366. package/number-input/numberInputContextTypes.d.ts +0 -19
  367. package/resultsetTable/ResultsetTable.d.ts +0 -4
  368. package/resultsetTable/ResultsetTable.js +0 -254
  369. package/resultsetTable/ResultsetTable.test.js +0 -348
  370. package/row/Row.d.ts +0 -3
  371. package/row/Row.js +0 -127
  372. package/row/Row.stories.tsx +0 -237
  373. package/row/types.d.ts +0 -28
  374. package/select/Icons.d.ts +0 -10
  375. package/select/Icons.js +0 -93
  376. package/slider/Slider.stories.tsx +0 -177
  377. package/stack/Stack.d.ts +0 -4
  378. package/stack/Stack.js +0 -50
  379. package/stack/Stack.stories.tsx +0 -225
  380. package/stack/types.d.ts +0 -28
  381. package/table/Table.stories.jsx +0 -277
  382. package/tabs-nav/NavTabs.d.ts +0 -8
  383. package/tabs-nav/NavTabs.stories.tsx +0 -170
  384. package/tabs-nav/Tab.js +0 -132
  385. package/text/Text.d.ts +0 -7
  386. package/text/Text.js +0 -30
  387. package/text/Text.stories.tsx +0 -19
  388. package/textarea/Textarea.stories.jsx +0 -157
  389. /package/{inline → action-icon}/types.js +0 -0
  390. /package/{list → bulleted-list}/types.js +0 -0
  391. /package/{resultsetTable → container}/types.js +0 -0
  392. /package/{row → contextual-menu}/types.js +0 -0
  393. /package/{stack → divider}/types.js +0 -0
  394. /package/{tabs-nav → flex}/types.js +0 -0
  395. /package/{number-input/numberInputContextTypes.js → grid/types.js} +0 -0
  396. /package/{tabs-nav → nav-tabs}/Tab.d.ts +0 -0
@@ -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 _jestAxe = require("jest-axe");
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, _jestAxe.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, _jestAxe.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, _jestAxe.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, _jestAxe.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, _jestAxe.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
+ });
@@ -0,0 +1,89 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
5
+ var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
6
+ var _react = _interopRequireDefault(require("react"));
7
+ var _react2 = require("@testing-library/react");
8
+ var _jestAxe = require("jest-axe");
9
+ var _Switch = _interopRequireDefault(require("./Switch.tsx"));
10
+ describe("Switch component accessibility tests", function () {
11
+ it("Should not have basic accessibility issues", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
12
+ var _render, container, results;
13
+ return _regenerator["default"].wrap(function _callee$(_context) {
14
+ while (1) switch (_context.prev = _context.next) {
15
+ case 0:
16
+ _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
17
+ label: "Default label",
18
+ defaultChecked: true,
19
+ value: "test-defaultChecked",
20
+ name: "test",
21
+ labelPosition: "after",
22
+ margin: "medium",
23
+ size: "medium",
24
+ checked: true
25
+ })), container = _render.container;
26
+ _context.next = 3;
27
+ return (0, _jestAxe.axe)(container);
28
+ case 3:
29
+ results = _context.sent;
30
+ expect(results).toHaveNoViolations();
31
+ case 5:
32
+ case "end":
33
+ return _context.stop();
34
+ }
35
+ }, _callee);
36
+ })));
37
+ it("Should not have basic accessibility issues for optional mode", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2() {
38
+ var _render2, container, results;
39
+ return _regenerator["default"].wrap(function _callee2$(_context2) {
40
+ while (1) switch (_context2.prev = _context2.next) {
41
+ case 0:
42
+ _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
43
+ label: "Default label",
44
+ defaultChecked: true,
45
+ value: "test-defaultChecked",
46
+ name: "test",
47
+ labelPosition: "after",
48
+ margin: "medium",
49
+ size: "medium",
50
+ optional: true
51
+ })), container = _render2.container;
52
+ _context2.next = 3;
53
+ return (0, _jestAxe.axe)(container);
54
+ case 3:
55
+ results = _context2.sent;
56
+ expect(results).toHaveNoViolations();
57
+ case 5:
58
+ case "end":
59
+ return _context2.stop();
60
+ }
61
+ }, _callee2);
62
+ })));
63
+ it("Should not have basic accessibility issues for disabled mode", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee3() {
64
+ var _render3, container, results;
65
+ return _regenerator["default"].wrap(function _callee3$(_context3) {
66
+ while (1) switch (_context3.prev = _context3.next) {
67
+ case 0:
68
+ _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
69
+ label: "Default label",
70
+ defaultChecked: true,
71
+ value: "test-defaultChecked",
72
+ name: "test",
73
+ labelPosition: "after",
74
+ margin: "medium",
75
+ size: "medium",
76
+ disabled: true
77
+ })), container = _render3.container;
78
+ _context3.next = 3;
79
+ return (0, _jestAxe.axe)(container);
80
+ case 3:
81
+ results = _context3.sent;
82
+ expect(results).toHaveNoViolations();
83
+ case 5:
84
+ case "end":
85
+ return _context3.stop();
86
+ }
87
+ }, _callee3);
88
+ })));
89
+ });
@@ -1,4 +1,4 @@
1
- /// <reference types="react" />
1
+ import React from "react";
2
2
  import SwitchPropsType from "./types";
3
- declare const DxcSwitch: ({ defaultChecked, checked, value, label, labelPosition, name, disabled, optional, onChange, margin, size, tabIndex, }: SwitchPropsType) => JSX.Element;
3
+ declare const DxcSwitch: React.ForwardRefExoticComponent<SwitchPropsType & React.RefAttributes<HTMLDivElement>>;
4
4
  export default DxcSwitch;