@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,586 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
- var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
6
-
7
- var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
8
-
9
- var _react = _interopRequireDefault(require("react"));
10
-
11
- var _react2 = require("@testing-library/react");
12
-
13
- var _userEvent = _interopRequireDefault(require("@testing-library/user-event"));
14
-
15
- var _Dropdown = _interopRequireDefault(require("./Dropdown.tsx"));
16
-
17
- // Mocking DOMRect for Radix Primitive Popover
18
- global.globalThis = global;
19
- global.DOMRect = {
20
- fromRect: function fromRect() {
21
- return {
22
- top: 0,
23
- left: 0,
24
- bottom: 0,
25
- right: 0,
26
- width: 0,
27
- height: 0
28
- };
29
- }
30
- };
31
-
32
- global.ResizeObserver = /*#__PURE__*/function () {
33
- function ResizeObserver() {
34
- (0, _classCallCheck2["default"])(this, ResizeObserver);
35
- }
36
-
37
- (0, _createClass2["default"])(ResizeObserver, [{
38
- key: "observe",
39
- value: function observe() {}
40
- }, {
41
- key: "unobserve",
42
- value: function unobserve() {}
43
- }, {
44
- key: "disconnect",
45
- value: function disconnect() {}
46
- }]);
47
- return ResizeObserver;
48
- }();
49
-
50
- var options = [{
51
- value: "1",
52
- label: "Amazon"
53
- }, {
54
- value: "2",
55
- label: "Ebay"
56
- }, {
57
- value: "3",
58
- label: "Wallapop"
59
- }, {
60
- value: "4",
61
- label: "Aliexpress"
62
- }];
63
- describe("Dropdown component tests", function () {
64
- test("Renders with correct aria attributes", function () {
65
- var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dropdown["default"], {
66
- options: options,
67
- label: "dropdown-test"
68
- })),
69
- getAllByRole = _render.getAllByRole,
70
- getByRole = _render.getByRole;
71
-
72
- var dropdown = getByRole("button");
73
- expect(dropdown.getAttribute("aria-haspopup")).toBe("true");
74
- expect(dropdown.getAttribute("aria-expanded")).toBeNull();
75
- expect(dropdown.getAttribute("aria-activedescendant")).toBeNull();
76
-
77
- _userEvent["default"].click(dropdown);
78
-
79
- var menu = getByRole("menu");
80
- expect(dropdown.getAttribute("aria-controls")).toBe(menu.id);
81
- expect(dropdown.getAttribute("aria-expanded")).toBe("true");
82
- expect(menu.getAttribute("aria-activedescendant")).toBe("option-0");
83
- expect(menu.getAttribute("aria-orientation")).toBe("vertical");
84
- expect(menu.getAttribute("aria-labelledby")).toBe(dropdown.id);
85
- expect(getAllByRole("menuitem").length).toBe(4);
86
- });
87
- test("Button trigger opens and closes the menu options when clicked", function () {
88
- var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dropdown["default"], {
89
- options: options,
90
- label: "dropdown-test"
91
- })),
92
- getByRole = _render2.getByRole,
93
- queryByRole = _render2.queryByRole,
94
- getByText = _render2.getByText;
95
-
96
- var dropdown = getByRole("button");
97
- expect(queryByRole("menu")).toBeFalsy();
98
-
99
- _userEvent["default"].click(dropdown);
100
-
101
- expect(queryByRole("menu")).toBeTruthy();
102
- expect(getByText("Amazon")).toBeTruthy();
103
- expect(getByText("Ebay")).toBeTruthy();
104
- expect(getByText("Wallapop")).toBeTruthy();
105
- expect(getByText("Aliexpress")).toBeTruthy();
106
-
107
- _userEvent["default"].click(dropdown);
108
-
109
- expect(queryByRole("menu")).toBeFalsy();
110
- });
111
- test("Button trigger is not interactable when disabled", function () {
112
- var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dropdown["default"], {
113
- disabled: true,
114
- options: options,
115
- label: "dropdown-test"
116
- })),
117
- getByRole = _render3.getByRole,
118
- queryByRole = _render3.queryByRole,
119
- queryByText = _render3.queryByText;
120
-
121
- var dropdown = getByRole("button");
122
- expect(queryByRole("menu")).toBeFalsy();
123
-
124
- _userEvent["default"].click(dropdown);
125
-
126
- expect(queryByRole("menu")).toBeFalsy();
127
- expect(queryByText("Amazon")).toBeFalsy();
128
-
129
- _userEvent["default"].click(dropdown);
130
-
131
- expect(queryByRole("menu")).toBeFalsy();
132
- expect(dropdown.getAttribute("aria-expanded")).toBeNull();
133
- });
134
- test("onSelectOption function is called correctly when an option is clicked", function () {
135
- var onSelectOption = jest.fn();
136
-
137
- var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dropdown["default"], {
138
- options: options,
139
- onSelectOption: onSelectOption,
140
- label: "dropdown-test"
141
- })),
142
- getByText = _render4.getByText;
143
-
144
- var dropdown = getByText("dropdown-test");
145
-
146
- _userEvent["default"].click(dropdown);
147
-
148
- var option = getByText("Aliexpress");
149
-
150
- _userEvent["default"].click(option);
151
-
152
- expect(onSelectOption).toHaveBeenCalledWith("4");
153
- });
154
- test("When expandOnHover is true, the dropdown trigger shows and hides the menu when it is hovered", function () {
155
- var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dropdown["default"], {
156
- options: options,
157
- expandOnHover: true,
158
- label: "dropdown-test"
159
- })),
160
- queryByText = _render5.queryByText,
161
- getByRole = _render5.getByRole,
162
- queryByRole = _render5.queryByRole;
163
-
164
- expect(queryByText("option-test")).toBeFalsy();
165
- expect(queryByRole("menu")).toBeFalsy();
166
-
167
- _react2.fireEvent.mouseOver(getByRole("button"));
168
-
169
- var menu = getByRole("menu");
170
- expect(menu).toBeTruthy();
171
- expect(document.activeElement === menu).toBeTruthy();
172
- expect(menu.getAttribute("aria-activedescendant")).toBe("option-0");
173
- });
174
- test("The menu is closed when the dropdown loses the focus (blur)", function () {
175
- var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dropdown["default"], {
176
- options: options,
177
- label: "dropdown-test"
178
- })),
179
- getByRole = _render6.getByRole,
180
- queryByRole = _render6.queryByRole;
181
-
182
- var dropdown = getByRole("button");
183
-
184
- _userEvent["default"].click(dropdown);
185
-
186
- expect(getByRole("menu")).toBeTruthy();
187
-
188
- _react2.fireEvent.blur(getByRole("menu"));
189
-
190
- expect(queryByRole("menu")).toBeFalsy();
191
- });
192
- test("Menu button key events - Arrow up opens the list and moves the focus to the last menu item", function () {
193
- var _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dropdown["default"], {
194
- options: options,
195
- label: "dropdown-test"
196
- })),
197
- getByRole = _render7.getByRole;
198
-
199
- var dropdown = getByRole("button");
200
-
201
- _react2.fireEvent.keyDown(dropdown, {
202
- key: "ArrowUp",
203
- code: "ArrowUp",
204
- keyCode: 38,
205
- charCode: 38
206
- });
207
-
208
- var menu = getByRole("menu");
209
- expect(menu).toBeTruthy();
210
- expect(document.activeElement === menu).toBeTruthy();
211
- expect(getByRole("menu").getAttribute("aria-activedescendant")).toBe("option-3");
212
- });
213
- test("Menu button key events - Arrow down opens the list and moves the focus to the first menu item", function () {
214
- var _render8 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dropdown["default"], {
215
- options: options,
216
- label: "dropdown-test"
217
- })),
218
- getByRole = _render8.getByRole;
219
-
220
- var dropdown = getByRole("button");
221
-
222
- _react2.fireEvent.keyDown(dropdown, {
223
- key: "ArrowDown",
224
- code: "ArrowDown",
225
- keyCode: 40,
226
- charCode: 40
227
- });
228
-
229
- var menu = getByRole("menu");
230
- expect(menu).toBeTruthy();
231
- expect(document.activeElement === menu).toBeTruthy();
232
- expect(getByRole("menu").getAttribute("aria-activedescendant")).toBe("option-0");
233
- });
234
- test("Menu button key events - Enter opens the list and moves the focus to the first menu item", function () {
235
- var _render9 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dropdown["default"], {
236
- options: options,
237
- label: "dropdown-test"
238
- })),
239
- getByRole = _render9.getByRole;
240
-
241
- var dropdown = getByRole("button");
242
-
243
- _react2.fireEvent.keyDown(dropdown, {
244
- key: "Enter",
245
- code: "Enter",
246
- keyCode: 13,
247
- charCode: 13
248
- });
249
-
250
- var menu = getByRole("menu");
251
- expect(menu).toBeTruthy();
252
- expect(document.activeElement === menu).toBeTruthy();
253
- expect(getByRole("menu").getAttribute("aria-activedescendant")).toBe("option-0");
254
- });
255
- test("Menu button key events - Space opens the list and moves the focus to the first menu item", function () {
256
- var _render10 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dropdown["default"], {
257
- options: options,
258
- label: "dropdown-test"
259
- })),
260
- getByRole = _render10.getByRole;
261
-
262
- var dropdown = getByRole("button");
263
-
264
- _react2.fireEvent.keyDown(dropdown, {
265
- key: " ",
266
- code: "Space",
267
- keyCode: 32,
268
- charCode: 32
269
- });
270
-
271
- var menu = getByRole("menu");
272
- expect(menu).toBeTruthy();
273
- expect(document.activeElement === menu).toBeTruthy();
274
- expect(getByRole("menu").getAttribute("aria-activedescendant")).toBe("option-0");
275
- });
276
- test("Menu key events - Arrow up moves the focus to the previous menu item", function () {
277
- var onSelectOption = jest.fn();
278
-
279
- var _render11 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dropdown["default"], {
280
- onSelectOption: onSelectOption,
281
- options: options,
282
- label: "dropdown-test"
283
- })),
284
- getByRole = _render11.getByRole;
285
-
286
- _react2.fireEvent.keyDown(getByRole("button"), {
287
- key: "ArrowUp",
288
- code: "ArrowUp",
289
- keyCode: 38,
290
- charCode: 38
291
- });
292
-
293
- var menu = getByRole("menu");
294
-
295
- _react2.fireEvent.keyDown(menu, {
296
- key: "ArrowUp",
297
- code: "ArrowUp",
298
- keyCode: 38,
299
- charCode: 38
300
- });
301
-
302
- expect(document.activeElement === menu).toBeTruthy();
303
- expect(menu.getAttribute("aria-activedescendant")).toBe("option-2");
304
-
305
- _react2.fireEvent.keyDown(menu, {
306
- key: "Enter",
307
- code: "Enter",
308
- keyCode: 13,
309
- charCode: 13
310
- });
311
-
312
- expect(onSelectOption).toHaveBeenCalledWith("3");
313
- });
314
- test("Menu key events - Arrow up, if focus is on the first menu item, moves focus to the last menu item.", function () {
315
- var onSelectOption = jest.fn();
316
-
317
- var _render12 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dropdown["default"], {
318
- onSelectOption: onSelectOption,
319
- options: options,
320
- label: "dropdown-test"
321
- })),
322
- getByRole = _render12.getByRole;
323
-
324
- _userEvent["default"].click(getByRole("button"));
325
-
326
- var menu = getByRole("menu");
327
-
328
- _react2.fireEvent.keyDown(menu, {
329
- key: "ArrowUp",
330
- code: "ArrowUp",
331
- keyCode: 38,
332
- charCode: 38
333
- });
334
-
335
- expect(document.activeElement === menu).toBeTruthy();
336
- expect(menu.getAttribute("aria-activedescendant")).toBe("option-3");
337
-
338
- _react2.fireEvent.keyDown(menu, {
339
- key: "Enter",
340
- code: "Enter",
341
- keyCode: 13,
342
- charCode: 13
343
- });
344
-
345
- expect(onSelectOption).toHaveBeenCalledWith("4");
346
- });
347
- test("Menu key events - Arrow down moves the focus to the next menu item", function () {
348
- var onSelectOption = jest.fn();
349
-
350
- var _render13 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dropdown["default"], {
351
- onSelectOption: onSelectOption,
352
- options: options,
353
- label: "dropdown-test"
354
- })),
355
- getByRole = _render13.getByRole;
356
-
357
- _userEvent["default"].click(getByRole("button"));
358
-
359
- var menu = getByRole("menu");
360
-
361
- _react2.fireEvent.keyDown(menu, {
362
- key: "ArrowDown",
363
- code: "ArrowDown",
364
- keyCode: 40,
365
- charCode: 40
366
- });
367
-
368
- _react2.fireEvent.keyDown(menu, {
369
- key: "ArrowDown",
370
- code: "ArrowDown",
371
- keyCode: 40,
372
- charCode: 40
373
- });
374
-
375
- expect(document.activeElement === menu).toBeTruthy();
376
- expect(menu.getAttribute("aria-activedescendant")).toBe("option-2");
377
-
378
- _react2.fireEvent.keyDown(menu, {
379
- key: "Enter",
380
- code: "Enter",
381
- keyCode: 13,
382
- charCode: 13
383
- });
384
-
385
- expect(onSelectOption).toHaveBeenCalledWith("3");
386
- });
387
- test("Menu key events - Arrow down, if focus is on the last menu item, moves focus to the first menu item. ", function () {
388
- var onSelectOption = jest.fn();
389
-
390
- var _render14 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dropdown["default"], {
391
- onSelectOption: onSelectOption,
392
- options: options,
393
- label: "dropdown-test"
394
- })),
395
- getByRole = _render14.getByRole;
396
-
397
- _react2.fireEvent.keyDown(getByRole("button"), {
398
- key: "ArrowUp",
399
- code: "ArrowUp",
400
- keyCode: 38,
401
- charCode: 38
402
- });
403
-
404
- var menu = getByRole("menu");
405
-
406
- _react2.fireEvent.keyDown(menu, {
407
- key: "ArrowDown",
408
- code: "ArrowDown",
409
- keyCode: 40,
410
- charCode: 40
411
- });
412
-
413
- expect(document.activeElement === menu).toBeTruthy();
414
- expect(menu.getAttribute("aria-activedescendant")).toBe("option-0");
415
-
416
- _react2.fireEvent.keyDown(menu, {
417
- key: "Enter",
418
- code: "Enter",
419
- keyCode: 13,
420
- charCode: 13
421
- });
422
-
423
- expect(onSelectOption).toHaveBeenCalledWith("1");
424
- });
425
- test("Menu key events - Enter key selects the current focused item and closes the menu", function () {
426
- var onSelectOption = jest.fn();
427
-
428
- var _render15 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dropdown["default"], {
429
- onSelectOption: onSelectOption,
430
- options: options,
431
- label: "dropdown-test"
432
- })),
433
- getByRole = _render15.getByRole,
434
- queryByRole = _render15.queryByRole;
435
-
436
- _userEvent["default"].click(getByRole("button"));
437
-
438
- _react2.fireEvent.keyDown(getByRole("menu"), {
439
- key: "Enter",
440
- code: "Enter",
441
- keyCode: 13,
442
- charCode: 13
443
- });
444
-
445
- expect(onSelectOption).toHaveBeenCalledWith("1");
446
- expect(queryByRole("menu")).toBeFalsy();
447
- expect(document.activeElement === getByRole("button")).toBeTruthy();
448
- });
449
- test("Menu key events - Esc closes the menu and sets focus on the menu button", function () {
450
- var _render16 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dropdown["default"], {
451
- options: options,
452
- label: "dropdown-test"
453
- })),
454
- getByRole = _render16.getByRole,
455
- queryByRole = _render16.queryByRole;
456
-
457
- _userEvent["default"].click(getByRole("button"));
458
-
459
- _react2.fireEvent.keyDown(getByRole("menu"), {
460
- key: "Esc",
461
- code: "Esc",
462
- keyCode: 27,
463
- charCode: 27
464
- });
465
-
466
- expect(queryByRole("menu")).toBeFalsy();
467
- expect(document.activeElement === getByRole("button")).toBeTruthy();
468
- });
469
- test("Menu key events - Home moves the focus to the first menu item", function () {
470
- var _render17 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dropdown["default"], {
471
- options: options,
472
- label: "dropdown-test-1"
473
- })),
474
- getByRole = _render17.getByRole;
475
-
476
- _react2.fireEvent.keyDown(getByRole("button"), {
477
- key: "ArrowUp",
478
- code: "ArrowUp",
479
- keyCode: 38,
480
- charCode: 38
481
- });
482
-
483
- var menu = getByRole("menu");
484
- expect(menu.getAttribute("aria-activedescendant")).toBe("option-3");
485
-
486
- _react2.fireEvent.keyDown(menu, {
487
- key: "Home",
488
- code: "Home",
489
- keyCode: 36,
490
- charCode: 36
491
- });
492
-
493
- expect(menu.getAttribute("aria-activedescendant")).toBe("option-0");
494
- });
495
- test("Menu key events - End moves the focus to the last menu item", function () {
496
- var _render18 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dropdown["default"], {
497
- options: options,
498
- label: "dropdown-test-1"
499
- })),
500
- getByRole = _render18.getByRole;
501
-
502
- _userEvent["default"].click(getByRole("button"));
503
-
504
- var menu = getByRole("menu");
505
- expect(menu.getAttribute("aria-activedescendant")).toBe("option-0");
506
-
507
- _react2.fireEvent.keyDown(menu, {
508
- key: "End",
509
- code: "End",
510
- keyCode: 35,
511
- charCode: 35
512
- });
513
-
514
- expect(menu.getAttribute("aria-activedescendant")).toBe("option-3");
515
- });
516
- test("Menu key events - PageUp moves the focus to the first menu item", function () {
517
- var _render19 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dropdown["default"], {
518
- options: options,
519
- label: "dropdown-test-1"
520
- })),
521
- getByRole = _render19.getByRole;
522
-
523
- _react2.fireEvent.keyDown(getByRole("button"), {
524
- key: "ArrowUp",
525
- code: "ArrowUp",
526
- keyCode: 38,
527
- charCode: 38
528
- });
529
-
530
- var menu = getByRole("menu");
531
- expect(menu.getAttribute("aria-activedescendant")).toBe("option-3");
532
-
533
- _react2.fireEvent.keyDown(menu, {
534
- key: "PageUp",
535
- code: "PageUp",
536
- keyCode: 33,
537
- charCode: 33
538
- });
539
-
540
- expect(menu.getAttribute("aria-activedescendant")).toBe("option-0");
541
- });
542
- test("Menu key events - PageDown moves the focus to the last menu item", function () {
543
- var _render20 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dropdown["default"], {
544
- options: options,
545
- label: "dropdown-test-1"
546
- })),
547
- getByRole = _render20.getByRole;
548
-
549
- _userEvent["default"].click(getByRole("button"));
550
-
551
- var menu = getByRole("menu");
552
- expect(menu.getAttribute("aria-activedescendant")).toBe("option-0");
553
-
554
- _react2.fireEvent.keyDown(menu, {
555
- key: "PageDown",
556
- code: "PageDown",
557
- keyCode: 34,
558
- charCode: 34
559
- });
560
-
561
- expect(menu.getAttribute("aria-activedescendant")).toBe("option-3");
562
- });
563
- test("Menu key events - Tab closes the menu and sets focus to the next element", function () {
564
- var _render21 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dropdown["default"], {
565
- options: options,
566
- label: "dropdown-test-1"
567
- })),
568
- getByRole = _render21.getByRole,
569
- queryByRole = _render21.queryByRole;
570
-
571
- var dropdown = getByRole("button");
572
-
573
- _userEvent["default"].click(dropdown);
574
-
575
- expect(getByRole("menu")).toBeTruthy();
576
-
577
- _react2.fireEvent.keyDown(getByRole("menu"), {
578
- key: "Tab",
579
- code: "Tab",
580
- keyCode: 9,
581
- charCode: 9
582
- });
583
-
584
- expect(queryByRole("menu")).toBeFalsy();
585
- });
586
- });
@@ -1,4 +0,0 @@
1
- import React from "react";
2
- import { DropdownMenuProps } from "./types";
3
- declare const _default: React.MemoExoticComponent<React.ForwardRefExoticComponent<DropdownMenuProps & React.RefAttributes<HTMLUListElement>>>;
4
- export default _default;
@@ -1,74 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
- Object.defineProperty(exports, "__esModule", {
6
- value: true
7
- });
8
- exports["default"] = void 0;
9
-
10
- var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
11
-
12
- var _react = _interopRequireDefault(require("react"));
13
-
14
- var _styledComponents = _interopRequireDefault(require("styled-components"));
15
-
16
- var _DropdownMenuItem = _interopRequireDefault(require("./DropdownMenuItem"));
17
-
18
- var _templateObject;
19
-
20
- var DropdownMenu = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
21
- var id = _ref.id,
22
- dropdownTriggerId = _ref.dropdownTriggerId,
23
- iconsPosition = _ref.iconsPosition,
24
- visualFocusIndex = _ref.visualFocusIndex,
25
- menuItemOnClick = _ref.menuItemOnClick,
26
- onKeyDown = _ref.onKeyDown,
27
- options = _ref.options,
28
- styles = _ref.styles;
29
- return /*#__PURE__*/_react["default"].createElement(DropdownMenuContainer, {
30
- onMouseDown: function onMouseDown(event) {
31
- // Prevent the onBlur event from closing menu when clicking on the menu since
32
- // it is implemented with a Portal and the menu is not a direct child of the container
33
- event.preventDefault();
34
- },
35
- onKeyDown: onKeyDown,
36
- id: id,
37
- role: "menu",
38
- "aria-labelledby": dropdownTriggerId,
39
- "aria-orientation": "vertical",
40
- "aria-activedescendant": "option-".concat(visualFocusIndex),
41
- tabIndex: -1,
42
- ref: ref,
43
- style: styles
44
- }, options.map(function (option, index) {
45
- return /*#__PURE__*/_react["default"].createElement(_DropdownMenuItem["default"], {
46
- id: "option-".concat(index),
47
- key: "option-".concat(index),
48
- visuallyFocused: index === visualFocusIndex,
49
- iconPosition: iconsPosition,
50
- onClick: menuItemOnClick,
51
- option: option
52
- });
53
- }));
54
- });
55
-
56
- var DropdownMenuContainer = _styledComponents["default"].ul(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n box-sizing: border-box;\n max-height: 230px;\n min-width: min-content;\n padding: 0;\n margin: 0;\n background-color: ", ";\n border-width: ", ";\n border-style: ", ";\n border-color: ", ";\n border-radius: ", ";\n border-top-right-radius: 0;\n border-top-left-radius: 0;\n box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);\n outline: none;\n\n overflow-y: auto;\n &::-webkit-scrollbar {\n width: 8px;\n height: 8px;\n }\n &::-webkit-scrollbar-thumb {\n background-color: ", ";\n border-radius: 6px;\n }\n &::-webkit-scrollbar-track {\n background-color: ", ";\n border-radius: 6px;\n }\n"])), function (props) {
57
- return props.theme.optionBackgroundColor;
58
- }, function (props) {
59
- return props.theme.borderThickness;
60
- }, function (props) {
61
- return props.theme.borderStyle;
62
- }, function (props) {
63
- return props.theme.borderColor;
64
- }, function (props) {
65
- return props.theme.borderRadius;
66
- }, function (props) {
67
- return props.theme.scrollBarThumbColor;
68
- }, function (props) {
69
- return props.theme.scrollBarTrackColor;
70
- });
71
-
72
- var _default = /*#__PURE__*/_react["default"].memo(DropdownMenu);
73
-
74
- exports["default"] = _default;
@@ -1,4 +0,0 @@
1
- import React from "react";
2
- import { DropdownMenuItemProps } from "./types";
3
- declare const _default: React.MemoExoticComponent<({ id, visuallyFocused, iconPosition, onClick, option, }: DropdownMenuItemProps) => JSX.Element>;
4
- export default _default;