@dxc-technology/halstack-react 0.0.0-a45812e → 0.0.0-a4bef7b

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 (281) 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.js +289 -0
  8. package/accordion/index.d.ts +28 -0
  9. package/accordion-group/AccordionGroup.js +184 -0
  10. package/accordion-group/index.d.ts +16 -0
  11. package/alert/Alert.js +309 -0
  12. package/alert/index.d.ts +51 -0
  13. package/badge/Badge.js +59 -0
  14. package/{dist/box → box}/Box.js +42 -26
  15. package/box/index.d.ts +25 -0
  16. package/button/Button.d.ts +4 -0
  17. package/button/Button.js +182 -0
  18. package/button/Button.stories.tsx +10 -0
  19. package/button/types.d.ts +22 -0
  20. package/button/types.js +5 -0
  21. package/card/Card.js +200 -0
  22. package/card/index.d.ts +22 -0
  23. package/checkbox/Checkbox.js +275 -0
  24. package/checkbox/index.d.ts +24 -0
  25. package/chip/Chip.js +221 -0
  26. package/chip/index.d.ts +22 -0
  27. package/{dist/common → common}/OpenSans.css +0 -0
  28. package/common/RequiredComponent.js +32 -0
  29. package/{dist/common → common}/fonts/OpenSans-Bold.ttf +0 -0
  30. package/{dist/common → common}/fonts/OpenSans-BoldItalic.ttf +0 -0
  31. package/{dist/common → common}/fonts/OpenSans-ExtraBold.ttf +0 -0
  32. package/{dist/common → common}/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  33. package/{dist/common → common}/fonts/OpenSans-Italic.ttf +0 -0
  34. package/{dist/common → common}/fonts/OpenSans-Light.ttf +0 -0
  35. package/{dist/common → common}/fonts/OpenSans-LightItalic.ttf +0 -0
  36. package/{dist/common → common}/fonts/OpenSans-Regular.ttf +0 -0
  37. package/{dist/common → common}/fonts/OpenSans-SemiBold.ttf +0 -0
  38. package/{dist/common → common}/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  39. package/{dist/common → common}/utils.js +0 -0
  40. package/common/variables.js +1567 -0
  41. package/{dist/date → date}/Date.js +121 -93
  42. package/date/index.d.ts +27 -0
  43. package/date-input/DateInput.js +396 -0
  44. package/date-input/index.d.ts +95 -0
  45. package/dialog/Dialog.js +184 -0
  46. package/dialog/index.d.ts +18 -0
  47. package/dropdown/Dropdown.js +450 -0
  48. package/dropdown/index.d.ts +26 -0
  49. package/file-input/FileInput.js +532 -0
  50. package/file-input/FileItem.js +193 -0
  51. package/file-input/index.d.ts +81 -0
  52. package/footer/Footer.js +297 -0
  53. package/footer/Icons.js +77 -0
  54. package/footer/index.d.ts +25 -0
  55. package/header/Header.js +326 -0
  56. package/header/Icons.js +59 -0
  57. package/header/index.d.ts +25 -0
  58. package/heading/Heading.js +176 -0
  59. package/heading/index.d.ts +17 -0
  60. package/input-text/Icons.js +22 -0
  61. package/input-text/InputText.js +611 -0
  62. package/input-text/index.d.ts +36 -0
  63. package/layout/ApplicationLayout.js +235 -0
  64. package/layout/Icons.js +55 -0
  65. package/link/Link.js +183 -0
  66. package/link/index.d.ts +23 -0
  67. package/main.d.ts +44 -0
  68. package/{dist/main.js → main.js} +147 -47
  69. package/number-input/NumberInput.js +128 -0
  70. package/{dist/ThemeContext.js → number-input/NumberInputContext.js} +3 -2
  71. package/number-input/index.d.ts +113 -0
  72. package/package.json +40 -24
  73. package/paginator/Icons.js +66 -0
  74. package/paginator/Paginator.js +221 -0
  75. package/paginator/index.d.ts +20 -0
  76. package/password-input/PasswordInput.js +199 -0
  77. package/password-input/index.d.ts +94 -0
  78. package/progress-bar/ProgressBar.js +188 -0
  79. package/progress-bar/index.d.ts +18 -0
  80. package/{dist/radio → radio}/Radio.js +47 -56
  81. package/radio/index.d.ts +23 -0
  82. package/resultsetTable/ResultsetTable.js +274 -0
  83. package/resultsetTable/index.d.ts +19 -0
  84. package/select/Select.js +864 -0
  85. package/select/index.d.ts +131 -0
  86. package/sidenav/Sidenav.js +145 -0
  87. package/sidenav/index.d.ts +13 -0
  88. package/slider/Slider.js +340 -0
  89. package/slider/index.d.ts +29 -0
  90. package/spinner/Spinner.js +267 -0
  91. package/spinner/index.d.ts +17 -0
  92. package/switch/Switch.js +208 -0
  93. package/switch/index.d.ts +24 -0
  94. package/table/Table.js +118 -0
  95. package/table/index.d.ts +13 -0
  96. package/tabs/Tabs.js +259 -0
  97. package/tabs/index.d.ts +19 -0
  98. package/tag/Tag.js +208 -0
  99. package/tag/index.d.ts +24 -0
  100. package/text-input/TextInput.js +818 -0
  101. package/text-input/index.d.ts +135 -0
  102. package/textarea/Textarea.js +315 -0
  103. package/textarea/index.d.ts +117 -0
  104. package/{dist/toggle → toggle}/Toggle.js +30 -67
  105. package/toggle/index.d.ts +21 -0
  106. package/toggle-group/ToggleGroup.js +243 -0
  107. package/toggle-group/index.d.ts +21 -0
  108. package/{dist/upload → upload}/Upload.js +23 -22
  109. package/upload/buttons-upload/ButtonsUpload.js +111 -0
  110. package/upload/buttons-upload/Icons.js +40 -0
  111. package/upload/dragAndDropArea/DragAndDropArea.js +225 -0
  112. package/upload/dragAndDropArea/Icons.js +39 -0
  113. package/upload/file-upload/FileToUpload.js +115 -0
  114. package/upload/file-upload/Icons.js +66 -0
  115. package/upload/files-upload/FilesToUpload.js +109 -0
  116. package/upload/index.d.ts +15 -0
  117. package/upload/transaction/Icons.js +160 -0
  118. package/upload/transaction/Transaction.js +104 -0
  119. package/upload/transactions/Transactions.js +94 -0
  120. package/useTheme.js +22 -0
  121. package/wizard/Icons.js +65 -0
  122. package/wizard/Wizard.js +271 -0
  123. package/wizard/index.d.ts +18 -0
  124. package/babel.config.js +0 -4
  125. package/dist/accordion/Accordion.js +0 -264
  126. package/dist/accordion/Accordion.stories.js +0 -207
  127. package/dist/accordion/readme.md +0 -96
  128. package/dist/alert/Alert.js +0 -302
  129. package/dist/alert/Alert.stories.js +0 -158
  130. package/dist/alert/close.svg +0 -4
  131. package/dist/alert/error.svg +0 -4
  132. package/dist/alert/info.svg +0 -4
  133. package/dist/alert/readme.md +0 -43
  134. package/dist/alert/success.svg +0 -4
  135. package/dist/alert/warning.svg +0 -4
  136. package/dist/button/Button.js +0 -187
  137. package/dist/button/Button.stories.js +0 -224
  138. package/dist/button/readme.md +0 -93
  139. package/dist/card/Card.js +0 -246
  140. package/dist/checkbox/Checkbox.js +0 -221
  141. package/dist/checkbox/Checkbox.stories.js +0 -144
  142. package/dist/checkbox/readme.md +0 -116
  143. package/dist/common/RequiredComponent.js +0 -50
  144. package/dist/common/services/example-service.js +0 -10
  145. package/dist/common/services/example-service.test.js +0 -12
  146. package/dist/common/variables.js +0 -77
  147. package/dist/date/Date.stories.js +0 -205
  148. package/dist/date/calendar.svg +0 -1
  149. package/dist/date/calendar_dark.svg +0 -1
  150. package/dist/date/readme.md +0 -73
  151. package/dist/dialog/Dialog.js +0 -164
  152. package/dist/dialog/Dialog.stories.js +0 -217
  153. package/dist/dialog/readme.md +0 -32
  154. package/dist/dropdown/Dropdown.js +0 -412
  155. package/dist/dropdown/Dropdown.stories.js +0 -249
  156. package/dist/dropdown/baseline-arrow_drop_down.svg +0 -1
  157. package/dist/dropdown/baseline-arrow_drop_down_wh.svg +0 -4
  158. package/dist/dropdown/baseline-arrow_drop_up.svg +0 -1
  159. package/dist/dropdown/baseline-arrow_drop_up_wh.svg +0 -4
  160. package/dist/dropdown/readme.md +0 -69
  161. package/dist/footer/Footer.js +0 -341
  162. package/dist/footer/Footer.stories.js +0 -94
  163. package/dist/footer/dxc_logo_wht.png +0 -0
  164. package/dist/footer/readme.md +0 -41
  165. package/dist/header/Header.js +0 -343
  166. package/dist/header/Header.stories.js +0 -176
  167. package/dist/header/close_icon.svg +0 -1
  168. package/dist/header/dxc_logo_black.png +0 -0
  169. package/dist/header/dxc_logo_white.png +0 -0
  170. package/dist/header/hamb_menu_black.svg +0 -1
  171. package/dist/header/hamb_menu_white.svg +0 -1
  172. package/dist/header/readme.md +0 -33
  173. package/dist/heading/Heading.js +0 -159
  174. package/dist/input-text/InputText.js +0 -510
  175. package/dist/input-text/InputText.stories.js +0 -209
  176. package/dist/input-text/error.svg +0 -1
  177. package/dist/input-text/readme.md +0 -91
  178. package/dist/link/Link.js +0 -129
  179. package/dist/link/readme.md +0 -51
  180. package/dist/paginator/Paginator.js +0 -178
  181. package/dist/paginator/images/next.svg +0 -3
  182. package/dist/paginator/images/nextPage.svg +0 -3
  183. package/dist/paginator/images/previous.svg +0 -3
  184. package/dist/paginator/images/previousPage.svg +0 -3
  185. package/dist/paginator/readme.md +0 -50
  186. package/dist/progress-bar/ProgressBar.js +0 -189
  187. package/dist/progress-bar/ProgressBar.stories.js +0 -280
  188. package/dist/progress-bar/readme.md +0 -63
  189. package/dist/radio/Radio.stories.js +0 -166
  190. package/dist/radio/readme.md +0 -70
  191. package/dist/resultsetTable/ResultsetTable.js +0 -334
  192. package/dist/resultsetTable/arrow_downward-24px_wht.svg +0 -1
  193. package/dist/resultsetTable/arrow_upward-24px_wht.svg +0 -1
  194. package/dist/resultsetTable/unfold_more-24px_wht.svg +0 -1
  195. package/dist/select/Select.js +0 -425
  196. package/dist/select/Select.stories.js +0 -235
  197. package/dist/select/readme.md +0 -72
  198. package/dist/sidenav/Sidenav.js +0 -217
  199. package/dist/sidenav/arrow_icon.svg +0 -3
  200. package/dist/slider/Slider.js +0 -268
  201. package/dist/slider/Slider.stories.js +0 -241
  202. package/dist/slider/readme.md +0 -64
  203. package/dist/spinner/Spinner.js +0 -196
  204. package/dist/spinner/Spinner.stories.js +0 -183
  205. package/dist/spinner/readme.md +0 -65
  206. package/dist/switch/Switch.js +0 -219
  207. package/dist/switch/Switch.stories.js +0 -134
  208. package/dist/switch/readme.md +0 -133
  209. package/dist/table/Table.js +0 -84
  210. package/dist/tabs/Tabs.js +0 -183
  211. package/dist/tabs/Tabs.stories.js +0 -130
  212. package/dist/tabs/readme.md +0 -78
  213. package/dist/tabs-for-sections/TabsForSections.js +0 -107
  214. package/dist/tabs-for-sections/readme.md +0 -78
  215. package/dist/tag/Tag.js +0 -217
  216. package/dist/textarea/Textarea.js +0 -226
  217. package/dist/toggle/Toggle.stories.js +0 -297
  218. package/dist/toggle/readme.md +0 -80
  219. package/dist/upload/Upload.stories.js +0 -72
  220. package/dist/upload/buttons-upload/ButtonsUpload.js +0 -125
  221. package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
  222. package/dist/upload/buttons-upload/upload-button.svg +0 -1
  223. package/dist/upload/dragAndDropArea/DragAndDropArea.js +0 -282
  224. package/dist/upload/dragAndDropArea/upload_drop.svg +0 -4
  225. package/dist/upload/dragAndDropArea/upload_file.svg +0 -4
  226. package/dist/upload/file-upload/FileToUpload.js +0 -158
  227. package/dist/upload/file-upload/audio-icon.svg +0 -4
  228. package/dist/upload/file-upload/close.svg +0 -4
  229. package/dist/upload/file-upload/file-icon.svg +0 -4
  230. package/dist/upload/file-upload/video-icon.svg +0 -4
  231. package/dist/upload/files-upload/FilesToUpload.js +0 -123
  232. package/dist/upload/readme.md +0 -37
  233. package/dist/upload/transaction/Transaction.js +0 -155
  234. package/dist/upload/transaction/audio-icon-err.svg +0 -4
  235. package/dist/upload/transaction/audio-icon.svg +0 -4
  236. package/dist/upload/transaction/error-icon.svg +0 -4
  237. package/dist/upload/transaction/file-icon-err.svg +0 -4
  238. package/dist/upload/transaction/file-icon.svg +0 -4
  239. package/dist/upload/transaction/image-icon-err.svg +0 -4
  240. package/dist/upload/transaction/image-icon.svg +0 -4
  241. package/dist/upload/transaction/success-icon.svg +0 -4
  242. package/dist/upload/transaction/video-icon-err.svg +0 -4
  243. package/dist/upload/transaction/video-icon.svg +0 -4
  244. package/dist/upload/transactions/Transactions.js +0 -120
  245. package/dist/wizard/Wizard.js +0 -310
  246. package/dist/wizard/invalid_icon.svg +0 -6
  247. package/dist/wizard/valid_icon.svg +0 -6
  248. package/dist/wizard/validation-wrong.svg +0 -6
  249. package/test/Accordion.test.js +0 -33
  250. package/test/Alert.test.js +0 -53
  251. package/test/Box.test.js +0 -10
  252. package/test/Button.test.js +0 -18
  253. package/test/Card.test.js +0 -30
  254. package/test/Checkbox.test.js +0 -45
  255. package/test/Date.test.js +0 -393
  256. package/test/Dialog.test.js +0 -23
  257. package/test/Dropdown.test.js +0 -130
  258. package/test/Footer.test.js +0 -99
  259. package/test/Header.test.js +0 -39
  260. package/test/Heading.test.js +0 -35
  261. package/test/InputText.test.js +0 -236
  262. package/test/Link.test.js +0 -25
  263. package/test/Paginator.test.js +0 -165
  264. package/test/ProgressBar.test.js +0 -35
  265. package/test/Radio.test.js +0 -37
  266. package/test/ResultsetTable.test.js +0 -282
  267. package/test/Select.test.js +0 -191
  268. package/test/Sidenav.test.js +0 -87
  269. package/test/Slider.test.js +0 -65
  270. package/test/Spinner.test.js +0 -27
  271. package/test/Switch.test.js +0 -45
  272. package/test/Table.test.js +0 -36
  273. package/test/Tabs.test.js +0 -88
  274. package/test/TabsForSections.test.js +0 -34
  275. package/test/Tag.test.js +0 -32
  276. package/test/TextArea.test.js +0 -52
  277. package/test/Toggle.test.js +0 -43
  278. package/test/Upload.test.js +0 -60
  279. package/test/Wizard.test.js +0 -130
  280. package/test/mocks/pngMock.js +0 -1
  281. package/test/mocks/svgMock.js +0 -1
@@ -1,166 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
- var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
6
-
7
- var _react = _interopRequireDefault(require("react"));
8
-
9
- var _react2 = require("@storybook/react");
10
-
11
- var _addonActions = require("@storybook/addon-actions");
12
-
13
- var _addonKnobs = require("@storybook/addon-knobs");
14
-
15
- var _readme = _interopRequireDefault(require("./readme.md"));
16
-
17
- var _Radio = _interopRequireDefault(require("./Radio"));
18
-
19
- var onChange = (0, _addonActions.action)("onChange");
20
-
21
- onChange.toString = function () {
22
- return "onChangeHandler";
23
- };
24
-
25
- (0, _react2.storiesOf)("Form Components|Radio", module).add("Component", function () {
26
- return _react["default"].createElement("div", null, _react["default"].createElement("h3", null, "Light"), _react["default"].createElement("div", null, _react["default"].createElement(_Radio["default"], {
27
- checked: false,
28
- theme: "light",
29
- value: "TestValue",
30
- label: "Enable Radio",
31
- labelPosition: "after",
32
- onChange: onChange,
33
- disabled: false,
34
- required: true
35
- }), _react["default"].createElement(_Radio["default"], {
36
- checked: false,
37
- theme: "light",
38
- value: "TestValue",
39
- label: "Label before",
40
- labelPosition: "before",
41
- onChange: onChange,
42
- disabled: false
43
- }), _react["default"].createElement(_Radio["default"], {
44
- checked: false,
45
- theme: "light",
46
- value: "TestValue",
47
- label: "Label after",
48
- labelPosition: "after",
49
- onChange: onChange,
50
- disabled: false
51
- }), _react["default"].createElement(_Radio["default"], {
52
- checked: true,
53
- theme: "light",
54
- value: "TestValue",
55
- label: "Selected Radio",
56
- labelPosition: "before",
57
- onChange: onChange,
58
- disabled: false
59
- }), _react["default"].createElement(_Radio["default"], {
60
- checked: false,
61
- theme: "light",
62
- value: "TestValue",
63
- label: "Disabled Radio",
64
- labelPosition: "before",
65
- onChange: onChange,
66
- disabled: true
67
- }), _react["default"].createElement(_Radio["default"], {
68
- checked: true,
69
- theme: "light",
70
- value: "TestValue",
71
- label: "Disabled Selected Radio",
72
- labelPosition: "before",
73
- onChange: onChange,
74
- disabled: true
75
- })), _react["default"].createElement("h3", null, "Dark"), _react["default"].createElement("div", {
76
- style: {
77
- background: "black"
78
- }
79
- }, _react["default"].createElement(_Radio["default"], {
80
- checked: false,
81
- theme: "dark",
82
- value: "TestValue",
83
- label: "Enable Radio",
84
- labelPosition: "after",
85
- onChange: onChange,
86
- disabled: false
87
- }), _react["default"].createElement(_Radio["default"], {
88
- checked: false,
89
- theme: "dark",
90
- value: "TestValue",
91
- label: "Label before",
92
- labelPosition: "before",
93
- onChange: onChange,
94
- disabled: false,
95
- required: true
96
- }), _react["default"].createElement(_Radio["default"], {
97
- checked: false,
98
- theme: "dark",
99
- value: "TestValue",
100
- label: "Label after",
101
- labelPosition: "after",
102
- onChange: onChange,
103
- disabled: false
104
- }), _react["default"].createElement(_Radio["default"], {
105
- checked: true,
106
- theme: "dark",
107
- value: "TestValue",
108
- label: "Selected Radio",
109
- labelPosition: "before",
110
- onChange: onChange,
111
- disabled: false
112
- }), _react["default"].createElement(_Radio["default"], {
113
- checked: false,
114
- theme: "dark",
115
- value: "TestValue",
116
- label: "Disabled Radio",
117
- labelPosition: "before",
118
- onChange: onChange,
119
- disabled: true
120
- }), _react["default"].createElement(_Radio["default"], {
121
- checked: true,
122
- theme: "dark",
123
- value: "TestValue",
124
- label: "Disabled Selected Radio",
125
- labelPosition: "before",
126
- onChange: onChange,
127
- disabled: true
128
- })));
129
- }, {
130
- notes: {
131
- markdown: _readme["default"]
132
- }
133
- });
134
-
135
- var knobProps = function knobProps() {
136
- return {
137
- label: (0, _addonKnobs.text)("Label", "Test Checkbox"),
138
- disabled: (0, _addonKnobs["boolean"])("Disabled", false),
139
- labelPosition: (0, _addonKnobs.select)("Label position", {
140
- before: "before",
141
- after: "after"
142
- }, "before"),
143
- theme: (0, _addonKnobs.select)("Theme", {
144
- light: "light",
145
- dark: "dark"
146
- }, "light"),
147
- disableRipple: (0, _addonKnobs["boolean"])("disableRipple", false),
148
- required: (0, _addonKnobs["boolean"])("Required", false)
149
- };
150
- };
151
-
152
- (0, _react2.storiesOf)("Form Components|Radio", module).add("Knobs example", function () {
153
- var props = knobProps();
154
- return _react["default"].createElement("div", {
155
- style: {
156
- background: props.theme === "dark" && "black" || "transparent"
157
- }
158
- }, _react["default"].createElement(_Radio["default"], (0, _extends2["default"])({}, props, {
159
- value: "TestValue",
160
- onChange: onChange
161
- })));
162
- }, {
163
- notes: {
164
- markdown: _readme["default"]
165
- }
166
- });
@@ -1,70 +0,0 @@
1
- # DXC Radio Component
2
-
3
- ## Usage
4
-
5
- ```js
6
- import { DxcRadio } from "@diaas/dxc-react-cdk";
7
-
8
- <DxcRadio onChange={handleNewValue} label="Test Radio" checked={checked} />;
9
- ```
10
-
11
- ## Props
12
-
13
- <table>
14
- <tr style="background-color: grey">
15
- <td>Name</td>
16
- <td>Default</td>
17
- <td>Description</td>
18
- </tr>
19
- <tr>
20
- <td>checked: boolean</td>
21
- <td><code>false</code></td>
22
- <td>If true, the component is checked.</td>
23
- </tr>
24
- <tr>
25
- <td>value: any</td>
26
- <td></td>
27
- <td>Will be passed to the value attribute of the html input element. When inside a form, this value will be only submitted if the radio is checked </td>
28
- </tr>
29
- <tr>
30
- <td>label: string</td>
31
- <td></td>
32
- <td>Text to be placed next to the radio.</td>
33
- </tr>
34
- <tr>
35
- <td>labelPosition: 'before' | 'after'</td>
36
- <td><code>'before'</code></td>
37
- <td>Whether the label should appear after or before the radio.</td>
38
- </tr>
39
- <tr>
40
- <td>theme: 'light' | 'dark'</td>
41
- <td><code>'light'</code></td>
42
- <td>Uses one of the available component themes.</td>
43
- </tr>
44
- <tr>
45
- <td>name: string</td>
46
- <td></td>
47
- <td>Name attribute of the input element.</td>
48
- </tr>
49
- <tr>
50
- <td>disabled: boolean</td>
51
- <td><code>false</code></td>
52
- <td>If true, the component will be disabled.</td>
53
- </tr>
54
- <tr>
55
- <td>required: boolean</td>
56
- <td><code>false</code></td>
57
- <td>If true, a red asterisk will appear before the label to indicate to the user that the field is required.</td>
58
- </tr>
59
- <tr>
60
- <td>disableRipple: boolean</td>
61
- <td><code>false</code></td>
62
- <td>If true, the ripple effect will be disabled.</td>
63
- </tr>
64
- <tr>
65
- <td>onChange: function</td>
66
- <td></td>
67
- <td>This function will be called when the user clicks the radio. The event object will be passed as a parameter.<br>
68
- Current state can be accessed via event.target.checked</td>
69
- </tr>
70
- </table>
@@ -1,334 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
4
-
5
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
6
-
7
- Object.defineProperty(exports, "__esModule", {
8
- value: true
9
- });
10
- exports["default"] = void 0;
11
-
12
- var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
13
-
14
- var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
15
-
16
- var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
17
-
18
- var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
19
-
20
- var _react = _interopRequireWildcard(require("react"));
21
-
22
- var _styledComponents = _interopRequireWildcard(require("styled-components"));
23
-
24
- var _propTypes = _interopRequireDefault(require("prop-types"));
25
-
26
- var _variables = require("../common/variables.js");
27
-
28
- var _ThemeContext = _interopRequireDefault(require("../ThemeContext.js"));
29
-
30
- var _Table = _interopRequireDefault(require("../table/Table"));
31
-
32
- var _Paginator = _interopRequireDefault(require("../paginator/Paginator"));
33
-
34
- var _arrow_upward24px_wht = _interopRequireDefault(require("./arrow_upward-24px_wht.svg"));
35
-
36
- var _arrow_downward24px_wht = _interopRequireDefault(require("./arrow_downward-24px_wht.svg"));
37
-
38
- var _unfold_more24px_wht = _interopRequireDefault(require("./unfold_more-24px_wht.svg"));
39
-
40
- function _templateObject9() {
41
- var data = (0, _taggedTemplateLiteral2["default"])(["\n overflow-x: auto;\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n\n &::-webkit-scrollbar {\n height: 6px;\n }\n\n &::-webkit-scrollbar-thumb {\n background-color: ", ";\n border-radius: 6px;\n }\n\n &::-webkit-scrollbar-track {\n background-color: ", ";\n border-radius: 6px;\n }\n"]);
42
-
43
- _templateObject9 = function _templateObject9() {
44
- return data;
45
- };
46
-
47
- return data;
48
- }
49
-
50
- function _templateObject8() {
51
- var data = (0, _taggedTemplateLiteral2["default"])(["\n height: 60px;\n"]);
52
-
53
- _templateObject8 = function _templateObject8() {
54
- return data;
55
- };
56
-
57
- return data;
58
- }
59
-
60
- function _templateObject7() {
61
- var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n width: fit-content;\n"]);
62
-
63
- _templateObject7 = function _templateObject7() {
64
- return data;
65
- };
66
-
67
- return data;
68
- }
69
-
70
- function _templateObject6() {
71
- var data = (0, _taggedTemplateLiteral2["default"])([""]);
72
-
73
- _templateObject6 = function _templateObject6() {
74
- return data;
75
- };
76
-
77
- return data;
78
- }
79
-
80
- function _templateObject5() {
81
- var data = (0, _taggedTemplateLiteral2["default"])(["\n cursor: ", ";\n"]);
82
-
83
- _templateObject5 = function _templateObject5() {
84
- return data;
85
- };
86
-
87
- return data;
88
- }
89
-
90
- function _templateObject4() {
91
- var data = (0, _taggedTemplateLiteral2["default"])(["\n top: 409px;\n left: 390px;\n height: 14px;\n cursor: pointer;\n"]);
92
-
93
- _templateObject4 = function _templateObject4() {
94
- return data;
95
- };
96
-
97
- return data;
98
- }
99
-
100
- function _templateObject3() {
101
- var data = (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: 70px;\n }\n"]);
102
-
103
- _templateObject3 = function _templateObject3() {
104
- return data;
105
- };
106
-
107
- return data;
108
- }
109
-
110
- function _templateObject2() {
111
- var data = (0, _taggedTemplateLiteral2["default"])(["\n margin-left: ", ";\n margin-right: ", ";\n"]);
112
-
113
- _templateObject2 = function _templateObject2() {
114
- return data;
115
- };
116
-
117
- return data;
118
- }
119
-
120
- function _templateObject() {
121
- var data = (0, _taggedTemplateLiteral2["default"])(["\n & table {\n table-layout: fixed;\n }\n"]);
122
-
123
- _templateObject = function _templateObject() {
124
- return data;
125
- };
126
-
127
- return data;
128
- }
129
-
130
- function normalizeSortValue(sortValue) {
131
- return typeof sortValue === "string" ? sortValue.toUpperCase() : sortValue;
132
- }
133
-
134
- function sortArray(index, order, resultset) {
135
- return resultset.slice().sort(function (element1, element2) {
136
- var sortValueA = normalizeSortValue(element1[index].sortValue || element1[index].displayValue);
137
- var sortValueB = normalizeSortValue(element2[index].sortValue || element2[index].displayValue);
138
- var comparison = 0;
139
-
140
- if ((0, _typeof2["default"])(sortValueA) === "object") {
141
- comparison = -1;
142
- } else if ((0, _typeof2["default"])(sortValueB) === "object") {
143
- comparison = 1;
144
- } else if (sortValueA > sortValueB) {
145
- comparison = 1;
146
- } else if (sortValueA < sortValueB) {
147
- comparison = -1;
148
- }
149
-
150
- return order === "desc" ? comparison * -1 : comparison;
151
- });
152
- }
153
-
154
- var getMinItemsPerPageIndex = function getMinItemsPerPageIndex(currentPageInternal, itemsPerPage, page) {
155
- return currentPageInternal === 1 ? 0 : itemsPerPage * (page - 1);
156
- };
157
-
158
- var getMaxItemsPerPageIndex = function getMaxItemsPerPageIndex(minItemsPerPageIndex, itemsPerPage, resultset, page) {
159
- return minItemsPerPageIndex + itemsPerPage > resultset.length ? resultset.length : itemsPerPage * page - 1;
160
- };
161
-
162
- var DxcResultsetTable = function DxcResultsetTable(_ref) {
163
- var columns = _ref.columns,
164
- rows = _ref.rows,
165
- _ref$itemsPerPage = _ref.itemsPerPage,
166
- itemsPerPage = _ref$itemsPerPage === void 0 ? 5 : _ref$itemsPerPage,
167
- margin = _ref.margin;
168
-
169
- var colorsTheme = (0, _react.useContext)(_ThemeContext["default"]) || _variables.colors;
170
-
171
- var _useState = (0, _react.useState)(1),
172
- _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
173
- page = _useState2[0],
174
- changePage = _useState2[1];
175
-
176
- var _useState3 = (0, _react.useState)(""),
177
- _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
178
- sortColumnIndex = _useState4[0],
179
- changeSortColumnIndex = _useState4[1];
180
-
181
- var _useState5 = (0, _react.useState)("asc"),
182
- _useState6 = (0, _slicedToArray2["default"])(_useState5, 2),
183
- sortOrder = _useState6[0],
184
- changeSortOrder = _useState6[1];
185
-
186
- var minItemsPerPageIndex = (0, _react.useMemo)(function () {
187
- return getMinItemsPerPageIndex(page, itemsPerPage, page);
188
- }, [page]); //Merece la pena sacar a una función para usar useMemo?
189
-
190
- var maxItemsPerPageIndex = (0, _react.useMemo)(function () {
191
- return getMaxItemsPerPageIndex(minItemsPerPageIndex, itemsPerPage, rows, page);
192
- }, [page]);
193
-
194
- var next = function next() {
195
- changePage(page + 1);
196
- };
197
-
198
- var previous = function previous() {
199
- changePage(page - 1);
200
- };
201
-
202
- var first = function first() {
203
- changePage(1);
204
- };
205
-
206
- var last = function last() {
207
- changePage(Math.ceil(rows.length / itemsPerPage));
208
- };
209
-
210
- var changeSorting = function changeSorting(columnIndex) {
211
- changePage(1);
212
- changeSortColumnIndex(columnIndex);
213
- changeSortOrder(sortColumnIndex === "" || sortColumnIndex !== columnIndex ? "asc" : sortOrder === "asc" ? "desc" : "asc");
214
- };
215
-
216
- var getIconForSortableColumn = function getIconForSortableColumn(clickedColumnIndex) {
217
- return sortColumnIndex === clickedColumnIndex ? sortOrder === "asc" ? _arrow_upward24px_wht["default"] : _arrow_downward24px_wht["default"] : _unfold_more24px_wht["default"];
218
- };
219
-
220
- (0, _react.useEffect)(function () {
221
- if (rows.length > 0) {
222
- changePage(1);
223
- } else {
224
- changePage(0);
225
- }
226
- }, [rows]);
227
- var sortedResultset = (0, _react.useMemo)(function () {
228
- return sortColumnIndex !== "" ? sortArray(sortColumnIndex, sortOrder, rows) : rows;
229
- }, [sortColumnIndex, sortOrder, rows]);
230
- var filteredResultset = (0, _react.useMemo)(function () {
231
- return sortedResultset && sortedResultset.slice(minItemsPerPageIndex, maxItemsPerPageIndex + 1);
232
- }, [page, sortColumnIndex, sortOrder, rows]);
233
- return _react["default"].createElement(_styledComponents.ThemeProvider, {
234
- theme: colorsTheme
235
- }, _react["default"].createElement(DxcResultsetTableContainer, {
236
- margin: margin
237
- }, _react["default"].createElement(TableContainer, null, _react["default"].createElement(_Table["default"], {
238
- margin: {
239
- top: margin,
240
- right: margin,
241
- bottom: "0px",
242
- left: margin
243
- }
244
- }, _react["default"].createElement(HeaderRow, null, _react["default"].createElement("tr", null, columns.map(function (column, index) {
245
- return _react["default"].createElement(TableHeader, {
246
- key: "tableHeader_".concat(index)
247
- }, _react["default"].createElement(HeaderContainer, {
248
- key: "headerContainer_".concat(index),
249
- onClick: function onClick() {
250
- return column.isSortable && changeSorting(index);
251
- }
252
- }, _react["default"].createElement(TitleDiv, {
253
- isSortable: column.isSortable
254
- }, column.displayValue), column.isSortable && _react["default"].createElement(SortIcon, {
255
- src: getIconForSortableColumn(index)
256
- })));
257
- }))), _react["default"].createElement(TableRowGroup, null, filteredResultset.map(function (cells, index) {
258
- return _react["default"].createElement("tr", {
259
- key: "resultSetTableCell_".concat(index)
260
- }, cells.map(function (cellContent, index) {
261
- return _react["default"].createElement("td", {
262
- key: "resultSetTableCellContent_".concat(index)
263
- }, cellContent.displayValue);
264
- }));
265
- })))), _react["default"].createElement(PaginatorContainer, {
266
- margin: margin
267
- }, _react["default"].createElement(_Paginator["default"], {
268
- totalItems: rows.length,
269
- itemsPerPage: itemsPerPage,
270
- currentPage: page,
271
- nextFunction: next,
272
- prevFunction: previous,
273
- firstFunction: first,
274
- lastFunction: last
275
- }))));
276
- };
277
-
278
- var TableContainer = _styledComponents["default"].div(_templateObject());
279
-
280
- var PaginatorContainer = _styledComponents["default"].div(_templateObject2(), function (props) {
281
- return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
282
- }, function (props) {
283
- return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
284
- });
285
-
286
- var TableRowGroup = _styledComponents["default"].tbody(_templateObject3());
287
-
288
- var SortIcon = _styledComponents["default"].img(_templateObject4());
289
-
290
- var TitleDiv = _styledComponents["default"].div(_templateObject5(), function (props) {
291
- return props.isSortable && "pointer" || "default";
292
- });
293
-
294
- var TableHeader = _styledComponents["default"].th(_templateObject6());
295
-
296
- var HeaderContainer = _styledComponents["default"].div(_templateObject7());
297
-
298
- var HeaderRow = _styledComponents["default"].thead(_templateObject8());
299
-
300
- var DxcResultsetTableContainer = _styledComponents["default"].div(_templateObject9(), function (props) {
301
- return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
302
- }, function (props) {
303
- return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.top ? _variables.spaces[props.margin.top] : "";
304
- }, function (props) {
305
- return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.right ? _variables.spaces[props.margin.right] : "";
306
- }, function (props) {
307
- return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.bottom ? _variables.spaces[props.margin.bottom] : "";
308
- }, function (props) {
309
- return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.left ? _variables.spaces[props.margin.left] : "";
310
- }, function (props) {
311
- return props.theme.darkGrey;
312
- }, function (props) {
313
- return props.theme.lightGrey;
314
- });
315
-
316
- DxcResultsetTable.propTypes = {
317
- rows: _propTypes["default"].array,
318
- columns: _propTypes["default"].array,
319
- itemsPerPage: _propTypes["default"].number,
320
- margin: _propTypes["default"].oneOfType([_propTypes["default"].shape({
321
- top: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
322
- bottom: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
323
- left: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
324
- right: _propTypes["default"].oneOf(Object.keys(_variables.spaces))
325
- }), _propTypes["default"].oneOf((0, _toConsumableArray2["default"])(Object.keys(_variables.spaces)))])
326
- };
327
- DxcResultsetTable.defaultProps = {
328
- rows: [],
329
- columns: [],
330
- itemsPerPage: 5,
331
- margin: "xxsmall"
332
- };
333
- var _default = DxcResultsetTable;
334
- exports["default"] = _default;
@@ -1 +0,0 @@
1
- <svg xmlns="http://www.w3.org/2000/svg" height="24" viewBox="0 0 24 24" width="24" fill="white"><path d="M0 0h24v24H0V0z" fill="none"/><path d="M20 12l-1.41-1.41L13 16.17V4h-2v12.17l-5.58-5.59L4 12l8 8 8-8z"/></svg>
@@ -1 +0,0 @@
1
- <svg xmlns="http://www.w3.org/2000/svg" height="24" viewBox="0 0 24 24" width="24" fill="white"><path d="M0 0h24v24H0V0z" fill="none"/><path d="M4 12l1.41 1.41L11 7.83V20h2V7.83l5.58 5.59L20 12l-8-8-8 8z"/></svg>
@@ -1 +0,0 @@
1
- <svg xmlns="http://www.w3.org/2000/svg" height="24" viewBox="0 0 24 24" width="24" fill="white"><path d="M0 0h24v24H0z" fill="none"/><path 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"/></svg>