@dxc-technology/halstack-react 0.0.0-bd47c58 → 0.0.0-bdaadec

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 (329) hide show
  1. package/BackgroundColorContext.d.ts +1 -10
  2. package/BackgroundColorContext.js +4 -21
  3. package/HalstackContext.d.ts +43 -138
  4. package/HalstackContext.js +10 -35
  5. package/accordion/Accordion.accessibility.test.js +71 -0
  6. package/accordion/Accordion.js +31 -84
  7. package/accordion/Accordion.stories.tsx +5 -51
  8. package/accordion/Accordion.test.js +18 -33
  9. package/accordion/types.d.ts +6 -6
  10. package/accordion-group/AccordionGroup.accessibility.test.js +88 -0
  11. package/accordion-group/AccordionGroup.d.ts +2 -3
  12. package/accordion-group/AccordionGroup.js +17 -44
  13. package/accordion-group/AccordionGroup.stories.tsx +1 -1
  14. package/accordion-group/AccordionGroup.test.js +42 -60
  15. package/accordion-group/AccordionGroupAccordion.js +11 -23
  16. package/accordion-group/AccordionGroupContext.d.ts +3 -0
  17. package/accordion-group/AccordionGroupContext.js +8 -0
  18. package/accordion-group/types.d.ts +7 -7
  19. package/action-icon/ActionIcon.accessibility.test.js +63 -0
  20. package/action-icon/ActionIcon.d.ts +4 -0
  21. package/action-icon/ActionIcon.js +48 -0
  22. package/action-icon/ActionIcon.stories.tsx +41 -0
  23. package/action-icon/ActionIcon.test.js +64 -0
  24. package/action-icon/types.d.ts +26 -0
  25. package/alert/Alert.accessibility.test.js +95 -0
  26. package/alert/Alert.js +29 -118
  27. package/alert/Alert.test.js +28 -45
  28. package/alert/types.d.ts +5 -5
  29. package/badge/Badge.accessibility.test.js +129 -0
  30. package/badge/Badge.d.ts +1 -1
  31. package/badge/Badge.js +141 -43
  32. package/badge/Badge.stories.tsx +210 -0
  33. package/badge/Badge.test.js +30 -0
  34. package/badge/types.d.ts +52 -3
  35. package/bleed/Bleed.js +13 -21
  36. package/bleed/types.d.ts +2 -2
  37. package/box/Box.accessibility.test.js +33 -0
  38. package/box/Box.js +11 -33
  39. package/box/Box.test.js +1 -6
  40. package/box/types.d.ts +3 -3
  41. package/bulleted-list/BulletedList.accessibility.test.js +107 -0
  42. package/bulleted-list/BulletedList.js +22 -55
  43. package/bulleted-list/BulletedList.stories.tsx +2 -93
  44. package/bulleted-list/types.d.ts +5 -5
  45. package/button/Button.accessibility.test.js +127 -0
  46. package/button/Button.js +36 -59
  47. package/button/Button.stories.tsx +33 -133
  48. package/button/Button.test.js +13 -21
  49. package/button/types.d.ts +5 -5
  50. package/card/Card.accessibility.test.js +36 -0
  51. package/card/Card.js +21 -44
  52. package/card/Card.test.js +10 -21
  53. package/card/types.d.ts +5 -5
  54. package/checkbox/Checkbox.accessibility.test.js +87 -0
  55. package/checkbox/Checkbox.js +85 -120
  56. package/checkbox/Checkbox.stories.tsx +16 -54
  57. package/checkbox/Checkbox.test.js +107 -63
  58. package/checkbox/types.d.ts +8 -4
  59. package/chip/Chip.accessibility.test.js +67 -0
  60. package/chip/Chip.js +20 -36
  61. package/chip/Chip.stories.tsx +5 -24
  62. package/chip/Chip.test.js +17 -30
  63. package/chip/types.d.ts +4 -4
  64. package/common/coreTokens.d.ts +105 -14
  65. package/common/coreTokens.js +40 -23
  66. package/common/utils.js +2 -8
  67. package/common/variables.d.ts +44 -139
  68. package/common/variables.js +55 -157
  69. package/container/Container.d.ts +4 -0
  70. package/container/Container.js +194 -0
  71. package/container/Container.stories.tsx +214 -0
  72. package/container/types.d.ts +74 -0
  73. package/container/types.js +5 -0
  74. package/contextual-menu/ContextualMenu.accessibility.test.js +86 -0
  75. package/contextual-menu/ContextualMenu.d.ts +7 -0
  76. package/contextual-menu/ContextualMenu.js +71 -0
  77. package/contextual-menu/ContextualMenu.stories.tsx +182 -0
  78. package/contextual-menu/ContextualMenu.test.js +71 -0
  79. package/contextual-menu/MenuItemAction.d.ts +4 -0
  80. package/contextual-menu/MenuItemAction.js +46 -0
  81. package/contextual-menu/types.d.ts +22 -0
  82. package/contextual-menu/types.js +5 -0
  83. package/date-input/Calendar.js +13 -57
  84. package/date-input/DateInput.accessibility.test.js +216 -0
  85. package/date-input/DateInput.js +50 -96
  86. package/date-input/DateInput.stories.tsx +11 -30
  87. package/date-input/DateInput.test.js +674 -701
  88. package/date-input/DatePicker.js +11 -42
  89. package/date-input/Icons.d.ts +6 -6
  90. package/date-input/Icons.js +6 -23
  91. package/date-input/YearPicker.js +8 -34
  92. package/date-input/types.d.ts +28 -22
  93. package/dialog/Dialog.accessibility.test.js +69 -0
  94. package/dialog/Dialog.js +13 -40
  95. package/dialog/Dialog.stories.tsx +170 -0
  96. package/dialog/Dialog.test.js +126 -188
  97. package/dialog/types.d.ts +18 -13
  98. package/divider/Divider.accessibility.test.js +33 -0
  99. package/divider/Divider.d.ts +4 -0
  100. package/divider/Divider.js +36 -0
  101. package/divider/Divider.stories.tsx +223 -0
  102. package/divider/Divider.test.js +38 -0
  103. package/divider/types.d.ts +21 -0
  104. package/divider/types.js +5 -0
  105. package/dropdown/Dropdown.accessibility.test.js +180 -0
  106. package/dropdown/Dropdown.js +59 -128
  107. package/dropdown/Dropdown.stories.tsx +5 -16
  108. package/dropdown/Dropdown.test.js +391 -378
  109. package/dropdown/DropdownMenu.js +8 -19
  110. package/dropdown/DropdownMenuItem.js +11 -20
  111. package/dropdown/types.d.ts +20 -24
  112. package/file-input/FileInput.accessibility.test.js +160 -0
  113. package/file-input/FileInput.js +180 -284
  114. package/file-input/FileInput.stories.tsx +1 -1
  115. package/file-input/FileInput.test.js +279 -354
  116. package/file-input/FileItem.js +25 -66
  117. package/file-input/types.d.ts +9 -9
  118. package/flex/Flex.js +25 -39
  119. package/flex/types.d.ts +6 -6
  120. package/footer/Footer.accessibility.test.js +117 -0
  121. package/footer/Footer.d.ts +1 -1
  122. package/footer/Footer.js +43 -68
  123. package/footer/Footer.stories.tsx +54 -9
  124. package/footer/Footer.test.js +18 -32
  125. package/footer/Icons.d.ts +3 -2
  126. package/footer/Icons.js +66 -7
  127. package/footer/types.d.ts +17 -17
  128. package/grid/Grid.js +1 -16
  129. package/grid/types.d.ts +10 -10
  130. package/header/Header.accessibility.test.js +84 -0
  131. package/header/Header.d.ts +1 -1
  132. package/header/Header.js +28 -84
  133. package/header/Header.test.js +12 -25
  134. package/header/Icons.d.ts +2 -2
  135. package/header/Icons.js +2 -7
  136. package/header/types.d.ts +7 -8
  137. package/heading/Heading.accessibility.test.js +33 -0
  138. package/heading/Heading.js +9 -31
  139. package/heading/Heading.test.js +70 -87
  140. package/heading/types.d.ts +7 -7
  141. package/icon/Icon.accessibility.test.js +30 -0
  142. package/icon/Icon.d.ts +4 -0
  143. package/icon/Icon.js +33 -0
  144. package/icon/Icon.stories.tsx +28 -0
  145. package/icon/types.d.ts +4 -0
  146. package/icon/types.js +5 -0
  147. package/image/Image.accessibility.test.js +56 -0
  148. package/image/Image.d.ts +2 -2
  149. package/image/Image.js +17 -32
  150. package/image/Image.stories.tsx +3 -1
  151. package/image/types.d.ts +2 -2
  152. package/inset/Inset.js +13 -21
  153. package/inset/types.d.ts +2 -2
  154. package/layout/ApplicationLayout.d.ts +2 -2
  155. package/layout/ApplicationLayout.js +26 -66
  156. package/layout/ApplicationLayout.stories.tsx +1 -1
  157. package/layout/Icons.d.ts +8 -5
  158. package/layout/Icons.js +49 -59
  159. package/layout/types.d.ts +3 -3
  160. package/link/Link.accessibility.test.js +112 -0
  161. package/link/Link.js +28 -47
  162. package/link/Link.stories.tsx +2 -2
  163. package/link/Link.test.js +23 -41
  164. package/link/types.d.ts +14 -14
  165. package/main.d.ts +7 -4
  166. package/main.js +32 -60
  167. package/nav-tabs/NavTabs.accessibility.test.js +52 -0
  168. package/nav-tabs/NavTabs.d.ts +1 -2
  169. package/nav-tabs/NavTabs.js +19 -48
  170. package/nav-tabs/NavTabs.stories.tsx +7 -5
  171. package/nav-tabs/NavTabs.test.js +38 -44
  172. package/nav-tabs/NavTabsContext.d.ts +3 -0
  173. package/nav-tabs/NavTabsContext.js +8 -0
  174. package/nav-tabs/Tab.js +24 -52
  175. package/nav-tabs/types.d.ts +9 -9
  176. package/number-input/NumberInput.accessibility.test.js +228 -0
  177. package/number-input/NumberInput.d.ts +0 -7
  178. package/number-input/NumberInput.js +47 -39
  179. package/number-input/NumberInput.stories.tsx +42 -26
  180. package/number-input/NumberInput.test.js +839 -575
  181. package/number-input/NumberInputContext.d.ts +3 -0
  182. package/number-input/NumberInputContext.js +8 -0
  183. package/number-input/types.d.ts +17 -5
  184. package/package.json +39 -37
  185. package/paginator/Icons.d.ts +5 -5
  186. package/paginator/Icons.js +5 -19
  187. package/paginator/Paginator.accessibility.test.js +79 -0
  188. package/paginator/Paginator.js +15 -43
  189. package/paginator/Paginator.test.js +224 -207
  190. package/paginator/types.d.ts +3 -3
  191. package/paragraph/Paragraph.accessibility.test.js +28 -0
  192. package/paragraph/Paragraph.js +3 -19
  193. package/paragraph/Paragraph.stories.tsx +0 -17
  194. package/password-input/Icons.d.ts +3 -3
  195. package/password-input/Icons.js +1 -5
  196. package/password-input/PasswordInput.accessibility.test.js +153 -0
  197. package/password-input/PasswordInput.js +26 -48
  198. package/password-input/PasswordInput.stories.tsx +1 -34
  199. package/password-input/PasswordInput.test.js +153 -129
  200. package/password-input/types.d.ts +8 -7
  201. package/progress-bar/ProgressBar.accessibility.test.js +35 -0
  202. package/progress-bar/ProgressBar.js +21 -53
  203. package/progress-bar/{ProgressBar.stories.jsx → ProgressBar.stories.tsx} +1 -1
  204. package/progress-bar/ProgressBar.test.js +35 -52
  205. package/progress-bar/types.d.ts +3 -3
  206. package/quick-nav/QuickNav.accessibility.test.js +57 -0
  207. package/quick-nav/QuickNav.js +4 -27
  208. package/quick-nav/QuickNav.stories.tsx +1 -1
  209. package/quick-nav/types.d.ts +10 -10
  210. package/radio-group/Radio.d.ts +1 -1
  211. package/radio-group/Radio.js +22 -54
  212. package/radio-group/RadioGroup.accessibility.test.js +97 -0
  213. package/radio-group/RadioGroup.js +37 -83
  214. package/radio-group/RadioGroup.stories.tsx +10 -10
  215. package/radio-group/RadioGroup.test.js +504 -470
  216. package/radio-group/types.d.ts +8 -8
  217. package/resultset-table/Icons.d.ts +7 -0
  218. package/{resultsetTable → resultset-table}/Icons.js +1 -5
  219. package/resultset-table/ResultsetTable.accessibility.test.js +274 -0
  220. package/resultset-table/ResultsetTable.d.ts +7 -0
  221. package/{resultsetTable → resultset-table}/ResultsetTable.js +44 -69
  222. package/{resultsetTable → resultset-table}/ResultsetTable.stories.tsx +106 -5
  223. package/{resultsetTable → resultset-table}/ResultsetTable.test.js +148 -92
  224. package/{resultsetTable → resultset-table}/types.d.ts +44 -11
  225. package/resultset-table/types.js +5 -0
  226. package/select/Icons.d.ts +7 -7
  227. package/select/Icons.js +1 -5
  228. package/select/Listbox.js +13 -39
  229. package/select/Option.js +17 -27
  230. package/select/Select.accessibility.test.js +217 -0
  231. package/select/Select.js +87 -163
  232. package/select/Select.stories.tsx +3 -4
  233. package/select/Select.test.js +1946 -1804
  234. package/select/types.d.ts +14 -15
  235. package/sidenav/Icons.d.ts +4 -4
  236. package/sidenav/Icons.js +1 -5
  237. package/sidenav/Sidenav.accessibility.test.js +59 -0
  238. package/sidenav/Sidenav.js +29 -70
  239. package/sidenav/Sidenav.stories.tsx +0 -1
  240. package/sidenav/Sidenav.test.js +3 -10
  241. package/{layout → sidenav}/SidenavContext.d.ts +1 -1
  242. package/{layout → sidenav}/SidenavContext.js +3 -9
  243. package/sidenav/types.d.ts +18 -18
  244. package/slider/Slider.accessibility.test.js +104 -0
  245. package/slider/Slider.js +68 -125
  246. package/slider/Slider.test.js +107 -103
  247. package/slider/types.d.ts +4 -4
  248. package/spinner/Spinner.accessibility.test.js +96 -0
  249. package/spinner/Spinner.js +16 -54
  250. package/spinner/Spinner.test.js +25 -34
  251. package/spinner/types.d.ts +3 -3
  252. package/status-light/StatusLight.accessibility.test.js +157 -0
  253. package/status-light/StatusLight.d.ts +4 -0
  254. package/status-light/StatusLight.js +51 -0
  255. package/status-light/StatusLight.stories.tsx +74 -0
  256. package/status-light/StatusLight.test.js +25 -0
  257. package/status-light/types.d.ts +17 -0
  258. package/status-light/types.js +5 -0
  259. package/switch/Switch.accessibility.test.js +89 -0
  260. package/switch/Switch.js +49 -97
  261. package/switch/Switch.stories.tsx +0 -34
  262. package/switch/Switch.test.js +51 -96
  263. package/switch/types.d.ts +4 -4
  264. package/table/DropdownTheme.js +62 -0
  265. package/table/Table.accessibility.test.js +82 -0
  266. package/table/Table.d.ts +6 -2
  267. package/table/Table.js +76 -33
  268. package/table/{Table.stories.jsx → Table.stories.tsx} +297 -2
  269. package/table/Table.test.js +93 -6
  270. package/table/types.d.ts +34 -6
  271. package/tabs/Tab.js +17 -33
  272. package/tabs/Tabs.accessibility.test.js +56 -0
  273. package/tabs/Tabs.js +52 -129
  274. package/tabs/Tabs.stories.tsx +1 -1
  275. package/tabs/Tabs.test.js +62 -118
  276. package/tabs/types.d.ts +19 -19
  277. package/tag/Tag.accessibility.test.js +69 -0
  278. package/tag/Tag.js +21 -51
  279. package/tag/Tag.test.js +19 -30
  280. package/tag/types.d.ts +7 -7
  281. package/text-input/Suggestion.js +9 -26
  282. package/text-input/Suggestions.d.ts +1 -1
  283. package/text-input/Suggestions.js +19 -67
  284. package/text-input/TextInput.accessibility.test.js +321 -0
  285. package/text-input/TextInput.js +197 -287
  286. package/text-input/TextInput.stories.tsx +49 -153
  287. package/text-input/TextInput.test.js +1227 -1194
  288. package/text-input/types.d.ts +25 -17
  289. package/textarea/Textarea.accessibility.test.js +155 -0
  290. package/textarea/Textarea.js +67 -109
  291. package/textarea/{Textarea.stories.jsx → Textarea.stories.tsx} +58 -100
  292. package/textarea/Textarea.test.js +150 -179
  293. package/textarea/types.d.ts +9 -5
  294. package/toggle-group/ToggleGroup.accessibility.test.js +107 -0
  295. package/toggle-group/ToggleGroup.js +21 -61
  296. package/toggle-group/ToggleGroup.stories.tsx +4 -4
  297. package/toggle-group/ToggleGroup.test.js +48 -81
  298. package/toggle-group/types.d.ts +10 -10
  299. package/typography/Typography.accessibility.test.js +339 -0
  300. package/typography/Typography.js +4 -13
  301. package/typography/types.d.ts +1 -1
  302. package/useTheme.d.ts +41 -136
  303. package/useTheme.js +1 -8
  304. package/useTranslatedLabels.js +1 -7
  305. package/utils/BaseTypography.d.ts +2 -2
  306. package/utils/BaseTypography.js +16 -30
  307. package/utils/FocusLock.js +25 -39
  308. package/wizard/Wizard.accessibility.test.js +55 -0
  309. package/wizard/Wizard.js +14 -49
  310. package/wizard/Wizard.test.js +53 -80
  311. package/wizard/types.d.ts +7 -7
  312. package/common/OpenSans.css +0 -69
  313. package/common/fonts/OpenSans-Bold.ttf +0 -0
  314. package/common/fonts/OpenSans-BoldItalic.ttf +0 -0
  315. package/common/fonts/OpenSans-ExtraBold.ttf +0 -0
  316. package/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  317. package/common/fonts/OpenSans-Italic.ttf +0 -0
  318. package/common/fonts/OpenSans-Light.ttf +0 -0
  319. package/common/fonts/OpenSans-LightItalic.ttf +0 -0
  320. package/common/fonts/OpenSans-Regular.ttf +0 -0
  321. package/common/fonts/OpenSans-SemiBold.ttf +0 -0
  322. package/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  323. package/resultsetTable/Icons.d.ts +0 -7
  324. package/resultsetTable/ResultsetTable.d.ts +0 -4
  325. package/slider/Slider.stories.tsx +0 -240
  326. package/text-input/Icons.d.ts +0 -8
  327. package/text-input/Icons.js +0 -60
  328. /package/{resultsetTable → action-icon}/types.js +0 -0
  329. /package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +0 -0
@@ -1,49 +1,110 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
4
+ var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
5
+ var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
5
6
  var _react = _interopRequireDefault(require("react"));
6
-
7
7
  var _react2 = require("@testing-library/react");
8
-
9
8
  var _userEvent = _interopRequireDefault(require("@testing-library/user-event"));
10
-
11
9
  var _Checkbox = _interopRequireDefault(require("./Checkbox.tsx"));
12
-
13
10
  describe("Checkbox component tests", function () {
14
11
  test("Checkbox renders with correct aria-labelledby and aria-required", function () {
15
12
  var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
16
- label: "Checkbox"
17
- })),
18
- getByText = _render.getByText,
19
- getByRole = _render.getByRole;
20
-
13
+ label: "Checkbox"
14
+ })),
15
+ getByText = _render.getByText,
16
+ getByRole = _render.getByRole;
21
17
  var labelId = getByText("Checkbox").getAttribute("id");
22
18
  expect(getByRole("checkbox").getAttribute("aria-labelledby")).toBe(labelId);
23
19
  expect(getByRole("checkbox").getAttribute("aria-required")).toBe("true");
20
+ expect(getByRole("checkbox").getAttribute("aria-readonly")).toBe("false");
21
+ expect(getByRole("checkbox").getAttribute("aria-disabled")).toBe("false");
24
22
  });
25
23
  test("Optional checkbox renders with correct aria-required", function () {
26
24
  var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
27
- label: "Checkbox",
28
- optional: true
29
- })),
30
- getByRole = _render2.getByRole;
31
-
25
+ label: "Checkbox",
26
+ optional: true
27
+ })),
28
+ getByRole = _render2.getByRole;
32
29
  expect(getByRole("checkbox").getAttribute("aria-required")).toBe("false");
33
30
  });
34
- test("Calls correct function on click", function () {
31
+ test("Calls correct function onChange", function () {
35
32
  var onChange = jest.fn();
36
-
37
33
  var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
38
- label: "Checkbox",
39
- onChange: onChange
40
- })),
41
- getByText = _render3.getByText;
42
-
34
+ label: "Checkbox",
35
+ onChange: onChange
36
+ })),
37
+ getByText = _render3.getByText;
43
38
  _react2.fireEvent.click(getByText("Checkbox"));
44
-
45
39
  expect(onChange).toHaveBeenCalled();
46
40
  });
41
+ test("Read-only checkbox does not trigger onChange function", function () {
42
+ var onChange = jest.fn();
43
+ var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
44
+ label: "Checkbox",
45
+ onChange: onChange,
46
+ readOnly: true
47
+ })),
48
+ getByRole = _render4.getByRole;
49
+ var checkbox = getByRole("checkbox");
50
+ expect(checkbox.getAttribute("aria-readonly")).toBe("true");
51
+ _react2.fireEvent.click(checkbox);
52
+ expect(onChange).not.toHaveBeenCalled();
53
+ });
54
+ test("Read-only checkbox sends its value on submit", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
55
+ var handlerOnSubmit, _render5, getByText, submit;
56
+ return _regenerator["default"].wrap(function _callee$(_context) {
57
+ while (1) switch (_context.prev = _context.next) {
58
+ case 0:
59
+ handlerOnSubmit = jest.fn(function (e) {
60
+ e.preventDefault();
61
+ var formData = new FormData(e.target);
62
+ var formProps = Object.fromEntries(formData);
63
+ expect(formProps).toStrictEqual({
64
+ data: "checked"
65
+ });
66
+ });
67
+ _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement("form", {
68
+ onSubmit: handlerOnSubmit
69
+ }, /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
70
+ label: "Checkbox",
71
+ name: "data",
72
+ value: "checked",
73
+ readOnly: true,
74
+ defaultChecked: true
75
+ }), /*#__PURE__*/_react["default"].createElement("button", {
76
+ type: "submit"
77
+ }, "Submit"))), getByText = _render5.getByText;
78
+ submit = getByText("Submit");
79
+ _context.next = 5;
80
+ return _userEvent["default"].click(submit);
81
+ case 5:
82
+ expect(handlerOnSubmit).toHaveBeenCalled();
83
+ case 6:
84
+ case "end":
85
+ return _context.stop();
86
+ }
87
+ }, _callee);
88
+ })));
89
+ test("Read-only checkbox doesn't change its value with Space key", function () {
90
+ var onChange = jest.fn();
91
+ var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
92
+ label: "Checkbox",
93
+ onChange: onChange,
94
+ readOnly: true
95
+ })),
96
+ getByRole = _render6.getByRole;
97
+ var checkbox = getByRole("checkbox");
98
+ _userEvent["default"].tab();
99
+ expect(document.activeElement === checkbox).toBeTruthy();
100
+ _react2.fireEvent.keyDown(checkbox, {
101
+ key: " ",
102
+ code: "Space",
103
+ keyCode: 32,
104
+ charCode: 32
105
+ });
106
+ expect(onChange).not.toHaveBeenCalled();
107
+ });
47
108
  test("Uncontrolled checkbox", function () {
48
109
  var onChange = jest.fn();
49
110
  var component = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
@@ -56,9 +117,7 @@ describe("Checkbox component tests", function () {
56
117
  var submitInput = component.container.querySelector("input[name=\"test\"]");
57
118
  expect(input.getAttribute("aria-checked")).toBe("false");
58
119
  expect(submitInput.checked).toBe(false);
59
-
60
120
  _react2.fireEvent.click(visibleCheckbox);
61
-
62
121
  expect(onChange).toHaveBeenCalled();
63
122
  expect(onChange).toHaveBeenCalledWith(true);
64
123
  expect(input.getAttribute("aria-checked")).toBe("true");
@@ -75,24 +134,21 @@ describe("Checkbox component tests", function () {
75
134
  var input = component.getByRole("checkbox");
76
135
  var visibleCheckbox = component.getByText("Checkbox");
77
136
  var submitInput = component.container.querySelector("input[name=\"test\"]");
78
-
79
137
  _react2.fireEvent.click(visibleCheckbox);
80
-
81
138
  expect(onChange).toHaveBeenCalled();
82
139
  expect(onChange).toHaveBeenCalledWith(true);
83
140
  expect(input.getAttribute("aria-checked")).toBe("false");
84
141
  expect(submitInput.checked).toBe(false);
85
142
  });
86
143
  test("Renders with correct initial value and initial state when it is uncontrolled", function () {
87
- var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
88
- label: "Default label",
89
- defaultChecked: true,
90
- value: "test-defaultChecked",
91
- name: "test"
92
- })),
93
- getByRole = _render4.getByRole,
94
- container = _render4.container;
95
-
144
+ var _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
145
+ label: "Default label",
146
+ defaultChecked: true,
147
+ value: "test-defaultChecked",
148
+ name: "test"
149
+ })),
150
+ getByRole = _render7.getByRole,
151
+ container = _render7.container;
96
152
  var checkbox = getByRole("checkbox");
97
153
  var submitInput = container.querySelector("input[name=\"test\"]");
98
154
  expect(submitInput.value).toBe("test-defaultChecked");
@@ -101,55 +157,43 @@ describe("Checkbox component tests", function () {
101
157
  });
102
158
  test("Test disable keyboard and mouse interactions", function () {
103
159
  var onChange = jest.fn();
104
-
105
- var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
106
- label: "Checkbox",
107
- onChange: onChange,
108
- disabled: true,
109
- name: "test"
110
- })),
111
- getByRole = _render5.getByRole,
112
- getByText = _render5.getByText,
113
- container = _render5.container;
114
-
160
+ var _render8 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
161
+ label: "Checkbox",
162
+ onChange: onChange,
163
+ disabled: true,
164
+ name: "test"
165
+ })),
166
+ getByRole = _render8.getByRole,
167
+ getByText = _render8.getByText,
168
+ container = _render8.container;
115
169
  var input = getByRole("checkbox");
116
170
  var visibleCheckbox = getByText("Checkbox");
117
171
  var submitInput = container.querySelector("input[name=\"test\"]");
118
-
119
172
  _react2.fireEvent.click(visibleCheckbox);
120
-
121
173
  expect(onChange).toHaveBeenCalledTimes(0);
122
174
  expect(input.getAttribute("aria-checked")).toBe("false");
123
175
  expect(input.getAttribute("aria-disabled")).toBe("true");
124
176
  expect(submitInput.checked).toBe(false);
125
-
126
177
  _userEvent["default"].tab();
127
-
128
178
  expect(document.activeElement === input).toBeFalsy();
129
179
  });
130
180
  test("Test keyboard interactions", function () {
131
181
  var onChange = jest.fn();
132
-
133
- var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
134
- label: "Checkbox",
135
- name: "test",
136
- onChange: onChange
137
- })),
138
- getByRole = _render6.getByRole;
139
-
182
+ var _render9 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
183
+ label: "Checkbox",
184
+ name: "test",
185
+ onChange: onChange
186
+ })),
187
+ getByRole = _render9.getByRole;
140
188
  var checkbox = getByRole("checkbox");
141
-
142
189
  _userEvent["default"].tab();
143
-
144
190
  expect(document.activeElement === checkbox).toBeTruthy();
145
-
146
191
  _react2.fireEvent.keyDown(checkbox, {
147
192
  key: " ",
148
193
  code: "Space",
149
194
  keyCode: 32,
150
195
  charCode: 32
151
196
  });
152
-
153
197
  expect(onChange).toHaveBeenCalledWith(true);
154
198
  });
155
199
  });
@@ -1,11 +1,11 @@
1
- declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
2
- declare type Margin = {
1
+ type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
2
+ type Margin = {
3
3
  top?: Space;
4
4
  bottom?: Space;
5
5
  left?: Space;
6
6
  right?: Space;
7
7
  };
8
- declare type Props = {
8
+ type Props = {
9
9
  /**
10
10
  * Initial state of the checkbox, only when it is uncontrolled.
11
11
  */
@@ -40,6 +40,10 @@ declare type Props = {
40
40
  * If true, the component will display '(Optional)' next to the label.
41
41
  */
42
42
  optional?: boolean;
43
+ /**
44
+ * If true, the component will not be mutable, meaning the user can not edit the control.
45
+ */
46
+ readOnly?: boolean;
43
47
  /**
44
48
  * This function will be called when the user clicks the checkbox.
45
49
  * The new value will be passed as a parameter.
@@ -64,5 +68,5 @@ declare type Props = {
64
68
  /**
65
69
  * Reference to the component.
66
70
  */
67
- export declare type RefType = HTMLDivElement;
71
+ export type RefType = HTMLDivElement;
68
72
  export default Props;
@@ -0,0 +1,67 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
5
+ var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
6
+ var _react = _interopRequireDefault(require("react"));
7
+ var _react2 = require("@testing-library/react");
8
+ var _jestAxe = require("jest-axe");
9
+ var _Chip = _interopRequireDefault(require("./Chip.tsx"));
10
+ var iconSVG = /*#__PURE__*/_react["default"].createElement("svg", {
11
+ version: "1.1",
12
+ x: "0px",
13
+ y: "0px",
14
+ width: "438.536px",
15
+ height: "438.536px",
16
+ viewBox: "0 0 438.536 438.536",
17
+ fill: "currentColor"
18
+ }, /*#__PURE__*/_react["default"].createElement("g", null, /*#__PURE__*/_react["default"].createElement("path", {
19
+ d: "M414.41,24.123C398.333,8.042,378.963,0,356.315,0H82.228C59.58,0,40.21,8.042,24.126,24.123\nC8.045,40.207,0.003,59.576,0.003,82.225v274.084c0,22.647,8.042,42.018,24.123,58.102c16.084,16.084,35.454,24.126,58.102,24.126\nh274.084c22.648,0,42.018-8.042,58.095-24.126c16.084-16.084,24.126-35.454,24.126-58.102V82.225\nC438.532,59.576,430.49,40.204,414.41,24.123z M373.155,225.548h-49.963V406.84h-74.802V225.548H210.99V163.02h37.401v-37.402\nc0-26.838,6.283-47.107,18.843-60.813c12.559-13.706,33.304-20.555,62.242-20.555h49.963v62.526h-31.401\nc-10.663,0-17.467,1.853-20.417,5.568c-2.949,3.711-4.428,10.23-4.428,19.558v31.119h56.534L373.155,225.548z"
20
+ })));
21
+ describe("Chip component accessibility tests", function () {
22
+ it("Should not have basic accessibility issues", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
23
+ var _render, container, results;
24
+ return _regenerator["default"].wrap(function _callee$(_context) {
25
+ while (1) switch (_context.prev = _context.next) {
26
+ case 0:
27
+ _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Chip["default"], {
28
+ margin: "small",
29
+ prefixIcon: iconSVG,
30
+ suffixIcon: iconSVG,
31
+ label: "Chip"
32
+ })), container = _render.container;
33
+ _context.next = 3;
34
+ return (0, _jestAxe.axe)(container);
35
+ case 3:
36
+ results = _context.sent;
37
+ expect(results).toHaveNoViolations();
38
+ case 5:
39
+ case "end":
40
+ return _context.stop();
41
+ }
42
+ }, _callee);
43
+ })));
44
+ it("Should not have basic accessibility issues for disabled mode", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2() {
45
+ var _render2, container, results;
46
+ return _regenerator["default"].wrap(function _callee2$(_context2) {
47
+ while (1) switch (_context2.prev = _context2.next) {
48
+ case 0:
49
+ _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Chip["default"], {
50
+ margin: "small",
51
+ prefixIcon: iconSVG,
52
+ suffixIcon: iconSVG,
53
+ label: "Chip",
54
+ disabled: true
55
+ })), container = _render2.container;
56
+ _context2.next = 3;
57
+ return (0, _jestAxe.axe)(container);
58
+ case 3:
59
+ results = _context2.sent;
60
+ expect(results).toHaveNoViolations();
61
+ case 5:
62
+ case "end":
63
+ return _context2.stop();
64
+ }
65
+ }, _callee2);
66
+ })));
67
+ });
package/chip/Chip.js CHANGED
@@ -1,44 +1,32 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
4
  var _typeof3 = require("@babel/runtime/helpers/typeof");
6
-
7
5
  Object.defineProperty(exports, "__esModule", {
8
6
  value: true
9
7
  });
10
8
  exports["default"] = void 0;
11
-
12
9
  var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
13
-
14
10
  var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
15
-
16
11
  var _react = _interopRequireDefault(require("react"));
17
-
18
12
  var _styledComponents = _interopRequireWildcard(require("styled-components"));
19
-
20
13
  var _variables = require("../common/variables");
21
-
22
14
  var _utils = require("../common/utils");
23
-
24
15
  var _useTheme = _interopRequireDefault(require("../useTheme"));
25
-
16
+ var _Icon = _interopRequireDefault(require("../icon/Icon"));
26
17
  var _templateObject, _templateObject2, _templateObject3;
27
-
28
- function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
29
-
30
- function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof3(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
31
-
18
+ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
19
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof3(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
32
20
  var DxcChip = function DxcChip(_ref) {
33
21
  var label = _ref.label,
34
- suffixIcon = _ref.suffixIcon,
35
- prefixIcon = _ref.prefixIcon,
36
- onClickSuffix = _ref.onClickSuffix,
37
- onClickPrefix = _ref.onClickPrefix,
38
- disabled = _ref.disabled,
39
- margin = _ref.margin,
40
- _ref$tabIndex = _ref.tabIndex,
41
- tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
22
+ suffixIcon = _ref.suffixIcon,
23
+ prefixIcon = _ref.prefixIcon,
24
+ onClickSuffix = _ref.onClickSuffix,
25
+ onClickPrefix = _ref.onClickPrefix,
26
+ disabled = _ref.disabled,
27
+ margin = _ref.margin,
28
+ _ref$tabIndex = _ref.tabIndex,
29
+ tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
42
30
  var colorsTheme = (0, _useTheme["default"])();
43
31
  return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
44
32
  theme: colorsTheme.chip
@@ -53,8 +41,8 @@ var DxcChip = function DxcChip(_ref) {
53
41
  onClick: function onClick() {
54
42
  return onClickPrefix && !disabled && onClickPrefix();
55
43
  }
56
- }, typeof prefixIcon === "string" ? /*#__PURE__*/_react["default"].createElement("img", {
57
- src: prefixIcon
44
+ }, typeof prefixIcon === "string" ? /*#__PURE__*/_react["default"].createElement(_Icon["default"], {
45
+ icon: prefixIcon
58
46
  }) : prefixIcon), label && /*#__PURE__*/_react["default"].createElement(LabelContainer, {
59
47
  disabled: disabled
60
48
  }, label), suffixIcon && /*#__PURE__*/_react["default"].createElement(IconContainer, {
@@ -65,15 +53,13 @@ var DxcChip = function DxcChip(_ref) {
65
53
  onClick: function onClick() {
66
54
  return !disabled && (onClickSuffix === null || onClickSuffix === void 0 ? void 0 : onClickSuffix());
67
55
  }
68
- }, typeof suffixIcon === "string" ? /*#__PURE__*/_react["default"].createElement("img", {
69
- src: suffixIcon
56
+ }, typeof suffixIcon === "string" ? /*#__PURE__*/_react["default"].createElement(_Icon["default"], {
57
+ icon: suffixIcon
70
58
  }) : suffixIcon)));
71
59
  };
72
-
73
60
  var calculateWidth = function calculateWidth(margin) {
74
61
  return "calc(100% - ".concat((0, _utils.getMargin)(margin, "left"), " - ").concat((0, _utils.getMargin)(margin, "right"), ")");
75
62
  };
76
-
77
63
  var Chip = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n box-sizing: border-box;\n display: inline-flex;\n align-items: center;\n gap: ", ";\n min-height: 40px;\n max-width: ", ";\n background-color: ", ";\n border-radius: ", ";\n border-width: ", ";\n border-style: ", ";\n border-color: ", ";\n\n padding-top: ", ";\n padding-bottom: ", ";\n padding-left: ", ";\n padding-right: ", ";\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n cursor: ", ";\n"])), function (props) {
78
64
  return props.theme.iconSpacing;
79
65
  }, function (props) {
@@ -110,7 +96,6 @@ var Chip = _styledComponents["default"].div(_templateObject || (_templateObject
110
96
  var disabled = _ref2.disabled;
111
97
  return disabled && "not-allowed";
112
98
  });
113
-
114
99
  var LabelContainer = _styledComponents["default"].span(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n font-size: ", ";\n font-family: ", ";\n font-weight: ", ";\n font-style: ", ";\n color: ", ";\n text-overflow: ellipsis;\n white-space: nowrap;\n overflow: hidden;\n"])), function (props) {
115
100
  return props.theme.fontSize;
116
101
  }, function (props) {
@@ -122,19 +107,18 @@ var LabelContainer = _styledComponents["default"].span(_templateObject2 || (_tem
122
107
  }, function (props) {
123
108
  return props.disabled ? props.theme.disabledFontColor : props.theme.fontColor;
124
109
  });
125
-
126
- var IconContainer = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n border-radius: 0.25rem;\n color: ", ";\n ", "\n\n ", "\n\n img,\n svg {\n width: ", ";\n height: ", ";\n }\n"])), function (props) {
110
+ var IconContainer = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n border-radius: 0.25rem;\n color: ", ";\n ", "\n\n ", "\n\n font-size: ", ";\n svg {\n width: ", ";\n height: ", ";\n }\n"])), function (props) {
127
111
  return props.disabled ? props.theme.disabledIconColor : props.theme.iconColor;
128
112
  }, function (_ref3) {
129
113
  var interactuable = _ref3.interactuable;
130
114
  return interactuable && "cursor: pointer;";
131
115
  }, function (props) {
132
- return props.interactuable && "\n &:hover {\n color: ".concat(props.theme.hoverIconColor, ";\n }\n &:focus,\n &:focus-visible {\n outline: ").concat(props.theme.focusBorderThickness, " solid ").concat(props.theme.focusColor, ";\n }\n &:active {\n color: ").concat(props.theme.activeIconColor, ";\n }\n ");
116
+ return props.interactuable && "\n &:hover {\n color: ".concat(props.theme.hoverIconColor, ";\n }\n &:focus,\n &:focus-visible {\n outline: ").concat(props.theme.focusBorderThickness, " ").concat(props.theme.focusBorderStyle, " ").concat(props.theme.focusColor, ";\n }\n &:active {\n color: ").concat(props.theme.activeIconColor, ";\n }\n ");
117
+ }, function (props) {
118
+ return props.theme.iconSize;
133
119
  }, function (props) {
134
120
  return props.theme.iconSize;
135
121
  }, function (props) {
136
122
  return props.theme.iconSize;
137
123
  });
138
-
139
- var _default = DxcChip;
140
- exports["default"] = _default;
124
+ var _default = exports["default"] = DxcChip;
@@ -13,7 +13,6 @@ export default {
13
13
  const iconSVG = (
14
14
  <svg
15
15
  version="1.1"
16
- id="Capa_1"
17
16
  x="0px"
18
17
  y="0px"
19
18
  width="438.536px"
@@ -64,20 +63,11 @@ export const Chromatic = () => (
64
63
  </ExampleContainer>
65
64
  <ExampleContainer>
66
65
  <Title title="Chip with prefix (SVG) and suffix (URL)" theme="light" level={4} />
67
- <DxcChip
68
- label="Chip with prefix and suffix"
69
- prefixIcon={iconSVG}
70
- suffixIcon="https://upload.wikimedia.org/wikipedia/commons/e/e0/Check_green_icon.svg"
71
- />
66
+ <DxcChip label="Chip with prefix and suffix" prefixIcon={iconSVG} suffixIcon="filled_check_circle" />
72
67
  </ExampleContainer>
73
68
  <ExampleContainer>
74
69
  <Title title="Disabled chip" theme="light" level={4} />
75
- <DxcChip
76
- label="Disabled"
77
- disabled
78
- prefixIcon={iconSVG}
79
- suffixIcon="https://upload.wikimedia.org/wikipedia/commons/e/e0/Check_green_icon.svg"
80
- />
70
+ <DxcChip label="Disabled" disabled prefixIcon={iconSVG} suffixIcon="filled_check_circle" />
81
71
  </ExampleContainer>
82
72
  <ExampleContainer>
83
73
  <Title title="Chip with ellipsis" theme="light" level={4} />
@@ -146,22 +136,13 @@ export const Chromatic = () => (
146
136
  <ExampleContainer>
147
137
  <Title title="Chip with prefix and suffix" theme="light" level={4} />
148
138
  <HalstackProvider theme={opinionatedTheme}>
149
- <DxcChip
150
- label="Chip"
151
- prefixIcon={iconSVG}
152
- suffixIcon="https://upload.wikimedia.org/wikipedia/commons/e/e0/Check_green_icon.svg"
153
- />
139
+ <DxcChip label="Chip" prefixIcon={iconSVG} suffixIcon="filled_check_circle" />
154
140
  </HalstackProvider>
155
141
  </ExampleContainer>
156
142
  <ExampleContainer>
157
143
  <Title title="Chip with prefix and suffix" theme="light" level={4} />
158
144
  <HalstackProvider theme={opinionatedTheme}>
159
- <DxcChip
160
- label="Chip"
161
- disabled
162
- prefixIcon={iconSVG}
163
- suffixIcon="https://upload.wikimedia.org/wikipedia/commons/e/e0/Check_green_icon.svg"
164
- />
145
+ <DxcChip label="Chip" disabled prefixIcon={iconSVG} suffixIcon="filled_check_circle" />
165
146
  </HalstackProvider>
166
147
  </ExampleContainer>
167
148
  <ExampleContainer pseudoState="pseudo-hover">
@@ -199,7 +180,7 @@ const ChipPrefixFocused = () => (
199
180
  const ChipSuffixFocused = () => (
200
181
  <ExampleContainer>
201
182
  <Title title="Chip with suffix" theme="light" level={4} />
202
- <DxcChip label="Chip with suffix" suffixIcon="https://icons-for-free.com/download-icon-close+icon-1320184117228553763_512.png" onClickSuffix={() => {}} />
183
+ <DxcChip label="Chip with suffix" suffixIcon="filled_delete" onClickSuffix={() => {}} />
203
184
  </ExampleContainer>
204
185
  );
205
186
 
package/chip/Chip.test.js CHANGED
@@ -1,54 +1,41 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
4
  var _react = _interopRequireDefault(require("react"));
6
-
7
5
  var _react2 = require("@testing-library/react");
8
-
9
6
  var _Chip = _interopRequireDefault(require("./Chip.tsx"));
10
-
11
7
  describe("Chip component tests", function () {
12
8
  test("Chip renders with correct text", function () {
13
9
  var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Chip["default"], {
14
- label: "Chip"
15
- })),
16
- getByText = _render.getByText;
17
-
10
+ label: "Chip"
11
+ })),
12
+ getByText = _render.getByText;
18
13
  expect(getByText("Chip")).toBeTruthy();
19
14
  });
20
15
  test("Calls correct function when clicking on prefix icon", function () {
21
16
  var onClick = jest.fn();
22
-
23
17
  var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Chip["default"], {
24
- label: "Chip",
25
- prefixIcon: "https://developer.apple.com/design/human-interface-guidelines/foundations/app-icons/images/icon-and-image-large-icon-settings_2x.png",
26
- onClickPrefix: onClick
27
- })),
28
- getByText = _render2.getByText,
29
- getByRole = _render2.getByRole;
30
-
18
+ label: "Chip",
19
+ prefixIcon: "nutrition",
20
+ onClickPrefix: onClick
21
+ })),
22
+ getByText = _render2.getByText,
23
+ getByRole = _render2.getByRole;
31
24
  expect(getByText("Chip")).toBeTruthy();
32
-
33
- _react2.fireEvent.click(getByRole("img"));
34
-
25
+ _react2.fireEvent.click(getByRole("button"));
35
26
  expect(onClick).toHaveBeenCalled();
36
27
  });
37
28
  test("Calls correct function when clicking on suffix icon", function () {
38
29
  var onClick = jest.fn();
39
-
40
30
  var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Chip["default"], {
41
- label: "Chip",
42
- suffixIcon: "https://developer.apple.com/design/human-interface-guidelines/foundations/app-icons/images/icon-and-image-large-icon-settings_2x.png",
43
- onClickSuffix: onClick
44
- })),
45
- getByText = _render3.getByText,
46
- getByRole = _render3.getByRole;
47
-
31
+ label: "Chip",
32
+ suffixIcon: "nutrition",
33
+ onClickSuffix: onClick
34
+ })),
35
+ getByText = _render3.getByText,
36
+ getByRole = _render3.getByRole;
48
37
  expect(getByText("Chip")).toBeTruthy();
49
-
50
- _react2.fireEvent.click(getByRole("img"));
51
-
38
+ _react2.fireEvent.click(getByRole("button"));
52
39
  expect(onClick).toHaveBeenCalled();
53
40
  });
54
41
  });
package/chip/types.d.ts CHANGED
@@ -1,13 +1,13 @@
1
1
  /// <reference types="react" />
2
- declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
- declare type Margin = {
2
+ type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
+ type Margin = {
4
4
  top?: Space;
5
5
  bottom?: Space;
6
6
  left?: Space;
7
7
  right?: Space;
8
8
  };
9
- declare type SVG = React.ReactNode & React.SVGProps<SVGSVGElement>;
10
- declare type Props = {
9
+ type SVG = React.ReactNode & React.SVGProps<SVGSVGElement>;
10
+ type Props = {
11
11
  /**
12
12
  * Text to be placed on the chip.
13
13
  */