@dxc-technology/halstack-react 0.0.0-9e83fd2 → 0.0.0-9ef63cd

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 (353) hide show
  1. package/BackgroundColorContext.d.ts +1 -10
  2. package/BackgroundColorContext.js +4 -21
  3. package/HalstackContext.d.ts +53 -143
  4. package/HalstackContext.js +10 -35
  5. package/README.md +47 -0
  6. package/accordion/Accordion.accessibility.test.js +71 -0
  7. package/accordion/Accordion.js +33 -87
  8. package/accordion/Accordion.stories.tsx +8 -64
  9. package/accordion/Accordion.test.js +18 -33
  10. package/accordion/types.d.ts +6 -6
  11. package/accordion-group/AccordionGroup.accessibility.test.js +88 -0
  12. package/accordion-group/AccordionGroup.d.ts +2 -3
  13. package/accordion-group/AccordionGroup.js +17 -44
  14. package/accordion-group/AccordionGroup.stories.tsx +24 -24
  15. package/accordion-group/AccordionGroup.test.js +42 -60
  16. package/accordion-group/AccordionGroupAccordion.js +11 -23
  17. package/accordion-group/AccordionGroupContext.d.ts +3 -0
  18. package/accordion-group/AccordionGroupContext.js +8 -0
  19. package/accordion-group/types.d.ts +7 -7
  20. package/action-icon/ActionIcon.accessibility.test.js +63 -0
  21. package/action-icon/ActionIcon.d.ts +4 -0
  22. package/action-icon/ActionIcon.js +48 -0
  23. package/action-icon/ActionIcon.stories.tsx +41 -0
  24. package/action-icon/ActionIcon.test.js +64 -0
  25. package/action-icon/types.d.ts +26 -0
  26. package/alert/Alert.accessibility.test.js +95 -0
  27. package/alert/Alert.js +34 -120
  28. package/alert/Alert.test.js +28 -45
  29. package/alert/types.d.ts +5 -5
  30. package/badge/Badge.accessibility.test.js +129 -0
  31. package/badge/Badge.d.ts +1 -1
  32. package/badge/Badge.js +142 -42
  33. package/badge/Badge.stories.tsx +210 -0
  34. package/badge/Badge.test.js +30 -0
  35. package/badge/types.d.ts +52 -3
  36. package/bleed/Bleed.js +13 -21
  37. package/bleed/types.d.ts +2 -2
  38. package/box/Box.accessibility.test.js +33 -0
  39. package/box/Box.js +11 -33
  40. package/box/Box.test.js +1 -6
  41. package/box/types.d.ts +3 -3
  42. package/breadcrumbs/Breadcrumbs.accessibility.test.d.ts +1 -0
  43. package/breadcrumbs/Breadcrumbs.accessibility.test.js +96 -0
  44. package/breadcrumbs/Breadcrumbs.d.ts +4 -0
  45. package/breadcrumbs/Breadcrumbs.js +79 -0
  46. package/breadcrumbs/Breadcrumbs.stories.tsx +194 -0
  47. package/breadcrumbs/Breadcrumbs.test.d.ts +1 -0
  48. package/breadcrumbs/Breadcrumbs.test.js +169 -0
  49. package/breadcrumbs/Item.d.ts +4 -0
  50. package/breadcrumbs/Item.js +52 -0
  51. package/breadcrumbs/dropdownTheme.d.ts +53 -0
  52. package/breadcrumbs/dropdownTheme.js +62 -0
  53. package/breadcrumbs/types.d.ts +16 -0
  54. package/breadcrumbs/types.js +5 -0
  55. package/bulleted-list/BulletedList.accessibility.test.js +119 -0
  56. package/bulleted-list/BulletedList.js +22 -55
  57. package/bulleted-list/BulletedList.stories.tsx +2 -93
  58. package/bulleted-list/types.d.ts +5 -5
  59. package/button/Button.accessibility.test.js +127 -0
  60. package/button/Button.js +36 -59
  61. package/button/Button.stories.tsx +35 -135
  62. package/button/Button.test.js +13 -21
  63. package/button/types.d.ts +5 -5
  64. package/card/Card.accessibility.test.js +36 -0
  65. package/card/Card.js +23 -45
  66. package/card/Card.test.js +10 -21
  67. package/card/types.d.ts +5 -5
  68. package/checkbox/Checkbox.accessibility.test.js +87 -0
  69. package/checkbox/Checkbox.js +88 -126
  70. package/checkbox/Checkbox.stories.tsx +16 -54
  71. package/checkbox/Checkbox.test.js +107 -63
  72. package/checkbox/types.d.ts +8 -4
  73. package/chip/Chip.accessibility.test.js +67 -0
  74. package/chip/Chip.js +22 -36
  75. package/chip/Chip.stories.tsx +10 -25
  76. package/chip/Chip.test.js +17 -30
  77. package/chip/types.d.ts +4 -4
  78. package/common/coreTokens.d.ts +105 -14
  79. package/common/coreTokens.js +40 -23
  80. package/common/utils.js +2 -8
  81. package/common/variables.d.ts +54 -144
  82. package/common/variables.js +128 -225
  83. package/container/Container.d.ts +4 -0
  84. package/container/Container.js +194 -0
  85. package/container/Container.stories.tsx +214 -0
  86. package/container/types.d.ts +74 -0
  87. package/container/types.js +5 -0
  88. package/contextual-menu/ContextualMenu.accessibility.test.js +97 -0
  89. package/contextual-menu/ContextualMenu.d.ts +5 -0
  90. package/contextual-menu/ContextualMenu.js +88 -0
  91. package/contextual-menu/ContextualMenu.stories.tsx +232 -0
  92. package/contextual-menu/ContextualMenu.test.js +205 -0
  93. package/contextual-menu/GroupItem.d.ts +4 -0
  94. package/contextual-menu/GroupItem.js +67 -0
  95. package/contextual-menu/ItemAction.d.ts +4 -0
  96. package/contextual-menu/ItemAction.js +51 -0
  97. package/contextual-menu/MenuItem.d.ts +4 -0
  98. package/contextual-menu/MenuItem.js +29 -0
  99. package/contextual-menu/SingleItem.d.ts +4 -0
  100. package/contextual-menu/SingleItem.js +38 -0
  101. package/contextual-menu/types.d.ts +58 -0
  102. package/contextual-menu/types.js +5 -0
  103. package/date-input/Calendar.js +13 -57
  104. package/date-input/DateInput.accessibility.test.js +228 -0
  105. package/date-input/DateInput.js +61 -108
  106. package/date-input/DateInput.stories.tsx +19 -31
  107. package/date-input/DateInput.test.js +674 -701
  108. package/date-input/DatePicker.js +23 -48
  109. package/date-input/YearPicker.js +8 -34
  110. package/date-input/types.d.ts +28 -22
  111. package/dialog/Dialog.accessibility.test.js +69 -0
  112. package/dialog/Dialog.js +21 -59
  113. package/dialog/Dialog.stories.tsx +175 -0
  114. package/dialog/Dialog.test.js +206 -204
  115. package/dialog/types.d.ts +18 -13
  116. package/divider/Divider.accessibility.test.js +33 -0
  117. package/divider/Divider.d.ts +4 -0
  118. package/divider/Divider.js +36 -0
  119. package/divider/Divider.stories.tsx +223 -0
  120. package/divider/Divider.test.js +38 -0
  121. package/divider/types.d.ts +21 -0
  122. package/divider/types.js +5 -0
  123. package/dropdown/Dropdown.accessibility.test.js +180 -0
  124. package/dropdown/Dropdown.js +67 -135
  125. package/dropdown/Dropdown.stories.tsx +15 -26
  126. package/dropdown/Dropdown.test.js +402 -389
  127. package/dropdown/DropdownMenu.js +12 -23
  128. package/dropdown/DropdownMenuItem.js +13 -21
  129. package/dropdown/types.d.ts +20 -24
  130. package/file-input/FileInput.accessibility.test.js +160 -0
  131. package/file-input/FileInput.js +179 -286
  132. package/file-input/FileInput.stories.tsx +1 -1
  133. package/file-input/FileInput.test.js +293 -354
  134. package/file-input/FileItem.js +29 -66
  135. package/file-input/types.d.ts +9 -9
  136. package/flex/Flex.js +25 -39
  137. package/flex/types.d.ts +6 -6
  138. package/footer/Footer.accessibility.test.js +125 -0
  139. package/footer/Footer.d.ts +1 -1
  140. package/footer/Footer.js +43 -68
  141. package/footer/Footer.stories.tsx +66 -9
  142. package/footer/Footer.test.js +18 -32
  143. package/footer/Icons.d.ts +3 -2
  144. package/footer/Icons.js +53 -22
  145. package/footer/types.d.ts +17 -17
  146. package/grid/Grid.js +1 -16
  147. package/grid/types.d.ts +10 -10
  148. package/header/Header.accessibility.test.js +93 -0
  149. package/header/Header.d.ts +1 -1
  150. package/header/Header.js +38 -104
  151. package/header/Header.stories.tsx +16 -0
  152. package/header/Header.test.js +12 -25
  153. package/header/Icons.d.ts +2 -2
  154. package/header/Icons.js +3 -13
  155. package/header/types.d.ts +7 -8
  156. package/heading/Heading.accessibility.test.js +33 -0
  157. package/heading/Heading.js +9 -31
  158. package/heading/Heading.test.js +70 -87
  159. package/heading/types.d.ts +7 -7
  160. package/icon/Icon.accessibility.test.js +30 -0
  161. package/icon/Icon.d.ts +4 -0
  162. package/icon/Icon.js +33 -0
  163. package/icon/Icon.stories.tsx +28 -0
  164. package/icon/types.d.ts +4 -0
  165. package/icon/types.js +5 -0
  166. package/image/Image.accessibility.test.js +56 -0
  167. package/image/Image.d.ts +4 -0
  168. package/image/Image.js +70 -0
  169. package/image/Image.stories.tsx +129 -0
  170. package/image/types.d.ts +72 -0
  171. package/image/types.js +5 -0
  172. package/inset/Inset.js +13 -21
  173. package/inset/types.d.ts +2 -2
  174. package/layout/ApplicationLayout.d.ts +2 -2
  175. package/layout/ApplicationLayout.js +32 -69
  176. package/layout/ApplicationLayout.stories.tsx +1 -1
  177. package/layout/Icons.d.ts +7 -5
  178. package/layout/Icons.js +41 -59
  179. package/layout/types.d.ts +3 -3
  180. package/link/Link.accessibility.test.js +108 -0
  181. package/link/Link.js +28 -47
  182. package/link/Link.stories.tsx +4 -4
  183. package/link/Link.test.js +23 -41
  184. package/link/types.d.ts +14 -14
  185. package/main.d.ts +9 -4
  186. package/main.js +46 -59
  187. package/nav-tabs/NavTabs.accessibility.test.js +44 -0
  188. package/nav-tabs/NavTabs.d.ts +1 -2
  189. package/nav-tabs/NavTabs.js +19 -48
  190. package/nav-tabs/NavTabs.stories.tsx +30 -25
  191. package/nav-tabs/NavTabs.test.js +45 -50
  192. package/nav-tabs/NavTabsContext.d.ts +3 -0
  193. package/nav-tabs/NavTabsContext.js +8 -0
  194. package/nav-tabs/Tab.js +38 -67
  195. package/nav-tabs/types.d.ts +10 -10
  196. package/number-input/NumberInput.accessibility.test.js +228 -0
  197. package/number-input/NumberInput.d.ts +0 -7
  198. package/number-input/NumberInput.js +47 -39
  199. package/number-input/NumberInput.stories.tsx +42 -26
  200. package/number-input/NumberInput.test.js +839 -575
  201. package/number-input/NumberInputContext.d.ts +3 -0
  202. package/number-input/NumberInputContext.js +8 -0
  203. package/number-input/types.d.ts +17 -5
  204. package/package.json +42 -40
  205. package/paginator/Paginator.accessibility.test.js +79 -0
  206. package/paginator/Paginator.js +27 -52
  207. package/paginator/Paginator.test.js +224 -207
  208. package/paginator/types.d.ts +3 -3
  209. package/paragraph/Paragraph.accessibility.test.js +28 -0
  210. package/paragraph/Paragraph.js +3 -19
  211. package/paragraph/Paragraph.stories.tsx +0 -17
  212. package/password-input/PasswordInput.accessibility.test.js +153 -0
  213. package/password-input/PasswordInput.js +32 -54
  214. package/password-input/PasswordInput.stories.tsx +1 -34
  215. package/password-input/PasswordInput.test.js +153 -129
  216. package/password-input/types.d.ts +8 -7
  217. package/progress-bar/ProgressBar.accessibility.test.js +35 -0
  218. package/progress-bar/ProgressBar.js +26 -56
  219. package/progress-bar/{ProgressBar.stories.jsx → ProgressBar.stories.tsx} +1 -1
  220. package/progress-bar/ProgressBar.test.js +35 -52
  221. package/progress-bar/types.d.ts +3 -3
  222. package/quick-nav/QuickNav.accessibility.test.js +57 -0
  223. package/quick-nav/QuickNav.js +4 -27
  224. package/quick-nav/QuickNav.stories.tsx +1 -1
  225. package/quick-nav/types.d.ts +10 -10
  226. package/radio-group/Radio.d.ts +1 -1
  227. package/radio-group/Radio.js +22 -57
  228. package/radio-group/RadioGroup.accessibility.test.js +97 -0
  229. package/radio-group/RadioGroup.js +40 -88
  230. package/radio-group/RadioGroup.stories.tsx +10 -10
  231. package/radio-group/RadioGroup.test.js +504 -472
  232. package/radio-group/types.d.ts +8 -8
  233. package/resultset-table/Icons.d.ts +7 -0
  234. package/{resultsetTable → resultset-table}/Icons.js +1 -5
  235. package/resultset-table/ResultsetTable.accessibility.test.js +285 -0
  236. package/resultset-table/ResultsetTable.d.ts +7 -0
  237. package/{resultsetTable → resultset-table}/ResultsetTable.js +45 -69
  238. package/{resultsetTable → resultset-table}/ResultsetTable.stories.tsx +118 -5
  239. package/{resultsetTable → resultset-table}/ResultsetTable.test.js +148 -92
  240. package/{resultsetTable → resultset-table}/types.d.ts +44 -11
  241. package/resultset-table/types.js +5 -0
  242. package/select/Listbox.js +36 -54
  243. package/select/Option.js +28 -36
  244. package/select/Select.accessibility.test.js +228 -0
  245. package/select/Select.js +111 -177
  246. package/select/Select.stories.tsx +59 -111
  247. package/select/Select.test.js +1895 -1858
  248. package/select/types.d.ts +15 -16
  249. package/sidenav/Sidenav.accessibility.test.js +59 -0
  250. package/sidenav/Sidenav.js +44 -81
  251. package/sidenav/Sidenav.stories.tsx +4 -9
  252. package/sidenav/Sidenav.test.js +3 -10
  253. package/{layout → sidenav}/SidenavContext.d.ts +1 -1
  254. package/{layout → sidenav}/SidenavContext.js +3 -9
  255. package/sidenav/types.d.ts +20 -20
  256. package/slider/Slider.accessibility.test.js +104 -0
  257. package/slider/Slider.js +66 -125
  258. package/slider/Slider.stories.tsx +0 -60
  259. package/slider/Slider.test.js +107 -103
  260. package/slider/types.d.ts +4 -4
  261. package/spinner/Spinner.accessibility.test.js +96 -0
  262. package/spinner/Spinner.js +21 -55
  263. package/spinner/Spinner.test.js +25 -34
  264. package/spinner/types.d.ts +3 -3
  265. package/status-light/StatusLight.accessibility.test.js +157 -0
  266. package/status-light/StatusLight.d.ts +4 -0
  267. package/status-light/StatusLight.js +51 -0
  268. package/status-light/StatusLight.stories.tsx +74 -0
  269. package/status-light/StatusLight.test.js +25 -0
  270. package/status-light/types.d.ts +17 -0
  271. package/status-light/types.js +5 -0
  272. package/switch/Switch.accessibility.test.js +98 -0
  273. package/switch/Switch.js +49 -100
  274. package/switch/Switch.stories.tsx +12 -34
  275. package/switch/Switch.test.js +51 -96
  276. package/switch/types.d.ts +4 -4
  277. package/table/DropdownTheme.js +62 -0
  278. package/table/Table.accessibility.test.js +93 -0
  279. package/table/Table.d.ts +6 -2
  280. package/table/Table.js +76 -33
  281. package/table/{Table.stories.jsx → Table.stories.tsx} +309 -2
  282. package/table/Table.test.js +93 -6
  283. package/table/types.d.ts +34 -6
  284. package/tabs/Tab.js +22 -37
  285. package/tabs/Tabs.accessibility.test.js +56 -0
  286. package/tabs/Tabs.js +59 -147
  287. package/tabs/Tabs.stories.tsx +8 -4
  288. package/tabs/Tabs.test.js +57 -131
  289. package/tabs/types.d.ts +21 -21
  290. package/tag/Tag.accessibility.test.js +69 -0
  291. package/tag/Tag.js +27 -57
  292. package/tag/Tag.stories.tsx +4 -7
  293. package/tag/Tag.test.js +17 -36
  294. package/tag/types.d.ts +9 -9
  295. package/text-input/Suggestion.js +9 -26
  296. package/text-input/Suggestions.d.ts +1 -1
  297. package/text-input/Suggestions.js +30 -70
  298. package/text-input/TextInput.accessibility.test.js +321 -0
  299. package/text-input/TextInput.js +198 -286
  300. package/text-input/TextInput.stories.tsx +65 -160
  301. package/text-input/TextInput.test.js +1227 -1194
  302. package/text-input/types.d.ts +25 -17
  303. package/textarea/Textarea.accessibility.test.js +155 -0
  304. package/textarea/Textarea.js +67 -111
  305. package/textarea/{Textarea.stories.jsx → Textarea.stories.tsx} +58 -100
  306. package/textarea/Textarea.test.js +150 -179
  307. package/textarea/types.d.ts +9 -5
  308. package/toggle-group/ToggleGroup.accessibility.test.js +107 -0
  309. package/toggle-group/ToggleGroup.js +25 -67
  310. package/toggle-group/ToggleGroup.stories.tsx +7 -7
  311. package/toggle-group/ToggleGroup.test.js +48 -81
  312. package/toggle-group/types.d.ts +12 -12
  313. package/typography/Typography.accessibility.test.js +339 -0
  314. package/typography/Typography.js +4 -13
  315. package/typography/types.d.ts +1 -1
  316. package/useTheme.d.ts +51 -141
  317. package/useTheme.js +1 -8
  318. package/useTranslatedLabels.js +1 -7
  319. package/utils/BaseTypography.d.ts +2 -2
  320. package/utils/BaseTypography.js +16 -30
  321. package/utils/FocusLock.js +25 -39
  322. package/wizard/Wizard.accessibility.test.js +55 -0
  323. package/wizard/Wizard.js +27 -73
  324. package/wizard/Wizard.stories.tsx +19 -0
  325. package/wizard/Wizard.test.js +53 -80
  326. package/wizard/types.d.ts +8 -8
  327. package/common/OpenSans.css +0 -69
  328. package/common/fonts/OpenSans-Bold.ttf +0 -0
  329. package/common/fonts/OpenSans-BoldItalic.ttf +0 -0
  330. package/common/fonts/OpenSans-ExtraBold.ttf +0 -0
  331. package/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  332. package/common/fonts/OpenSans-Italic.ttf +0 -0
  333. package/common/fonts/OpenSans-Light.ttf +0 -0
  334. package/common/fonts/OpenSans-LightItalic.ttf +0 -0
  335. package/common/fonts/OpenSans-Regular.ttf +0 -0
  336. package/common/fonts/OpenSans-SemiBold.ttf +0 -0
  337. package/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  338. package/date-input/Icons.d.ts +0 -6
  339. package/date-input/Icons.js +0 -75
  340. package/paginator/Icons.d.ts +0 -5
  341. package/paginator/Icons.js +0 -54
  342. package/password-input/Icons.d.ts +0 -6
  343. package/password-input/Icons.js +0 -39
  344. package/resultsetTable/Icons.d.ts +0 -7
  345. package/resultsetTable/ResultsetTable.d.ts +0 -4
  346. package/select/Icons.d.ts +0 -10
  347. package/select/Icons.js +0 -93
  348. package/sidenav/Icons.d.ts +0 -7
  349. package/sidenav/Icons.js +0 -51
  350. package/text-input/Icons.d.ts +0 -8
  351. package/text-input/Icons.js +0 -60
  352. /package/{resultsetTable → action-icon}/types.js +0 -0
  353. /package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +0 -0
@@ -0,0 +1,153 @@
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 _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
7
+ var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
8
+ var _react = _interopRequireDefault(require("react"));
9
+ var _react2 = require("@testing-library/react");
10
+ var _axeHelper = require("../../test/accessibility/axe-helper.js");
11
+ var _PasswordInput = _interopRequireDefault(require("./PasswordInput.tsx"));
12
+ // Mocking DOMRect for Radix Primitive Popover
13
+ global.globalThis = global;
14
+ global.DOMRect = {
15
+ fromRect: function fromRect() {
16
+ return {
17
+ top: 0,
18
+ left: 0,
19
+ bottom: 0,
20
+ right: 0,
21
+ width: 0,
22
+ height: 0
23
+ };
24
+ }
25
+ };
26
+ global.ResizeObserver = /*#__PURE__*/function () {
27
+ function ResizeObserver() {
28
+ (0, _classCallCheck2["default"])(this, ResizeObserver);
29
+ }
30
+ (0, _createClass2["default"])(ResizeObserver, [{
31
+ key: "observe",
32
+ value: function observe() {}
33
+ }, {
34
+ key: "unobserve",
35
+ value: function unobserve() {}
36
+ }, {
37
+ key: "disconnect",
38
+ value: function disconnect() {}
39
+ }]);
40
+ return ResizeObserver;
41
+ }();
42
+ describe("Password input component accessibility tests", function () {
43
+ it("Should not have basic accessibility issues", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
44
+ var _render, container, results;
45
+ return _regenerator["default"].wrap(function _callee$(_context) {
46
+ while (1) switch (_context.prev = _context.next) {
47
+ case 0:
48
+ _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_PasswordInput["default"], {
49
+ label: "Password input label",
50
+ helperText: "Helper text",
51
+ margin: "medium",
52
+ name: "Password",
53
+ size: "medium",
54
+ value: "Password",
55
+ minLength: 5,
56
+ maxLength: 10,
57
+ clearable: true
58
+ })), container = _render.container;
59
+ _context.next = 3;
60
+ return (0, _axeHelper.axe)(container);
61
+ case 3:
62
+ results = _context.sent;
63
+ expect(results).toHaveNoViolations();
64
+ case 5:
65
+ case "end":
66
+ return _context.stop();
67
+ }
68
+ }, _callee);
69
+ })));
70
+ it("Should not have basic accessibility issues for pattern mode", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2() {
71
+ var _render2, container, results;
72
+ return _regenerator["default"].wrap(function _callee2$(_context2) {
73
+ while (1) switch (_context2.prev = _context2.next) {
74
+ case 0:
75
+ _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_PasswordInput["default"], {
76
+ label: "Password input label",
77
+ helperText: "Helper text",
78
+ margin: "medium",
79
+ name: "Password",
80
+ size: "medium",
81
+ value: "Password",
82
+ minLength: 5,
83
+ maxLength: 10,
84
+ autocomplete: "on",
85
+ pattern: "^.*(?=.*[a-zA-Z])(?=.*)(?=.*[!&$%&? \"]).*$"
86
+ })), container = _render2.container;
87
+ _context2.next = 3;
88
+ return (0, _axeHelper.axe)(container);
89
+ case 3:
90
+ results = _context2.sent;
91
+ expect(results).toHaveNoViolations();
92
+ case 5:
93
+ case "end":
94
+ return _context2.stop();
95
+ }
96
+ }, _callee2);
97
+ })));
98
+ it("Should not have basic accessibility issues for clearable mode", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee3() {
99
+ var _render3, container, results;
100
+ return _regenerator["default"].wrap(function _callee3$(_context3) {
101
+ while (1) switch (_context3.prev = _context3.next) {
102
+ case 0:
103
+ _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_PasswordInput["default"], {
104
+ label: "Password input label",
105
+ helperText: "Helper text",
106
+ margin: "medium",
107
+ name: "Password",
108
+ size: "medium",
109
+ error: "Password error",
110
+ value: "Password",
111
+ minLength: 5,
112
+ maxLength: 10,
113
+ clearable: true
114
+ })), container = _render3.container;
115
+ _context3.next = 3;
116
+ return (0, _axeHelper.axe)(container);
117
+ case 3:
118
+ results = _context3.sent;
119
+ expect(results).toHaveNoViolations();
120
+ case 5:
121
+ case "end":
122
+ return _context3.stop();
123
+ }
124
+ }, _callee3);
125
+ })));
126
+ it("Should not have basic accessibility issues for autocomplete mode", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee4() {
127
+ var _render4, container, results;
128
+ return _regenerator["default"].wrap(function _callee4$(_context4) {
129
+ while (1) switch (_context4.prev = _context4.next) {
130
+ case 0:
131
+ _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_PasswordInput["default"], {
132
+ label: "Password input label",
133
+ helperText: "Helper text",
134
+ margin: "medium",
135
+ name: "Password",
136
+ size: "medium",
137
+ value: "Password",
138
+ minLength: 5,
139
+ maxLength: 10,
140
+ autocomplete: "on"
141
+ })), container = _render4.container;
142
+ _context4.next = 3;
143
+ return (0, _axeHelper.axe)(container);
144
+ case 3:
145
+ results = _context4.sent;
146
+ expect(results).toHaveNoViolations();
147
+ case 5:
148
+ case "end":
149
+ return _context4.stop();
150
+ }
151
+ }, _callee4);
152
+ })));
153
+ });
@@ -1,76 +1,56 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
4
  var _typeof = require("@babel/runtime/helpers/typeof");
6
-
7
5
  Object.defineProperty(exports, "__esModule", {
8
6
  value: true
9
7
  });
10
8
  exports["default"] = void 0;
11
-
12
9
  var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
13
-
14
10
  var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
15
-
16
11
  var _react = _interopRequireWildcard(require("react"));
17
-
18
12
  var _styledComponents = _interopRequireDefault(require("styled-components"));
19
-
20
13
  var _TextInput = _interopRequireDefault(require("../text-input/TextInput"));
21
-
22
14
  var _useTranslatedLabels2 = _interopRequireDefault(require("../useTranslatedLabels"));
23
-
24
- var _Icons = _interopRequireDefault(require("./Icons"));
25
-
26
15
  var _templateObject;
27
-
28
- function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
29
-
30
- function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
31
-
16
+ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
17
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
32
18
  var setInputType = function setInputType(type, element) {
33
19
  element === null || element === void 0 ? void 0 : element.getElementsByTagName("input")[0].setAttribute("type", type);
34
20
  };
35
-
36
21
  var setAriaAttributes = function setAriaAttributes(ariaExpanded, ariaLabel, element) {
37
- var inputElement = element === null || element === void 0 ? void 0 : element.getElementsByTagName("input")[0];
38
- inputElement === null || inputElement === void 0 ? void 0 : inputElement.setAttribute("aria-expanded", ariaExpanded);
39
- inputElement === null || inputElement === void 0 ? void 0 : inputElement.setAttribute("aria-label", ariaLabel);
22
+ var buttonElement = element === null || element === void 0 ? void 0 : element.getElementsByTagName("button")[0];
23
+ buttonElement === null || buttonElement === void 0 ? void 0 : buttonElement.setAttribute("aria-expanded", ariaExpanded);
24
+ buttonElement === null || buttonElement === void 0 ? void 0 : buttonElement.setAttribute("aria-label", ariaLabel);
40
25
  };
41
-
42
26
  var DxcPasswordInput = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
43
27
  var label = _ref.label,
44
- _ref$name = _ref.name,
45
- name = _ref$name === void 0 ? "" : _ref$name,
46
- value = _ref.value,
47
- helperText = _ref.helperText,
48
- _ref$clearable = _ref.clearable,
49
- clearable = _ref$clearable === void 0 ? false : _ref$clearable,
50
- onChange = _ref.onChange,
51
- onBlur = _ref.onBlur,
52
- error = _ref.error,
53
- pattern = _ref.pattern,
54
- minLength = _ref.minLength,
55
- maxLength = _ref.maxLength,
56
- _ref$autocomplete = _ref.autocomplete,
57
- autocomplete = _ref$autocomplete === void 0 ? "off" : _ref$autocomplete,
58
- margin = _ref.margin,
59
- _ref$size = _ref.size,
60
- size = _ref$size === void 0 ? "medium" : _ref$size,
61
- _ref$tabIndex = _ref.tabIndex,
62
- tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
63
-
28
+ _ref$name = _ref.name,
29
+ name = _ref$name === void 0 ? "" : _ref$name,
30
+ value = _ref.value,
31
+ helperText = _ref.helperText,
32
+ _ref$clearable = _ref.clearable,
33
+ clearable = _ref$clearable === void 0 ? false : _ref$clearable,
34
+ onChange = _ref.onChange,
35
+ onBlur = _ref.onBlur,
36
+ error = _ref.error,
37
+ pattern = _ref.pattern,
38
+ minLength = _ref.minLength,
39
+ maxLength = _ref.maxLength,
40
+ _ref$autocomplete = _ref.autocomplete,
41
+ autocomplete = _ref$autocomplete === void 0 ? "off" : _ref$autocomplete,
42
+ margin = _ref.margin,
43
+ _ref$size = _ref.size,
44
+ size = _ref$size === void 0 ? "medium" : _ref$size,
45
+ _ref$tabIndex = _ref.tabIndex,
46
+ tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
64
47
  var _useState = (0, _react.useState)(false),
65
- _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
66
- isPasswordVisible = _useState2[0],
67
- setIsPasswordVisible = _useState2[1];
68
-
48
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
49
+ isPasswordVisible = _useState2[0],
50
+ setIsPasswordVisible = _useState2[1];
69
51
  var inputRef = (0, _react.useRef)(null);
70
-
71
52
  var _useTranslatedLabels = (0, _useTranslatedLabels2["default"])(),
72
- passwordInput = _useTranslatedLabels.passwordInput;
73
-
53
+ passwordInput = _useTranslatedLabels.passwordInput;
74
54
  (0, _react.useEffect)(function () {
75
55
  (function () {
76
56
  if (isPasswordVisible) {
@@ -83,7 +63,8 @@ var DxcPasswordInput = /*#__PURE__*/_react["default"].forwardRef(function (_ref,
83
63
  })();
84
64
  }, [isPasswordVisible, passwordInput]);
85
65
  return /*#__PURE__*/_react["default"].createElement(PasswordInput, {
86
- ref: ref
66
+ ref: ref,
67
+ role: "group"
87
68
  }, /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
88
69
  label: label,
89
70
  name: name,
@@ -95,7 +76,7 @@ var DxcPasswordInput = /*#__PURE__*/_react["default"].forwardRef(function (_ref,
95
76
  return !isPasswordVisible;
96
77
  });
97
78
  },
98
- icon: isPasswordVisible ? _Icons["default"].hidePassword : _Icons["default"].showPassword,
79
+ icon: isPasswordVisible ? 'Visibility_Off' : 'Visibility',
99
80
  title: isPasswordVisible ? passwordInput.inputHidePasswordTitle : passwordInput.inputShowPasswordTitle
100
81
  },
101
82
  error: error,
@@ -112,8 +93,5 @@ var DxcPasswordInput = /*#__PURE__*/_react["default"].forwardRef(function (_ref,
112
93
  tabIndex: tabIndex
113
94
  }));
114
95
  });
115
-
116
96
  var PasswordInput = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n & ::-ms-reveal {\n display: none;\n }\n"])));
117
-
118
- var _default = DxcPasswordInput;
119
- exports["default"] = _default;
97
+ var _default = exports["default"] = DxcPasswordInput;
@@ -1,13 +1,11 @@
1
1
  import React from "react";
2
2
  import { userEvent, within } from "@storybook/testing-library";
3
3
  import DxcPasswordInput from "./PasswordInput";
4
- import { BackgroundColorProvider } from "../BackgroundColorContext";
5
4
  import Title from "../../.storybook/components/Title";
6
5
  import ExampleContainer from "../../.storybook/components/ExampleContainer";
7
- import DarkContainer from "../../.storybook/components/DarkSection";
8
6
 
9
7
  export default {
10
- title: "Password input",
8
+ title: "Password Input",
11
9
  component: DxcPasswordInput,
12
10
  };
13
11
 
@@ -37,19 +35,6 @@ export const Chromatic = () => (
37
35
  <Title title="Invalid" theme="light" level={4} />
38
36
  <DxcPasswordInput label="Error password input" error="Error message." />
39
37
  </ExampleContainer>
40
- <BackgroundColorProvider color="#333333">
41
- <DarkContainer>
42
- <Title title="Dark" theme="dark" level={2} />
43
- <ExampleContainer>
44
- <Title title="With label, helper text and value" theme="dark" level={4} />
45
- <DxcPasswordInput label="Password input" helperText="Help message" value="Password" />
46
- </ExampleContainer>
47
- <ExampleContainer>
48
- <Title title="With label, helper text, value and error" theme="dark" level={4} />
49
- <DxcPasswordInput label="Password input" helperText="Help message" error="Error message." value="Password" />
50
- </ExampleContainer>
51
- </DarkContainer>
52
- </BackgroundColorProvider>
53
38
  <Title title="Margins" theme="light" level={2} />
54
39
  <ExampleContainer>
55
40
  <Title title="Xxsmall margin" theme="light" level={4} />
@@ -106,27 +91,9 @@ const Password = () => (
106
91
  </ExampleContainer>
107
92
  );
108
93
 
109
- const PasswordDark = () => (
110
- <BackgroundColorProvider color="#333333">
111
- <DarkContainer>
112
- <ExampleContainer expanded>
113
- <Title title="Show password" theme="dark" level={4} />
114
- <DxcPasswordInput label="Password input" value="Password" />
115
- </ExampleContainer>
116
- </DarkContainer>
117
- </BackgroundColorProvider>
118
- );
119
-
120
94
  export const ShowPassword = Password.bind({});
121
95
  ShowPassword.play = async ({ canvasElement }) => {
122
96
  const canvas = within(canvasElement);
123
97
  const passwordBtn = canvas.getByRole("button");
124
98
  await userEvent.click(passwordBtn);
125
99
  };
126
-
127
- export const ShowPasswordDark = PasswordDark.bind({});
128
- ShowPasswordDark.play = async ({ canvasElement }) => {
129
- const canvas = within(canvasElement);
130
- const passwordBtn = canvas.getByRole("button");
131
- await userEvent.click(passwordBtn);
132
- };