@pingux/astro 2.33.0-alpha.9 → 2.34.0-alpha.0

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 (233) hide show
  1. package/lib/cjs/components/AccordionGridGroup/AccordionGridGroup.test.js +8 -9
  2. package/lib/cjs/components/AccordionGroup/AccordionGroup.test.js +8 -11
  3. package/lib/cjs/components/ArrayField/ArrayField.js +5 -3
  4. package/lib/cjs/components/ArrayField/ArrayField.test.js +13 -4
  5. package/lib/cjs/components/Avatar/Avatar.test.js +7 -4
  6. package/lib/cjs/components/Badge/Badge.test.js +7 -3
  7. package/lib/cjs/components/Box/Box.test.js +7 -4
  8. package/lib/cjs/components/Bracket/Bracket.js +3 -1
  9. package/lib/cjs/components/Bracket/Bracket.test.js +7 -3
  10. package/lib/cjs/components/Breadcrumbs/Breadcrumb.styles.js +25 -24
  11. package/lib/cjs/components/Breadcrumbs/BreadcrumbItem.js +23 -9
  12. package/lib/cjs/components/Breadcrumbs/Breadcrumbs.js +11 -18
  13. package/lib/cjs/components/Breadcrumbs/Breadcrumbs.stories.js +53 -11
  14. package/lib/cjs/components/Breadcrumbs/Breadcrumbs.test.js +11 -6
  15. package/lib/cjs/components/ButtonBar/ButtonBar.js +9 -3
  16. package/lib/cjs/components/ButtonBar/ButtonBar.test.js +13 -3
  17. package/lib/cjs/components/Callout/Callout.js +8 -3
  18. package/lib/cjs/components/Callout/Callout.test.js +8 -0
  19. package/lib/cjs/components/Card/Card.test.js +7 -4
  20. package/lib/cjs/components/Checkbox/Checkbox.test.js +7 -4
  21. package/lib/cjs/components/CheckboxField/CheckboxField.js +4 -2
  22. package/lib/cjs/components/CheckboxField/CheckboxField.test.js +7 -3
  23. package/lib/cjs/components/CodeView/CodeView.js +1 -0
  24. package/lib/cjs/components/CodeView/CodeView.test.js +7 -3
  25. package/lib/cjs/components/CollapsiblePanel/CollapsiblePanel.test.js +5 -10
  26. package/lib/cjs/components/CollapsiblePanelContainer/CollapsiblePanelBadge.js +9 -3
  27. package/lib/cjs/components/CollapsiblePanelContainer/CollapsiblePanelBadge.test.js +7 -3
  28. package/lib/cjs/components/CollapsiblePanelContainer/CollapsiblePanelContainer.test.js +7 -3
  29. package/lib/cjs/components/CollapsiblePanelItem/CollapsiblePanelItem.test.js +7 -3
  30. package/lib/cjs/components/ColorField/ColorField.test.js +7 -3
  31. package/lib/cjs/components/ComboBoxField/ComboBoxField.test.js +11 -21
  32. package/lib/cjs/components/CopyText/CopyText.test.js +15 -5
  33. package/lib/cjs/components/DataTable/DataTableBadge.test.js +8 -0
  34. package/lib/cjs/components/DataTable/DataTableMenu.test.js +8 -0
  35. package/lib/cjs/components/DataTable/DataTableMultiLine.test.js +16 -5
  36. package/lib/cjs/components/DatePicker/DatePicker.test.js +11 -20
  37. package/lib/cjs/components/EditButton/EditButton.test.js +8 -2
  38. package/lib/cjs/components/FieldHelperText/FieldHelperText.test.js +7 -3
  39. package/lib/cjs/components/FileInputField/FileInputField.test.js +8 -2
  40. package/lib/cjs/components/HelpHint/HelpHint.test.js +7 -3
  41. package/lib/cjs/components/IconBadge/IconBadge.js +8 -3
  42. package/lib/cjs/components/IconBadge/IconBadge.test.js +9 -3
  43. package/lib/cjs/components/IconButton/IconButton.test.js +7 -3
  44. package/lib/cjs/components/IconButtonToggle/IconButtonToggle.js +11 -6
  45. package/lib/cjs/components/IconButtonToggle/IconButtonToggle.test.js +7 -3
  46. package/lib/cjs/components/ImageUploadField/ImageUploadField.test.js +7 -3
  47. package/lib/cjs/components/Input/Input.test.js +7 -3
  48. package/lib/cjs/components/Link/Link.test.js +7 -3
  49. package/lib/cjs/components/LinkSelectField/LinkSelectField.test.js +12 -31
  50. package/lib/cjs/components/ListItem/ListItem.test.js +5 -8
  51. package/lib/cjs/components/ListView/ListView.test.js +19 -0
  52. package/lib/cjs/components/ListViewItem/ListViewItem.test.js +7 -3
  53. package/lib/cjs/components/ListViewItem/controls/ListViewItemEditButton.js +11 -4
  54. package/lib/cjs/components/ListViewItem/controls/ListViewItemEditButton.test.js +7 -3
  55. package/lib/cjs/components/ListViewItem/controls/ListViewItemMenu.js +10 -4
  56. package/lib/cjs/components/ListViewItem/controls/ListViewItemMenu.test.js +7 -4
  57. package/lib/cjs/components/ListViewItem/controls/ListViewItemSwitchField.js +9 -3
  58. package/lib/cjs/components/ListViewItem/controls/ListViewItemSwitchField.test.js +7 -3
  59. package/lib/cjs/components/ListViewItem/controls/chart/ListViewItemChart.js +4 -3
  60. package/lib/cjs/components/ListViewItem/controls/chart/ListViewItemChart.test.js +7 -3
  61. package/lib/cjs/components/Loader/Loader.test.js +7 -3
  62. package/lib/cjs/components/Menu/Menu.test.js +11 -3
  63. package/lib/cjs/components/MenuItem/MenuItem.test.js +15 -3
  64. package/lib/cjs/components/Messages/Messages.test.js +9 -3
  65. package/lib/cjs/components/Modal/tests/Modal.unit.test.js +7 -3
  66. package/lib/cjs/components/MultivaluesField/MultivaluesField.test.js +14 -20
  67. package/lib/cjs/components/NavBar/NavBar.js +3 -2
  68. package/lib/cjs/components/NavBar/NavBar.test.js +10 -2
  69. package/lib/cjs/components/NumberField/NumberField.test.js +5 -8
  70. package/lib/cjs/components/OverlayPanel/OverlayPanel.test.js +7 -3
  71. package/lib/cjs/components/PageHeader/PageHeader.test.js +11 -2
  72. package/lib/cjs/components/PanelHeader/controls/PanelHeaderCloseButton.js +9 -3
  73. package/lib/cjs/components/PanelHeader/controls/PanelHeaderCloseButton.test.js +7 -3
  74. package/lib/cjs/components/PanelHeader/controls/PanelHeaderMenu.js +12 -4
  75. package/lib/cjs/components/PanelHeader/controls/PanelHeaderMenu.test.js +7 -3
  76. package/lib/cjs/components/PanelHeader/controls/PanelHeaderSwitchField.js +12 -4
  77. package/lib/cjs/components/PanelHeader/controls/PanelHeaderSwitchField.test.js +7 -3
  78. package/lib/cjs/components/PasswordField/PasswordField.test.js +7 -3
  79. package/lib/cjs/components/RadioField/RadioField.test.js +9 -3
  80. package/lib/cjs/components/RadioGroupField/RadioGroupField.test.js +10 -3
  81. package/lib/cjs/components/RequirementsList/RequirementsList.test.js +7 -3
  82. package/lib/cjs/components/RockerButtonGroup/RockerButtonGroup.test.js +11 -3
  83. package/lib/cjs/components/ScrollBox/ScrollBox.test.js +8 -0
  84. package/lib/cjs/components/SearchField/SearchField.test.js +7 -3
  85. package/lib/cjs/components/SelectField/SelectField.test.js +11 -3
  86. package/lib/cjs/components/SelectFieldBase/SelectFieldBase.test.js +14 -30
  87. package/lib/cjs/components/Separator/Separator.test.js +7 -3
  88. package/lib/cjs/components/Stepper/Stepper.test.js +12 -14
  89. package/lib/cjs/components/SwitchField/SwitchField.test.js +7 -3
  90. package/lib/cjs/components/Table/Table.js +9 -3
  91. package/lib/cjs/components/Table/Table.test.js +26 -3
  92. package/lib/cjs/components/TableBody/TableBody.js +9 -3
  93. package/lib/cjs/components/TableBody/TableBody.test.d.ts +1 -0
  94. package/lib/cjs/components/TableBody/TableBody.test.js +13 -0
  95. package/lib/cjs/components/TableCaption/TableCaption.js +9 -3
  96. package/lib/cjs/components/TableCaption/TableCaption.test.js +13 -0
  97. package/lib/cjs/components/TableCell/TableCell.d.ts +2 -2
  98. package/lib/cjs/components/TableCell/TableCell.js +9 -3
  99. package/lib/cjs/components/TableCell/TableCell.test.js +7 -3
  100. package/lib/cjs/components/TableHead/TableHead.js +9 -3
  101. package/lib/cjs/components/TableHead/TableHead.test.js +13 -0
  102. package/lib/cjs/components/TableRow/TableRow.js +9 -3
  103. package/lib/cjs/components/TableRow/TableRow.test.js +13 -0
  104. package/lib/cjs/components/Tabs/Tabs.test.js +10 -3
  105. package/lib/cjs/components/Text/Text.test.js +7 -3
  106. package/lib/cjs/components/TextArea/TextArea.test.js +8 -3
  107. package/lib/cjs/components/TextAreaField/TextAreaField.test.js +7 -3
  108. package/lib/cjs/components/TextField/TextField.test.js +7 -3
  109. package/lib/cjs/components/TimeZonePicker/TimeZonePicker.test.js +8 -0
  110. package/lib/cjs/components/TooltipTrigger/TooltipTrigger.test.js +7 -3
  111. package/lib/cjs/hooks/useComponentToggle/useComponentToggle.js +1 -3
  112. package/lib/cjs/hooks/useProgressiveState/index.d.ts +1 -0
  113. package/lib/cjs/hooks/useProgressiveState/useProgressiveState.d.ts +11 -0
  114. package/lib/cjs/hooks/useProgressiveState/useProgressiveState.js +3 -6
  115. package/lib/cjs/hooks/useProgressiveState/useProgressiveState.test.d.ts +1 -0
  116. package/lib/cjs/hooks/useProgressiveState/useProgressiveState.test.js +7 -16
  117. package/lib/cjs/utils/designUtils/figmaLinks.js +2 -1
  118. package/lib/cjs/utils/testUtils/universalComponentTest.d.ts +1 -2
  119. package/lib/cjs/utils/testUtils/universalComponentTest.js +6 -4
  120. package/lib/components/AccordionGridGroup/AccordionGridGroup.test.js +8 -9
  121. package/lib/components/AccordionGroup/AccordionGroup.test.js +8 -11
  122. package/lib/components/ArrayField/ArrayField.js +6 -4
  123. package/lib/components/ArrayField/ArrayField.test.js +13 -4
  124. package/lib/components/Avatar/Avatar.test.js +7 -4
  125. package/lib/components/Badge/Badge.test.js +7 -3
  126. package/lib/components/Box/Box.test.js +7 -4
  127. package/lib/components/Bracket/Bracket.js +3 -1
  128. package/lib/components/Bracket/Bracket.test.js +7 -3
  129. package/lib/components/Breadcrumbs/Breadcrumb.styles.js +26 -25
  130. package/lib/components/Breadcrumbs/BreadcrumbItem.js +22 -9
  131. package/lib/components/Breadcrumbs/Breadcrumbs.js +11 -18
  132. package/lib/components/Breadcrumbs/Breadcrumbs.stories.js +52 -11
  133. package/lib/components/Breadcrumbs/Breadcrumbs.test.js +11 -6
  134. package/lib/components/ButtonBar/ButtonBar.js +4 -3
  135. package/lib/components/ButtonBar/ButtonBar.test.js +13 -3
  136. package/lib/components/Callout/Callout.js +4 -3
  137. package/lib/components/Callout/Callout.test.js +8 -0
  138. package/lib/components/Card/Card.test.js +7 -4
  139. package/lib/components/Checkbox/Checkbox.test.js +7 -4
  140. package/lib/components/CheckboxField/CheckboxField.js +4 -2
  141. package/lib/components/CheckboxField/CheckboxField.test.js +7 -3
  142. package/lib/components/CodeView/CodeView.js +1 -0
  143. package/lib/components/CodeView/CodeView.test.js +7 -3
  144. package/lib/components/CollapsiblePanel/CollapsiblePanel.test.js +5 -10
  145. package/lib/components/CollapsiblePanelContainer/CollapsiblePanelBadge.js +4 -3
  146. package/lib/components/CollapsiblePanelContainer/CollapsiblePanelBadge.test.js +7 -3
  147. package/lib/components/CollapsiblePanelContainer/CollapsiblePanelContainer.test.js +7 -3
  148. package/lib/components/CollapsiblePanelItem/CollapsiblePanelItem.test.js +7 -3
  149. package/lib/components/ColorField/ColorField.test.js +7 -3
  150. package/lib/components/ComboBoxField/ComboBoxField.test.js +11 -21
  151. package/lib/components/CopyText/CopyText.test.js +15 -5
  152. package/lib/components/DataTable/DataTableBadge.test.js +8 -0
  153. package/lib/components/DataTable/DataTableMenu.test.js +8 -0
  154. package/lib/components/DataTable/DataTableMultiLine.test.js +16 -5
  155. package/lib/components/DatePicker/DatePicker.test.js +11 -20
  156. package/lib/components/EditButton/EditButton.test.js +8 -2
  157. package/lib/components/FieldHelperText/FieldHelperText.test.js +7 -3
  158. package/lib/components/FileInputField/FileInputField.test.js +8 -2
  159. package/lib/components/HelpHint/HelpHint.test.js +7 -3
  160. package/lib/components/IconBadge/IconBadge.js +4 -3
  161. package/lib/components/IconBadge/IconBadge.test.js +9 -3
  162. package/lib/components/IconButton/IconButton.test.js +7 -3
  163. package/lib/components/IconButtonToggle/IconButtonToggle.js +6 -6
  164. package/lib/components/IconButtonToggle/IconButtonToggle.test.js +7 -3
  165. package/lib/components/ImageUploadField/ImageUploadField.test.js +7 -3
  166. package/lib/components/Input/Input.test.js +7 -3
  167. package/lib/components/Link/Link.test.js +7 -3
  168. package/lib/components/LinkSelectField/LinkSelectField.test.js +12 -31
  169. package/lib/components/ListItem/ListItem.test.js +5 -8
  170. package/lib/components/ListView/ListView.test.js +19 -0
  171. package/lib/components/ListViewItem/ListViewItem.test.js +7 -3
  172. package/lib/components/ListViewItem/controls/ListViewItemEditButton.js +6 -4
  173. package/lib/components/ListViewItem/controls/ListViewItemEditButton.test.js +7 -3
  174. package/lib/components/ListViewItem/controls/ListViewItemMenu.js +5 -4
  175. package/lib/components/ListViewItem/controls/ListViewItemMenu.test.js +7 -4
  176. package/lib/components/ListViewItem/controls/ListViewItemSwitchField.js +4 -3
  177. package/lib/components/ListViewItem/controls/ListViewItemSwitchField.test.js +7 -3
  178. package/lib/components/ListViewItem/controls/chart/ListViewItemChart.js +5 -4
  179. package/lib/components/ListViewItem/controls/chart/ListViewItemChart.test.js +7 -3
  180. package/lib/components/Loader/Loader.test.js +7 -3
  181. package/lib/components/Menu/Menu.test.js +11 -3
  182. package/lib/components/MenuItem/MenuItem.test.js +15 -3
  183. package/lib/components/Messages/Messages.test.js +9 -3
  184. package/lib/components/Modal/tests/Modal.unit.test.js +7 -3
  185. package/lib/components/MultivaluesField/MultivaluesField.test.js +14 -20
  186. package/lib/components/NavBar/NavBar.js +4 -3
  187. package/lib/components/NavBar/NavBar.test.js +10 -2
  188. package/lib/components/NumberField/NumberField.test.js +5 -8
  189. package/lib/components/OverlayPanel/OverlayPanel.test.js +7 -3
  190. package/lib/components/PageHeader/PageHeader.test.js +11 -2
  191. package/lib/components/PanelHeader/controls/PanelHeaderCloseButton.js +4 -3
  192. package/lib/components/PanelHeader/controls/PanelHeaderCloseButton.test.js +7 -3
  193. package/lib/components/PanelHeader/controls/PanelHeaderMenu.js +7 -4
  194. package/lib/components/PanelHeader/controls/PanelHeaderMenu.test.js +7 -3
  195. package/lib/components/PanelHeader/controls/PanelHeaderSwitchField.js +7 -4
  196. package/lib/components/PanelHeader/controls/PanelHeaderSwitchField.test.js +7 -3
  197. package/lib/components/PasswordField/PasswordField.test.js +7 -3
  198. package/lib/components/RadioField/RadioField.test.js +9 -3
  199. package/lib/components/RadioGroupField/RadioGroupField.test.js +10 -3
  200. package/lib/components/RequirementsList/RequirementsList.test.js +7 -3
  201. package/lib/components/RockerButtonGroup/RockerButtonGroup.test.js +11 -3
  202. package/lib/components/ScrollBox/ScrollBox.test.js +8 -0
  203. package/lib/components/SearchField/SearchField.test.js +7 -3
  204. package/lib/components/SelectField/SelectField.test.js +11 -3
  205. package/lib/components/SelectFieldBase/SelectFieldBase.test.js +13 -31
  206. package/lib/components/Separator/Separator.test.js +7 -3
  207. package/lib/components/Stepper/Stepper.test.js +12 -14
  208. package/lib/components/SwitchField/SwitchField.test.js +7 -3
  209. package/lib/components/Table/Table.js +4 -3
  210. package/lib/components/Table/Table.test.js +26 -3
  211. package/lib/components/TableBody/TableBody.js +4 -3
  212. package/lib/components/TableBody/TableBody.test.js +11 -0
  213. package/lib/components/TableCaption/TableCaption.js +4 -3
  214. package/lib/components/TableCaption/TableCaption.test.js +11 -0
  215. package/lib/components/TableCell/TableCell.js +4 -3
  216. package/lib/components/TableCell/TableCell.test.js +7 -3
  217. package/lib/components/TableHead/TableHead.js +4 -3
  218. package/lib/components/TableHead/TableHead.test.js +11 -0
  219. package/lib/components/TableRow/TableRow.js +4 -3
  220. package/lib/components/TableRow/TableRow.test.js +11 -0
  221. package/lib/components/Tabs/Tabs.test.js +10 -3
  222. package/lib/components/Text/Text.test.js +7 -3
  223. package/lib/components/TextArea/TextArea.test.js +8 -3
  224. package/lib/components/TextAreaField/TextAreaField.test.js +7 -3
  225. package/lib/components/TextField/TextField.test.js +7 -3
  226. package/lib/components/TimeZonePicker/TimeZonePicker.test.js +8 -0
  227. package/lib/components/TooltipTrigger/TooltipTrigger.test.js +7 -3
  228. package/lib/hooks/useComponentToggle/useComponentToggle.js +1 -3
  229. package/lib/hooks/useProgressiveState/useProgressiveState.js +3 -7
  230. package/lib/hooks/useProgressiveState/useProgressiveState.test.js +7 -16
  231. package/lib/utils/designUtils/figmaLinks.js +2 -1
  232. package/lib/utils/testUtils/universalComponentTest.js +6 -4
  233. package/package.json +1 -1
@@ -30,7 +30,8 @@ var FIGMA_LINKS = {
30
30
  isLast: 'https://www.figma.com/file/bpbEw54gTTcdIiZs4PKK1p/Astro-Specs?node-id=45365%3A7832&mode=dev'
31
31
  },
32
32
  breadcrumbs: {
33
- "default": 'https://www.figma.com/file/bpbEw54gTTcdIiZs4PKK1p/Astro-Specs?type=design&node-id=1162-11924&t=8Wwd3tIBh3GEjCJB-0'
33
+ "default": 'https://www.figma.com/file/bpbEw54gTTcdIiZs4PKK1p/Astro-Specs?type=design&node-id=1162-11924&t=8Wwd3tIBh3GEjCJB-0',
34
+ overflowing: 'https://www.figma.com/file/bpbEw54gTTcdIiZs4PKK1p/Astro-Specs?type=design&node-id=45064-7148&mode=design&t=0RGDgLyKBzT6bOXO-0'
34
35
  },
35
36
  button: {
36
37
  "default": 'https://www.figma.com/file/bpbEw54gTTcdIiZs4PKK1p/Astro-Specs?type=design&node-id=0-1&t=8Wwd3tIBh3GEjCJB-0'
@@ -1,5 +1,4 @@
1
- export declare const universalComponentTests: ({ renderComponent, props, rules }: {
1
+ export declare const universalComponentTests: ({ renderComponent, rules }: {
2
2
  renderComponent: any;
3
- props: any;
4
3
  rules?: {} | undefined;
5
4
  }) => Promise<void>;
@@ -44,20 +44,22 @@ var ComponentWithRef = function ComponentWithRef(_ref) {
44
44
  };
45
45
  var universalComponentTests = /*#__PURE__*/function () {
46
46
  var _ref3 = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regeneratorRuntime().mark(function _callee2(_ref2) {
47
- var renderComponent, props, _ref2$rules, rules;
47
+ var renderComponent, _ref2$rules, rules;
48
48
  return _regeneratorRuntime().wrap(function _callee2$(_context2) {
49
49
  while (1) switch (_context2.prev = _context2.next) {
50
50
  case 0:
51
- renderComponent = _ref2.renderComponent, props = _ref2.props, _ref2$rules = _ref2.rules, rules = _ref2$rules === void 0 ? {} : _ref2$rules;
51
+ renderComponent = _ref2.renderComponent, _ref2$rules = _ref2.rules, rules = _ref2$rules === void 0 ? {} : _ref2$rules;
52
52
  test('should have no accessibility violations', /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regeneratorRuntime().mark(function _callee() {
53
53
  var _render, container, results;
54
54
  return _regeneratorRuntime().wrap(function _callee$(_context) {
55
55
  while (1) switch (_context.prev = _context.next) {
56
56
  case 0:
57
57
  jest.useRealTimers();
58
- _render = (0, _react2.render)(renderComponent(props)), container = _render.container;
58
+ _render = (0, _react2.render)(renderComponent()), container = _render.container;
59
59
  _context.next = 4;
60
- return (0, _jestAxe.axe)(container, rules);
60
+ return (0, _jestAxe.axe)(container, {
61
+ rules: rules
62
+ });
61
63
  case 4:
62
64
  results = _context.sent;
63
65
  expect(results).toHaveNoViolations();
@@ -15,14 +15,21 @@ import React from 'react';
15
15
  import { Item } from 'react-stately';
16
16
  import userEvent from '@testing-library/user-event';
17
17
  import { Box, Link, OverlayPanel, Text, TextField } from '../../index';
18
- import axeTest from '../../utils/testUtils/testAxe';
19
18
  import { act, fireEvent, render, screen, waitFor } from '../../utils/testUtils/testWrapper';
19
+ import { universalComponentTests } from '../../utils/testUtils/universalComponentTest';
20
20
  import AccordionGridGroup from '.';
21
21
  import { jsx as ___EmotionJSX } from "@emotion/react";
22
22
  var testId = 'test-accordion';
23
23
  var defaultProps = {
24
24
  'data-testid': testId
25
25
  };
26
+
27
+ // Needs to be added to each components test file
28
+ universalComponentTests({
29
+ renderComponent: function renderComponent(props) {
30
+ return ___EmotionJSX(AccordionGridGroup, props);
31
+ }
32
+ });
26
33
  var getComponent = function getComponent() {
27
34
  var props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
28
35
  return render(___EmotionJSX(AccordionGridGroup, _extends({}, defaultProps, props), ___EmotionJSX(Item, {
@@ -64,14 +71,6 @@ var getComponentWithTextFields = function getComponentWithTextFields() {
64
71
  label: "label 2"
65
72
  })))));
66
73
  };
67
- axeTest(getComponent, {
68
- // landmark-unique rule conflicts with react-aria role definition
69
- rules: {
70
- 'landmark-unique': {
71
- enabled: false
72
- }
73
- }
74
- });
75
74
  test('button press uses callback', function () {
76
75
  var onPress = jest.fn();
77
76
  getComponent({
@@ -5,8 +5,8 @@ import React from 'react';
5
5
  import { Item } from 'react-stately';
6
6
  import userEvent from '@testing-library/user-event';
7
7
  import { Box, Button, Menu, OverlayPanel, PopoverMenu, TextField } from '../../index';
8
- import axeTest from '../../utils/testUtils/testAxe';
9
8
  import { act, fireEvent, render, screen } from '../../utils/testUtils/testWrapper';
9
+ import { universalComponentTests } from '../../utils/testUtils/universalComponentTest';
10
10
  import { validHeadingTags } from '../AccordionItem/AccordionItem';
11
11
  import Text from '../Text';
12
12
  import AccordionGroup from '.';
@@ -15,6 +15,13 @@ var testId = 'test-accordion';
15
15
  var defaultProps = {
16
16
  'data-testid': testId
17
17
  };
18
+
19
+ // Needs to be added to each components test file
20
+ universalComponentTests({
21
+ renderComponent: function renderComponent(props) {
22
+ return ___EmotionJSX(AccordionGroup, props);
23
+ }
24
+ });
18
25
  var items = [{
19
26
  key: 'identityProvider',
20
27
  label: 'some label1',
@@ -147,16 +154,6 @@ var getComponentWithMultipleAccordion = function getComponentWithMultipleAccordi
147
154
  "data-id": "connection-configuration-custom-form"
148
155
  }, ___EmotionJSX(Box, null, ___EmotionJSX(Text, null, "other text1"), ___EmotionJSX(Text, null, "another text1")))))));
149
156
  };
150
-
151
- // Need to be added to each test file to test accessibility using axe.
152
- axeTest(getComponent, {
153
- // landmark-unique rule conflicts with react-aria role definition
154
- rules: {
155
- 'landmark-unique': {
156
- enabled: false
157
- }
158
- }
159
- });
160
157
  test('button press uses callback', function () {
161
158
  var onPress = jest.fn();
162
159
  getComponent({
@@ -16,7 +16,7 @@ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { va
16
16
  import _mapInstanceProperty from "@babel/runtime-corejs3/core-js-stable/instance/map";
17
17
  import _filterInstanceProperty from "@babel/runtime-corejs3/core-js-stable/instance/filter";
18
18
  import _concatInstanceProperty from "@babel/runtime-corejs3/core-js-stable/instance/concat";
19
- import React, { useCallback, useState } from 'react';
19
+ import React, { forwardRef, useCallback, useState } from 'react';
20
20
  import { mergeProps, useLabel } from 'react-aria';
21
21
  import PropTypes from 'prop-types';
22
22
  import { v4 as uuid } from 'uuid';
@@ -26,7 +26,7 @@ import isValidPositiveInt from '../../utils/devUtils/props/isValidPositiveInt';
26
26
  import { ariaAttributesBasePropTypes, getAriaAttributeProps } from '../../utils/docUtils/ariaAttributes';
27
27
  import { statusPropTypes } from '../../utils/docUtils/statusProp';
28
28
  import { jsx as ___EmotionJSX } from "@emotion/react";
29
- var ArrayField = function ArrayField(props) {
29
+ var ArrayField = /*#__PURE__*/forwardRef(function (props, ref) {
30
30
  var _context2;
31
31
  var addButtonLabel = props.addButtonLabel,
32
32
  defaultValue = props.defaultValue,
@@ -119,7 +119,9 @@ var ArrayField = function ArrayField(props) {
119
119
  var _getAriaAttributeProp = getAriaAttributeProps(others),
120
120
  ariaProps = _getAriaAttributeProp.ariaProps,
121
121
  nonAriaProps = _getAriaAttributeProp.nonAriaProps;
122
- return ___EmotionJSX(Box, nonAriaProps, ___EmotionJSX(Label, _extends({}, raLabelProps, mergeProps(labelProps, raLabelProps, {
122
+ return ___EmotionJSX(Box, _extends({}, nonAriaProps, {
123
+ ref: ref
124
+ }), ___EmotionJSX(Label, _extends({}, raLabelProps, mergeProps(labelProps, raLabelProps, {
123
125
  children: label
124
126
  }))), ___EmotionJSX(Box, _extends({
125
127
  as: "ul",
@@ -150,7 +152,7 @@ var ArrayField = function ArrayField(props) {
150
152
  variant: "label",
151
153
  color: "active"
152
154
  }, addButtonLabel)));
153
- };
155
+ });
154
156
  ArrayField.propTypes = _objectSpread(_objectSpread({
155
157
  /** Label for add button */
156
158
  addButtonLabel: PropTypes.string,
@@ -1,6 +1,7 @@
1
1
  import _extends from "@babel/runtime-corejs3/helpers/esm/extends";
2
2
  import React from 'react';
3
3
  import { fireEvent, render, screen } from '../../utils/testUtils/testWrapper';
4
+ import { universalComponentTests } from '../../utils/testUtils/universalComponentTest';
4
5
  import TextField from '../TextField';
5
6
  import ArrayField from './ArrayField';
6
7
  import ArrayFieldDeleteButton from './ArrayFieldDeleteButton';
@@ -20,13 +21,12 @@ var defaultData = [{
20
21
  value: 'World'
21
22
  }];
22
23
  var defaultProps = {
23
- defaultValue: defaultData
24
+ defaultValue: defaultData,
25
+ label: 'test-label'
24
26
  };
25
27
  var getComponent = function getComponent() {
26
28
  var props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
27
- return render(___EmotionJSX(ArrayField, _extends({
28
- label: "test-label"
29
- }, defaultProps, props)));
29
+ return render(___EmotionJSX(ArrayField, _extends({}, defaultProps, props)));
30
30
  };
31
31
  var renderField = function renderField(id, value, onFieldValueChange, onFieldDelete, otherFieldProps) {
32
32
  return ___EmotionJSX(TextField, _extends({
@@ -46,6 +46,15 @@ var renderField = function renderField(id, value, onFieldValueChange, onFieldDel
46
46
  }
47
47
  }, otherFieldProps));
48
48
  };
49
+
50
+ // Needs to be added to each components test file
51
+ universalComponentTests({
52
+ renderComponent: function renderComponent(props) {
53
+ return ___EmotionJSX(ArrayField, _extends({
54
+ renderField: renderField
55
+ }, defaultProps, props));
56
+ }
57
+ });
49
58
  test('displays multiple text fields', function () {
50
59
  var onChange = jest.fn();
51
60
  getComponent({
@@ -1,8 +1,8 @@
1
1
  import _extends from "@babel/runtime-corejs3/helpers/esm/extends";
2
2
  import React from 'react';
3
3
  import { faker } from '@faker-js/faker';
4
- import axeTest from '../../utils/testUtils/testAxe';
5
4
  import { render, screen } from '../../utils/testUtils/testWrapper';
5
+ import { universalComponentTests } from '../../utils/testUtils/universalComponentTest';
6
6
  import Avatar from '.';
7
7
  import { jsx as ___EmotionJSX } from "@emotion/react";
8
8
  var defaultProps = {
@@ -12,9 +12,12 @@ var getComponent = function getComponent() {
12
12
  var props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
13
13
  return render(___EmotionJSX(Avatar, _extends({}, defaultProps, props)));
14
14
  };
15
-
16
- // Need to be added to each test file to test accessibility using axe.
17
- axeTest(getComponent);
15
+ // Needs to be added to each components test file
16
+ universalComponentTests({
17
+ renderComponent: function renderComponent(props) {
18
+ return ___EmotionJSX(Avatar, _extends({}, defaultProps, props));
19
+ }
20
+ });
18
21
  test('an avatar is rendered', function () {
19
22
  getComponent();
20
23
  var img = screen.getByRole('img');
@@ -3,7 +3,7 @@ import React from 'react';
3
3
  import Earth from '@pingux/mdi-react/EarthIcon';
4
4
  import { render, screen } from '@testing-library/react';
5
5
  import { Badge, Button, Icon } from '../..';
6
- import axeTest from '../../utils/testUtils/testAxe';
6
+ import { universalComponentTests } from '../../utils/testUtils/universalComponentTest';
7
7
  import { jsx as ___EmotionJSX } from "@emotion/react";
8
8
  var testId = 'test-separator';
9
9
  var defaultProps = {
@@ -15,8 +15,12 @@ var getComponent = function getComponent() {
15
15
  return render(___EmotionJSX(Badge, _extends({}, defaultProps, props)));
16
16
  };
17
17
 
18
- // Need to be added to each test file to test accessibility using axe.
19
- axeTest(getComponent);
18
+ // Needs to be added to each components test file
19
+ universalComponentTests({
20
+ renderComponent: function renderComponent(props) {
21
+ return ___EmotionJSX(Badge, props);
22
+ }
23
+ });
20
24
  test('renders Badge component', function () {
21
25
  getComponent();
22
26
  var badge = screen.getByTestId(testId);
@@ -3,7 +3,7 @@ import React from 'react';
3
3
  import createCache from '@emotion/cache';
4
4
  import { CacheProvider } from '@emotion/react';
5
5
  import { render, screen } from '@testing-library/react';
6
- import axeTest from '../../utils/testUtils/testAxe';
6
+ import { universalComponentTests } from '../../utils/testUtils/universalComponentTest';
7
7
  import Box from '.';
8
8
 
9
9
  // Emotion Cache added as test fails otherwise, root cause of this failure is unknown.
@@ -24,9 +24,12 @@ var getComponent = function getComponent() {
24
24
  value: emotionCache
25
25
  }, ___EmotionJSX(Box, _extends({}, defaultProps, props))));
26
26
  };
27
-
28
- // Need to be added to each test file to test accessibility using axe.
29
- axeTest(getComponent);
27
+ // Needs to be added to each components test file
28
+ universalComponentTests({
29
+ renderComponent: function renderComponent(props) {
30
+ return ___EmotionJSX(Box, props);
31
+ }
32
+ });
30
33
  test('default box', function () {
31
34
  getComponent();
32
35
  var box = screen.getByTestId(testId);
@@ -28,7 +28,9 @@ var Bracket = /*#__PURE__*/forwardRef(function (props, ref) {
28
28
  }, []);
29
29
  return ___EmotionJSX(Box, _extends({
30
30
  variant: "bracket.base"
31
- }, others), !isLast && ___EmotionJSX(Box, {
31
+ }, others, {
32
+ ref: bracketRef
33
+ }), !isLast && ___EmotionJSX(Box, {
32
34
  width: 15,
33
35
  sx: {
34
36
  position: 'absolute',
@@ -1,7 +1,7 @@
1
1
  import _extends from "@babel/runtime-corejs3/helpers/esm/extends";
2
2
  import React from 'react';
3
3
  import { render, screen } from '@testing-library/react';
4
- import axeTest from '../../utils/testUtils/testAxe';
4
+ import { universalComponentTests } from '../../utils/testUtils/universalComponentTest';
5
5
  import Bracket from '.';
6
6
  import { jsx as ___EmotionJSX } from "@emotion/react";
7
7
  var testId = 'test-bracket';
@@ -13,8 +13,12 @@ var getComponent = function getComponent() {
13
13
  return render(___EmotionJSX(Bracket, _extends({}, defaultProps, props)));
14
14
  };
15
15
 
16
- // // Need to be added to each test file to test accessibility using axe.
17
- axeTest(getComponent);
16
+ // Needs to be added to each components test file
17
+ universalComponentTests({
18
+ renderComponent: function renderComponent(props) {
19
+ return ___EmotionJSX(Bracket, props);
20
+ }
21
+ });
18
22
  test('default bracket', function () {
19
23
  getComponent();
20
24
  var bracket = screen.getByTestId(testId);
@@ -9,34 +9,35 @@ import _Object$defineProperty from "@babel/runtime-corejs3/core-js-stable/object
9
9
  import _defineProperty from "@babel/runtime-corejs3/helpers/esm/defineProperty";
10
10
  function ownKeys(object, enumerableOnly) { var keys = _Object$keys(object); if (_Object$getOwnPropertySymbols) { var symbols = _Object$getOwnPropertySymbols(object); enumerableOnly && (symbols = _filterInstanceProperty(symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
11
11
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var _context, _context2; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty(_context = ownKeys(Object(source), !0)).call(_context, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(target, _Object$getOwnPropertyDescriptors(source)) : _forEachInstanceProperty(_context2 = ownKeys(Object(source))).call(_context2, function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } return target; }
12
- import { base } from '../Button/Buttons.styles';
13
- var link = {
14
- color: 'active',
15
- fontFamily: 'standard',
16
- fontSize: '15px',
17
- textDecoration: 'none',
18
- outline: 'none',
19
- '&.is-hovered': {
20
- textDecoration: 'underline'
21
- },
22
- '&.is-focused': {
23
- textDecoration: 'underline'
24
- },
25
- '&.is-disabled': {
26
- pointerEvents: 'none'
27
- },
28
- '&.is-current': _objectSpread(_objectSpread({
29
- pointerEvents: 'none'
30
- }, base), {}, {
31
- fontWeight: 1
32
- })
33
- };
34
- var containerLi = {
12
+ import { link as buttonLink } from '../Button/Buttons.styles';
13
+ import { text } from '../Text/Text.styles';
14
+ var breadcrumbMinWidth = '40px';
15
+ var link = _objectSpread(_objectSpread(_objectSpread({}, text.textEllipsis), buttonLink), {}, {
16
+ display: 'block',
17
+ minWidth: breadcrumbMinWidth,
18
+ '&.is-current': {
19
+ color: 'text.primary',
20
+ textDecoration: 'none',
21
+ cursor: 'default'
22
+ }
23
+ });
24
+ var containerOl = {
25
+ alignItems: 'center',
26
+ minHeight: 42,
27
+ paddingInlineStart: 'unset',
35
28
  'a.is-hovered.is-current ': {
36
29
  textDecoration: 'none'
37
30
  }
38
31
  };
32
+ var containerLi = {
33
+ flex: '0 1000000 auto',
34
+ minWidth: breadcrumbMinWidth,
35
+ '&.is-current': {
36
+ flex: '0 1 auto'
37
+ }
38
+ };
39
39
  export default {
40
- link: link,
41
- containerLi: containerLi
40
+ containerLi: containerLi,
41
+ containerOl: containerOl,
42
+ link: link
42
43
  };
@@ -17,8 +17,15 @@ import { mergeProps, useBreadcrumbItem } from 'react-aria';
17
17
  import { omit } from 'lodash/object';
18
18
  import PropTypes from 'prop-types';
19
19
  import { usePropWarning } from '../../hooks';
20
- import { Button, IconButton, Link, Text } from '../../index';
20
+ import { Box, Button, IconButton, Link, Text } from '../../index';
21
21
  import { jsx as ___EmotionJSX } from "@emotion/react";
22
+ export var ELEMENT_TYPE = {
23
+ BUTTON: 'Button',
24
+ ICON_BUTTON: 'IconButton',
25
+ TEXT: 'Text',
26
+ LINK: 'Link',
27
+ FRAGMENT: 'Fragment'
28
+ };
22
29
  var BreadcrumbItem = /*#__PURE__*/forwardRef(function (props, ref) {
23
30
  var children = props.children,
24
31
  elementType = props.elementType,
@@ -36,15 +43,15 @@ var BreadcrumbItem = /*#__PURE__*/forwardRef(function (props, ref) {
36
43
  itemProps = _useBreadcrumbItem.itemProps;
37
44
  var ElementType = useMemo(function () {
38
45
  switch (elementType) {
39
- case 'Button':
46
+ case ELEMENT_TYPE.BUTTON:
40
47
  return Button;
41
- case 'IconButton':
48
+ case ELEMENT_TYPE.ICON_BUTTON:
42
49
  return IconButton;
43
- case 'Text':
50
+ case ELEMENT_TYPE.TEXT:
44
51
  return Text;
45
- case 'Link':
52
+ case ELEMENT_TYPE.LINK:
46
53
  return Link;
47
- case 'Fragment':
54
+ case ELEMENT_TYPE.FRAGMENT:
48
55
  return Fragment;
49
56
  default:
50
57
  return elementType;
@@ -66,9 +73,15 @@ var BreadcrumbItem = /*#__PURE__*/forwardRef(function (props, ref) {
66
73
  }
67
74
  return omit(elementTypeProps, 'onClick', 'onKeyDown', 'onKeyUp');
68
75
  }, [elementType, itemProps, others, onPressHandler]);
69
- return /*#__PURE__*/React.cloneElement(___EmotionJSX(ElementType, null), _objectSpread(_objectSpread({}, elementProps), {}, {
70
- ref: ref
71
- }), children);
76
+ var elementVariantProps = elementType !== ELEMENT_TYPE.FRAGMENT && _objectSpread({
77
+ variant: elementType === ELEMENT_TYPE.LINK ? 'variants.breadcrumb.link' : '',
78
+ ref: itemRef
79
+ }, elementProps);
80
+ return ___EmotionJSX(Box, {
81
+ as: "li",
82
+ className: isCurrent && 'is-current',
83
+ variant: "variants.breadcrumb.containerLi"
84
+ }, ___EmotionJSX(ElementType, elementVariantProps, children));
72
85
  });
73
86
  BreadcrumbItem.propTypes = {
74
87
  actionKey: PropTypes.string,
@@ -31,37 +31,30 @@ var Breadcrumbs = /*#__PURE__*/forwardRef(function (props, ref) {
31
31
  });
32
32
  var createBreadcrumb = useCallback(function (child, idx) {
33
33
  var isCurrentItem = _Array$isArray(filteredChildren) && filteredChildren.length > 1 ? idx === children.length - 1 : true;
34
- return ___EmotionJSX(Box, {
35
- isRow: true,
36
- sx: {
37
- alignItems: 'center',
38
- minHeight: 42
39
- },
40
- as: "li",
41
- key: "li-".concat(child.key),
42
- variant: "variants.breadcrumb.containerLi"
34
+ return ___EmotionJSX(React.Fragment, {
35
+ key: "li-".concat(child.key)
43
36
  }, ___EmotionJSX(BreadcrumbItem, _extends({
37
+ actionKey: child.key,
44
38
  "data-id": child['data-id'],
45
39
  isCurrent: isCurrentItem,
46
- onAction: onAction,
47
- actionKey: child.key,
48
- variant: "variants.breadcrumb.link"
40
+ onAction: onAction
49
41
  }, child.props), child.props.children), icon && !isCurrentItem && ___EmotionJSX(Icon, _extends({
50
42
  "aria-hidden": "true",
51
43
  icon: icon,
52
44
  mx: 5,
53
- size: "xs"
45
+ size: "xs",
46
+ title: {
47
+ name: 'Breadcrumb Separator'
48
+ }
54
49
  }, iconProps)));
55
50
  }, [children.length, filteredChildren, icon, iconProps, onAction]);
56
51
  return ___EmotionJSX("nav", {
57
52
  "aria-label": "Breadcrumb"
58
53
  }, ___EmotionJSX(Box, _extends({
59
- ref: breadcrumbsRef,
54
+ as: "ol",
60
55
  isRow: true,
61
- sx: {
62
- paddingInlineStart: 'unset'
63
- },
64
- as: "ol"
56
+ ref: breadcrumbsRef,
57
+ variant: "variants.breadcrumb.containerOl"
65
58
  }, mergeProps(wrapperProps, others)), _Array$isArray(filteredChildren) ? _mapInstanceProperty(filteredChildren).call(filteredChildren, createBreadcrumb) : createBreadcrumb(children)));
66
59
  });
67
60
  Breadcrumbs.propTypes = {
@@ -5,7 +5,7 @@ import ChevronRightIcon from '@pingux/mdi-react/ChevronRightIcon';
5
5
  import { action } from '@storybook/addon-actions';
6
6
  import { withDesign } from 'storybook-addon-designs';
7
7
  import DocsLayout from '../../../.storybook/storybookDocsLayout';
8
- import { Breadcrumbs } from '../../index';
8
+ import { Box, Breadcrumbs } from '../../index';
9
9
  import { FIGMA_LINKS } from '../../utils/designUtils/figmaLinks.ts';
10
10
  import BreadcrumbsReadme from './Breadcrumbs.mdx';
11
11
  import { jsx as ___EmotionJSX } from "@emotion/react";
@@ -35,9 +35,6 @@ export default {
35
35
  type: 'none'
36
36
  }
37
37
  }
38
- },
39
- args: {
40
- icon: ChevronRightIcon
41
38
  }
42
39
  };
43
40
  export var Default = function Default(args) {
@@ -46,23 +43,22 @@ export var Default = function Default(args) {
46
43
  };
47
44
  return ___EmotionJSX(Breadcrumbs, _extends({
48
45
  onAction: onAction
49
- }, args), ___EmotionJSX(Item, {
46
+ }, args, {
47
+ icon: ChevronRightIcon
48
+ }), ___EmotionJSX(Item, {
50
49
  "aria-label": "home",
51
50
  "data-id": "home",
52
51
  href: "https://www.pingidentity.com",
53
- key: "home",
54
- variant: "buttons.link"
52
+ key: "home"
55
53
  }, "Home"), ___EmotionJSX(Item, {
56
54
  "aria-label": "trendy",
57
55
  "data-id": "trendy",
58
56
  href: "https://www.pingidentity.com",
59
- key: "trendy",
60
- variant: "buttons.link"
57
+ key: "trendy"
61
58
  }, "Trendy"), ___EmotionJSX(Item, {
62
59
  "aria-label": "march-2020-assets",
63
60
  "data-id": "march",
64
- key: "march 2020 assets",
65
- variant: "buttons.link"
61
+ key: "march 2020 assets"
66
62
  }, "March 2020 Assets"));
67
63
  };
68
64
  Default.parameters = {
@@ -70,4 +66,49 @@ Default.parameters = {
70
66
  type: 'figma',
71
67
  url: FIGMA_LINKS.breadcrumbs["default"]
72
68
  }
69
+ };
70
+ export var Overflowing = function Overflowing() {
71
+ var reallyLongText = 'If This Text Were Really Very Much So Extremely Long';
72
+ return ___EmotionJSX(Box, {
73
+ gap: "md",
74
+ maxWidth: "385px"
75
+ }, ___EmotionJSX(Breadcrumbs, {
76
+ icon: ChevronRightIcon
77
+ }, ___EmotionJSX(Item, {
78
+ "aria-label": "breadcrumb_1",
79
+ "data-id": "breadcrumb_1",
80
+ href: "https://www.pingidentity.com",
81
+ key: "breadcrumb_1"
82
+ }, reallyLongText), ___EmotionJSX(Item, {
83
+ "aria-label": "breadcrumb_2",
84
+ "data-id": "breadcrumb_2",
85
+ href: "https://www.pingidentity.com",
86
+ key: "breadcrumb_2"
87
+ }, "Edit")), ___EmotionJSX(Breadcrumbs, {
88
+ icon: ChevronRightIcon
89
+ }, ___EmotionJSX(Item, {
90
+ "aria-label": "breadcrumb_1",
91
+ "data-id": "breadcrumb_1",
92
+ href: "https://www.pingidentity.com",
93
+ key: "breadcrumb_1"
94
+ }, reallyLongText), ___EmotionJSX(Item, {
95
+ "aria-label": "breadcrumb_1",
96
+ "data-id": "breadcrumb_2",
97
+ href: "https://www.pingidentity.com",
98
+ key: "breadcrumb_2"
99
+ }, reallyLongText)));
100
+ };
101
+ Overflowing.parameters = {
102
+ design: {
103
+ type: 'figma',
104
+ url: FIGMA_LINKS.breadcrumbs.overflowing
105
+ },
106
+ a11y: {
107
+ config: {
108
+ rules: [{
109
+ id: 'landmark-unique',
110
+ enabled: false
111
+ }]
112
+ }
113
+ }
73
114
  };
@@ -6,8 +6,9 @@ import { Item } from 'react-stately';
6
6
  import ChevronRightIcon from '@pingux/mdi-react/ChevronRightIcon';
7
7
  import CreateIcon from '@pingux/mdi-react/CreateIcon';
8
8
  import userEvent from '@testing-library/user-event';
9
- import axeTest from '../../utils/testUtils/testAxe';
10
9
  import { render, screen } from '../../utils/testUtils/testWrapper';
10
+ import { universalComponentTests } from '../../utils/testUtils/universalComponentTest';
11
+ import { ELEMENT_TYPE } from './BreadcrumbItem';
11
12
  import Breadcrumbs from './Breadcrumbs';
12
13
  import { jsx as ___EmotionJSX } from "@emotion/react";
13
14
  var testId = 'test-breadcrumbs';
@@ -31,8 +32,12 @@ var getComponent = function getComponent() {
31
32
  })));
32
33
  };
33
34
 
34
- // Need to be added to each test file to test accessibility using axe.
35
- axeTest(getComponent);
35
+ // Needs to be added to each components test file
36
+ universalComponentTests({
37
+ renderComponent: function renderComponent(props) {
38
+ return ___EmotionJSX(Breadcrumbs, mergeProps(defaultProps, props), ___EmotionJSX(Item, null, testItemsArr[0]));
39
+ }
40
+ });
36
41
  test('default breadcrumbs', function () {
37
42
  getComponent();
38
43
  expect(screen.getByTestId(testId)).toBeInTheDocument();
@@ -53,14 +58,14 @@ test('should render correct amount of icons', function () {
53
58
  });
54
59
  test('breadcrumbItem should render breadcrumbItem as a Text component when appropriate elementType passed', function () {
55
60
  getComponent({}, {
56
- elementType: 'Text',
61
+ elementType: ELEMENT_TYPE.TEXT,
57
62
  'data-testid': testItemId
58
63
  });
59
64
  expect(screen.getAllByTestId(testItemId)[0]).toBeInstanceOf(HTMLSpanElement);
60
65
  });
61
66
  test('breadcrumbItem should render breadcrumbItem as a IconButton component when appropriate elementType passed', function () {
62
67
  getComponent({}, {
63
- elementType: 'IconButton',
68
+ elementType: ELEMENT_TYPE.ICON_BUTTON,
64
69
  'data-testid': testItemId,
65
70
  icon: CreateIcon
66
71
  });
@@ -77,7 +82,7 @@ test('breadcrumbItem should render breadcrumbItem as a html tag when appropriate
77
82
  test('breadcrumbs will use onAction if provided', function () {
78
83
  var mockOnAction = jest.fn();
79
84
  getComponent({}, {
80
- elementType: 'Link',
85
+ elementType: ELEMENT_TYPE.LINK,
81
86
  onAction: mockOnAction
82
87
  });
83
88
  userEvent.click(screen.getByText(testItemsArr[0]));