@dxc-technology/halstack-react 0.0.0-9b341c0 → 0.0.0-9d82cb9

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 (360) hide show
  1. package/BackgroundColorContext.d.ts +10 -0
  2. package/BackgroundColorContext.js +47 -0
  3. package/ThemeContext.d.ts +15 -0
  4. package/ThemeContext.js +243 -0
  5. package/{dist/V3Select → V3Select}/V3Select.js +35 -129
  6. package/{dist/V3Select → V3Select}/index.d.ts +0 -0
  7. package/{dist/V3Textarea → V3Textarea}/V3Textarea.js +12 -16
  8. package/{dist/V3Textarea → V3Textarea}/index.d.ts +0 -0
  9. package/accordion/Accordion.d.ts +4 -0
  10. package/{dist/accordion → accordion}/Accordion.js +37 -132
  11. package/accordion/Accordion.stories.tsx +307 -0
  12. package/accordion/types.d.ts +68 -0
  13. package/accordion/types.js +5 -0
  14. package/accordion-group/AccordionGroup.d.ts +7 -0
  15. package/accordion-group/AccordionGroup.js +170 -0
  16. package/accordion-group/AccordionGroup.stories.tsx +225 -0
  17. package/accordion-group/types.d.ts +72 -0
  18. package/accordion-group/types.js +5 -0
  19. package/alert/Alert.d.ts +4 -0
  20. package/{dist/alert → alert}/Alert.js +40 -153
  21. package/alert/Alert.stories.tsx +170 -0
  22. package/alert/types.d.ts +49 -0
  23. package/alert/types.js +5 -0
  24. package/badge/Badge.js +59 -0
  25. package/bleed/Bleed.d.ts +3 -0
  26. package/bleed/Bleed.js +84 -0
  27. package/bleed/Bleed.stories.tsx +342 -0
  28. package/bleed/types.d.ts +13 -0
  29. package/bleed/types.js +5 -0
  30. package/box/Box.d.ts +4 -0
  31. package/{dist/box → box}/Box.js +15 -45
  32. package/box/Box.stories.tsx +132 -0
  33. package/box/types.d.ts +43 -0
  34. package/box/types.js +5 -0
  35. package/button/Button.d.ts +4 -0
  36. package/{dist/button → button}/Button.js +26 -93
  37. package/button/Button.stories.tsx +274 -0
  38. package/button/types.d.ts +53 -0
  39. package/button/types.js +5 -0
  40. package/card/Card.d.ts +4 -0
  41. package/{dist/card → card}/Card.js +34 -124
  42. package/card/Card.stories.tsx +201 -0
  43. package/card/ice-cream.jpg +0 -0
  44. package/card/types.d.ts +67 -0
  45. package/card/types.js +5 -0
  46. package/checkbox/Checkbox.d.ts +4 -0
  47. package/{dist/checkbox → checkbox}/Checkbox.js +15 -61
  48. package/checkbox/Checkbox.stories.tsx +192 -0
  49. package/checkbox/types.d.ts +60 -0
  50. package/checkbox/types.js +5 -0
  51. package/chip/Chip.d.ts +4 -0
  52. package/{dist/chip → chip}/Chip.js +22 -88
  53. package/chip/Chip.stories.tsx +121 -0
  54. package/chip/types.d.ts +53 -0
  55. package/chip/types.js +5 -0
  56. package/{dist/common → common}/OpenSans.css +0 -0
  57. package/{dist/common → common}/RequiredComponent.js +3 -11
  58. package/{dist/common → common}/fonts/OpenSans-Bold.ttf +0 -0
  59. package/{dist/common → common}/fonts/OpenSans-BoldItalic.ttf +0 -0
  60. package/{dist/common → common}/fonts/OpenSans-ExtraBold.ttf +0 -0
  61. package/{dist/common → common}/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  62. package/{dist/common → common}/fonts/OpenSans-Italic.ttf +0 -0
  63. package/{dist/common → common}/fonts/OpenSans-Light.ttf +0 -0
  64. package/{dist/common → common}/fonts/OpenSans-LightItalic.ttf +0 -0
  65. package/{dist/common → common}/fonts/OpenSans-Regular.ttf +0 -0
  66. package/{dist/common → common}/fonts/OpenSans-SemiBold.ttf +0 -0
  67. package/{dist/common → common}/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  68. package/{dist/common → common}/utils.js +0 -0
  69. package/{dist/common → common}/variables.js +126 -88
  70. package/{dist/date → date}/Date.js +17 -23
  71. package/{dist/date → date}/index.d.ts +0 -0
  72. package/date-input/DateInput.d.ts +4 -0
  73. package/{dist/date-input → date-input}/DateInput.js +32 -74
  74. package/date-input/DateInput.stories.tsx +138 -0
  75. package/date-input/types.d.ts +100 -0
  76. package/date-input/types.js +5 -0
  77. package/dialog/Dialog.d.ts +4 -0
  78. package/{dist/dialog → dialog}/Dialog.js +24 -76
  79. package/dialog/Dialog.stories.tsx +212 -0
  80. package/dialog/types.d.ts +43 -0
  81. package/dialog/types.js +5 -0
  82. package/dropdown/Dropdown.d.ts +4 -0
  83. package/{dist/dropdown → dropdown}/Dropdown.js +45 -172
  84. package/dropdown/Dropdown.stories.tsx +247 -0
  85. package/dropdown/types.d.ts +89 -0
  86. package/dropdown/types.js +5 -0
  87. package/file-input/FileInput.d.ts +4 -0
  88. package/file-input/FileInput.js +590 -0
  89. package/file-input/FileInput.stories.tsx +507 -0
  90. package/file-input/FileItem.d.ts +14 -0
  91. package/file-input/FileItem.js +184 -0
  92. package/file-input/types.d.ts +112 -0
  93. package/file-input/types.js +5 -0
  94. package/footer/Footer.d.ts +4 -0
  95. package/footer/Footer.js +260 -0
  96. package/footer/Footer.stories.tsx +130 -0
  97. package/footer/Icons.d.ts +2 -0
  98. package/{dist/footer → footer}/Icons.js +15 -15
  99. package/footer/types.d.ts +65 -0
  100. package/footer/types.js +5 -0
  101. package/header/Header.d.ts +7 -0
  102. package/{dist/header → header}/Header.js +58 -204
  103. package/header/Header.stories.tsx +162 -0
  104. package/header/Icons.d.ts +2 -0
  105. package/{dist/header → header}/Icons.js +7 -32
  106. package/header/types.d.ts +47 -0
  107. package/header/types.js +5 -0
  108. package/heading/Heading.d.ts +4 -0
  109. package/{dist/heading → heading}/Heading.js +25 -96
  110. package/heading/Heading.stories.tsx +54 -0
  111. package/heading/types.d.ts +33 -0
  112. package/heading/types.js +5 -0
  113. package/{dist/input-text → input-text}/Icons.js +2 -2
  114. package/{dist/input-text → input-text}/InputText.js +38 -132
  115. package/{dist/input-text → input-text}/index.d.ts +1 -1
  116. package/inset/Inset.d.ts +3 -0
  117. package/inset/Inset.js +84 -0
  118. package/inset/Inset.stories.tsx +229 -0
  119. package/inset/types.d.ts +13 -0
  120. package/inset/types.js +5 -0
  121. package/layout/ApplicationLayout.d.ts +10 -0
  122. package/{dist/layout → layout}/ApplicationLayout.js +39 -141
  123. package/layout/ApplicationLayout.stories.tsx +171 -0
  124. package/{dist/layout → layout}/Icons.js +7 -7
  125. package/layout/types.d.ts +57 -0
  126. package/layout/types.js +5 -0
  127. package/link/Link.d.ts +3 -0
  128. package/{dist/link → link}/Link.js +19 -95
  129. package/link/Link.stories.tsx +146 -0
  130. package/link/types.d.ts +74 -0
  131. package/link/types.js +5 -0
  132. package/list/List.d.ts +8 -0
  133. package/list/List.js +47 -0
  134. package/list/List.stories.tsx +95 -0
  135. package/main.d.ts +48 -0
  136. package/{dist/main.js → main.js} +118 -82
  137. package/number-input/NumberInput.d.ts +4 -0
  138. package/number-input/NumberInput.js +83 -0
  139. package/number-input/NumberInput.stories.tsx +115 -0
  140. package/number-input/NumberInputContext.d.ts +4 -0
  141. package/{dist/number-input → number-input}/NumberInputContext.js +5 -2
  142. package/number-input/numberInputContextTypes.d.ts +19 -0
  143. package/number-input/numberInputContextTypes.js +5 -0
  144. package/number-input/types.d.ts +117 -0
  145. package/number-input/types.js +5 -0
  146. package/package.json +30 -17
  147. package/{dist/paginator → paginator}/Icons.js +9 -9
  148. package/paginator/Paginator.d.ts +4 -0
  149. package/paginator/Paginator.js +192 -0
  150. package/paginator/Paginator.stories.tsx +63 -0
  151. package/paginator/types.d.ts +38 -0
  152. package/paginator/types.js +5 -0
  153. package/password-input/PasswordInput.d.ts +4 -0
  154. package/{dist/password-input → password-input}/PasswordInput.js +37 -77
  155. package/password-input/PasswordInput.stories.tsx +131 -0
  156. package/password-input/types.d.ts +107 -0
  157. package/password-input/types.js +5 -0
  158. package/progress-bar/ProgressBar.d.ts +4 -0
  159. package/{dist/progress-bar → progress-bar}/ProgressBar.js +22 -94
  160. package/progress-bar/ProgressBar.stories.jsx +58 -0
  161. package/progress-bar/types.d.ts +37 -0
  162. package/progress-bar/types.js +5 -0
  163. package/radio/Radio.d.ts +4 -0
  164. package/{dist/radio → radio}/Radio.js +17 -52
  165. package/radio/Radio.stories.tsx +192 -0
  166. package/radio/types.d.ts +54 -0
  167. package/radio/types.js +5 -0
  168. package/radio-group/Radio.d.ts +4 -0
  169. package/radio-group/Radio.js +130 -0
  170. package/radio-group/RadioGroup.d.ts +4 -0
  171. package/radio-group/RadioGroup.js +268 -0
  172. package/radio-group/RadioGroup.stories.tsx +79 -0
  173. package/radio-group/types.d.ts +36 -0
  174. package/radio-group/types.js +5 -0
  175. package/resultsetTable/ResultsetTable.d.ts +4 -0
  176. package/{dist/resultsetTable → resultsetTable}/ResultsetTable.js +39 -146
  177. package/resultsetTable/ResultsetTable.stories.tsx +275 -0
  178. package/resultsetTable/types.d.ts +67 -0
  179. package/resultsetTable/types.js +5 -0
  180. package/row/Row.d.ts +11 -0
  181. package/row/Row.js +127 -0
  182. package/row/Row.stories.tsx +239 -0
  183. package/select/Select.d.ts +4 -0
  184. package/{dist/select → select}/Select.js +271 -477
  185. package/select/Select.stories.tsx +572 -0
  186. package/select/types.d.ts +170 -0
  187. package/select/types.js +5 -0
  188. package/sidenav/Sidenav.d.ts +9 -0
  189. package/{dist/sidenav → sidenav}/Sidenav.js +21 -64
  190. package/sidenav/Sidenav.stories.tsx +182 -0
  191. package/sidenav/types.d.ts +50 -0
  192. package/sidenav/types.js +5 -0
  193. package/slider/Slider.d.ts +4 -0
  194. package/{dist/slider → slider}/Slider.js +74 -161
  195. package/slider/Slider.stories.tsx +177 -0
  196. package/slider/types.d.ts +78 -0
  197. package/slider/types.js +5 -0
  198. package/spinner/Spinner.d.ts +4 -0
  199. package/spinner/Spinner.js +250 -0
  200. package/spinner/Spinner.stories.jsx +103 -0
  201. package/spinner/types.d.ts +32 -0
  202. package/spinner/types.js +5 -0
  203. package/stack/Stack.d.ts +10 -0
  204. package/stack/Stack.js +97 -0
  205. package/stack/Stack.stories.tsx +166 -0
  206. package/switch/Switch.d.ts +4 -0
  207. package/{dist/switch → switch}/Switch.js +28 -71
  208. package/switch/Switch.stories.tsx +160 -0
  209. package/switch/types.d.ts +58 -0
  210. package/switch/types.js +5 -0
  211. package/table/Table.d.ts +4 -0
  212. package/{dist/table → table}/Table.js +12 -26
  213. package/table/Table.stories.jsx +277 -0
  214. package/table/types.d.ts +21 -0
  215. package/table/types.js +5 -0
  216. package/tabs/Tabs.d.ts +4 -0
  217. package/tabs/Tabs.js +213 -0
  218. package/tabs/Tabs.stories.tsx +122 -0
  219. package/tabs/types.d.ts +70 -0
  220. package/tabs/types.js +5 -0
  221. package/tag/Tag.d.ts +4 -0
  222. package/tag/Tag.js +193 -0
  223. package/tag/Tag.stories.tsx +145 -0
  224. package/tag/types.d.ts +60 -0
  225. package/tag/types.js +5 -0
  226. package/text/Text.d.ts +7 -0
  227. package/text/Text.js +30 -0
  228. package/text/Text.stories.tsx +19 -0
  229. package/text-input/TextInput.d.ts +4 -0
  230. package/{dist/text-input → text-input}/TextInput.js +278 -458
  231. package/text-input/TextInput.stories.tsx +456 -0
  232. package/text-input/types.d.ts +159 -0
  233. package/text-input/types.js +5 -0
  234. package/textarea/Textarea.d.ts +4 -0
  235. package/{dist/textarea → textarea}/Textarea.js +38 -123
  236. package/textarea/Textarea.stories.jsx +136 -0
  237. package/textarea/types.d.ts +130 -0
  238. package/textarea/types.js +5 -0
  239. package/{dist/toggle → toggle}/Toggle.js +16 -50
  240. package/{dist/toggle → toggle}/index.d.ts +0 -0
  241. package/toggle-group/ToggleGroup.d.ts +4 -0
  242. package/{dist/toggle-group → toggle-group}/ToggleGroup.js +35 -148
  243. package/toggle-group/ToggleGroup.stories.tsx +173 -0
  244. package/toggle-group/types.d.ts +97 -0
  245. package/toggle-group/types.js +5 -0
  246. package/{dist/upload → upload}/Upload.js +11 -15
  247. package/upload/buttons-upload/ButtonsUpload.js +111 -0
  248. package/{dist/upload → upload}/buttons-upload/Icons.js +7 -7
  249. package/upload/dragAndDropArea/DragAndDropArea.js +225 -0
  250. package/{dist/upload → upload}/dragAndDropArea/Icons.js +6 -6
  251. package/upload/file-upload/FileToUpload.js +115 -0
  252. package/{dist/upload → upload}/file-upload/Icons.js +13 -13
  253. package/{dist/upload → upload}/files-upload/FilesToUpload.js +13 -27
  254. package/{dist/upload → upload}/index.d.ts +0 -0
  255. package/{dist/upload → upload}/transaction/Icons.js +31 -31
  256. package/upload/transaction/Transaction.js +104 -0
  257. package/upload/transactions/Transactions.js +94 -0
  258. package/useTheme.d.ts +2 -0
  259. package/{dist/useTheme.js → useTheme.js} +1 -1
  260. package/wizard/Wizard.d.ts +4 -0
  261. package/wizard/Wizard.js +281 -0
  262. package/wizard/Wizard.stories.tsx +224 -0
  263. package/wizard/types.d.ts +60 -0
  264. package/wizard/types.js +5 -0
  265. package/README.md +0 -66
  266. package/babel.config.js +0 -8
  267. package/dist/BackgroundColorContext.js +0 -46
  268. package/dist/ThemeContext.js +0 -250
  269. package/dist/accordion/index.d.ts +0 -28
  270. package/dist/accordion-group/AccordionGroup.js +0 -186
  271. package/dist/accordion-group/index.d.ts +0 -16
  272. package/dist/alert/index.d.ts +0 -51
  273. package/dist/badge/Badge.js +0 -63
  274. package/dist/box/index.d.ts +0 -25
  275. package/dist/button/index.d.ts +0 -24
  276. package/dist/card/index.d.ts +0 -22
  277. package/dist/checkbox/index.d.ts +0 -24
  278. package/dist/chip/index.d.ts +0 -22
  279. package/dist/date-input/index.d.ts +0 -95
  280. package/dist/dialog/index.d.ts +0 -18
  281. package/dist/dropdown/index.d.ts +0 -26
  282. package/dist/file-input/FileInput.js +0 -644
  283. package/dist/file-input/FileItem.js +0 -287
  284. package/dist/file-input/index.d.ts +0 -81
  285. package/dist/footer/Footer.js +0 -421
  286. package/dist/footer/index.d.ts +0 -25
  287. package/dist/header/index.d.ts +0 -25
  288. package/dist/heading/index.d.ts +0 -17
  289. package/dist/link/index.d.ts +0 -23
  290. package/dist/main.d.ts +0 -40
  291. package/dist/number-input/NumberInput.js +0 -136
  292. package/dist/number-input/index.d.ts +0 -113
  293. package/dist/paginator/Paginator.js +0 -283
  294. package/dist/paginator/index.d.ts +0 -20
  295. package/dist/password-input/index.d.ts +0 -94
  296. package/dist/progress-bar/index.d.ts +0 -18
  297. package/dist/radio/index.d.ts +0 -23
  298. package/dist/resultsetTable/index.d.ts +0 -19
  299. package/dist/select/index.d.ts +0 -53
  300. package/dist/sidenav/index.d.ts +0 -13
  301. package/dist/slider/index.d.ts +0 -29
  302. package/dist/spinner/Spinner.js +0 -381
  303. package/dist/spinner/index.d.ts +0 -17
  304. package/dist/switch/index.d.ts +0 -24
  305. package/dist/table/index.d.ts +0 -13
  306. package/dist/tabs/Tabs.js +0 -343
  307. package/dist/tabs/index.d.ts +0 -19
  308. package/dist/tag/Tag.js +0 -282
  309. package/dist/tag/index.d.ts +0 -24
  310. package/dist/text-input/index.d.ts +0 -135
  311. package/dist/textarea/index.d.ts +0 -117
  312. package/dist/toggle-group/index.d.ts +0 -21
  313. package/dist/upload/buttons-upload/ButtonsUpload.js +0 -135
  314. package/dist/upload/dragAndDropArea/DragAndDropArea.js +0 -329
  315. package/dist/upload/file-upload/FileToUpload.js +0 -189
  316. package/dist/upload/transaction/Transaction.js +0 -148
  317. package/dist/upload/transactions/Transactions.js +0 -138
  318. package/dist/wizard/Icons.js +0 -65
  319. package/dist/wizard/Wizard.js +0 -405
  320. package/dist/wizard/index.d.ts +0 -18
  321. package/test/Accordion.test.js +0 -33
  322. package/test/AccordionGroup.test.js +0 -125
  323. package/test/Alert.test.js +0 -53
  324. package/test/Box.test.js +0 -10
  325. package/test/Button.test.js +0 -18
  326. package/test/Card.test.js +0 -30
  327. package/test/Checkbox.test.js +0 -45
  328. package/test/Chip.test.js +0 -25
  329. package/test/Date.test.js +0 -395
  330. package/test/DateInput.test.js +0 -242
  331. package/test/Dialog.test.js +0 -23
  332. package/test/Dropdown.test.js +0 -145
  333. package/test/FileInput.test.js +0 -201
  334. package/test/Footer.test.js +0 -94
  335. package/test/Header.test.js +0 -34
  336. package/test/Heading.test.js +0 -83
  337. package/test/InputText.test.js +0 -240
  338. package/test/Link.test.js +0 -43
  339. package/test/NumberInput.test.js +0 -259
  340. package/test/Paginator.test.js +0 -177
  341. package/test/PasswordInput.test.js +0 -83
  342. package/test/ProgressBar.test.js +0 -35
  343. package/test/Radio.test.js +0 -37
  344. package/test/ResultsetTable.test.js +0 -329
  345. package/test/Sidenav.test.js +0 -45
  346. package/test/Slider.test.js +0 -74
  347. package/test/Spinner.test.js +0 -32
  348. package/test/Switch.test.js +0 -45
  349. package/test/Table.test.js +0 -36
  350. package/test/Tabs.test.js +0 -109
  351. package/test/Tag.test.js +0 -32
  352. package/test/TextInput.test.js +0 -732
  353. package/test/Textarea.test.js +0 -193
  354. package/test/ToggleGroup.test.js +0 -85
  355. package/test/Upload.test.js +0 -60
  356. package/test/V3Select.test.js +0 -212
  357. package/test/V3TextArea.test.js +0 -51
  358. package/test/Wizard.test.js +0 -130
  359. package/test/mocks/pngMock.js +0 -1
  360. package/test/mocks/svgMock.js +0 -1
@@ -1,125 +0,0 @@
1
- import React from "react";
2
- import { render, fireEvent } from "@testing-library/react";
3
- import DxcAccordionGroup from "../src/accordion-group/AccordionGroup";
4
-
5
- describe("Accordion component tests", () => {
6
- test("Uncontrolled accordion group renders with children", () => {
7
- const { getByText, getAllByRole } = render(
8
- <DxcAccordionGroup>
9
- <DxcAccordionGroup.Accordion label="Accordion1" padding="medium">
10
- <div>
11
- Lorem ipsum dolor sit amet, consectetur adipiscing elit. Suspendisse malesuada lacus ex, sit amet blandit
12
- leo lobortis eget.
13
- </div>
14
- </DxcAccordionGroup.Accordion>
15
- <DxcAccordionGroup.Accordion label="Accordion2" padding="medium">
16
- <div>
17
- Lorem ipsum dolor sit amet, consectetur adipiscing elit. Suspendisse malesuada lacus ex, sit amet blandit
18
- leo lobortis eget.
19
- </div>
20
- </DxcAccordionGroup.Accordion>
21
- </DxcAccordionGroup>
22
- );
23
-
24
- expect(getByText("Accordion1")).toBeTruthy();
25
- expect(getByText("Accordion2")).toBeTruthy();
26
- expect(getAllByRole("button")[0].getAttribute("aria-expanded")).toBe("false");
27
- expect(getAllByRole("button")[1].getAttribute("aria-expanded")).toBe("false");
28
- });
29
-
30
- test("Uncontrolled accordion group renders with only one children", () => {
31
- const { getByText, getAllByRole } = render(
32
- <DxcAccordionGroup>
33
- <DxcAccordionGroup.Accordion label="Accordion1" padding="medium">
34
- <div>
35
- Lorem ipsum dolor sit amet, consectetur adipiscing elit. Suspendisse malesuada lacus ex, sit amet blandit
36
- leo lobortis eget.
37
- </div>
38
- </DxcAccordionGroup.Accordion>
39
- </DxcAccordionGroup>
40
- );
41
-
42
- expect(getByText("Accordion1")).toBeTruthy();
43
- expect(getAllByRole("button")[0].getAttribute("aria-expanded")).toBe("false");
44
- });
45
-
46
- test("Uncontrolled accordion group calls correct function on click", () => {
47
- const onActiveChange = jest.fn();
48
- const { getByText, getAllByRole } = render(
49
- <DxcAccordionGroup margin="large" onActiveChange={onActiveChange}>
50
- <DxcAccordionGroup.Accordion label="Accordion1" padding="medium" margin="large">
51
- <div>
52
- Lorem ipsum dolor sit amet, consectetur adipiscing elit. Suspendisse malesuada lacus ex, sit amet blandit
53
- leo lobortis eget.
54
- </div>
55
- </DxcAccordionGroup.Accordion>
56
- <DxcAccordionGroup.Accordion label="Accordion2" padding="medium">
57
- <div>
58
- Lorem ipsum dolor sit amet, consectetur adipiscing elit. Suspendisse malesuada lacus ex, sit amet blandit
59
- leo lobortis eget.
60
- </div>
61
- </DxcAccordionGroup.Accordion>
62
- </DxcAccordionGroup>
63
- );
64
-
65
- expect(getAllByRole("button")[0].getAttribute("aria-expanded")).toBe("false");
66
- expect(getAllByRole("button")[1].getAttribute("aria-expanded")).toBe("false");
67
- fireEvent.click(getByText("Accordion1"));
68
- expect(onActiveChange).toHaveBeenCalled();
69
- expect(getAllByRole("button")[0].getAttribute("aria-expanded")).toBe("true");
70
- expect(getAllByRole("button")[1].getAttribute("aria-expanded")).toBe("false");
71
- });
72
-
73
- test("Controlled accordion with indexActive change", () => {
74
- const onActiveChange = jest.fn();
75
- const { getByText, getAllByRole, rerender } = render(
76
- <DxcAccordionGroup margin="large" indexActive={1} onActiveChange={onActiveChange}>
77
- <DxcAccordionGroup.Accordion label="Accordion1" padding="medium" margin="large">
78
- <div>Text1</div>
79
- </DxcAccordionGroup.Accordion>
80
- <DxcAccordionGroup.Accordion label="Accordion2" padding="medium">
81
- <div>Text2</div>
82
- </DxcAccordionGroup.Accordion>
83
- </DxcAccordionGroup>
84
- );
85
- expect(getByText("Text1")).toBeTruthy();
86
- expect(getByText("Text2")).toBeTruthy();
87
- fireEvent.click(getByText("Accordion1"));
88
- fireEvent.click(getByText("Accordion2"));
89
- expect(onActiveChange.mock.calls[0][0]).toBe(0);
90
- expect(onActiveChange.mock.calls[1][0]).toBe(1);
91
- expect(getAllByRole("button")[0].getAttribute("aria-expanded")).toBe("false");
92
- expect(getAllByRole("button")[1].getAttribute("aria-expanded")).toBe("true");
93
-
94
- rerender(
95
- <DxcAccordionGroup margin="large" indexActive={0} onActiveChange={onActiveChange}>
96
- <DxcAccordionGroup.Accordion label="Accordion1" padding="medium" margin="large">
97
- <div>Text1</div>
98
- </DxcAccordionGroup.Accordion>
99
- <DxcAccordionGroup.Accordion label="Accordion2" padding="medium">
100
- <div>Text2</div>
101
- </DxcAccordionGroup.Accordion>
102
- </DxcAccordionGroup>
103
- );
104
-
105
- expect(getAllByRole("button")[0].getAttribute("aria-expanded")).toBe("true");
106
- expect(getAllByRole("button")[1].getAttribute("aria-expanded")).toBe("false");
107
- });
108
-
109
- test("Disabled uncontrolled accordion group", () => {
110
- const onActiveChange = jest.fn();
111
- const { getByText } = render(
112
- <DxcAccordionGroup margin="large" onActiveChange={onActiveChange} disabled={true}>
113
- <DxcAccordionGroup.Accordion label="Accordion1" padding="medium" margin="large">
114
- <div>Text1</div>
115
- </DxcAccordionGroup.Accordion>
116
- <DxcAccordionGroup.Accordion label="Accordion2" padding="medium">
117
- <div>Text2</div>
118
- </DxcAccordionGroup.Accordion>
119
- </DxcAccordionGroup>
120
- );
121
- fireEvent.click(getByText("Accordion1"));
122
- fireEvent.click(getByText("Accordion2"));
123
- expect(onActiveChange).toHaveBeenCalledTimes(0);
124
- });
125
- });
@@ -1,53 +0,0 @@
1
- import React from "react";
2
- import { render, fireEvent } from "@testing-library/react";
3
- import DxcAlert from "../src/alert/Alert";
4
-
5
- describe("Alert component tests", () => {
6
- test("Info alert renders with correct text", () => {
7
- const { getByText } = render(<DxcAlert type="info" inlineText="info-alert-text" />);
8
- expect(getByText("information")).toBeTruthy();
9
- expect(getByText("info-alert-text")).toBeTruthy();
10
- });
11
-
12
- test("Confirm alert renders with correct text", () => {
13
- const { getByText } = render(<DxcAlert type="confirm" inlineText="confirm-alert-text" />);
14
- expect(getByText("success")).toBeTruthy();
15
- expect(getByText("confirm-alert-text")).toBeTruthy();
16
- });
17
-
18
- test("Warning alert renders with correct text", () => {
19
- const { getByText } = render(<DxcAlert type="warning" inlineText="warning-alert-text" />);
20
- expect(getByText("warning")).toBeTruthy();
21
- expect(getByText("warning-alert-text")).toBeTruthy();
22
- });
23
-
24
- test("Error alert renders with correct text", () => {
25
- const { getByText } = render(<DxcAlert type="error" inlineText="error-alert-text" />);
26
- expect(getByText("error")).toBeTruthy();
27
- expect(getByText("error-alert-text")).toBeTruthy();
28
- });
29
-
30
- test("Alert renders with correct children", () => {
31
- const { getByText } = render(<DxcAlert inlineText="alert-text"><p>sample-children</p></DxcAlert>);
32
- expect(getByText("alert-text")).toBeTruthy();
33
- expect(getByText("sample-children")).toBeTruthy();
34
- });
35
-
36
- test("Calls correct function on close", () => {
37
- const onClose = jest.fn();
38
- const { getByRole } = render(<DxcAlert onClose={onClose} inlineText="info-alert-text" />);
39
-
40
- const closeButton = getByRole("button");
41
- fireEvent.click(closeButton);
42
- expect(onClose).toHaveBeenCalled();
43
- });
44
-
45
- test("Modal alert calls correct function on close", () => {
46
- const onClose = jest.fn();
47
- const { getByRole } = render(<DxcAlert onClose={onClose} mode="modal" inlineText="info-alert-text" />);
48
-
49
- const closeButton = getByRole("button");
50
- fireEvent.click(closeButton);
51
- expect(onClose).toHaveBeenCalled();
52
- });
53
- });
package/test/Box.test.js DELETED
@@ -1,10 +0,0 @@
1
- import React from "react";
2
- import { render } from "@testing-library/react";
3
- import DxcBox from "../src/card/Card";
4
-
5
- describe("Box component tests", () => {
6
- test("Box renders with correct text", () => {
7
- const { getByText } = render(<DxcBox>test-box</DxcBox>);
8
- expect(getByText("test-box")).toBeTruthy();
9
- });
10
- });
@@ -1,18 +0,0 @@
1
- import React from "react";
2
- import { render, fireEvent } from "@testing-library/react";
3
- import DxcButton from "../src/button/Button";
4
-
5
- describe("Button component tests", () => {
6
- test("Button renders with correct text", () => {
7
- const { getByText } = render(<DxcButton label="Button" />);
8
- expect(getByText("Button")).toBeTruthy();
9
- });
10
- test("Calls correct function on click", () => {
11
- const onClick = jest.fn();
12
- const { getByText } = render(<DxcButton label="Button" onClick={onClick} />);
13
-
14
- const button = getByText("Button");
15
- fireEvent.click(button);
16
- expect(onClick).toHaveBeenCalled();
17
- });
18
- });
package/test/Card.test.js DELETED
@@ -1,30 +0,0 @@
1
- import React from "react";
2
- import { render, fireEvent } from "@testing-library/react";
3
- import DxcCard from "../src/card/Card";
4
-
5
- describe("Card component tests", () => {
6
- test("Card renders with correct content", () => {
7
- const { getByText } = render(<DxcCard>test-card</DxcCard>);
8
- expect(getByText("test-card")).toBeTruthy();
9
- });
10
-
11
- test("Card renders with correct href", () => {
12
- const { getByRole } = render(<DxcCard linkHref="/testPage">test-card</DxcCard>);
13
- const card = getByRole("link");
14
- expect(card.getAttribute("href")).toEqual("/testPage");
15
- });
16
-
17
- test("Card renders with correct image", () => {
18
- const { getByRole } = render(<DxcCard imageSrc="/testImage">test-card</DxcCard>);
19
- const card = getByRole("img");
20
- expect(card.getAttribute("src")).toEqual("/testImage");
21
- });
22
-
23
- test("OnClick function is called", () => {
24
- const onClick = jest.fn();
25
- const { getByText } = render(<DxcCard onClick={onClick}>test-card</DxcCard>);
26
- const card = getByText("test-card");
27
- fireEvent.click(card);
28
- expect(onClick).toHaveBeenCalled();
29
- });
30
- });
@@ -1,45 +0,0 @@
1
- import React from "react";
2
- import { render, fireEvent } from "@testing-library/react";
3
-
4
- import DxcCheckbox from "../src/checkbox/Checkbox";
5
-
6
- describe("Checkbox component tests", () => {
7
- test("Checkbox renders with correct text", () => {
8
- const { getByText } = render(<DxcCheckbox label="Checkbox" />);
9
-
10
- expect(getByText("Checkbox")).toBeTruthy();
11
- });
12
-
13
- test("Calls correct function on click", () => {
14
- const onChange = jest.fn();
15
- const { getByText } = render(<DxcCheckbox label="Checkbox" onChange={onChange} />);
16
-
17
- fireEvent.click(getByText("Checkbox"));
18
- expect(onChange).toHaveBeenCalled();
19
- });
20
-
21
- test("Uncontrolled checkbox", () => {
22
- const onChange = jest.fn();
23
- const component = render(<DxcCheckbox label="Checkbox" onChange={onChange} />);
24
- const visibleCheckbox = component.getByText("Checkbox");
25
- const input = component.getByRole("checkbox");
26
- expect(input.checked).toBe(false);
27
- fireEvent.click(visibleCheckbox);
28
- expect(onChange).toHaveBeenCalled();
29
- expect(onChange).toHaveBeenCalledWith(true);
30
- expect(input.checked).toBe(true);
31
- });
32
-
33
- test("Controlled checkbox", () => {
34
- const onChange = jest.fn();
35
- const component = render(<DxcCheckbox label="Checkbox" checked={false} onChange={onChange} />);
36
-
37
- const input = component.getByRole("checkbox");
38
- const visibleCheckbox = component.getByText("Checkbox");
39
-
40
- fireEvent.click(visibleCheckbox);
41
- expect(onChange).toHaveBeenCalled();
42
- expect(onChange).toHaveBeenCalledWith(true);
43
- expect(input.checked).toBe(false);
44
- });
45
- });
package/test/Chip.test.js DELETED
@@ -1,25 +0,0 @@
1
- import React from "react";
2
- import { render, fireEvent } from "@testing-library/react";
3
- import DxcChip from "../src/chip/Chip";
4
- import icon from "../../app/src/images/invision.svg";
5
-
6
- describe("Chip component tests", () => {
7
- test("Chip renders with correct text", () => {
8
- const { getByText } = render(<DxcChip label="Chip" />);
9
- expect(getByText("Chip")).toBeTruthy();
10
- });
11
- test("Calls correct function when clicking on prefix icon", () => {
12
- const onClick = jest.fn();
13
- const { getByText, getByRole } = render(<DxcChip label="Chip" prefixIconSrc={icon} onClickPrefix={onClick} />);
14
- expect(getByText("Chip")).toBeTruthy();
15
- fireEvent.click(getByRole("img"));
16
- expect(onClick).toHaveBeenCalled();
17
- });
18
- test("Calls correct function when clicking on suffix icon", () => {
19
- const onClick = jest.fn();
20
- const { getByText, getByRole } = render(<DxcChip label="Chip" suffixIconSrc={icon} onClickSuffix={onClick} />);
21
- expect(getByText("Chip")).toBeTruthy();
22
- fireEvent.click(getByRole("img"));
23
- expect(onClick).toHaveBeenCalled();
24
- });
25
- });