@dxc-technology/halstack-react 0.0.0-afd5470 → 0.0.0-b061aa1

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 (394) hide show
  1. package/BackgroundColorContext.js +50 -0
  2. package/ThemeContext.js +246 -0
  3. package/V3Select/V3Select.js +455 -0
  4. package/V3Select/index.d.ts +27 -0
  5. package/V3Textarea/V3Textarea.js +260 -0
  6. package/V3Textarea/index.d.ts +27 -0
  7. package/accordion/Accordion.d.ts +4 -0
  8. package/accordion/Accordion.js +258 -0
  9. package/accordion/types.d.ts +68 -0
  10. package/accordion/types.js +5 -0
  11. package/accordion-group/AccordionGroup.d.ts +7 -0
  12. package/accordion-group/AccordionGroup.js +170 -0
  13. package/accordion-group/AccordionGroup.stories.tsx +225 -0
  14. package/accordion-group/types.d.ts +72 -0
  15. package/accordion-group/types.js +5 -0
  16. package/alert/Alert.d.ts +4 -0
  17. package/alert/Alert.js +290 -0
  18. package/alert/Alert.stories.tsx +170 -0
  19. package/alert/types.d.ts +49 -0
  20. package/alert/types.js +5 -0
  21. package/badge/Badge.js +59 -0
  22. package/box/Box.d.ts +4 -0
  23. package/box/Box.js +126 -0
  24. package/box/Box.stories.tsx +132 -0
  25. package/box/types.d.ts +43 -0
  26. package/box/types.js +5 -0
  27. package/button/Button.d.ts +4 -0
  28. package/button/Button.js +179 -0
  29. package/button/Button.stories.tsx +276 -0
  30. package/button/types.d.ts +57 -0
  31. package/button/types.js +5 -0
  32. package/card/Card.d.ts +4 -0
  33. package/card/Card.js +164 -0
  34. package/card/Card.stories.tsx +201 -0
  35. package/card/ice-cream.jpg +0 -0
  36. package/card/types.d.ts +67 -0
  37. package/card/types.js +5 -0
  38. package/checkbox/Checkbox.d.ts +4 -0
  39. package/checkbox/Checkbox.js +253 -0
  40. package/checkbox/Checkbox.stories.tsx +192 -0
  41. package/checkbox/types.d.ts +60 -0
  42. package/checkbox/types.js +5 -0
  43. package/chip/Chip.d.ts +4 -0
  44. package/chip/Chip.js +199 -0
  45. package/chip/Chip.stories.tsx +121 -0
  46. package/chip/types.d.ts +53 -0
  47. package/chip/types.js +5 -0
  48. package/{dist/common → common}/OpenSans.css +0 -0
  49. package/{dist/common → common}/RequiredComponent.js +5 -19
  50. package/{dist/common → common}/fonts/OpenSans-Bold.ttf +0 -0
  51. package/{dist/common → common}/fonts/OpenSans-BoldItalic.ttf +0 -0
  52. package/{dist/common → common}/fonts/OpenSans-ExtraBold.ttf +0 -0
  53. package/{dist/common → common}/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  54. package/{dist/common → common}/fonts/OpenSans-Italic.ttf +0 -0
  55. package/{dist/common → common}/fonts/OpenSans-Light.ttf +0 -0
  56. package/{dist/common → common}/fonts/OpenSans-LightItalic.ttf +0 -0
  57. package/{dist/common → common}/fonts/OpenSans-Regular.ttf +0 -0
  58. package/{dist/common → common}/fonts/OpenSans-SemiBold.ttf +0 -0
  59. package/{dist/common → common}/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  60. package/common/utils.js +22 -0
  61. package/common/variables.js +1578 -0
  62. package/{dist/date → date}/Date.js +87 -70
  63. package/date/index.d.ts +27 -0
  64. package/date-input/DateInput.d.ts +4 -0
  65. package/date-input/DateInput.js +361 -0
  66. package/date-input/DateInput.stories.tsx +138 -0
  67. package/date-input/types.d.ts +100 -0
  68. package/date-input/types.js +5 -0
  69. package/dialog/Dialog.d.ts +4 -0
  70. package/dialog/Dialog.js +165 -0
  71. package/dialog/Dialog.stories.tsx +212 -0
  72. package/dialog/types.d.ts +43 -0
  73. package/dialog/types.js +5 -0
  74. package/dropdown/Dropdown.d.ts +4 -0
  75. package/dropdown/Dropdown.js +417 -0
  76. package/dropdown/types.d.ts +89 -0
  77. package/dropdown/types.js +5 -0
  78. package/file-input/FileInput.d.ts +4 -0
  79. package/file-input/FileInput.js +511 -0
  80. package/file-input/FileItem.d.ts +14 -0
  81. package/file-input/FileItem.js +184 -0
  82. package/file-input/types.d.ts +87 -0
  83. package/file-input/types.js +5 -0
  84. package/footer/Footer.d.ts +4 -0
  85. package/footer/Footer.js +266 -0
  86. package/footer/Footer.stories.jsx +151 -0
  87. package/footer/Icons.js +77 -0
  88. package/footer/types.d.ts +69 -0
  89. package/footer/types.js +5 -0
  90. package/header/Header.d.ts +7 -0
  91. package/header/Header.js +324 -0
  92. package/header/Header.stories.tsx +162 -0
  93. package/header/Icons.js +34 -0
  94. package/header/types.d.ts +47 -0
  95. package/header/types.js +5 -0
  96. package/heading/Heading.d.ts +4 -0
  97. package/heading/Heading.js +159 -0
  98. package/heading/Heading.stories.tsx +53 -0
  99. package/heading/types.d.ts +33 -0
  100. package/heading/types.js +5 -0
  101. package/input-text/Icons.js +22 -0
  102. package/input-text/InputText.js +611 -0
  103. package/input-text/index.d.ts +36 -0
  104. package/layout/ApplicationLayout.d.ts +10 -0
  105. package/layout/ApplicationLayout.js +224 -0
  106. package/layout/Icons.js +55 -0
  107. package/layout/types.d.ts +57 -0
  108. package/layout/types.js +5 -0
  109. package/link/Link.d.ts +3 -0
  110. package/link/Link.js +161 -0
  111. package/link/Link.stories.tsx +146 -0
  112. package/link/types.d.ts +74 -0
  113. package/link/types.js +5 -0
  114. package/main.d.ts +44 -0
  115. package/{dist/main.js → main.js} +137 -53
  116. package/number-input/NumberInput.d.ts +4 -0
  117. package/number-input/NumberInput.js +86 -0
  118. package/number-input/NumberInput.stories.tsx +115 -0
  119. package/number-input/NumberInputContext.d.ts +4 -0
  120. package/{dist/ThemeContext.js → number-input/NumberInputContext.js} +6 -2
  121. package/number-input/numberInputContextTypes.d.ts +19 -0
  122. package/number-input/numberInputContextTypes.js +5 -0
  123. package/number-input/types.d.ts +117 -0
  124. package/number-input/types.js +5 -0
  125. package/package.json +38 -23
  126. package/paginator/Icons.js +66 -0
  127. package/paginator/Paginator.d.ts +4 -0
  128. package/paginator/Paginator.js +198 -0
  129. package/paginator/Paginator.stories.tsx +63 -0
  130. package/paginator/types.d.ts +38 -0
  131. package/paginator/types.js +5 -0
  132. package/password-input/PasswordInput.d.ts +4 -0
  133. package/password-input/PasswordInput.js +164 -0
  134. package/password-input/PasswordInput.stories.tsx +131 -0
  135. package/password-input/types.d.ts +107 -0
  136. package/password-input/types.js +5 -0
  137. package/progress-bar/ProgressBar.d.ts +4 -0
  138. package/progress-bar/ProgressBar.js +170 -0
  139. package/progress-bar/ProgressBar.stories.jsx +58 -0
  140. package/progress-bar/types.d.ts +37 -0
  141. package/progress-bar/types.js +5 -0
  142. package/radio/Radio.d.ts +4 -0
  143. package/radio/Radio.js +174 -0
  144. package/radio/Radio.stories.tsx +192 -0
  145. package/radio/types.d.ts +54 -0
  146. package/radio/types.js +5 -0
  147. package/resultsetTable/ResultsetTable.d.ts +4 -0
  148. package/resultsetTable/ResultsetTable.js +251 -0
  149. package/resultsetTable/types.d.ts +67 -0
  150. package/resultsetTable/types.js +5 -0
  151. package/select/Select.js +865 -0
  152. package/select/Select.stories.tsx +572 -0
  153. package/select/index.d.ts +131 -0
  154. package/sidenav/Sidenav.d.ts +9 -0
  155. package/sidenav/Sidenav.js +136 -0
  156. package/sidenav/Sidenav.stories.tsx +165 -0
  157. package/sidenav/types.d.ts +50 -0
  158. package/sidenav/types.js +5 -0
  159. package/slider/Slider.d.ts +4 -0
  160. package/slider/Slider.js +317 -0
  161. package/slider/Slider.stories.tsx +177 -0
  162. package/slider/types.d.ts +78 -0
  163. package/slider/types.js +5 -0
  164. package/spinner/Spinner.d.ts +4 -0
  165. package/spinner/Spinner.js +250 -0
  166. package/spinner/Spinner.stories.jsx +102 -0
  167. package/spinner/types.d.ts +32 -0
  168. package/spinner/types.js +5 -0
  169. package/switch/Switch.d.ts +4 -0
  170. package/switch/Switch.js +179 -0
  171. package/switch/Switch.stories.tsx +160 -0
  172. package/switch/types.d.ts +58 -0
  173. package/switch/types.js +5 -0
  174. package/table/Table.d.ts +4 -0
  175. package/table/Table.js +118 -0
  176. package/table/Table.stories.jsx +276 -0
  177. package/table/types.d.ts +21 -0
  178. package/table/types.js +5 -0
  179. package/tabs/Tabs.d.ts +4 -0
  180. package/tabs/Tabs.js +213 -0
  181. package/tabs/Tabs.stories.tsx +121 -0
  182. package/tabs/types.d.ts +70 -0
  183. package/tabs/types.js +5 -0
  184. package/tag/Tag.d.ts +4 -0
  185. package/tag/Tag.js +193 -0
  186. package/tag/Tag.stories.tsx +145 -0
  187. package/tag/types.d.ts +60 -0
  188. package/tag/types.js +5 -0
  189. package/text-input/TextInput.d.ts +4 -0
  190. package/text-input/TextInput.js +788 -0
  191. package/text-input/TextInput.stories.tsx +456 -0
  192. package/text-input/types.d.ts +159 -0
  193. package/text-input/types.js +5 -0
  194. package/textarea/Textarea.js +316 -0
  195. package/textarea/Textarea.stories.jsx +135 -0
  196. package/textarea/index.d.ts +127 -0
  197. package/{dist/toggle → toggle}/Toggle.js +30 -67
  198. package/toggle/index.d.ts +21 -0
  199. package/toggle-group/ToggleGroup.d.ts +4 -0
  200. package/toggle-group/ToggleGroup.js +217 -0
  201. package/toggle-group/ToggleGroup.stories.tsx +178 -0
  202. package/toggle-group/types.d.ts +84 -0
  203. package/toggle-group/types.js +5 -0
  204. package/{dist/upload → upload}/Upload.js +23 -22
  205. package/upload/buttons-upload/ButtonsUpload.js +111 -0
  206. package/upload/buttons-upload/Icons.js +40 -0
  207. package/upload/dragAndDropArea/DragAndDropArea.js +225 -0
  208. package/upload/dragAndDropArea/Icons.js +39 -0
  209. package/upload/file-upload/FileToUpload.js +115 -0
  210. package/upload/file-upload/Icons.js +66 -0
  211. package/upload/files-upload/FilesToUpload.js +109 -0
  212. package/upload/index.d.ts +15 -0
  213. package/upload/transaction/Icons.js +160 -0
  214. package/upload/transaction/Transaction.js +104 -0
  215. package/upload/transactions/Transactions.js +94 -0
  216. package/useTheme.js +22 -0
  217. package/wizard/Icons.js +65 -0
  218. package/wizard/Wizard.d.ts +4 -0
  219. package/wizard/Wizard.js +231 -0
  220. package/wizard/Wizard.stories.jsx +224 -0
  221. package/wizard/types.d.ts +64 -0
  222. package/wizard/types.js +5 -0
  223. package/README.md +0 -66
  224. package/babel.config.js +0 -4
  225. package/dist/accordion/Accordion.js +0 -248
  226. package/dist/accordion/Accordion.stories.js +0 -207
  227. package/dist/accordion/readme.md +0 -96
  228. package/dist/alert/Alert.js +0 -304
  229. package/dist/alert/Alert.stories.js +0 -158
  230. package/dist/alert/close.svg +0 -4
  231. package/dist/alert/error.svg +0 -4
  232. package/dist/alert/info.svg +0 -4
  233. package/dist/alert/readme.md +0 -43
  234. package/dist/alert/success.svg +0 -4
  235. package/dist/alert/warning.svg +0 -4
  236. package/dist/box/Box.js +0 -148
  237. package/dist/button/Button.js +0 -181
  238. package/dist/button/Button.stories.js +0 -224
  239. package/dist/button/readme.md +0 -93
  240. package/dist/card/Card.js +0 -217
  241. package/dist/checkbox/Checkbox.js +0 -240
  242. package/dist/checkbox/Checkbox.stories.js +0 -144
  243. package/dist/checkbox/readme.md +0 -116
  244. package/dist/chip/Chip.js +0 -173
  245. package/dist/common/services/example-service.js +0 -10
  246. package/dist/common/services/example-service.test.js +0 -12
  247. package/dist/common/utils.js +0 -42
  248. package/dist/common/variables.js +0 -438
  249. package/dist/date/Date.stories.js +0 -205
  250. package/dist/date/calendar.svg +0 -1
  251. package/dist/date/calendar_dark.svg +0 -1
  252. package/dist/date/readme.md +0 -73
  253. package/dist/dialog/Dialog.js +0 -197
  254. package/dist/dialog/Dialog.stories.js +0 -217
  255. package/dist/dialog/readme.md +0 -32
  256. package/dist/dropdown/Dropdown.js +0 -416
  257. package/dist/dropdown/Dropdown.stories.js +0 -249
  258. package/dist/dropdown/baseline-arrow_drop_down.svg +0 -1
  259. package/dist/dropdown/baseline-arrow_drop_down_wh.svg +0 -4
  260. package/dist/dropdown/baseline-arrow_drop_up.svg +0 -1
  261. package/dist/dropdown/baseline-arrow_drop_up_wh.svg +0 -4
  262. package/dist/dropdown/readme.md +0 -69
  263. package/dist/footer/Footer.js +0 -346
  264. package/dist/footer/Footer.stories.js +0 -94
  265. package/dist/footer/dxc_logo_wht.png +0 -0
  266. package/dist/footer/readme.md +0 -41
  267. package/dist/header/Header.js +0 -360
  268. package/dist/header/Header.stories.js +0 -176
  269. package/dist/header/close_icon.svg +0 -1
  270. package/dist/header/dxc_logo_black.png +0 -0
  271. package/dist/header/dxc_logo_blk_rgb.svg +0 -6
  272. package/dist/header/dxc_logo_white.png +0 -0
  273. package/dist/header/hamb_menu_black.svg +0 -1
  274. package/dist/header/hamb_menu_white.svg +0 -1
  275. package/dist/header/readme.md +0 -33
  276. package/dist/heading/Heading.js +0 -153
  277. package/dist/input-text/InputText.js +0 -519
  278. package/dist/input-text/InputText.stories.js +0 -209
  279. package/dist/input-text/error.svg +0 -1
  280. package/dist/input-text/readme.md +0 -91
  281. package/dist/layout/ApplicationLayout.js +0 -320
  282. package/dist/layout/SideNav.js +0 -67
  283. package/dist/layout/facebook.svg +0 -45
  284. package/dist/layout/linkedin.svg +0 -50
  285. package/dist/layout/twitter.svg +0 -53
  286. package/dist/link/Link.js +0 -136
  287. package/dist/link/readme.md +0 -51
  288. package/dist/paginator/Paginator.js +0 -196
  289. package/dist/paginator/images/next.svg +0 -3
  290. package/dist/paginator/images/nextPage.svg +0 -3
  291. package/dist/paginator/images/previous.svg +0 -3
  292. package/dist/paginator/images/previousPage.svg +0 -3
  293. package/dist/paginator/readme.md +0 -50
  294. package/dist/progress-bar/ProgressBar.js +0 -185
  295. package/dist/progress-bar/ProgressBar.stories.js +0 -280
  296. package/dist/progress-bar/readme.md +0 -63
  297. package/dist/radio/Radio.js +0 -195
  298. package/dist/radio/Radio.stories.js +0 -166
  299. package/dist/radio/readme.md +0 -70
  300. package/dist/resultsetTable/ResultsetTable.js +0 -333
  301. package/dist/resultsetTable/arrow_downward-24px_wht.svg +0 -1
  302. package/dist/resultsetTable/arrow_upward-24px_wht.svg +0 -1
  303. package/dist/resultsetTable/unfold_more-24px_wht.svg +0 -1
  304. package/dist/select/Select.js +0 -451
  305. package/dist/select/Select.stories.js +0 -235
  306. package/dist/select/readme.md +0 -72
  307. package/dist/sidenav/Sidenav.js +0 -222
  308. package/dist/sidenav/arrow_icon.svg +0 -3
  309. package/dist/slider/Slider.js +0 -258
  310. package/dist/slider/Slider.stories.js +0 -241
  311. package/dist/slider/readme.md +0 -64
  312. package/dist/spinner/Spinner.js +0 -193
  313. package/dist/spinner/Spinner.stories.js +0 -183
  314. package/dist/spinner/readme.md +0 -65
  315. package/dist/switch/Switch.js +0 -199
  316. package/dist/switch/Switch.stories.js +0 -134
  317. package/dist/switch/readme.md +0 -133
  318. package/dist/table/Table.js +0 -93
  319. package/dist/tabs/Tabs.js +0 -172
  320. package/dist/tabs/Tabs.stories.js +0 -130
  321. package/dist/tabs/readme.md +0 -78
  322. package/dist/tabs-for-sections/TabsForSections.js +0 -107
  323. package/dist/tabs-for-sections/readme.md +0 -78
  324. package/dist/tag/Tag.js +0 -234
  325. package/dist/textarea/Textarea.js +0 -227
  326. package/dist/toggle/Toggle.stories.js +0 -297
  327. package/dist/toggle/readme.md +0 -80
  328. package/dist/toggle-group/ToggleGroup.js +0 -214
  329. package/dist/toggle-group/readme.md +0 -82
  330. package/dist/upload/Upload.stories.js +0 -72
  331. package/dist/upload/buttons-upload/ButtonsUpload.js +0 -122
  332. package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
  333. package/dist/upload/buttons-upload/upload-button.svg +0 -1
  334. package/dist/upload/dragAndDropArea/DragAndDropArea.js +0 -279
  335. package/dist/upload/dragAndDropArea/upload_drop.svg +0 -4
  336. package/dist/upload/dragAndDropArea/upload_file.svg +0 -4
  337. package/dist/upload/file-upload/FileToUpload.js +0 -158
  338. package/dist/upload/file-upload/audio-icon.svg +0 -4
  339. package/dist/upload/file-upload/close.svg +0 -4
  340. package/dist/upload/file-upload/file-icon.svg +0 -4
  341. package/dist/upload/file-upload/video-icon.svg +0 -4
  342. package/dist/upload/files-upload/FilesToUpload.js +0 -123
  343. package/dist/upload/readme.md +0 -37
  344. package/dist/upload/transaction/Transaction.js +0 -155
  345. package/dist/upload/transaction/audio-icon-err.svg +0 -4
  346. package/dist/upload/transaction/audio-icon.svg +0 -4
  347. package/dist/upload/transaction/error-icon.svg +0 -4
  348. package/dist/upload/transaction/file-icon-err.svg +0 -4
  349. package/dist/upload/transaction/file-icon.svg +0 -4
  350. package/dist/upload/transaction/image-icon-err.svg +0 -4
  351. package/dist/upload/transaction/image-icon.svg +0 -4
  352. package/dist/upload/transaction/success-icon.svg +0 -4
  353. package/dist/upload/transaction/video-icon-err.svg +0 -4
  354. package/dist/upload/transaction/video-icon.svg +0 -4
  355. package/dist/upload/transactions/Transactions.js +0 -120
  356. package/dist/wizard/Wizard.js +0 -327
  357. package/dist/wizard/invalid_icon.svg +0 -6
  358. package/dist/wizard/valid_icon.svg +0 -6
  359. package/dist/wizard/validation-wrong.svg +0 -6
  360. package/test/Accordion.test.js +0 -33
  361. package/test/Alert.test.js +0 -53
  362. package/test/Box.test.js +0 -10
  363. package/test/Button.test.js +0 -18
  364. package/test/Card.test.js +0 -30
  365. package/test/Checkbox.test.js +0 -45
  366. package/test/Chip.test.js +0 -25
  367. package/test/Date.test.js +0 -393
  368. package/test/Dialog.test.js +0 -23
  369. package/test/Dropdown.test.js +0 -130
  370. package/test/Footer.test.js +0 -99
  371. package/test/Header.test.js +0 -39
  372. package/test/Heading.test.js +0 -35
  373. package/test/InputText.test.js +0 -236
  374. package/test/Link.test.js +0 -25
  375. package/test/Paginator.test.js +0 -165
  376. package/test/ProgressBar.test.js +0 -35
  377. package/test/Radio.test.js +0 -37
  378. package/test/ResultsetTable.test.js +0 -282
  379. package/test/Select.test.js +0 -191
  380. package/test/Sidenav.test.js +0 -87
  381. package/test/Slider.test.js +0 -65
  382. package/test/Spinner.test.js +0 -27
  383. package/test/Switch.test.js +0 -45
  384. package/test/Table.test.js +0 -36
  385. package/test/Tabs.test.js +0 -88
  386. package/test/TabsForSections.test.js +0 -34
  387. package/test/Tag.test.js +0 -32
  388. package/test/TextArea.test.js +0 -52
  389. package/test/Toggle.test.js +0 -43
  390. package/test/ToggleGroup.test.js +0 -81
  391. package/test/Upload.test.js +0 -60
  392. package/test/Wizard.test.js +0 -130
  393. package/test/mocks/pngMock.js +0 -1
  394. package/test/mocks/svgMock.js +0 -1
@@ -0,0 +1,192 @@
1
+ import React from "react";
2
+ import DxcRadio from "./Radio";
3
+ import { BackgroundColorProvider } from "../BackgroundColorContext";
4
+ import Title from "../../.storybook/components/Title";
5
+ import ExampleContainer from "../../.storybook/components/ExampleContainer";
6
+ import DarkContainer from "../../.storybook/components/DarkSection";
7
+ import { userEvent, within } from "@storybook/testing-library";
8
+
9
+ export default {
10
+ title: "Radio",
11
+ component: DxcRadio,
12
+ };
13
+
14
+ const Radio = () => (
15
+ <>
16
+ <>
17
+ <ExampleContainer>
18
+ <Title title="Default" theme="light" level={4} />
19
+ <DxcRadio label="Radio" />
20
+ </ExampleContainer>
21
+ <ExampleContainer>
22
+ <Title title="Focused" theme="light" level={4} />
23
+ <DxcRadio label="Focused" />
24
+ </ExampleContainer>
25
+ <ExampleContainer>
26
+ <Title title="Checked" theme="light" level={4} />
27
+ <DxcRadio label="Radio" checked />
28
+ </ExampleContainer>
29
+ <ExampleContainer>
30
+ <Title title="Required" theme="light" level={4} />
31
+ <DxcRadio label="Radio" required />
32
+ </ExampleContainer>
33
+ <ExampleContainer>
34
+ <Title title="Disabled and checked" theme="light" level={4} />
35
+ <DxcRadio label="Radio" disabled checked />
36
+ </ExampleContainer>
37
+ <ExampleContainer>
38
+ <Title title="Disabled and required" theme="light" level={4} />
39
+ <DxcRadio label="Radio" disabled required />
40
+ </ExampleContainer>
41
+ <ExampleContainer>
42
+ <Title title="Disabled, required and checked" theme="light" level={4} />
43
+ <DxcRadio label="Radio" disabled required checked />
44
+ </ExampleContainer>
45
+ <ExampleContainer>
46
+ <Title title="Label after" theme="light" level={4} />
47
+ <DxcRadio label="Radio" labelPosition="after" />
48
+ </ExampleContainer>
49
+ <ExampleContainer>
50
+ <Title title="Checked with label after" theme="light" level={4} />
51
+ <DxcRadio label="Radio" checked labelPosition="after" />
52
+ </ExampleContainer>
53
+ <ExampleContainer>
54
+ <Title title="Required with label after" theme="light" level={4} />
55
+ <DxcRadio label="Radio" required labelPosition="after" />
56
+ </ExampleContainer>
57
+ <ExampleContainer>
58
+ <Title title="Disabled and checked with label after" theme="light" level={4} />
59
+ <DxcRadio label="Radio" disabled checked labelPosition="after" />
60
+ </ExampleContainer>
61
+ <ExampleContainer>
62
+ <Title title="Disabled and required with label after" theme="light" level={4} />
63
+ <DxcRadio label="Radio" disabled required labelPosition="after" />
64
+ </ExampleContainer>
65
+ <ExampleContainer>
66
+ <Title title="Disabled, required and checked with label after" theme="light" level={4} />
67
+ <DxcRadio label="Radio" disabled required checked labelPosition="after" />
68
+ </ExampleContainer>
69
+ <ExampleContainer pseudoState="pseudo-hover">
70
+ <Title title="Hovered" theme="light" level={4} />
71
+ <DxcRadio label="Hovered" />
72
+ </ExampleContainer>
73
+ <ExampleContainer pseudoState="pseudo-hover">
74
+ <Title title="Hovered and checked" theme="light" level={4} />
75
+ <DxcRadio label="Hovered" checked />
76
+ </ExampleContainer>
77
+ </>
78
+ <BackgroundColorProvider color="#333333">
79
+ <DarkContainer>
80
+ <>
81
+ <ExampleContainer>
82
+ <Title title="Default" theme="dark" level={4} />
83
+ <DxcRadio label="Radio" />
84
+ </ExampleContainer>
85
+ <ExampleContainer>
86
+ <Title title="Checked" theme="dark" level={4} />
87
+ <DxcRadio label="Radio" checked />
88
+ </ExampleContainer>
89
+ <ExampleContainer>
90
+ <Title title="Required" theme="dark" level={4} />
91
+ <DxcRadio label="Radio" required />
92
+ </ExampleContainer>
93
+ <ExampleContainer>
94
+ <Title title="Disabled and checked" theme="dark" level={4} />
95
+ <DxcRadio label="Radio" disabled checked />
96
+ </ExampleContainer>
97
+ <ExampleContainer>
98
+ <Title title="Disabled and required" theme="dark" level={4} />
99
+ <DxcRadio label="Radio" disabled required />
100
+ </ExampleContainer>
101
+ <ExampleContainer>
102
+ <Title title="Disabled, required and checked" theme="dark" level={4} />
103
+ <DxcRadio label="Radio" disabled required checked />
104
+ </ExampleContainer>
105
+ <ExampleContainer>
106
+ <Title title="Label after" theme="dark" level={4} />
107
+ <DxcRadio label="Radio" labelPosition="after" />
108
+ </ExampleContainer>
109
+ <ExampleContainer>
110
+ <Title title="Checked with label after" theme="dark" level={4} />
111
+ <DxcRadio label="Radio" checked labelPosition="after" />
112
+ </ExampleContainer>
113
+ <ExampleContainer>
114
+ <Title title="Required with label after" theme="dark" level={4} />
115
+ <DxcRadio label="Radio" required labelPosition="after" />
116
+ </ExampleContainer>
117
+ <ExampleContainer>
118
+ <Title title="Disabled and checked with label after" theme="dark" level={4} />
119
+ <DxcRadio label="Radio" disabled checked labelPosition="after" />
120
+ </ExampleContainer>
121
+ <ExampleContainer>
122
+ <Title title="Disabled and required with label after" theme="dark" level={4} />
123
+ <DxcRadio label="Radio" disabled required labelPosition="after" />
124
+ </ExampleContainer>
125
+ <ExampleContainer>
126
+ <Title title="Disabled, required and checked with label after" theme="dark" level={4} />
127
+ <DxcRadio label="Radio" disabled required checked labelPosition="after" />
128
+ </ExampleContainer>
129
+ <ExampleContainer pseudoState="pseudo-hover">
130
+ <Title title="Hovered" theme="dark" level={4} />
131
+ <DxcRadio label="Hovered" />
132
+ </ExampleContainer>
133
+ <ExampleContainer pseudoState="pseudo-hover">
134
+ <Title title="Hovered and checked" theme="dark" level={4} />
135
+ <DxcRadio label="Hovered" checked />
136
+ </ExampleContainer>
137
+ </>
138
+ </DarkContainer>
139
+ </BackgroundColorProvider>
140
+ <Title title="Sizes" theme="light" level={2} />
141
+ <ExampleContainer>
142
+ <DxcRadio label="Small" size="small" />
143
+ </ExampleContainer>
144
+ <ExampleContainer>
145
+ <DxcRadio label="Medium" size="medium" />
146
+ </ExampleContainer>
147
+ <ExampleContainer>
148
+ <DxcRadio label="Large" size="large" />
149
+ </ExampleContainer>
150
+ <ExampleContainer>
151
+ <DxcRadio label="FitContent" size="fitContent" />
152
+ </ExampleContainer>
153
+ <ExampleContainer>
154
+ <DxcRadio label="FillParent" size="fillParent" />
155
+ </ExampleContainer>
156
+ <Title title="Margins" theme="light" level={2} />
157
+ <ExampleContainer>
158
+ <Title title="Xxsmall" theme="light" level={4} />
159
+ <DxcRadio label="Xxsmall" margin={"xxsmall"} />
160
+ </ExampleContainer>
161
+ <ExampleContainer>
162
+ <Title title="Xsmall" theme="light" level={4} />
163
+ <DxcRadio label="Xsmall" margin={"xsmall"} />
164
+ </ExampleContainer>
165
+ <ExampleContainer>
166
+ <Title title="Small" theme="light" level={4} />
167
+ <DxcRadio label="Small" margin={"small"} />
168
+ </ExampleContainer>
169
+ <ExampleContainer>
170
+ <Title title="Medium" theme="light" level={4} />
171
+ <DxcRadio label="Medium" margin={"medium"} />
172
+ </ExampleContainer>
173
+ <ExampleContainer>
174
+ <Title title="Large" theme="light" level={4} />
175
+ <DxcRadio label="Large" margin={"large"} />
176
+ </ExampleContainer>
177
+ <ExampleContainer>
178
+ <Title title="Xlarge" theme="light" level={4} />
179
+ <DxcRadio label="Xlarge" margin={"xlarge"} />
180
+ </ExampleContainer>
181
+ <ExampleContainer>
182
+ <Title title="Xxlarge" theme="light" level={4} />
183
+ <DxcRadio label="Xxlarge" margin={"xxlarge"} />
184
+ </ExampleContainer>
185
+ </>
186
+ );
187
+
188
+ export const Chromatic = Radio.bind({});
189
+ Chromatic.play = async () => {
190
+ await userEvent.tab();
191
+ await userEvent.tab();
192
+ };
@@ -0,0 +1,54 @@
1
+ declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
2
+ declare type Margin = {
3
+ top?: Space;
4
+ bottom?: Space;
5
+ left?: Space;
6
+ right?: Space;
7
+ };
8
+ declare type Props = {
9
+ /**
10
+ * If true, the radio is selected. If undefined the component will be uncontrolled
11
+ * and the value will be managed internally by the component.
12
+ */
13
+ checked?: boolean;
14
+ /**
15
+ * Will be passed to the value attribute of the html input element. When inside a
16
+ * form, this value will be only submitted if the radio is checked.
17
+ */
18
+ value?: string;
19
+ /**
20
+ * Text to be placed next to the radio.
21
+ */
22
+ label: string;
23
+ /**
24
+ * Whether the label should appear after or before the radio.
25
+ */
26
+ labelPosition?: "before" | "after";
27
+ /**
28
+ * Name attribute of the input element.
29
+ */
30
+ name?: string;
31
+ /**
32
+ * If true, the component will be disabled.
33
+ */
34
+ disabled?: boolean;
35
+ /**
36
+ * If true, the radio will change its appearence, showing that the value is required.
37
+ */
38
+ required?: boolean;
39
+ /**
40
+ * This function will be called when the user clicks the radio. The new value will
41
+ * be passed as a parameter.
42
+ */
43
+ onClick?: (val: boolean) => void;
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 | Margin;
49
+ /**
50
+ * Size of the component.
51
+ */
52
+ size?: "small" | "medium" | "large" | "fillParent" | "fitContent";
53
+ };
54
+ export default Props;
package/radio/types.js ADDED
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
@@ -0,0 +1,4 @@
1
+ /// <reference types="react" />
2
+ import ResultsetTablePropsType from "./types";
3
+ declare const DxcResultsetTable: ({ columns, rows, showGoToPage, itemsPerPage, itemsPerPageOptions, itemsPerPageFunction, margin, tabIndex, }: ResultsetTablePropsType) => JSX.Element;
4
+ export default DxcResultsetTable;
@@ -0,0 +1,251 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _typeof3 = require("@babel/runtime/helpers/typeof");
6
+
7
+ Object.defineProperty(exports, "__esModule", {
8
+ value: true
9
+ });
10
+ exports["default"] = void 0;
11
+
12
+ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
13
+
14
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
15
+
16
+ var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
17
+
18
+ var _react = _interopRequireWildcard(require("react"));
19
+
20
+ var _styledComponents = _interopRequireWildcard(require("styled-components"));
21
+
22
+ var _variables = require("../common/variables.js");
23
+
24
+ var _Table = _interopRequireDefault(require("../table/Table"));
25
+
26
+ var _Paginator = _interopRequireDefault(require("../paginator/Paginator"));
27
+
28
+ var _useTheme = _interopRequireDefault(require("../useTheme.js"));
29
+
30
+ var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8, _templateObject9;
31
+
32
+ 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); }
33
+
34
+ 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; }
35
+
36
+ function normalizeSortValue(sortValue) {
37
+ return typeof sortValue === "string" ? sortValue.toUpperCase() : sortValue;
38
+ }
39
+
40
+ function sortArray(index, order, resultset) {
41
+ return resultset.slice().sort(function (element1, element2) {
42
+ var sortValueA = normalizeSortValue(element1[index].sortValue || element1[index].displayValue);
43
+ var sortValueB = normalizeSortValue(element2[index].sortValue || element2[index].displayValue);
44
+ var comparison = 0;
45
+
46
+ if ((0, _typeof2["default"])(sortValueA) === "object") {
47
+ comparison = -1;
48
+ } else if ((0, _typeof2["default"])(sortValueB) === "object") {
49
+ comparison = 1;
50
+ } else if (sortValueA > sortValueB) {
51
+ comparison = 1;
52
+ } else if (sortValueA < sortValueB) {
53
+ comparison = -1;
54
+ }
55
+
56
+ return order === "desc" ? comparison * -1 : comparison;
57
+ });
58
+ }
59
+
60
+ var getMinItemsPerPageIndex = function getMinItemsPerPageIndex(currentPageInternal, itemsPerPage, page) {
61
+ return currentPageInternal === 1 ? 0 : itemsPerPage * (page - 1);
62
+ };
63
+
64
+ var getMaxItemsPerPageIndex = function getMaxItemsPerPageIndex(minItemsPerPageIndex, itemsPerPage, resultset, page) {
65
+ return minItemsPerPageIndex + itemsPerPage > resultset.length ? resultset.length : itemsPerPage * page - 1;
66
+ };
67
+
68
+ var ArrowUp = function ArrowUp() {
69
+ return /*#__PURE__*/_react["default"].createElement("svg", {
70
+ xmlns: "http://www.w3.org/2000/svg",
71
+ height: "24",
72
+ viewBox: "0 0 24 24",
73
+ width: "24",
74
+ fill: "currentColor"
75
+ }, /*#__PURE__*/_react["default"].createElement("path", {
76
+ d: "M0 0h24v24H0V0z",
77
+ fill: "none"
78
+ }), /*#__PURE__*/_react["default"].createElement("path", {
79
+ d: "M4 12l1.41 1.41L11 7.83V20h2V7.83l5.58 5.59L20 12l-8-8-8 8z"
80
+ }));
81
+ };
82
+
83
+ var ArrowDown = function ArrowDown() {
84
+ return /*#__PURE__*/_react["default"].createElement("svg", {
85
+ xmlns: "http://www.w3.org/2000/svg",
86
+ height: "24",
87
+ viewBox: "0 0 24 24",
88
+ width: "24",
89
+ fill: "currentColor"
90
+ }, /*#__PURE__*/_react["default"].createElement("path", {
91
+ d: "M0 0h24v24H0V0z",
92
+ fill: "none"
93
+ }), /*#__PURE__*/_react["default"].createElement("path", {
94
+ d: "M20 12l-1.41-1.41L13 16.17V4h-2v12.17l-5.58-5.59L4 12l8 8 8-8z"
95
+ }));
96
+ };
97
+
98
+ var BothArrows = function BothArrows() {
99
+ return /*#__PURE__*/_react["default"].createElement("svg", {
100
+ xmlns: "http://www.w3.org/2000/svg",
101
+ height: "24",
102
+ viewBox: "0 0 24 24",
103
+ width: "24",
104
+ fill: "currentColor"
105
+ }, /*#__PURE__*/_react["default"].createElement("path", {
106
+ d: "M0 0h24v24H0z",
107
+ fill: "none"
108
+ }), /*#__PURE__*/_react["default"].createElement("path", {
109
+ d: "M12 5.83L15.17 9l1.41-1.41L12 3 7.41 7.59 8.83 9 12 5.83zm0 12.34L8.83 15l-1.41 1.41L12 21l4.59-4.59L15.17 15 12 18.17z"
110
+ }));
111
+ };
112
+
113
+ var DxcResultsetTable = function DxcResultsetTable(_ref) {
114
+ var columns = _ref.columns,
115
+ rows = _ref.rows,
116
+ _ref$showGoToPage = _ref.showGoToPage,
117
+ showGoToPage = _ref$showGoToPage === void 0 ? true : _ref$showGoToPage,
118
+ _ref$itemsPerPage = _ref.itemsPerPage,
119
+ itemsPerPage = _ref$itemsPerPage === void 0 ? 5 : _ref$itemsPerPage,
120
+ itemsPerPageOptions = _ref.itemsPerPageOptions,
121
+ itemsPerPageFunction = _ref.itemsPerPageFunction,
122
+ margin = _ref.margin,
123
+ _ref$tabIndex = _ref.tabIndex,
124
+ tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
125
+ var colorsTheme = (0, _useTheme["default"])();
126
+
127
+ var _useState = (0, _react.useState)(1),
128
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
129
+ page = _useState2[0],
130
+ changePage = _useState2[1];
131
+
132
+ var _useState3 = (0, _react.useState)(""),
133
+ _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
134
+ sortColumnIndex = _useState4[0],
135
+ changeSortColumnIndex = _useState4[1];
136
+
137
+ var _useState5 = (0, _react.useState)("asc"),
138
+ _useState6 = (0, _slicedToArray2["default"])(_useState5, 2),
139
+ sortOrder = _useState6[0],
140
+ changeSortOrder = _useState6[1];
141
+
142
+ var minItemsPerPageIndex = (0, _react.useMemo)(function () {
143
+ return getMinItemsPerPageIndex(page, itemsPerPage, page);
144
+ }, [itemsPerPage, page]);
145
+ var maxItemsPerPageIndex = (0, _react.useMemo)(function () {
146
+ return getMaxItemsPerPageIndex(minItemsPerPageIndex, itemsPerPage, rows, page);
147
+ }, [itemsPerPage, minItemsPerPageIndex, page, rows]);
148
+
149
+ var goToPage = function goToPage(newPage) {
150
+ changePage(newPage);
151
+ };
152
+
153
+ var changeSorting = function changeSorting(columnIndex) {
154
+ changePage(1);
155
+ changeSortColumnIndex(columnIndex);
156
+ changeSortOrder(sortColumnIndex === "" || sortColumnIndex !== columnIndex ? "asc" : sortOrder === "asc" ? "desc" : "asc");
157
+ };
158
+
159
+ var getIconForSortableColumn = function getIconForSortableColumn(clickedColumnIndex) {
160
+ return sortColumnIndex === clickedColumnIndex ? sortOrder === "asc" ? /*#__PURE__*/_react["default"].createElement(ArrowUp, null) : /*#__PURE__*/_react["default"].createElement(ArrowDown, null) : /*#__PURE__*/_react["default"].createElement(BothArrows, null);
161
+ };
162
+
163
+ (0, _react.useEffect)(function () {
164
+ if (rows.length > 0) {
165
+ changePage(1);
166
+ } else {
167
+ changePage(0);
168
+ }
169
+ }, [rows.length, itemsPerPage]);
170
+ var sortedResultset = (0, _react.useMemo)(function () {
171
+ return sortColumnIndex !== "" ? sortArray(sortColumnIndex, sortOrder, rows) : rows;
172
+ }, [sortColumnIndex, sortOrder, rows]);
173
+ var filteredResultset = (0, _react.useMemo)(function () {
174
+ return sortedResultset && sortedResultset.slice(minItemsPerPageIndex, maxItemsPerPageIndex + 1);
175
+ }, [sortedResultset, minItemsPerPageIndex, maxItemsPerPageIndex]);
176
+ return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
177
+ theme: colorsTheme.table
178
+ }, /*#__PURE__*/_react["default"].createElement(DxcResultsetTableContainer, {
179
+ margin: margin
180
+ }, /*#__PURE__*/_react["default"].createElement(TableContainer, null, /*#__PURE__*/_react["default"].createElement(_Table["default"], null, /*#__PURE__*/_react["default"].createElement(HeaderRow, null, /*#__PURE__*/_react["default"].createElement("tr", null, columns.map(function (column, index) {
181
+ return /*#__PURE__*/_react["default"].createElement(TableHeader, {
182
+ key: "tableHeader_".concat(index)
183
+ }, /*#__PURE__*/_react["default"].createElement(HeaderContainer, {
184
+ key: "headerContainer_".concat(index),
185
+ onClick: function onClick() {
186
+ return column.isSortable && changeSorting(index);
187
+ },
188
+ tabIndex: column.isSortable ? tabIndex : -1
189
+ }, /*#__PURE__*/_react["default"].createElement(TitleDiv, {
190
+ isSortable: column.isSortable
191
+ }, column.displayValue), column.isSortable && /*#__PURE__*/_react["default"].createElement(SortIcon, null, getIconForSortableColumn(index))));
192
+ }))), /*#__PURE__*/_react["default"].createElement(TableRowGroup, null, filteredResultset.map(function (cells, index) {
193
+ return /*#__PURE__*/_react["default"].createElement("tr", {
194
+ key: "resultSetTableCell_".concat(index)
195
+ }, cells.map(function (cellContent, index) {
196
+ return /*#__PURE__*/_react["default"].createElement("td", {
197
+ key: "resultSetTableCellContent_".concat(index)
198
+ }, cellContent.displayValue);
199
+ }));
200
+ })))), /*#__PURE__*/_react["default"].createElement(PaginatorContainer, null, /*#__PURE__*/_react["default"].createElement(_Paginator["default"], {
201
+ totalItems: rows.length,
202
+ itemsPerPage: itemsPerPage,
203
+ itemsPerPageOptions: itemsPerPageOptions,
204
+ itemsPerPageFunction: itemsPerPageFunction,
205
+ currentPage: page,
206
+ showGoToPage: showGoToPage,
207
+ onPageChange: goToPage,
208
+ tabIndex: tabIndex
209
+ }))));
210
+ };
211
+
212
+ var TableContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n & table {\n table-layout: auto;\n }\n"])));
213
+
214
+ var PaginatorContainer = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])([""])));
215
+
216
+ var TableRowGroup = _styledComponents["default"].tbody(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n > div:nth-child(1) {\n position: absolute;\n left: calc(50% - 68.5px);\n bottom: calc(50% - 68.5px - 30px);\n }\n & tr {\n height: ", ";\n }\n"])), function (props) {
217
+ return props.theme.rowHeight || "70px";
218
+ });
219
+
220
+ var SortIcon = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n top: 409px;\n left: 390px;\n height: 14px;\n cursor: pointer;\n color: ", ";\n\n svg {\n height: 100%;\n width: 100%;\n }\n"])), function (props) {
221
+ return props.theme.sortIconColor;
222
+ });
223
+
224
+ var TitleDiv = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n cursor: ", ";\n"])), function (props) {
225
+ return props.isSortable && "pointer" || "default";
226
+ });
227
+
228
+ var TableHeader = _styledComponents["default"].th(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])([""])));
229
+
230
+ var HeaderContainer = _styledComponents["default"].div(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n justify-content: ", ";\n width: 100%;\n"])), function (props) {
231
+ return props.theme.headerTextAlign === "center" ? "center" : props.theme.headerTextAlign === "right" ? "flex-end" : "flex-start";
232
+ });
233
+
234
+ var HeaderRow = _styledComponents["default"].thead(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])(["\n height: 60px;\n"])));
235
+
236
+ var DxcResultsetTableContainer = _styledComponents["default"].div(_templateObject9 || (_templateObject9 = (0, _taggedTemplateLiteral2["default"])(["\n font-size: ", ";\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n"])), function (props) {
237
+ return props.theme.fontSizeBase;
238
+ }, function (props) {
239
+ return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
240
+ }, function (props) {
241
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.top ? _variables.spaces[props.margin.top] : "";
242
+ }, function (props) {
243
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.right ? _variables.spaces[props.margin.right] : "";
244
+ }, function (props) {
245
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.bottom ? _variables.spaces[props.margin.bottom] : "";
246
+ }, function (props) {
247
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.left ? _variables.spaces[props.margin.left] : "";
248
+ });
249
+
250
+ var _default = DxcResultsetTable;
251
+ exports["default"] = _default;
@@ -0,0 +1,67 @@
1
+ /// <reference types="react" />
2
+ declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
+ declare type Margin = {
4
+ top?: Space;
5
+ bottom?: Space;
6
+ left?: Space;
7
+ right?: Space;
8
+ };
9
+ declare type Column = {
10
+ /**
11
+ * Column display value.
12
+ */
13
+ displayValue: React.ReactNode;
14
+ /**
15
+ * Boolean value to indicate whether the column is sortable or not.
16
+ */
17
+ isSortable?: boolean;
18
+ };
19
+ declare type Row = {
20
+ /**
21
+ * Value to be displayed in the cell.
22
+ */
23
+ displayValue: React.ReactNode;
24
+ /**
25
+ * Value to be used when sorting the table by that
26
+ * column. If not indicated displayValue will be used for sorting.
27
+ */
28
+ sortValue?: string;
29
+ };
30
+ declare type Props = {
31
+ /**
32
+ * An array of objects representing the columns of the table.
33
+ */
34
+ columns: Column[];
35
+ /**
36
+ * An array of objects representing the rows of the table, you will have
37
+ * as many objects as columns in the table.
38
+ */
39
+ rows: Row[];
40
+ /**
41
+ * If true, a select component for navigation between pages will be displayed.
42
+ */
43
+ showGoToPage?: boolean;
44
+ /**
45
+ * Number of items per page.
46
+ */
47
+ itemsPerPage?: number;
48
+ /**
49
+ * An array of numbers representing the items per page options.
50
+ */
51
+ itemsPerPageOptions?: number[];
52
+ /**
53
+ * This function will be called when the user selects an item per page
54
+ * option. The value selected will be passed as a parameter.
55
+ */
56
+ itemsPerPageFunction?: (newValue: number) => void;
57
+ /**
58
+ * Size of the margin to be applied to the component. You can pass an object with 'top',
59
+ * 'bottom', 'left' and 'right' properties in order to specify different margin sizes.
60
+ */
61
+ margin?: Space | Margin;
62
+ /**
63
+ * Value of the tabindex attribute given to the sortable icon.
64
+ */
65
+ tabIndex?: number;
66
+ };
67
+ export default Props;
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });