@dxc-technology/halstack-react 0.0.0-da4b2be → 0.0.0-da56eb6

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 (347) hide show
  1. package/README.md +46 -0
  2. package/dist/index.d.mts +4014 -0
  3. package/dist/index.d.ts +4014 -0
  4. package/dist/index.js +14967 -0
  5. package/dist/index.mjs +14878 -0
  6. package/package.json +85 -67
  7. package/BackgroundColorContext.d.ts +0 -10
  8. package/BackgroundColorContext.js +0 -47
  9. package/HalstackContext.d.ts +0 -1336
  10. package/HalstackContext.js +0 -335
  11. package/accordion/Accordion.d.ts +0 -4
  12. package/accordion/Accordion.js +0 -234
  13. package/accordion/Accordion.stories.tsx +0 -395
  14. package/accordion/Accordion.test.js +0 -71
  15. package/accordion/types.d.ts +0 -69
  16. package/accordion/types.js +0 -5
  17. package/accordion-group/AccordionGroup.d.ts +0 -8
  18. package/accordion-group/AccordionGroup.js +0 -128
  19. package/accordion-group/AccordionGroup.stories.tsx +0 -251
  20. package/accordion-group/AccordionGroup.test.js +0 -126
  21. package/accordion-group/AccordionGroupAccordion.d.ts +0 -4
  22. package/accordion-group/AccordionGroupAccordion.js +0 -43
  23. package/accordion-group/types.d.ts +0 -79
  24. package/accordion-group/types.js +0 -5
  25. package/alert/Alert.d.ts +0 -4
  26. package/alert/Alert.js +0 -289
  27. package/alert/Alert.stories.tsx +0 -198
  28. package/alert/Alert.test.js +0 -92
  29. package/alert/types.d.ts +0 -49
  30. package/alert/types.js +0 -5
  31. package/badge/Badge.d.ts +0 -4
  32. package/badge/Badge.js +0 -61
  33. package/badge/types.d.ts +0 -5
  34. package/badge/types.js +0 -5
  35. package/bleed/Bleed.d.ts +0 -3
  36. package/bleed/Bleed.js +0 -51
  37. package/bleed/Bleed.stories.tsx +0 -342
  38. package/bleed/types.d.ts +0 -37
  39. package/bleed/types.js +0 -5
  40. package/box/Box.d.ts +0 -4
  41. package/box/Box.js +0 -97
  42. package/box/Box.stories.tsx +0 -119
  43. package/box/Box.test.js +0 -18
  44. package/box/types.d.ts +0 -32
  45. package/box/types.js +0 -5
  46. package/bulleted-list/BulletedList.d.ts +0 -7
  47. package/bulleted-list/BulletedList.js +0 -125
  48. package/bulleted-list/BulletedList.stories.tsx +0 -206
  49. package/bulleted-list/types.d.ts +0 -38
  50. package/bulleted-list/types.js +0 -5
  51. package/button/Button.d.ts +0 -4
  52. package/button/Button.js +0 -153
  53. package/button/Button.stories.tsx +0 -425
  54. package/button/Button.test.js +0 -35
  55. package/button/types.d.ts +0 -53
  56. package/button/types.js +0 -5
  57. package/card/Card.d.ts +0 -4
  58. package/card/Card.js +0 -160
  59. package/card/Card.stories.tsx +0 -200
  60. package/card/Card.test.js +0 -50
  61. package/card/ice-cream.jpg +0 -0
  62. package/card/types.d.ts +0 -68
  63. package/card/types.js +0 -5
  64. package/checkbox/Checkbox.d.ts +0 -4
  65. package/checkbox/Checkbox.js +0 -250
  66. package/checkbox/Checkbox.stories.tsx +0 -260
  67. package/checkbox/Checkbox.test.js +0 -155
  68. package/checkbox/types.d.ts +0 -68
  69. package/checkbox/types.js +0 -5
  70. package/chip/Chip.d.ts +0 -4
  71. package/chip/Chip.js +0 -140
  72. package/chip/Chip.stories.tsx +0 -214
  73. package/chip/Chip.test.js +0 -54
  74. package/chip/types.d.ts +0 -45
  75. package/chip/types.js +0 -5
  76. package/common/OpenSans.css +0 -69
  77. package/common/coreTokens.d.ts +0 -146
  78. package/common/coreTokens.js +0 -167
  79. package/common/fonts/OpenSans-Bold.ttf +0 -0
  80. package/common/fonts/OpenSans-BoldItalic.ttf +0 -0
  81. package/common/fonts/OpenSans-ExtraBold.ttf +0 -0
  82. package/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  83. package/common/fonts/OpenSans-Italic.ttf +0 -0
  84. package/common/fonts/OpenSans-Light.ttf +0 -0
  85. package/common/fonts/OpenSans-LightItalic.ttf +0 -0
  86. package/common/fonts/OpenSans-Regular.ttf +0 -0
  87. package/common/fonts/OpenSans-SemiBold.ttf +0 -0
  88. package/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  89. package/common/utils.d.ts +0 -1
  90. package/common/utils.js +0 -22
  91. package/common/variables.d.ts +0 -1482
  92. package/common/variables.js +0 -1361
  93. package/date-input/Calendar.d.ts +0 -4
  94. package/date-input/Calendar.js +0 -258
  95. package/date-input/DateInput.d.ts +0 -4
  96. package/date-input/DateInput.js +0 -269
  97. package/date-input/DateInput.stories.tsx +0 -304
  98. package/date-input/DateInput.test.js +0 -835
  99. package/date-input/DatePicker.d.ts +0 -4
  100. package/date-input/DatePicker.js +0 -146
  101. package/date-input/Icons.d.ts +0 -6
  102. package/date-input/Icons.js +0 -75
  103. package/date-input/YearPicker.d.ts +0 -4
  104. package/date-input/YearPicker.js +0 -126
  105. package/date-input/types.d.ts +0 -158
  106. package/date-input/types.js +0 -5
  107. package/dialog/Dialog.d.ts +0 -4
  108. package/dialog/Dialog.js +0 -131
  109. package/dialog/Dialog.stories.tsx +0 -195
  110. package/dialog/Dialog.test.js +0 -369
  111. package/dialog/types.d.ts +0 -31
  112. package/dialog/types.js +0 -5
  113. package/dropdown/Dropdown.d.ts +0 -4
  114. package/dropdown/Dropdown.js +0 -388
  115. package/dropdown/Dropdown.stories.tsx +0 -438
  116. package/dropdown/Dropdown.test.js +0 -586
  117. package/dropdown/DropdownMenu.d.ts +0 -4
  118. package/dropdown/DropdownMenu.js +0 -74
  119. package/dropdown/DropdownMenuItem.d.ts +0 -4
  120. package/dropdown/DropdownMenuItem.js +0 -79
  121. package/dropdown/types.d.ts +0 -100
  122. package/dropdown/types.js +0 -5
  123. package/file-input/FileInput.d.ts +0 -4
  124. package/file-input/FileInput.js +0 -547
  125. package/file-input/FileInput.stories.tsx +0 -618
  126. package/file-input/FileInput.test.js +0 -457
  127. package/file-input/FileItem.d.ts +0 -4
  128. package/file-input/FileItem.js +0 -162
  129. package/file-input/types.d.ts +0 -129
  130. package/file-input/types.js +0 -5
  131. package/flex/Flex.d.ts +0 -4
  132. package/flex/Flex.js +0 -71
  133. package/flex/Flex.stories.tsx +0 -112
  134. package/flex/types.d.ts +0 -97
  135. package/flex/types.js +0 -5
  136. package/footer/Footer.d.ts +0 -4
  137. package/footer/Footer.js +0 -183
  138. package/footer/Footer.stories.tsx +0 -228
  139. package/footer/Footer.test.js +0 -97
  140. package/footer/Icons.d.ts +0 -2
  141. package/footer/Icons.js +0 -77
  142. package/footer/types.d.ts +0 -66
  143. package/footer/types.js +0 -5
  144. package/grid/Grid.d.ts +0 -7
  145. package/grid/Grid.js +0 -91
  146. package/grid/Grid.stories.tsx +0 -219
  147. package/grid/types.d.ts +0 -115
  148. package/grid/types.js +0 -5
  149. package/header/Header.d.ts +0 -8
  150. package/header/Header.js +0 -303
  151. package/header/Header.stories.tsx +0 -315
  152. package/header/Header.test.js +0 -79
  153. package/header/Icons.d.ts +0 -2
  154. package/header/Icons.js +0 -34
  155. package/header/types.d.ts +0 -48
  156. package/header/types.js +0 -5
  157. package/heading/Heading.d.ts +0 -4
  158. package/heading/Heading.js +0 -159
  159. package/heading/Heading.stories.tsx +0 -54
  160. package/heading/Heading.test.js +0 -186
  161. package/heading/types.d.ts +0 -33
  162. package/heading/types.js +0 -5
  163. package/inset/Inset.d.ts +0 -3
  164. package/inset/Inset.js +0 -51
  165. package/inset/Inset.stories.tsx +0 -230
  166. package/inset/types.d.ts +0 -37
  167. package/inset/types.js +0 -5
  168. package/layout/ApplicationLayout.d.ts +0 -20
  169. package/layout/ApplicationLayout.js +0 -171
  170. package/layout/ApplicationLayout.stories.tsx +0 -162
  171. package/layout/Icons.d.ts +0 -5
  172. package/layout/Icons.js +0 -66
  173. package/layout/SidenavContext.d.ts +0 -5
  174. package/layout/SidenavContext.js +0 -19
  175. package/layout/types.d.ts +0 -41
  176. package/layout/types.js +0 -5
  177. package/link/Link.d.ts +0 -4
  178. package/link/Link.js +0 -136
  179. package/link/Link.stories.tsx +0 -253
  180. package/link/Link.test.js +0 -81
  181. package/link/types.d.ts +0 -54
  182. package/link/types.js +0 -5
  183. package/main.d.ts +0 -45
  184. package/main.js +0 -377
  185. package/nav-tabs/NavTabs.d.ts +0 -8
  186. package/nav-tabs/NavTabs.js +0 -122
  187. package/nav-tabs/NavTabs.stories.tsx +0 -274
  188. package/nav-tabs/NavTabs.test.js +0 -82
  189. package/nav-tabs/Tab.d.ts +0 -4
  190. package/nav-tabs/Tab.js +0 -146
  191. package/nav-tabs/types.d.ts +0 -52
  192. package/nav-tabs/types.js +0 -5
  193. package/number-input/NumberInput.d.ts +0 -4
  194. package/number-input/NumberInput.js +0 -76
  195. package/number-input/NumberInput.stories.tsx +0 -115
  196. package/number-input/NumberInput.test.js +0 -542
  197. package/number-input/NumberInputContext.d.ts +0 -4
  198. package/number-input/NumberInputContext.js +0 -19
  199. package/number-input/numberInputContextTypes.d.ts +0 -19
  200. package/number-input/numberInputContextTypes.js +0 -5
  201. package/number-input/types.d.ts +0 -124
  202. package/number-input/types.js +0 -5
  203. package/paginator/Icons.d.ts +0 -5
  204. package/paginator/Icons.js +0 -54
  205. package/paginator/Paginator.d.ts +0 -4
  206. package/paginator/Paginator.js +0 -163
  207. package/paginator/Paginator.stories.tsx +0 -87
  208. package/paginator/Paginator.test.js +0 -318
  209. package/paginator/types.d.ts +0 -38
  210. package/paginator/types.js +0 -5
  211. package/paragraph/Paragraph.d.ts +0 -5
  212. package/paragraph/Paragraph.js +0 -38
  213. package/paragraph/Paragraph.stories.tsx +0 -44
  214. package/password-input/PasswordInput.d.ts +0 -4
  215. package/password-input/PasswordInput.js +0 -166
  216. package/password-input/PasswordInput.stories.tsx +0 -131
  217. package/password-input/PasswordInput.test.js +0 -181
  218. package/password-input/types.d.ts +0 -110
  219. package/password-input/types.js +0 -5
  220. package/progress-bar/ProgressBar.d.ts +0 -4
  221. package/progress-bar/ProgressBar.js +0 -176
  222. package/progress-bar/ProgressBar.stories.jsx +0 -93
  223. package/progress-bar/ProgressBar.test.js +0 -110
  224. package/progress-bar/types.d.ts +0 -37
  225. package/progress-bar/types.js +0 -5
  226. package/quick-nav/QuickNav.d.ts +0 -4
  227. package/quick-nav/QuickNav.js +0 -117
  228. package/quick-nav/QuickNav.stories.tsx +0 -356
  229. package/quick-nav/types.d.ts +0 -21
  230. package/quick-nav/types.js +0 -5
  231. package/radio-group/Radio.d.ts +0 -4
  232. package/radio-group/Radio.js +0 -156
  233. package/radio-group/RadioGroup.d.ts +0 -4
  234. package/radio-group/RadioGroup.js +0 -281
  235. package/radio-group/RadioGroup.stories.tsx +0 -214
  236. package/radio-group/RadioGroup.test.js +0 -722
  237. package/radio-group/types.d.ts +0 -114
  238. package/radio-group/types.js +0 -5
  239. package/resultsetTable/Icons.d.ts +0 -7
  240. package/resultsetTable/Icons.js +0 -51
  241. package/resultsetTable/ResultsetTable.d.ts +0 -4
  242. package/resultsetTable/ResultsetTable.js +0 -195
  243. package/resultsetTable/ResultsetTable.stories.tsx +0 -300
  244. package/resultsetTable/ResultsetTable.test.js +0 -325
  245. package/resultsetTable/types.d.ts +0 -67
  246. package/resultsetTable/types.js +0 -5
  247. package/select/Icons.d.ts +0 -10
  248. package/select/Icons.js +0 -93
  249. package/select/Listbox.d.ts +0 -4
  250. package/select/Listbox.js +0 -169
  251. package/select/Option.d.ts +0 -4
  252. package/select/Option.js +0 -97
  253. package/select/Select.d.ts +0 -4
  254. package/select/Select.js +0 -666
  255. package/select/Select.stories.tsx +0 -971
  256. package/select/Select.test.js +0 -2228
  257. package/select/types.d.ts +0 -210
  258. package/select/types.js +0 -5
  259. package/sidenav/Icons.d.ts +0 -7
  260. package/sidenav/Icons.js +0 -51
  261. package/sidenav/Sidenav.d.ts +0 -10
  262. package/sidenav/Sidenav.js +0 -238
  263. package/sidenav/Sidenav.stories.tsx +0 -282
  264. package/sidenav/Sidenav.test.js +0 -44
  265. package/sidenav/types.d.ts +0 -76
  266. package/sidenav/types.js +0 -5
  267. package/slider/Slider.d.ts +0 -4
  268. package/slider/Slider.js +0 -342
  269. package/slider/Slider.stories.tsx +0 -240
  270. package/slider/Slider.test.js +0 -250
  271. package/slider/types.d.ts +0 -86
  272. package/slider/types.js +0 -5
  273. package/spinner/Spinner.d.ts +0 -4
  274. package/spinner/Spinner.js +0 -244
  275. package/spinner/Spinner.stories.jsx +0 -129
  276. package/spinner/Spinner.test.js +0 -64
  277. package/spinner/types.d.ts +0 -32
  278. package/spinner/types.js +0 -5
  279. package/switch/Switch.d.ts +0 -4
  280. package/switch/Switch.js +0 -262
  281. package/switch/Switch.stories.tsx +0 -171
  282. package/switch/Switch.test.js +0 -225
  283. package/switch/types.d.ts +0 -66
  284. package/switch/types.js +0 -5
  285. package/table/Table.d.ts +0 -4
  286. package/table/Table.js +0 -118
  287. package/table/Table.stories.jsx +0 -356
  288. package/table/Table.test.js +0 -26
  289. package/table/types.d.ts +0 -21
  290. package/table/types.js +0 -5
  291. package/tabs/Tab.d.ts +0 -4
  292. package/tabs/Tab.js +0 -132
  293. package/tabs/Tabs.d.ts +0 -4
  294. package/tabs/Tabs.js +0 -461
  295. package/tabs/Tabs.stories.tsx +0 -226
  296. package/tabs/Tabs.test.js +0 -350
  297. package/tabs/types.d.ts +0 -92
  298. package/tabs/types.js +0 -5
  299. package/tag/Tag.d.ts +0 -4
  300. package/tag/Tag.js +0 -181
  301. package/tag/Tag.stories.tsx +0 -155
  302. package/tag/Tag.test.js +0 -60
  303. package/tag/types.d.ts +0 -69
  304. package/tag/types.js +0 -5
  305. package/text-input/Icons.d.ts +0 -8
  306. package/text-input/Icons.js +0 -60
  307. package/text-input/Suggestion.d.ts +0 -4
  308. package/text-input/Suggestion.js +0 -84
  309. package/text-input/Suggestions.d.ts +0 -4
  310. package/text-input/Suggestions.js +0 -134
  311. package/text-input/TextInput.d.ts +0 -4
  312. package/text-input/TextInput.js +0 -673
  313. package/text-input/TextInput.stories.tsx +0 -569
  314. package/text-input/TextInput.test.js +0 -1723
  315. package/text-input/types.d.ts +0 -197
  316. package/text-input/types.js +0 -5
  317. package/textarea/Textarea.d.ts +0 -4
  318. package/textarea/Textarea.js +0 -276
  319. package/textarea/Textarea.stories.jsx +0 -216
  320. package/textarea/Textarea.test.js +0 -435
  321. package/textarea/types.d.ts +0 -137
  322. package/textarea/types.js +0 -5
  323. package/toggle-group/ToggleGroup.d.ts +0 -4
  324. package/toggle-group/ToggleGroup.js +0 -218
  325. package/toggle-group/ToggleGroup.stories.tsx +0 -215
  326. package/toggle-group/ToggleGroup.test.js +0 -156
  327. package/toggle-group/types.d.ts +0 -105
  328. package/toggle-group/types.js +0 -5
  329. package/typography/Typography.d.ts +0 -4
  330. package/typography/Typography.js +0 -32
  331. package/typography/Typography.stories.tsx +0 -198
  332. package/typography/types.d.ts +0 -18
  333. package/typography/types.js +0 -5
  334. package/useTheme.d.ts +0 -1235
  335. package/useTheme.js +0 -22
  336. package/useTranslatedLabels.d.ts +0 -85
  337. package/useTranslatedLabels.js +0 -20
  338. package/utils/BaseTypography.d.ts +0 -21
  339. package/utils/BaseTypography.js +0 -108
  340. package/utils/FocusLock.d.ts +0 -13
  341. package/utils/FocusLock.js +0 -138
  342. package/wizard/Wizard.d.ts +0 -4
  343. package/wizard/Wizard.js +0 -285
  344. package/wizard/Wizard.stories.tsx +0 -253
  345. package/wizard/Wizard.test.js +0 -141
  346. package/wizard/types.d.ts +0 -64
  347. package/wizard/types.js +0 -5
@@ -1,369 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
- var _react = _interopRequireDefault(require("react"));
6
-
7
- var _react2 = require("@testing-library/react");
8
-
9
- var _userEvent = _interopRequireDefault(require("@testing-library/user-event"));
10
-
11
- var _Dialog = _interopRequireDefault(require("./Dialog.tsx"));
12
-
13
- var _TextInput = _interopRequireDefault(require("../text-input/TextInput.tsx"));
14
-
15
- var _Textarea = _interopRequireDefault(require("../textarea/Textarea.tsx"));
16
-
17
- var _Checkbox = _interopRequireDefault(require("../checkbox/Checkbox.tsx"));
18
-
19
- var _Select = _interopRequireDefault(require("../select/Select.tsx"));
20
-
21
- var _Button = _interopRequireDefault(require("../button/Button.tsx"));
22
-
23
- var _Link = _interopRequireDefault(require("../link/Link.tsx"));
24
-
25
- var _Card = _interopRequireDefault(require("../card/Card.tsx"));
26
-
27
- var _RadioGroup = _interopRequireDefault(require("../radio-group/RadioGroup.tsx"));
28
-
29
- var _Slider = _interopRequireDefault(require("../slider/Slider.tsx"));
30
-
31
- var _Switch = _interopRequireDefault(require("../switch/Switch.tsx"));
32
-
33
- var options = [{
34
- label: "Female",
35
- value: "female"
36
- }, {
37
- label: "Male",
38
- value: "male"
39
- }, {
40
- label: "Non-binary",
41
- value: "non-binary"
42
- }, {
43
- label: "Other",
44
- value: "other"
45
- }];
46
- describe("Dialog component tests", function () {
47
- test("Dialog renders with correct text and accesibility attributes", function () {
48
- var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], null, "dialog-text")),
49
- getByText = _render.getByText,
50
- getByRole = _render.getByRole;
51
-
52
- expect(getByRole("dialog")).toBeTruthy();
53
- expect(getByRole("dialog").getAttribute("aria-modal")).toBe("true");
54
- expect(getByText("dialog-text")).toBeTruthy();
55
- });
56
- test("Dialog renders without close button", function () {
57
- var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], {
58
- isCloseVisible: false
59
- }, "dialog-text")),
60
- queryByRole = _render2.queryByRole;
61
-
62
- expect(queryByRole("button")).toBeFalsy();
63
- });
64
- test("Dialog renders with aria-modal false when overlay is not used", function () {
65
- var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], {
66
- isCloseVisible: false,
67
- overlay: false
68
- }, "dialog-text")),
69
- getByRole = _render3.getByRole;
70
-
71
- expect(getByRole("dialog")).toBeTruthy();
72
- expect(getByRole("dialog").getAttribute("aria-modal")).toBe("false");
73
- });
74
- test("Calls correct function onCloseClick", function () {
75
- var onCloseClick = jest.fn();
76
-
77
- var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], {
78
- onCloseClick: onCloseClick
79
- }, "dialog-text")),
80
- getByRole = _render4.getByRole;
81
-
82
- var closeButton = getByRole("button");
83
-
84
- _react2.fireEvent.click(closeButton);
85
-
86
- expect(onCloseClick).toHaveBeenCalled();
87
- });
88
- test("Calls correct function onCloseClick when 'Escape' key is pressed", function () {
89
- var onCloseClick = jest.fn();
90
-
91
- var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], {
92
- onCloseClick: onCloseClick
93
- }, "dialog-text")),
94
- getByRole = _render5.getByRole;
95
-
96
- _react2.fireEvent.keyDown(getByRole("dialog"), {
97
- key: "Escape",
98
- code: "Escape",
99
- keyCode: 27,
100
- charCode: 27
101
- });
102
-
103
- expect(onCloseClick).toHaveBeenCalled();
104
- });
105
- });
106
- describe("Dialog component: Focus lock tests", function () {
107
- test("Close action: when there's no focusable content, the focus never leaves the close action (unless you click outside)", function () {
108
- var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], null, "example-dialog")),
109
- getByRole = _render6.getByRole;
110
-
111
- var button = getByRole("button");
112
- var dialog = getByRole("dialog");
113
- expect(document.activeElement).toEqual(button);
114
- expect(button.getAttribute("aria-label")).toBe("Close dialog");
115
-
116
- _userEvent["default"].tab();
117
-
118
- expect(document.activeElement).toEqual(button);
119
-
120
- _react2.fireEvent.keyDown(dialog, {
121
- key: "Tab",
122
- shiftKey: true
123
- });
124
-
125
- expect(document.activeElement).toEqual(button);
126
- });
127
- test("Autofocus with Button component", function () {
128
- var _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], null, /*#__PURE__*/_react["default"].createElement(_Button["default"], {
129
- label: "Accept"
130
- }))),
131
- getAllByRole = _render7.getAllByRole;
132
-
133
- var button = getAllByRole("button")[0];
134
- expect(document.activeElement).toEqual(button);
135
- expect(button.getAttribute("aria-label")).not.toBe("Close dialog");
136
- });
137
- test("Autofocus with Card component", function () {
138
- var _render8 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], null, /*#__PURE__*/_react["default"].createElement(_Card["default"], {
139
- linkHref: "https://developer.dxc.com/halstack/next/components/card/"
140
- }, "example-card"))),
141
- getByRole = _render8.getByRole;
142
-
143
- var card = getByRole("link");
144
- expect(document.activeElement).toEqual(card);
145
- });
146
- test("Autofocus with Checkbox component", function () {
147
- var _render9 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], null, /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
148
- label: "Name"
149
- }))),
150
- getByRole = _render9.getByRole;
151
-
152
- var checkbox = getByRole("checkbox");
153
- expect(document.activeElement).toEqual(checkbox);
154
- });
155
- test("Autofocus with Link component", function () {
156
- var _render10 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], null, "This is a text with a ", /*#__PURE__*/_react["default"].createElement(_Link["default"], {
157
- href: "#"
158
- }, "Link"), " to another page.")),
159
- getByRole = _render10.getByRole;
160
-
161
- var link = getByRole("link");
162
- expect(document.activeElement).toEqual(link);
163
- });
164
- test("Autofocus with RadioGroup component", function () {
165
- var _render11 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], null, /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
166
- label: "Example",
167
- options: options
168
- }))),
169
- getAllByRole = _render11.getAllByRole;
170
-
171
- var checkedRadio = getAllByRole("radio")[0];
172
- expect(document.activeElement).toEqual(checkedRadio);
173
- });
174
- test("Autofocus with Select component", function () {
175
- var _render12 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], null, /*#__PURE__*/_react["default"].createElement(_Select["default"], {
176
- label: "Country",
177
- options: options
178
- }))),
179
- getByRole = _render12.getByRole;
180
-
181
- var select = getByRole("combobox");
182
- expect(document.activeElement).toEqual(select);
183
- });
184
- test("Autofocus with Slider component", function () {
185
- var _render13 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], null, /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
186
- label: "label",
187
- minValue: 0,
188
- maxValue: 100,
189
- showLimitsValues: true
190
- }))),
191
- getByRole = _render13.getByRole;
192
-
193
- var slider = getByRole("slider");
194
- expect(document.activeElement).toEqual(slider);
195
- });
196
- test("Autofocus with Switch component", function () {
197
- var _render14 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], null, /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
198
- label: "Example"
199
- }))),
200
- getByRole = _render14.getByRole;
201
-
202
- var switchButton = getByRole("switch");
203
- expect(document.activeElement).toEqual(switchButton);
204
- });
205
- test("Autofocus with Text Input component", function () {
206
- var _render15 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], null, /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
207
- label: "Name"
208
- }))),
209
- getByRole = _render15.getByRole;
210
-
211
- var input = getByRole("textbox");
212
- expect(document.activeElement).toEqual(input);
213
- });
214
- test("Autofocus with Textarea component", function () {
215
- var _render16 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], null, /*#__PURE__*/_react["default"].createElement(_Textarea["default"], {
216
- label: "Name"
217
- }))),
218
- getByRole = _render16.getByRole;
219
-
220
- var textarea = getByRole("textbox");
221
- expect(document.activeElement).toEqual(textarea);
222
- });
223
- test("Negative tabindex elements are not automatically focused, even if it is enabled and a valid focusable item (programatically and by click)", function () {
224
- var _render17 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], null, /*#__PURE__*/_react["default"].createElement("input", {
225
- label: "Name",
226
- tabIndex: -1
227
- }), /*#__PURE__*/_react["default"].createElement("input", {
228
- label: "Name"
229
- }))),
230
- getAllByRole = _render17.getAllByRole,
231
- getByRole = _render17.getByRole;
232
-
233
- var inputs = getAllByRole("textbox");
234
- var button = getByRole("button");
235
- expect(document.activeElement).toEqual(inputs[1]);
236
-
237
- _userEvent["default"].tab();
238
-
239
- expect(document.activeElement).toEqual(button);
240
-
241
- _userEvent["default"].tab();
242
-
243
- expect(document.activeElement).toEqual(inputs[1]);
244
- });
245
- test("Focus jumps disabled components and negative tabIndexes when autofocusing first item", function () {
246
- var _render18 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], null, /*#__PURE__*/_react["default"].createElement(_Button["default"], {
247
- label: "Accept",
248
- disabled: true
249
- }), /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
250
- label: "Older age",
251
- disabled: true
252
- }), /*#__PURE__*/_react["default"].createElement(_Select["default"], {
253
- label: "Country",
254
- options: options,
255
- disabled: true
256
- }), /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
257
- label: "Country",
258
- options: options,
259
- disabled: true
260
- }), /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
261
- label: "Name",
262
- disabled: true
263
- }), /*#__PURE__*/_react["default"].createElement(_Button["default"], {
264
- label: "Accept",
265
- tabIndex: -1
266
- }), /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
267
- label: "Older age",
268
- tabIndex: -1
269
- }), /*#__PURE__*/_react["default"].createElement(_Select["default"], {
270
- label: "Country",
271
- options: options,
272
- tabIndex: -1
273
- }), /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
274
- label: "Country",
275
- options: options,
276
- tabIndex: -1
277
- }), /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
278
- label: "Name",
279
- tabIndex: -1
280
- }), /*#__PURE__*/_react["default"].createElement(_Textarea["default"], {
281
- label: "Description"
282
- }))),
283
- getAllByRole = _render18.getAllByRole;
284
-
285
- var textarea = getAllByRole("textbox")[2];
286
- expect(document.activeElement).toEqual(textarea);
287
- });
288
- test("Focus jumps from last element to the first", function () {
289
- var _render19 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], null, /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
290
- label: "Accept",
291
- disabled: true
292
- }), /*#__PURE__*/_react["default"].createElement(_Textarea["default"], {
293
- label: "Name"
294
- }), /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
295
- label: "Name",
296
- options: options
297
- }))),
298
- getByRole = _render19.getByRole;
299
-
300
- var closeAction = getByRole("button");
301
- var textarea = getByRole("textbox");
302
- expect(document.activeElement).toEqual(textarea);
303
-
304
- _userEvent["default"].tab();
305
-
306
- _userEvent["default"].tab();
307
-
308
- expect(document.activeElement).toEqual(closeAction);
309
-
310
- _userEvent["default"].tab();
311
-
312
- expect(document.activeElement).toEqual(textarea);
313
- });
314
- test("'display: none;', 'visibility: hidden;' and 'type = 'hidden'' elements are never autofocused", function () {
315
- var _render20 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], null, /*#__PURE__*/_react["default"].createElement("input", {
316
- label: "Name",
317
- style: {
318
- display: "none"
319
- }
320
- }), /*#__PURE__*/_react["default"].createElement("input", {
321
- label: "Name",
322
- style: {
323
- visibility: "hidden"
324
- }
325
- }), /*#__PURE__*/_react["default"].createElement("input", {
326
- type: "hidden",
327
- name: "example"
328
- }))),
329
- getByRole = _render20.getByRole;
330
-
331
- var closeAction = getByRole("button");
332
- expect(document.activeElement).toEqual(closeAction);
333
-
334
- _userEvent["default"].tab();
335
-
336
- expect(document.activeElement).toEqual(closeAction);
337
- });
338
- test("Focus gets trapped in the Dialog when there are not focusable elements inside until it is closed", function () {
339
- var _render21 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
340
- label: "Name"
341
- }), /*#__PURE__*/_react["default"].createElement(_Dialog["default"], {
342
- isCloseVisible: false
343
- }, /*#__PURE__*/_react["default"].createElement("h2", null, "Policy agreement"), /*#__PURE__*/_react["default"].createElement("p", null, "Sample text.")), /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
344
- label: "Surname"
345
- }))),
346
- getAllByRole = _render21.getAllByRole;
347
-
348
- var inputs = getAllByRole("textbox");
349
- var dialog = getAllByRole("dialog")[0];
350
-
351
- _userEvent["default"].tab();
352
-
353
- _userEvent["default"].tab();
354
-
355
- expect(document.activeElement).not.toEqual(inputs[1]);
356
-
357
- _react2.fireEvent.keyDown(dialog, {
358
- key: "Tab",
359
- shiftKey: true
360
- });
361
-
362
- _react2.fireEvent.keyDown(dialog, {
363
- key: "Tab",
364
- shiftKey: true
365
- });
366
-
367
- expect(document.activeElement).not.toEqual(inputs[0]);
368
- });
369
- });
package/dialog/types.d.ts DELETED
@@ -1,31 +0,0 @@
1
- /// <reference types="react" />
2
- declare type Props = {
3
- /**
4
- * If true, the close 'x' button will be visible.
5
- */
6
- isCloseVisible?: boolean;
7
- /**
8
- * This function will be called when the user clicks the close 'x' button.
9
- * The responsibility of hiding the modal lies with the user.
10
- */
11
- onCloseClick?: () => void;
12
- /**
13
- * If true, the dialog will be displayed over a darker background that covers the content behind.
14
- */
15
- overlay?: boolean;
16
- /**
17
- * This function will be called when the user clicks background of the modal.
18
- * The responsibility of hiding the modal lies with the user.
19
- */
20
- onBackgroundClick?: () => void;
21
- /**
22
- * Value of the tabindex given to the close 'x' button.
23
- */
24
- tabIndex?: number;
25
- /**
26
- * The area inside the dialog. This area can be used to render
27
- * custom content.
28
- */
29
- children: React.ReactNode;
30
- };
31
- export default Props;
package/dialog/types.js DELETED
@@ -1,5 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
@@ -1,4 +0,0 @@
1
- /// <reference types="react" />
2
- import DropdownPropsType from "./types";
3
- declare const DxcDropdown: ({ options, optionsIconPosition, icon, iconPosition, label, caretHidden, disabled, expandOnHover, onSelectOption, margin, size, tabIndex, }: DropdownPropsType) => JSX.Element;
4
- export default DxcDropdown;