@dxc-technology/halstack-react 0.0.0-e4ccd42 → 0.0.0-e690193

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 (368) hide show
  1. package/README.md +1 -2
  2. package/dist/index.d.mts +3923 -0
  3. package/dist/index.d.ts +3923 -0
  4. package/dist/index.js +14133 -0
  5. package/dist/index.mjs +14045 -0
  6. package/package.json +83 -67
  7. package/BackgroundColorContext.d.ts +0 -1
  8. package/BackgroundColorContext.js +0 -30
  9. package/HalstackContext.d.ts +0 -1249
  10. package/HalstackContext.js +0 -310
  11. package/accordion/Accordion.d.ts +0 -4
  12. package/accordion/Accordion.js +0 -182
  13. package/accordion/Accordion.stories.tsx +0 -283
  14. package/accordion/Accordion.test.js +0 -56
  15. package/accordion/types.d.ts +0 -57
  16. package/accordion/types.js +0 -5
  17. package/accordion-group/AccordionGroup.d.ts +0 -8
  18. package/accordion-group/AccordionGroup.js +0 -101
  19. package/accordion-group/AccordionGroup.stories.tsx +0 -252
  20. package/accordion-group/AccordionGroup.test.js +0 -98
  21. package/accordion-group/AccordionGroupAccordion.d.ts +0 -4
  22. package/accordion-group/AccordionGroupAccordion.js +0 -31
  23. package/accordion-group/types.d.ts +0 -67
  24. package/accordion-group/types.js +0 -5
  25. package/action-icon/ActionIcon.d.ts +0 -4
  26. package/action-icon/ActionIcon.js +0 -47
  27. package/action-icon/ActionIcon.stories.tsx +0 -41
  28. package/action-icon/ActionIcon.test.js +0 -64
  29. package/action-icon/types.d.ts +0 -26
  30. package/action-icon/types.js +0 -5
  31. package/alert/Alert.d.ts +0 -4
  32. package/alert/Alert.js +0 -254
  33. package/alert/Alert.stories.tsx +0 -198
  34. package/alert/Alert.test.js +0 -75
  35. package/alert/types.d.ts +0 -49
  36. package/alert/types.js +0 -5
  37. package/badge/Badge.d.ts +0 -4
  38. package/badge/Badge.js +0 -159
  39. package/badge/Badge.stories.tsx +0 -210
  40. package/badge/Badge.test.js +0 -30
  41. package/badge/types.d.ts +0 -54
  42. package/badge/types.js +0 -5
  43. package/bleed/Bleed.d.ts +0 -3
  44. package/bleed/Bleed.js +0 -43
  45. package/bleed/Bleed.stories.tsx +0 -342
  46. package/bleed/types.d.ts +0 -37
  47. package/bleed/types.js +0 -5
  48. package/box/Box.d.ts +0 -4
  49. package/box/Box.js +0 -75
  50. package/box/Box.stories.tsx +0 -119
  51. package/box/Box.test.js +0 -13
  52. package/box/types.d.ts +0 -32
  53. package/box/types.js +0 -5
  54. package/bulleted-list/BulletedList.d.ts +0 -7
  55. package/bulleted-list/BulletedList.js +0 -89
  56. package/bulleted-list/BulletedList.stories.tsx +0 -115
  57. package/bulleted-list/types.d.ts +0 -38
  58. package/bulleted-list/types.js +0 -5
  59. package/button/Button.d.ts +0 -4
  60. package/button/Button.js +0 -120
  61. package/button/Button.stories.tsx +0 -344
  62. package/button/Button.test.js +0 -38
  63. package/button/types.d.ts +0 -57
  64. package/button/types.js +0 -5
  65. package/card/Card.d.ts +0 -4
  66. package/card/Card.js +0 -120
  67. package/card/Card.stories.tsx +0 -171
  68. package/card/Card.test.js +0 -39
  69. package/card/types.d.ts +0 -62
  70. package/card/types.js +0 -5
  71. package/checkbox/Checkbox.d.ts +0 -4
  72. package/checkbox/Checkbox.js +0 -215
  73. package/checkbox/Checkbox.stories.tsx +0 -222
  74. package/checkbox/Checkbox.test.js +0 -199
  75. package/checkbox/types.d.ts +0 -72
  76. package/checkbox/types.js +0 -5
  77. package/chip/Chip.d.ts +0 -4
  78. package/chip/Chip.js +0 -121
  79. package/chip/Chip.stories.tsx +0 -214
  80. package/chip/Chip.test.js +0 -41
  81. package/chip/types.d.ts +0 -45
  82. package/chip/types.js +0 -5
  83. package/common/OpenSans.css +0 -69
  84. package/common/coreTokens.d.ts +0 -237
  85. package/common/coreTokens.js +0 -184
  86. package/common/fonts/OpenSans-Bold.ttf +0 -0
  87. package/common/fonts/OpenSans-BoldItalic.ttf +0 -0
  88. package/common/fonts/OpenSans-ExtraBold.ttf +0 -0
  89. package/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  90. package/common/fonts/OpenSans-Italic.ttf +0 -0
  91. package/common/fonts/OpenSans-Light.ttf +0 -0
  92. package/common/fonts/OpenSans-LightItalic.ttf +0 -0
  93. package/common/fonts/OpenSans-Regular.ttf +0 -0
  94. package/common/fonts/OpenSans-SemiBold.ttf +0 -0
  95. package/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  96. package/common/utils.d.ts +0 -1
  97. package/common/utils.js +0 -16
  98. package/common/variables.d.ts +0 -1395
  99. package/common/variables.js +0 -1267
  100. package/container/Container.d.ts +0 -4
  101. package/container/Container.js +0 -194
  102. package/container/Container.stories.tsx +0 -214
  103. package/container/types.d.ts +0 -74
  104. package/container/types.js +0 -5
  105. package/date-input/Calendar.d.ts +0 -4
  106. package/date-input/Calendar.js +0 -214
  107. package/date-input/DateInput.d.ts +0 -4
  108. package/date-input/DateInput.js +0 -223
  109. package/date-input/DateInput.stories.tsx +0 -285
  110. package/date-input/DateInput.test.js +0 -808
  111. package/date-input/DatePicker.d.ts +0 -4
  112. package/date-input/DatePicker.js +0 -115
  113. package/date-input/Icons.d.ts +0 -6
  114. package/date-input/Icons.js +0 -58
  115. package/date-input/YearPicker.d.ts +0 -4
  116. package/date-input/YearPicker.js +0 -100
  117. package/date-input/types.d.ts +0 -164
  118. package/date-input/types.js +0 -5
  119. package/dialog/Dialog.d.ts +0 -4
  120. package/dialog/Dialog.js +0 -104
  121. package/dialog/Dialog.stories.tsx +0 -365
  122. package/dialog/Dialog.test.js +0 -307
  123. package/dialog/types.d.ts +0 -36
  124. package/dialog/types.js +0 -5
  125. package/dropdown/Dropdown.d.ts +0 -4
  126. package/dropdown/Dropdown.js +0 -336
  127. package/dropdown/Dropdown.stories.tsx +0 -438
  128. package/dropdown/Dropdown.test.js +0 -599
  129. package/dropdown/DropdownMenu.d.ts +0 -4
  130. package/dropdown/DropdownMenu.js +0 -63
  131. package/dropdown/DropdownMenuItem.d.ts +0 -4
  132. package/dropdown/DropdownMenuItem.js +0 -67
  133. package/dropdown/types.d.ts +0 -98
  134. package/dropdown/types.js +0 -5
  135. package/file-input/FileInput.d.ts +0 -4
  136. package/file-input/FileInput.js +0 -479
  137. package/file-input/FileInput.stories.tsx +0 -618
  138. package/file-input/FileInput.test.js +0 -459
  139. package/file-input/FileItem.d.ts +0 -4
  140. package/file-input/FileItem.js +0 -135
  141. package/file-input/types.d.ts +0 -129
  142. package/file-input/types.js +0 -5
  143. package/flex/Flex.d.ts +0 -4
  144. package/flex/Flex.js +0 -57
  145. package/flex/Flex.stories.tsx +0 -112
  146. package/flex/types.d.ts +0 -97
  147. package/flex/types.js +0 -5
  148. package/footer/Footer.d.ts +0 -4
  149. package/footer/Footer.js +0 -138
  150. package/footer/Footer.stories.tsx +0 -171
  151. package/footer/Footer.test.js +0 -85
  152. package/footer/Icons.d.ts +0 -3
  153. package/footer/Icons.js +0 -136
  154. package/footer/types.d.ts +0 -64
  155. package/footer/types.js +0 -5
  156. package/grid/Grid.d.ts +0 -7
  157. package/grid/Grid.js +0 -76
  158. package/grid/Grid.stories.tsx +0 -219
  159. package/grid/types.d.ts +0 -115
  160. package/grid/types.js +0 -5
  161. package/header/Header.d.ts +0 -8
  162. package/header/Header.js +0 -220
  163. package/header/Header.stories.tsx +0 -251
  164. package/header/Header.test.js +0 -66
  165. package/header/Icons.d.ts +0 -2
  166. package/header/Icons.js +0 -29
  167. package/header/types.d.ts +0 -33
  168. package/header/types.js +0 -5
  169. package/heading/Heading.d.ts +0 -4
  170. package/heading/Heading.js +0 -137
  171. package/heading/Heading.stories.tsx +0 -54
  172. package/heading/Heading.test.js +0 -169
  173. package/heading/types.d.ts +0 -33
  174. package/heading/types.js +0 -5
  175. package/image/Image.d.ts +0 -4
  176. package/image/Image.js +0 -70
  177. package/image/Image.stories.tsx +0 -129
  178. package/image/types.d.ts +0 -72
  179. package/image/types.js +0 -5
  180. package/inset/Inset.d.ts +0 -3
  181. package/inset/Inset.js +0 -43
  182. package/inset/Inset.stories.tsx +0 -230
  183. package/inset/types.d.ts +0 -37
  184. package/inset/types.js +0 -5
  185. package/layout/ApplicationLayout.d.ts +0 -20
  186. package/layout/ApplicationLayout.js +0 -134
  187. package/layout/ApplicationLayout.stories.tsx +0 -162
  188. package/layout/Icons.d.ts +0 -8
  189. package/layout/Icons.js +0 -58
  190. package/layout/SidenavContext.d.ts +0 -5
  191. package/layout/SidenavContext.js +0 -13
  192. package/layout/types.d.ts +0 -41
  193. package/layout/types.js +0 -5
  194. package/link/Link.d.ts +0 -4
  195. package/link/Link.js +0 -115
  196. package/link/Link.stories.tsx +0 -253
  197. package/link/Link.test.js +0 -63
  198. package/link/types.d.ts +0 -54
  199. package/link/types.js +0 -5
  200. package/main.d.ts +0 -47
  201. package/main.js +0 -343
  202. package/nav-tabs/NavTabs.d.ts +0 -8
  203. package/nav-tabs/NavTabs.js +0 -93
  204. package/nav-tabs/NavTabs.stories.tsx +0 -276
  205. package/nav-tabs/NavTabs.test.js +0 -76
  206. package/nav-tabs/Tab.d.ts +0 -4
  207. package/nav-tabs/Tab.js +0 -118
  208. package/nav-tabs/types.d.ts +0 -52
  209. package/nav-tabs/types.js +0 -5
  210. package/number-input/NumberInput.d.ts +0 -11
  211. package/number-input/NumberInput.js +0 -86
  212. package/number-input/NumberInput.stories.tsx +0 -131
  213. package/number-input/NumberInput.test.js +0 -989
  214. package/number-input/types.d.ts +0 -130
  215. package/number-input/types.js +0 -5
  216. package/paginator/Icons.d.ts +0 -5
  217. package/paginator/Icons.js +0 -40
  218. package/paginator/Paginator.d.ts +0 -4
  219. package/paginator/Paginator.js +0 -135
  220. package/paginator/Paginator.stories.tsx +0 -87
  221. package/paginator/Paginator.test.js +0 -335
  222. package/paginator/types.d.ts +0 -38
  223. package/paginator/types.js +0 -5
  224. package/paragraph/Paragraph.d.ts +0 -5
  225. package/paragraph/Paragraph.js +0 -22
  226. package/paragraph/Paragraph.stories.tsx +0 -27
  227. package/password-input/Icons.d.ts +0 -6
  228. package/password-input/Icons.js +0 -35
  229. package/password-input/PasswordInput.d.ts +0 -4
  230. package/password-input/PasswordInput.js +0 -97
  231. package/password-input/PasswordInput.stories.tsx +0 -99
  232. package/password-input/PasswordInput.test.js +0 -198
  233. package/password-input/types.d.ts +0 -111
  234. package/password-input/types.js +0 -5
  235. package/progress-bar/ProgressBar.d.ts +0 -4
  236. package/progress-bar/ProgressBar.js +0 -144
  237. package/progress-bar/ProgressBar.stories.tsx +0 -93
  238. package/progress-bar/ProgressBar.test.js +0 -93
  239. package/progress-bar/types.d.ts +0 -37
  240. package/progress-bar/types.js +0 -5
  241. package/quick-nav/QuickNav.d.ts +0 -4
  242. package/quick-nav/QuickNav.js +0 -94
  243. package/quick-nav/QuickNav.stories.tsx +0 -356
  244. package/quick-nav/types.d.ts +0 -21
  245. package/quick-nav/types.js +0 -5
  246. package/radio-group/Radio.d.ts +0 -4
  247. package/radio-group/Radio.js +0 -124
  248. package/radio-group/RadioGroup.d.ts +0 -4
  249. package/radio-group/RadioGroup.js +0 -235
  250. package/radio-group/RadioGroup.stories.tsx +0 -214
  251. package/radio-group/RadioGroup.test.js +0 -756
  252. package/radio-group/types.d.ts +0 -114
  253. package/radio-group/types.js +0 -5
  254. package/resultset-table/Icons.d.ts +0 -7
  255. package/resultset-table/Icons.js +0 -47
  256. package/resultset-table/ResultsetTable.d.ts +0 -7
  257. package/resultset-table/ResultsetTable.js +0 -166
  258. package/resultset-table/ResultsetTable.stories.tsx +0 -397
  259. package/resultset-table/ResultsetTable.test.js +0 -371
  260. package/resultset-table/types.d.ts +0 -73
  261. package/resultset-table/types.js +0 -5
  262. package/select/Icons.d.ts +0 -10
  263. package/select/Icons.js +0 -89
  264. package/select/Listbox.d.ts +0 -4
  265. package/select/Listbox.js +0 -143
  266. package/select/Option.d.ts +0 -4
  267. package/select/Option.js +0 -87
  268. package/select/Select.d.ts +0 -4
  269. package/select/Select.js +0 -590
  270. package/select/Select.stories.tsx +0 -971
  271. package/select/Select.test.js +0 -2370
  272. package/select/types.d.ts +0 -209
  273. package/select/types.js +0 -5
  274. package/sidenav/Icons.d.ts +0 -7
  275. package/sidenav/Icons.js +0 -47
  276. package/sidenav/Sidenav.d.ts +0 -10
  277. package/sidenav/Sidenav.js +0 -196
  278. package/sidenav/Sidenav.stories.tsx +0 -282
  279. package/sidenav/Sidenav.test.js +0 -37
  280. package/sidenav/types.d.ts +0 -76
  281. package/sidenav/types.js +0 -5
  282. package/slider/Slider.d.ts +0 -4
  283. package/slider/Slider.js +0 -285
  284. package/slider/Slider.test.js +0 -254
  285. package/slider/types.d.ts +0 -86
  286. package/slider/types.js +0 -5
  287. package/spinner/Spinner.d.ts +0 -4
  288. package/spinner/Spinner.js +0 -206
  289. package/spinner/Spinner.stories.tsx +0 -129
  290. package/spinner/Spinner.test.js +0 -55
  291. package/spinner/types.d.ts +0 -32
  292. package/spinner/types.js +0 -5
  293. package/status-light/StatusLight.d.ts +0 -4
  294. package/status-light/StatusLight.js +0 -51
  295. package/status-light/StatusLight.stories.tsx +0 -74
  296. package/status-light/StatusLight.test.js +0 -25
  297. package/status-light/types.d.ts +0 -17
  298. package/status-light/types.js +0 -5
  299. package/switch/Switch.d.ts +0 -4
  300. package/switch/Switch.js +0 -214
  301. package/switch/Switch.stories.tsx +0 -137
  302. package/switch/Switch.test.js +0 -180
  303. package/switch/types.d.ts +0 -66
  304. package/switch/types.js +0 -5
  305. package/table/DropdownTheme.js +0 -62
  306. package/table/Table.d.ts +0 -8
  307. package/table/Table.js +0 -170
  308. package/table/Table.stories.tsx +0 -658
  309. package/table/Table.test.js +0 -113
  310. package/table/types.d.ts +0 -63
  311. package/table/types.js +0 -5
  312. package/tabs/Tab.d.ts +0 -4
  313. package/tabs/Tab.js +0 -116
  314. package/tabs/Tabs.d.ts +0 -4
  315. package/tabs/Tabs.js +0 -384
  316. package/tabs/Tabs.stories.tsx +0 -226
  317. package/tabs/Tabs.test.js +0 -294
  318. package/tabs/types.d.ts +0 -92
  319. package/tabs/types.js +0 -5
  320. package/tag/Tag.d.ts +0 -4
  321. package/tag/Tag.js +0 -151
  322. package/tag/Tag.stories.tsx +0 -155
  323. package/tag/Tag.test.js +0 -49
  324. package/tag/types.d.ts +0 -69
  325. package/tag/types.js +0 -5
  326. package/text-input/Icons.d.ts +0 -8
  327. package/text-input/Icons.js +0 -56
  328. package/text-input/Suggestion.d.ts +0 -4
  329. package/text-input/Suggestion.js +0 -67
  330. package/text-input/Suggestions.d.ts +0 -4
  331. package/text-input/Suggestions.js +0 -84
  332. package/text-input/TextInput.d.ts +0 -4
  333. package/text-input/TextInput.js +0 -565
  334. package/text-input/TextInput.stories.tsx +0 -465
  335. package/text-input/TextInput.test.js +0 -1756
  336. package/text-input/types.d.ts +0 -205
  337. package/text-input/types.js +0 -5
  338. package/textarea/Textarea.d.ts +0 -4
  339. package/textarea/Textarea.js +0 -234
  340. package/textarea/Textarea.stories.tsx +0 -174
  341. package/textarea/Textarea.test.js +0 -406
  342. package/textarea/types.d.ts +0 -141
  343. package/textarea/types.js +0 -5
  344. package/toggle-group/ToggleGroup.d.ts +0 -4
  345. package/toggle-group/ToggleGroup.js +0 -201
  346. package/toggle-group/ToggleGroup.stories.tsx +0 -218
  347. package/toggle-group/ToggleGroup.test.js +0 -137
  348. package/toggle-group/types.d.ts +0 -114
  349. package/toggle-group/types.js +0 -5
  350. package/typography/Typography.d.ts +0 -4
  351. package/typography/Typography.js +0 -23
  352. package/typography/Typography.stories.tsx +0 -198
  353. package/typography/types.d.ts +0 -18
  354. package/typography/types.js +0 -5
  355. package/useTheme.d.ts +0 -1148
  356. package/useTheme.js +0 -15
  357. package/useTranslatedLabels.d.ts +0 -85
  358. package/useTranslatedLabels.js +0 -14
  359. package/utils/BaseTypography.d.ts +0 -21
  360. package/utils/BaseTypography.js +0 -94
  361. package/utils/FocusLock.d.ts +0 -13
  362. package/utils/FocusLock.js +0 -124
  363. package/wizard/Wizard.d.ts +0 -4
  364. package/wizard/Wizard.js +0 -250
  365. package/wizard/Wizard.stories.tsx +0 -253
  366. package/wizard/Wizard.test.js +0 -114
  367. package/wizard/types.d.ts +0 -64
  368. package/wizard/types.js +0 -5
@@ -1,171 +0,0 @@
1
- import React from "react";
2
- import Title from "../../.storybook/components/Title";
3
- import ExampleContainer from "../../.storybook/components/ExampleContainer";
4
- import DxcCard from "./Card";
5
- import { userEvent, within } from "@storybook/testing-library";
6
-
7
- export default {
8
- title: "Card",
9
- component: DxcCard,
10
- };
11
-
12
- const Card = () => (
13
- <>
14
- <Title title="Default" theme="light" level={4} />
15
- <ExampleContainer>
16
- <DxcCard>Default</DxcCard>
17
- </ExampleContainer>
18
- <Title title="Not outlined" theme="light" level={4} />
19
- <ExampleContainer>
20
- <DxcCard outlined={false}>Not outlined</DxcCard>
21
- </ExampleContainer>
22
- <Title title="Default with link" theme="light" level={4} />
23
- <ExampleContainer>
24
- <DxcCard linkHref="https://www.dxc.com">Default with link</DxcCard>
25
- </ExampleContainer>
26
- <Title title="Focused default with link" theme="light" level={4} />
27
- <ExampleContainer>
28
- <DxcCard linkHref="https://www.dxc.com">Focused default with link</DxcCard>
29
- </ExampleContainer>
30
- <Title title="Hovered default with link" theme="light" level={4} />
31
- <ExampleContainer>
32
- <DxcCard linkHref="https://www.dxc.com">Hovered default with link</DxcCard>
33
- </ExampleContainer>
34
- <Title title="Default with action" theme="light" level={4} />
35
- <ExampleContainer>
36
- <DxcCard onClick={() => {}}>Default with action</DxcCard>
37
- </ExampleContainer>
38
- <Title title="Default with image" theme="light" level={4} />
39
- <ExampleContainer>
40
- <DxcCard imageSrc="https://picsum.photos/id/1022/200/300">Default</DxcCard>
41
- </ExampleContainer>
42
- <Title title="Default image with background color" theme="light" level={4} />
43
- <ExampleContainer>
44
- <DxcCard imageSrc="https://picsum.photos/id/1022/200/300" imageBgColor="yellow">
45
- Background color
46
- </DxcCard>
47
- </ExampleContainer>
48
- <Title title="Default image with position after" theme="light" level={4} />
49
- <ExampleContainer>
50
- <DxcCard imageSrc="https://picsum.photos/id/1022/200/300" imagePosition="after">
51
- Position after
52
- </DxcCard>
53
- </ExampleContainer>
54
- <Title title="Image cover" theme="light" level={4} />
55
- <ExampleContainer>
56
- <DxcCard imageSrc="https://picsum.photos/id/1022/200/300" imageCover>
57
- Image cover
58
- </DxcCard>
59
- </ExampleContainer>
60
- <Title title="Image cover with position after" theme="light" level={4} />
61
- <ExampleContainer>
62
- <DxcCard imageSrc="https://picsum.photos/id/1022/200/300" imageCover imagePosition="after">
63
- Image cover with position after
64
- </DxcCard>
65
- </ExampleContainer>
66
- <Title title="Image padding" theme="light" level={2} />
67
- <ExampleContainer>
68
- <Title title="Xxsmall" theme="light" level={4} />
69
- <DxcCard imageSrc="https://picsum.photos/id/1022/200/300" imagePadding="xxsmall" imageCover>
70
- Xxsmall
71
- </DxcCard>
72
- </ExampleContainer>
73
- <ExampleContainer>
74
- <Title title="Xsmall" theme="light" level={4} />
75
- <DxcCard imageSrc="https://picsum.photos/id/1022/200/300" imagePadding="xsmall" imageCover>
76
- Xsmall
77
- </DxcCard>
78
- </ExampleContainer>
79
- <ExampleContainer>
80
- <Title title="Small" theme="light" level={4} />
81
- <DxcCard imageSrc="https://picsum.photos/id/1022/200/300" imagePadding="small" imageCover>
82
- Small
83
- </DxcCard>
84
- </ExampleContainer>
85
- <ExampleContainer>
86
- <Title title="Medium" theme="light" level={4} />
87
- <DxcCard imageSrc="https://picsum.photos/id/1022/200/300" imagePadding="medium" imageCover>
88
- Medium
89
- </DxcCard>
90
- </ExampleContainer>
91
- <ExampleContainer>
92
- <Title title="Large" theme="light" level={4} />
93
- <DxcCard imageSrc="https://picsum.photos/id/1022/200/300" imagePadding="large" imageCover>
94
- Large
95
- </DxcCard>
96
- </ExampleContainer>
97
- <ExampleContainer>
98
- <Title title="Xlarge" theme="light" level={4} />
99
- <DxcCard imageSrc="https://picsum.photos/id/1022/200/300" imagePadding="xlarge" imageCover>
100
- Xlarge
101
- </DxcCard>
102
- </ExampleContainer>
103
- <ExampleContainer>
104
- <Title title="Xxlarge" theme="light" level={4} />
105
- <DxcCard imageSrc="https://picsum.photos/id/1022/200/300" imagePadding="xxlarge" imageCover>
106
- Xxlarge
107
- </DxcCard>
108
- </ExampleContainer>
109
- <Title title="Margin" theme="light" level={2} />
110
- <ExampleContainer>
111
- <Title title="Xxsmall" theme="light" level={4} />
112
- <DxcCard margin="xxsmall">Xxsmall</DxcCard>
113
- </ExampleContainer>
114
- <ExampleContainer>
115
- <Title title="Xsmall" theme="light" level={4} />
116
- <DxcCard margin="xsmall">Xsmall</DxcCard>
117
- </ExampleContainer>
118
- <ExampleContainer>
119
- <Title title="Small" theme="light" level={4} />
120
- <DxcCard margin="small">Small</DxcCard>
121
- </ExampleContainer>
122
- <ExampleContainer>
123
- <Title title="Medium" theme="light" level={4} />
124
- <DxcCard margin="medium">Medium</DxcCard>
125
- </ExampleContainer>
126
- <ExampleContainer>
127
- <Title title="Large" theme="light" level={4} />
128
- <DxcCard margin="large">Large</DxcCard>
129
- </ExampleContainer>
130
- <ExampleContainer>
131
- <Title title="Xlarge" theme="light" level={4} />
132
- <DxcCard margin="xlarge">Xlarge</DxcCard>
133
- </ExampleContainer>
134
- <ExampleContainer>
135
- <Title title="Xxlarge" theme="light" level={4} />
136
- <DxcCard margin="xxlarge">Xxlarge</DxcCard>
137
- </ExampleContainer>
138
- </>
139
- );
140
-
141
- const actionCard = () => (
142
- <>
143
- <ExampleContainer>
144
- <Title title="Focused default with action" theme="light" level={4} />
145
- <DxcCard onClick={() => {}}>Focused default with action</DxcCard>
146
- </ExampleContainer>
147
- <ExampleContainer expanded>
148
- <Title title="Hovered default with action" theme="light" level={4} />
149
- <DxcCard onClick={() => {}}>Hovered default with action</DxcCard>
150
- </ExampleContainer>
151
- </>
152
- );
153
-
154
- const linkStates = async (focusCard, hoverCard) => {
155
- await focusCard.focus();
156
- await userEvent.hover(hoverCard);
157
- };
158
-
159
- export const ActionCardStates = actionCard.bind({});
160
- ActionCardStates.play = async ({ canvasElement }) => {
161
- const canvas = within(canvasElement);
162
- await userEvent.tab();
163
- await userEvent.hover(canvas.getAllByText("Hovered default with action")[1]);
164
- };
165
-
166
- export const Chromatic = Card.bind({});
167
- Chromatic.play = async ({ canvasElement }) => {
168
- const canvas = within(canvasElement);
169
- const linkCards = canvas.getAllByRole("link");
170
- await linkStates(linkCards[1], linkCards[2]);
171
- };
package/card/Card.test.js DELETED
@@ -1,39 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
- var _react = _interopRequireDefault(require("react"));
5
- var _react2 = require("@testing-library/react");
6
- var _Card = _interopRequireDefault(require("./Card.tsx"));
7
- describe("Card component tests", function () {
8
- test("Card renders with correct content", function () {
9
- var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Card["default"], null, "test-card")),
10
- getByText = _render.getByText;
11
- expect(getByText("test-card")).toBeTruthy();
12
- });
13
- test("Card renders with correct href", function () {
14
- var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Card["default"], {
15
- linkHref: "/testPage"
16
- }, "test-card")),
17
- getByRole = _render2.getByRole;
18
- var card = getByRole("link");
19
- expect(card.getAttribute("href")).toEqual("/testPage");
20
- });
21
- test("Card renders with correct image", function () {
22
- var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Card["default"], {
23
- imageSrc: "/testImage"
24
- }, "test-card")),
25
- getByRole = _render3.getByRole;
26
- var card = getByRole("img");
27
- expect(card.getAttribute("src")).toEqual("/testImage");
28
- });
29
- test("OnClick function is called", function () {
30
- var onClick = jest.fn();
31
- var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Card["default"], {
32
- onClick: onClick
33
- }, "test-card")),
34
- getByText = _render4.getByText;
35
- var card = getByText("test-card");
36
- _react2.fireEvent.click(card);
37
- expect(onClick).toHaveBeenCalled();
38
- });
39
- });
package/card/types.d.ts DELETED
@@ -1,62 +0,0 @@
1
- /// <reference types="react" />
2
- type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
- type Size = {
4
- top?: Space;
5
- bottom?: Space;
6
- left?: Space;
7
- right?: Space;
8
- };
9
- type Props = {
10
- /**
11
- * URL of the image that will be placed in the card component.
12
- * In case of omission, the image container will not appear and
13
- * the content will occupy its space.
14
- */
15
- imageSrc?: string;
16
- /**
17
- * Color of the image background.
18
- */
19
- imageBgColor?: string;
20
- /**
21
- * Size of the padding to be applied to the image section of the
22
- * component. You can pass an object with 'top', 'bottom', 'left'
23
- * and 'right' properties in order to specify different padding sizes.
24
- */
25
- imagePadding?: Space | Size;
26
- /**
27
- * Whether the image should appear in relation to the content.
28
- */
29
- imagePosition?: "before" | "after";
30
- /**
31
- * If defined, the tag will be displayed as an anchor, using this prop
32
- * as "href". Component will show some visual feedback on hover.
33
- */
34
- linkHref?: string;
35
- /**
36
- * This function will be called when the user clicks the card. Component
37
- * will show some visual feedback on hover.
38
- */
39
- onClick?: () => void;
40
- /**
41
- * Whether the image must cover the whole image area of the card.
42
- */
43
- imageCover?: boolean;
44
- /**
45
- * Size of the margin to be applied to the component ('xxsmall' | 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge' | 'xxlarge').
46
- * You can pass an object with 'top', 'bottom', 'left' and 'right' properties in order to specify different margin sizes.
47
- */
48
- margin?: Space | Size;
49
- /**
50
- * Value of the tabindex attribute applied when the component is clickable.
51
- */
52
- tabIndex?: number;
53
- /**
54
- * Determines whether or not the component should have an outline.
55
- */
56
- outlined?: boolean;
57
- /**
58
- * Custom content that will be placed inside the component.
59
- */
60
- children?: React.ReactNode;
61
- };
62
- export default Props;
package/card/types.js DELETED
@@ -1,5 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
@@ -1,4 +0,0 @@
1
- import React from "react";
2
- import CheckboxPropsType from "./types";
3
- declare const DxcCheckbox: React.ForwardRefExoticComponent<CheckboxPropsType & React.RefAttributes<HTMLDivElement>>;
4
- export default DxcCheckbox;
@@ -1,215 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
- var _typeof3 = require("@babel/runtime/helpers/typeof");
5
- Object.defineProperty(exports, "__esModule", {
6
- value: true
7
- });
8
- exports["default"] = void 0;
9
- var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
10
- var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
11
- var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
12
- var _react = _interopRequireWildcard(require("react"));
13
- var _styledComponents = _interopRequireWildcard(require("styled-components"));
14
- var _variables = require("../common/variables");
15
- var _utils = require("../common/utils");
16
- var _uuid = require("uuid");
17
- var _useTheme = _interopRequireDefault(require("../useTheme"));
18
- var _useTranslatedLabels = _interopRequireDefault(require("../useTranslatedLabels"));
19
- var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5;
20
- 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); }
21
- 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; }
22
- var checkedIcon = /*#__PURE__*/_react["default"].createElement("svg", {
23
- fill: "currentColor",
24
- focusable: "false",
25
- "aria-hidden": "true",
26
- viewBox: "0 0 24 24"
27
- }, /*#__PURE__*/_react["default"].createElement("path", {
28
- d: "M19 3H5c-1.11 0-2 .9-2 2v14c0 1.1.89 2 2 2h14c1.11 0 2-.9 2-2V5c0-1.1-.89-2-2-2zm-9 14-5-5 1.41-1.41L10 14.17l7.59-7.59L19 8l-9 9z"
29
- }));
30
- var DxcCheckbox = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
31
- var checked = _ref.checked,
32
- _ref$defaultChecked = _ref.defaultChecked,
33
- defaultChecked = _ref$defaultChecked === void 0 ? false : _ref$defaultChecked,
34
- value = _ref.value,
35
- _ref$label = _ref.label,
36
- label = _ref$label === void 0 ? "" : _ref$label,
37
- _ref$labelPosition = _ref.labelPosition,
38
- labelPosition = _ref$labelPosition === void 0 ? "before" : _ref$labelPosition,
39
- _ref$name = _ref.name,
40
- name = _ref$name === void 0 ? "" : _ref$name,
41
- _ref$disabled = _ref.disabled,
42
- disabled = _ref$disabled === void 0 ? false : _ref$disabled,
43
- _ref$optional = _ref.optional,
44
- optional = _ref$optional === void 0 ? false : _ref$optional,
45
- _ref$readOnly = _ref.readOnly,
46
- readOnly = _ref$readOnly === void 0 ? false : _ref$readOnly,
47
- onChange = _ref.onChange,
48
- margin = _ref.margin,
49
- _ref$size = _ref.size,
50
- size = _ref$size === void 0 ? "fitContent" : _ref$size,
51
- _ref$tabIndex = _ref.tabIndex,
52
- tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
53
- var _useState = (0, _react.useState)("label-checkbox-".concat((0, _uuid.v4)())),
54
- _useState2 = (0, _slicedToArray2["default"])(_useState, 1),
55
- labelId = _useState2[0];
56
- var _useState3 = (0, _react.useState)(defaultChecked),
57
- _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
58
- innerChecked = _useState4[0],
59
- setInnerChecked = _useState4[1];
60
- var checkboxRef = (0, _react.useRef)(null);
61
- var colorsTheme = (0, _useTheme["default"])();
62
- var translatedLabels = (0, _useTranslatedLabels["default"])();
63
- var handleCheckboxChange = function handleCheckboxChange() {
64
- if (!disabled && !readOnly) {
65
- var _checkboxRef$current;
66
- document.activeElement !== (checkboxRef === null || checkboxRef === void 0 ? void 0 : checkboxRef.current) && (checkboxRef === null || checkboxRef === void 0 ? void 0 : (_checkboxRef$current = checkboxRef.current) === null || _checkboxRef$current === void 0 ? void 0 : _checkboxRef$current.focus());
67
- var newChecked = checked !== null && checked !== void 0 ? checked : innerChecked;
68
- checked !== null && checked !== void 0 ? checked : setInnerChecked(function (innerChecked) {
69
- return !innerChecked;
70
- });
71
- onChange === null || onChange === void 0 ? void 0 : onChange(!newChecked);
72
- }
73
- };
74
- var handleKeyboard = function handleKeyboard(event) {
75
- switch (event.key) {
76
- case " ":
77
- event.preventDefault();
78
- handleCheckboxChange();
79
- }
80
- };
81
- return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
82
- theme: colorsTheme.checkbox
83
- }, /*#__PURE__*/_react["default"].createElement(MainContainer, {
84
- disabled: disabled,
85
- readOnly: readOnly,
86
- onClick: handleCheckboxChange,
87
- margin: margin,
88
- size: size,
89
- checked: checked !== null && checked !== void 0 ? checked : innerChecked,
90
- ref: ref
91
- }, label && /*#__PURE__*/_react["default"].createElement(LabelContainer, {
92
- id: labelId,
93
- disabled: disabled,
94
- labelPosition: labelPosition
95
- }, label, optional && " ".concat(translatedLabels.formFields.optionalLabel)), /*#__PURE__*/_react["default"].createElement(ValueInput, {
96
- type: "checkbox",
97
- checked: checked !== null && checked !== void 0 ? checked : innerChecked,
98
- name: name,
99
- "aria-hidden": "true",
100
- value: value,
101
- disabled: disabled,
102
- readOnly: true
103
- }), /*#__PURE__*/_react["default"].createElement(CheckboxContainer, null, /*#__PURE__*/_react["default"].createElement(Checkbox, {
104
- onKeyDown: handleKeyboard,
105
- role: "checkbox",
106
- tabIndex: disabled ? -1 : tabIndex,
107
- "aria-checked": checked !== null && checked !== void 0 ? checked : innerChecked,
108
- "aria-disabled": disabled,
109
- "aria-readonly": readOnly,
110
- "aria-required": !disabled && !optional,
111
- "aria-labelledby": labelId,
112
- checked: checked !== null && checked !== void 0 ? checked : innerChecked,
113
- disabled: disabled,
114
- readOnly: readOnly,
115
- ref: checkboxRef
116
- }, (checked !== null && checked !== void 0 ? checked : innerChecked) && checkedIcon))));
117
- });
118
- var sizes = {
119
- small: "120px",
120
- medium: "240px",
121
- large: "480px",
122
- fillParent: "100%",
123
- fitContent: "fit-content"
124
- };
125
- var calculateWidth = function calculateWidth(margin, size) {
126
- return size === "fillParent" ? "calc(".concat(sizes[size], " - ").concat((0, _utils.getMargin)(margin, "left"), " - ").concat((0, _utils.getMargin)(margin, "right"), ")") : sizes[size];
127
- };
128
- var getDisabledColor = function getDisabledColor(theme, element) {
129
- switch (element) {
130
- case "check":
131
- return theme.disabledCheckColor;
132
- case "background":
133
- return theme.disabledBackgroundColorChecked;
134
- case "border":
135
- return theme.disabledBorderColor;
136
- case "label":
137
- return theme.disabledFontColor;
138
- }
139
- };
140
- var getReadOnlyColor = function getReadOnlyColor(theme, element) {
141
- switch (element) {
142
- case "check":
143
- return theme.readOnlyCheckColor;
144
- case "background":
145
- return theme.readOnlyBackgroundColorChecked;
146
- case "hoverBackground":
147
- return theme.hoverReadOnlyBackgroundColorChecked;
148
- case "border":
149
- return theme.readOnlyBorderColor;
150
- case "hoverBorder":
151
- return theme.hoverReadOnlyBorderColor;
152
- }
153
- };
154
- var getEnabledColor = function getEnabledColor(theme, element) {
155
- switch (element) {
156
- case "check":
157
- return theme.checkColor;
158
- case "background":
159
- return theme.backgroundColorChecked;
160
- case "hoverBackground":
161
- return theme.hoverBackgroundColorChecked;
162
- case "border":
163
- return theme.borderColor;
164
- case "hoverBorder":
165
- return theme.hoverBorderColor;
166
- case "label":
167
- return theme.fontColor;
168
- }
169
- };
170
- var LabelContainer = _styledComponents["default"].span(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n order: ", ";\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n"])), function (props) {
171
- return props.labelPosition === "before" ? 0 : 1;
172
- }, function (props) {
173
- return props.disabled ? getDisabledColor(props.theme, "label") : getEnabledColor(props.theme, "label");
174
- }, function (props) {
175
- return props.theme.fontFamily;
176
- }, function (props) {
177
- return props.theme.fontSize;
178
- }, function (props) {
179
- return props.theme.fontWeight;
180
- });
181
- var ValueInput = _styledComponents["default"].input(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: none;\n"])));
182
- var CheckboxContainer = _styledComponents["default"].span(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n justify-content: center;\n height: 24px;\n width: 24px;\n"])));
183
- var Checkbox = _styledComponents["default"].span(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n position: relative;\n box-sizing: border-box;\n display: flex;\n align-items: center;\n justify-content: center;\n height: 18px;\n width: 18px;\n border: 2px solid\n ", ";\n border-radius: 2px;\n background-color: ", ";\n color: ", ";\n\n &:focus {\n outline: 2px solid ", ";\n outline-offset: 2px;\n }\n svg {\n position: absolute;\n width: 22px;\n height: 22px;\n }\n ", "\n"])), function (props) {
184
- return props.disabled ? getDisabledColor(props.theme, "border") : props.readOnly ? getReadOnlyColor(props.theme, "border") : getEnabledColor(props.theme, "border");
185
- }, function (props) {
186
- return props.checked ? props.disabled ? getDisabledColor(props.theme, "check") : props.readOnly ? getReadOnlyColor(props.theme, "check") : getEnabledColor(props.theme, "check") : "transparent";
187
- }, function (props) {
188
- return props.disabled ? getDisabledColor(props.theme, "background") : props.readOnly ? getReadOnlyColor(props.theme, "background") : getEnabledColor(props.theme, "background");
189
- }, function (props) {
190
- return props.theme.focusColor;
191
- }, function (props) {
192
- return props.disabled && "pointer-events: none;";
193
- });
194
- var MainContainer = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n align-items: center;\n gap: ", ";\n width: ", ";\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n cursor: ", ";\n\n &:hover ", " {\n border: 2px solid\n ", ";\n color: ", ";\n }\n"])), function (props) {
195
- return props.theme.checkLabelSpacing;
196
- }, function (props) {
197
- return calculateWidth(props.margin, props.size);
198
- }, function (props) {
199
- return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
200
- }, function (props) {
201
- return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.top ? _variables.spaces[props.margin.top] : "";
202
- }, function (props) {
203
- return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.right ? _variables.spaces[props.margin.right] : "";
204
- }, function (props) {
205
- return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.bottom ? _variables.spaces[props.margin.bottom] : "";
206
- }, function (props) {
207
- return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.left ? _variables.spaces[props.margin.left] : "";
208
- }, function (props) {
209
- return props.disabled ? "not-allowed" : props.readOnly ? "default" : "pointer";
210
- }, Checkbox, function (props) {
211
- if (!props.disabled) return props.readOnly ? getReadOnlyColor(props.theme, "hoverBorder") : getEnabledColor(props.theme, "hoverBorder");
212
- }, function (props) {
213
- if (!props.disabled) return props.readOnly ? getReadOnlyColor(props.theme, "hoverBackground") : getEnabledColor(props.theme, "hoverBackground");
214
- });
215
- var _default = exports["default"] = DxcCheckbox;