@dxc-technology/halstack-react 3.2.0 → 4.0.0

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 (265) hide show
  1. package/BackgroundColorContext.js +46 -0
  2. package/ThemeContext.js +250 -0
  3. package/V3Select/V3Select.js +549 -0
  4. package/V3Select/index.d.ts +27 -0
  5. package/V3Textarea/V3Textarea.js +264 -0
  6. package/V3Textarea/index.d.ts +27 -0
  7. package/{dist/accordion → accordion}/Accordion.js +119 -50
  8. package/accordion/index.d.ts +28 -0
  9. package/{dist/accordion-group → accordion-group}/AccordionGroup.js +33 -1
  10. package/accordion-group/index.d.ts +16 -0
  11. package/alert/Alert.js +403 -0
  12. package/alert/index.d.ts +51 -0
  13. package/badge/Badge.js +63 -0
  14. package/{dist/box → box}/Box.js +27 -18
  15. package/box/index.d.ts +25 -0
  16. package/button/Button.js +238 -0
  17. package/button/Button.stories.js +27 -0
  18. package/button/index.d.ts +24 -0
  19. package/{dist/card → card}/Card.js +16 -9
  20. package/card/index.d.ts +22 -0
  21. package/{dist/checkbox → checkbox}/Checkbox.js +89 -23
  22. package/checkbox/index.d.ts +24 -0
  23. package/{dist/chip → chip}/Chip.js +63 -21
  24. package/chip/index.d.ts +22 -0
  25. package/{dist/common → common}/OpenSans.css +0 -0
  26. package/{dist/common → common}/RequiredComponent.js +0 -0
  27. package/{dist/common → common}/fonts/OpenSans-Bold.ttf +0 -0
  28. package/{dist/common → common}/fonts/OpenSans-BoldItalic.ttf +0 -0
  29. package/{dist/common → common}/fonts/OpenSans-ExtraBold.ttf +0 -0
  30. package/{dist/common → common}/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  31. package/{dist/common → common}/fonts/OpenSans-Italic.ttf +0 -0
  32. package/{dist/common → common}/fonts/OpenSans-Light.ttf +0 -0
  33. package/{dist/common → common}/fonts/OpenSans-LightItalic.ttf +0 -0
  34. package/{dist/common → common}/fonts/OpenSans-Regular.ttf +0 -0
  35. package/{dist/common → common}/fonts/OpenSans-SemiBold.ttf +0 -0
  36. package/{dist/common → common}/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  37. package/common/utils.js +22 -0
  38. package/common/variables.js +1567 -0
  39. package/{dist/date → date}/Date.js +60 -38
  40. package/date/index.d.ts +27 -0
  41. package/date-input/DateInput.js +400 -0
  42. package/date-input/index.d.ts +95 -0
  43. package/{dist/dialog → dialog}/Dialog.js +44 -29
  44. package/dialog/index.d.ts +18 -0
  45. package/{dist/dropdown → dropdown}/Dropdown.js +162 -74
  46. package/dropdown/index.d.ts +26 -0
  47. package/file-input/FileInput.js +644 -0
  48. package/file-input/FileItem.js +287 -0
  49. package/file-input/index.d.ts +81 -0
  50. package/{dist/footer → footer}/Footer.js +79 -37
  51. package/footer/Icons.js +77 -0
  52. package/footer/index.d.ts +25 -0
  53. package/{dist/header → header}/Header.js +157 -72
  54. package/header/Icons.js +59 -0
  55. package/header/index.d.ts +25 -0
  56. package/heading/Heading.js +230 -0
  57. package/heading/index.d.ts +17 -0
  58. package/input-text/Icons.js +22 -0
  59. package/{dist/input-text → input-text}/InputText.js +162 -66
  60. package/input-text/index.d.ts +36 -0
  61. package/{dist/layout → layout}/ApplicationLayout.js +7 -11
  62. package/layout/Icons.js +55 -0
  63. package/{dist/link → link}/Link.js +76 -39
  64. package/link/index.d.ts +23 -0
  65. package/main.d.ts +40 -0
  66. package/{dist/main.js → main.js} +71 -15
  67. package/number-input/NumberInput.js +136 -0
  68. package/number-input/NumberInputContext.js +16 -0
  69. package/number-input/index.d.ts +113 -0
  70. package/package.json +25 -19
  71. package/paginator/Icons.js +66 -0
  72. package/{dist/paginator → paginator}/Paginator.js +86 -42
  73. package/paginator/index.d.ts +20 -0
  74. package/password-input/PasswordInput.js +203 -0
  75. package/password-input/index.d.ts +94 -0
  76. package/{dist/progress-bar → progress-bar}/ProgressBar.js +88 -38
  77. package/progress-bar/index.d.ts +18 -0
  78. package/{dist/radio → radio}/Radio.js +28 -9
  79. package/radio/index.d.ts +23 -0
  80. package/{dist/resultsetTable → resultsetTable}/ResultsetTable.js +65 -40
  81. package/resultsetTable/index.d.ts +19 -0
  82. package/select/Select.js +1138 -0
  83. package/select/index.d.ts +131 -0
  84. package/{dist/sidenav → sidenav}/Sidenav.js +47 -23
  85. package/sidenav/index.d.ts +13 -0
  86. package/slider/Slider.js +404 -0
  87. package/slider/index.d.ts +29 -0
  88. package/spinner/Spinner.js +381 -0
  89. package/spinner/index.d.ts +17 -0
  90. package/{dist/switch → switch}/Switch.js +42 -14
  91. package/switch/index.d.ts +24 -0
  92. package/{dist/table → table}/Table.js +45 -11
  93. package/table/index.d.ts +13 -0
  94. package/{dist/tabs → tabs}/Tabs.js +37 -19
  95. package/tabs/index.d.ts +19 -0
  96. package/{dist/tag → tag}/Tag.js +50 -36
  97. package/tag/index.d.ts +24 -0
  98. package/text-input/TextInput.js +992 -0
  99. package/text-input/index.d.ts +135 -0
  100. package/textarea/Textarea.js +369 -0
  101. package/textarea/index.d.ts +117 -0
  102. package/{dist/toggle → toggle}/Toggle.js +0 -0
  103. package/toggle/index.d.ts +21 -0
  104. package/toggle-group/ToggleGroup.js +327 -0
  105. package/toggle-group/index.d.ts +21 -0
  106. package/{dist/upload → upload}/Upload.js +1 -5
  107. package/{dist/upload → upload}/buttons-upload/ButtonsUpload.js +28 -16
  108. package/upload/buttons-upload/Icons.js +40 -0
  109. package/{dist/upload → upload}/dragAndDropArea/DragAndDropArea.js +61 -25
  110. package/upload/dragAndDropArea/Icons.js +39 -0
  111. package/{dist/upload → upload}/file-upload/FileToUpload.js +52 -25
  112. package/upload/file-upload/Icons.js +66 -0
  113. package/{dist/upload → upload}/files-upload/FilesToUpload.js +3 -3
  114. package/upload/index.d.ts +15 -0
  115. package/upload/transaction/Icons.js +160 -0
  116. package/{dist/upload → upload}/transaction/Transaction.js +37 -41
  117. package/{dist/upload → upload}/transactions/Transactions.js +24 -8
  118. package/{dist/useTheme.js → useTheme.js} +0 -0
  119. package/wizard/Icons.js +65 -0
  120. package/{dist/wizard → wizard}/Wizard.js +106 -56
  121. package/wizard/index.d.ts +18 -0
  122. package/README.md +0 -66
  123. package/babel.config.js +0 -8
  124. package/dist/ThemeContext.js +0 -201
  125. package/dist/accordion/Accordion.stories.js +0 -207
  126. package/dist/accordion/readme.md +0 -96
  127. package/dist/accordion-group/AccordionGroup.stories.js +0 -207
  128. package/dist/accordion-group/readme.md +0 -70
  129. package/dist/alert/Alert.js +0 -318
  130. package/dist/alert/Alert.stories.js +0 -158
  131. package/dist/alert/close.svg +0 -4
  132. package/dist/alert/error.svg +0 -4
  133. package/dist/alert/info.svg +0 -4
  134. package/dist/alert/readme.md +0 -43
  135. package/dist/alert/success.svg +0 -4
  136. package/dist/alert/warning.svg +0 -4
  137. package/dist/badge/Badge.js +0 -40
  138. package/dist/button/Button.js +0 -219
  139. package/dist/button/Button.stories.js +0 -224
  140. package/dist/button/readme.md +0 -93
  141. package/dist/checkbox/Checkbox.stories.js +0 -144
  142. package/dist/checkbox/readme.md +0 -116
  143. package/dist/common/utils.js +0 -42
  144. package/dist/common/variables.js +0 -523
  145. package/dist/date/Date.stories.js +0 -205
  146. package/dist/date/calendar.svg +0 -1
  147. package/dist/date/calendar_dark.svg +0 -1
  148. package/dist/date/readme.md +0 -73
  149. package/dist/dialog/Dialog.stories.js +0 -217
  150. package/dist/dialog/readme.md +0 -32
  151. package/dist/dropdown/Dropdown.stories.js +0 -249
  152. package/dist/dropdown/baseline-arrow_drop_down.svg +0 -1
  153. package/dist/dropdown/baseline-arrow_drop_down_wh.svg +0 -4
  154. package/dist/dropdown/baseline-arrow_drop_up.svg +0 -1
  155. package/dist/dropdown/baseline-arrow_drop_up_wh.svg +0 -4
  156. package/dist/dropdown/readme.md +0 -69
  157. package/dist/footer/Footer.stories.js +0 -94
  158. package/dist/footer/dxc_logo_wht.png +0 -0
  159. package/dist/footer/readme.md +0 -41
  160. package/dist/header/Header.stories.js +0 -176
  161. package/dist/header/close_icon.svg +0 -1
  162. package/dist/header/dxc_logo_black.png +0 -0
  163. package/dist/header/dxc_logo_blk_rgb.svg +0 -6
  164. package/dist/header/dxc_logo_white.png +0 -0
  165. package/dist/header/hamb_menu_black.svg +0 -1
  166. package/dist/header/hamb_menu_white.svg +0 -1
  167. package/dist/header/readme.md +0 -33
  168. package/dist/heading/Heading.js +0 -163
  169. package/dist/input-text/InputText.stories.js +0 -209
  170. package/dist/input-text/error.svg +0 -1
  171. package/dist/input-text/readme.md +0 -91
  172. package/dist/layout/facebook.svg +0 -45
  173. package/dist/layout/linkedin.svg +0 -50
  174. package/dist/layout/twitter.svg +0 -53
  175. package/dist/link/readme.md +0 -51
  176. package/dist/paginator/images/next.svg +0 -3
  177. package/dist/paginator/images/nextPage.svg +0 -3
  178. package/dist/paginator/images/previous.svg +0 -3
  179. package/dist/paginator/images/previousPage.svg +0 -3
  180. package/dist/paginator/readme.md +0 -50
  181. package/dist/progress-bar/ProgressBar.stories.js +0 -280
  182. package/dist/progress-bar/readme.md +0 -63
  183. package/dist/radio/Radio.stories.js +0 -166
  184. package/dist/radio/readme.md +0 -70
  185. package/dist/resultsetTable/arrow_downward-24px_wht.svg +0 -1
  186. package/dist/resultsetTable/arrow_upward-24px_wht.svg +0 -1
  187. package/dist/resultsetTable/unfold_more-24px_wht.svg +0 -1
  188. package/dist/select/Select.js +0 -490
  189. package/dist/select/Select.stories.js +0 -235
  190. package/dist/select/readme.md +0 -72
  191. package/dist/slider/Slider.js +0 -267
  192. package/dist/slider/Slider.stories.js +0 -241
  193. package/dist/slider/readme.md +0 -64
  194. package/dist/spinner/Spinner.js +0 -198
  195. package/dist/spinner/Spinner.stories.js +0 -183
  196. package/dist/spinner/readme.md +0 -65
  197. package/dist/switch/Switch.stories.js +0 -134
  198. package/dist/switch/readme.md +0 -133
  199. package/dist/tabs/Tabs.stories.js +0 -130
  200. package/dist/tabs/readme.md +0 -78
  201. package/dist/tabs-for-sections/TabsForSections.js +0 -92
  202. package/dist/tabs-for-sections/readme.md +0 -78
  203. package/dist/textarea/Textarea.js +0 -238
  204. package/dist/toggle/Toggle.stories.js +0 -297
  205. package/dist/toggle/readme.md +0 -80
  206. package/dist/toggle-group/ToggleGroup.js +0 -223
  207. package/dist/toggle-group/readme.md +0 -82
  208. package/dist/upload/Upload.stories.js +0 -72
  209. package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
  210. package/dist/upload/buttons-upload/upload-button.svg +0 -1
  211. package/dist/upload/dragAndDropArea/upload_drop.svg +0 -4
  212. package/dist/upload/dragAndDropArea/upload_file.svg +0 -4
  213. package/dist/upload/file-upload/audio-icon.svg +0 -4
  214. package/dist/upload/file-upload/close.svg +0 -4
  215. package/dist/upload/file-upload/file-icon.svg +0 -4
  216. package/dist/upload/file-upload/video-icon.svg +0 -4
  217. package/dist/upload/readme.md +0 -37
  218. package/dist/upload/transaction/audio-icon-err.svg +0 -4
  219. package/dist/upload/transaction/audio-icon.svg +0 -4
  220. package/dist/upload/transaction/error-icon.svg +0 -4
  221. package/dist/upload/transaction/file-icon-err.svg +0 -4
  222. package/dist/upload/transaction/file-icon.svg +0 -4
  223. package/dist/upload/transaction/image-icon-err.svg +0 -4
  224. package/dist/upload/transaction/image-icon.svg +0 -4
  225. package/dist/upload/transaction/success-icon.svg +0 -4
  226. package/dist/upload/transaction/video-icon-err.svg +0 -4
  227. package/dist/upload/transaction/video-icon.svg +0 -4
  228. package/dist/wizard/invalid_icon.svg +0 -6
  229. package/dist/wizard/valid_icon.svg +0 -6
  230. package/dist/wizard/validation-wrong.svg +0 -6
  231. package/test/Accordion.test.js +0 -33
  232. package/test/AccordionGroup.test.js +0 -125
  233. package/test/Alert.test.js +0 -53
  234. package/test/Box.test.js +0 -10
  235. package/test/Button.test.js +0 -18
  236. package/test/Card.test.js +0 -30
  237. package/test/Checkbox.test.js +0 -45
  238. package/test/Chip.test.js +0 -25
  239. package/test/Date.test.js +0 -393
  240. package/test/Dialog.test.js +0 -23
  241. package/test/Dropdown.test.js +0 -130
  242. package/test/Footer.test.js +0 -99
  243. package/test/Header.test.js +0 -39
  244. package/test/Heading.test.js +0 -35
  245. package/test/InputText.test.js +0 -240
  246. package/test/Link.test.js +0 -42
  247. package/test/Paginator.test.js +0 -177
  248. package/test/ProgressBar.test.js +0 -35
  249. package/test/Radio.test.js +0 -37
  250. package/test/ResultsetTable.test.js +0 -330
  251. package/test/Select.test.js +0 -192
  252. package/test/Sidenav.test.js +0 -45
  253. package/test/Slider.test.js +0 -82
  254. package/test/Spinner.test.js +0 -27
  255. package/test/Switch.test.js +0 -45
  256. package/test/Table.test.js +0 -36
  257. package/test/Tabs.test.js +0 -109
  258. package/test/TabsForSections.test.js +0 -34
  259. package/test/Tag.test.js +0 -32
  260. package/test/TextArea.test.js +0 -52
  261. package/test/ToggleGroup.test.js +0 -81
  262. package/test/Upload.test.js +0 -60
  263. package/test/Wizard.test.js +0 -130
  264. package/test/mocks/pngMock.js +0 -1
  265. package/test/mocks/svgMock.js +0 -1
@@ -0,0 +1,113 @@
1
+ type Size = "small" | "medium" | "large" | "fillParent";
2
+ type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
+ type Margin = {
4
+ top?: Space;
5
+ bottom?: Space;
6
+ left?: Space;
7
+ right?: Space;
8
+ };
9
+ type Props = {
10
+ /**
11
+ * Text to be placed above the number.
12
+ */
13
+ label?: string;
14
+ /**
15
+ * Name attribute of the input element.
16
+ */
17
+ name?: string;
18
+ /**
19
+ * Value of the input element. If undefined, the component will be uncontrolled and the value will be managed internally by the component.
20
+ */
21
+ value?: string;
22
+ /**
23
+ * Helper text to be placed above the number.
24
+ */
25
+ helperText?: string;
26
+ /**
27
+ * Text to be put as placeholder of the number.
28
+ */
29
+ placeholder?: string;
30
+ /**
31
+ * If true, the component will be disabled.
32
+ */
33
+ disabled?: boolean;
34
+ /**
35
+ * If true, the number will be optional, showing '(Optional)'
36
+ * next to the label. Otherwise, the field will be considered required
37
+ * and an error will be passed as a parameter to the OnBlur and onChange
38
+ * functions when it has not been filled.
39
+ */
40
+ optional?: boolean;
41
+ /**
42
+ * Prefix to be placed before the number value.
43
+ */
44
+ prefix?: string;
45
+ /**
46
+ * Suffix to be placed after the number value.
47
+ */
48
+ suffix?: string;
49
+ /**
50
+ * Minimum value allowed by the number input. If the typed value by the user is
51
+ * lower than min, the onBlur and onChange functions will be called with
52
+ * the current value and an internal error informing that the current
53
+ * value is not correct. If a valid state is reached, the error parameter
54
+ * will be null in both events.
55
+ */
56
+ min?: number;
57
+ /**
58
+ * Maximum value allowed by the number input. If the typed value by the user
59
+ * surpasses max, the onBlur and onChange functions will be called with
60
+ * the current value and an internal error informing that the current
61
+ * value is not correct. If a valid state is reached, the error parameter
62
+ * will be null in both events.
63
+ */
64
+ max?: number;
65
+ /**
66
+ * The step interval to use when using the up and down arrows to adjust the value.
67
+ */
68
+ step?: number;
69
+ /**
70
+ * This function will be called when the user types within the input
71
+ * element of the component. An object including the current value and
72
+ * the error (if the value entered is not valid) will be passed to this
73
+ * function. If there is no error, error will be null.
74
+ */
75
+ onChange?: (val: { value: string; error: string }) => void;
76
+ /**
77
+ * This function will be called when the input element loses the focus.
78
+ * An object including the input value and the error (if the value
79
+ * entered is not valid) will be passed to this function. If there is no error,
80
+ * error will be null.
81
+ */
82
+ onBlur?: (val: { value: string; error: string }) => void;
83
+ /**
84
+ * If it is defined, the component will change its appearance, showing
85
+ * the error below the input component. If it is not defined, the error
86
+ * messages will be managed internally, but never displayed on its own.
87
+ */
88
+ error?: string;
89
+ /**
90
+ * HTML autocomplete attribute. Lets the user specify if any permission the user agent has to provide automated assistance in filling out the input value.
91
+ * Its value must be one of all the possible values of the HTML autocomplete attribute: 'on', 'off', 'email', 'username', 'new-password', ...
92
+ */
93
+ autocomplete?: string;
94
+ /**
95
+ * Size of the margin to be applied to the component ('xxsmall' | 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge' | 'xxlarge').
96
+ * You can pass an object with 'top', 'bottom', 'left' and 'right' properties in order to specify different margin sizes.
97
+ */
98
+ margin?: Space | Margin;
99
+ /**
100
+ * Size of the component ('small' | 'medium' | 'large' | 'fillParent').
101
+ */
102
+ size?: Size;
103
+ /**
104
+ * Value of the tabindex attribute.
105
+ */
106
+ tabIndex?: number;
107
+ /**
108
+ * Reference to the component.
109
+ */
110
+ ref?: React.RefObject<HTMLDivElement>;
111
+ };
112
+
113
+ export default function DxcNumberInput(props: Props): JSX.Element;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@dxc-technology/halstack-react",
3
- "version": "3.2.0",
3
+ "version": "4.0.0",
4
4
  "description": "DXC Halstack React components library",
5
5
  "repository": "dxc-technology/halstack-react",
6
6
  "homepage": "http://developer.dxc.com/tools/react",
@@ -10,11 +10,12 @@
10
10
  "email": "DigitalInsurance@dxc.com",
11
11
  "url": "https://dxc.com"
12
12
  },
13
- "main": "./dist/main.js",
13
+ "main": "./main.js",
14
+ "types": "./main.d.ts",
14
15
  "peerDependencies": {
15
- "react": "^16.8.6",
16
- "react-dom": "^16.8.6",
17
- "styled-components": ">= 4.3.1"
16
+ "react": "^17.0.1",
17
+ "react-dom": "^17.0.1",
18
+ "styled-components": "^5.0.1"
18
19
  },
19
20
  "dependencies": {
20
21
  "@date-io/date-fns": "^1.3.9",
@@ -28,27 +29,34 @@
28
29
  "date-fns": "^2.0.0-beta.4",
29
30
  "moment": "2.24.0",
30
31
  "prop-types": "^15.7.2",
31
- "react-use-scrollspy": "^2.0.0",
32
- "rgb-hex": "^3.0.0"
32
+ "rgb-hex": "^3.0.0",
33
+ "uuid": "^8.3.2"
33
34
  },
34
35
  "scripts": {
35
36
  "test": "jest",
36
37
  "test:watch": "npm test -- --watch --coverage",
37
- "build": "babel src --out-dir dist --copy-files --verbose && node ../scripts/build/copy-readme.js",
38
- "build:watch": "babel src --watch --out-dir dist --copy-files --verbose"
38
+ "build": "babel src --out-dir ../dist --copy-files --verbose && node ../scripts/build/copy-readme.js",
39
+ "build:watch": "babel src --watch --out-dir ../dist --copy-files --verbose",
40
+ "storybook": "start-storybook -p 6006",
41
+ "build-storybook": "build-storybook"
39
42
  },
40
43
  "devDependencies": {
41
44
  "@babel/cli": "^7.6.2",
42
45
  "@babel/core": "^7.6.2",
43
46
  "@babel/plugin-proposal-class-properties": "^7.5.5",
44
- "@babel/plugin-proposal-nullish-coalescing-operator": "^7.13.8",
45
- "@babel/plugin-proposal-optional-chaining": "^7.13.8",
47
+ "@babel/plugin-proposal-nullish-coalescing-operator": "7.13.8",
48
+ "@babel/plugin-proposal-optional-chaining": "7.13.8",
46
49
  "@babel/plugin-transform-runtime": "^7.10.1",
47
50
  "@babel/preset-env": "^7.6.2",
48
51
  "@babel/preset-react": "^7.0.0",
52
+ "@storybook/addon-actions": "^6.4.9",
53
+ "@storybook/addon-essentials": "^6.4.9",
54
+ "@storybook/addon-links": "^6.4.9",
55
+ "@storybook/react": "^6.4.9",
49
56
  "@testing-library/react": "^11.2.5",
50
57
  "babel-jest": "^24.8.0",
51
58
  "babel-loader": "^8.0.6",
59
+ "chromatic": "^6.3.3",
52
60
  "eslint": "^5.16.0",
53
61
  "eslint-config-airbnb": "^17.1.0",
54
62
  "eslint-config-prettier": "^6.7.0",
@@ -57,21 +65,19 @@
57
65
  "eslint-plugin-jsx-a11y": "^6.2.1",
58
66
  "eslint-plugin-react": "^7.13.0",
59
67
  "eslint-plugin-react-hooks": "^4.2.0",
68
+ "eslint-plugin-storybook": "^0.5.5",
60
69
  "identity-obj-proxy": "^3.0.0",
61
70
  "jest": "^25.5.4",
62
- "react": "file:../node_modules/react",
63
- "react-dom": "file:../node_modules/react-dom",
64
- "react-test-renderer": "^16.8.6",
65
- "styled-components": "file:../node_modules/styled-components"
71
+ "react": "^17.0.1",
72
+ "react-dom": "^17.0.1",
73
+ "styled-components": "^5.0.1",
74
+ "react-test-renderer": "^16.8.6"
66
75
  },
67
76
  "jest": {
68
77
  "moduleNameMapper": {
69
78
  "\\.(css|less|scss|sass)$": "identity-obj-proxy",
70
79
  "\\.(svg)$": "<rootDir>/test/mocks/svgMock.js",
71
80
  "\\.(png)$": "<rootDir>/test/mocks/pngMock.js"
72
- },
73
- "transformIgnorePatterns": [
74
- "/node_modules/(?!react-use-scrollspy).+\\.js$"
75
- ]
81
+ }
76
82
  }
77
83
  }
@@ -0,0 +1,66 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.lastIcon = exports.nextIcon = exports.previousIcon = exports.firstIcon = void 0;
9
+
10
+ var _react = _interopRequireDefault(require("react"));
11
+
12
+ var firstIcon = _react["default"].createElement("svg", {
13
+ xmlns: "http://www.w3.org/2000/svg",
14
+ width: "12.41",
15
+ height: "12",
16
+ viewBox: "0 0 12.41 12"
17
+ }, _react["default"].createElement("path", {
18
+ id: "Path_2463",
19
+ "data-name": "Path 2463",
20
+ d: "M18.41,16.59,13.82,12l4.59-4.59L17,6l-6,6,6,6ZM6,6H8V18H6Z",
21
+ transform: "translate(-6 -6)"
22
+ }));
23
+
24
+ exports.firstIcon = firstIcon;
25
+
26
+ var previousIcon = _react["default"].createElement("svg", {
27
+ xmlns: "http://www.w3.org/2000/svg",
28
+ width: "7.41",
29
+ height: "12",
30
+ viewBox: "0 0 7.41 12"
31
+ }, _react["default"].createElement("path", {
32
+ id: "Path_2459",
33
+ "data-name": "Path 2459",
34
+ d: "M15.41,7.41,14,6,8,12l6,6,1.41-1.41L10.83,12Z",
35
+ transform: "translate(-8 -6)"
36
+ }));
37
+
38
+ exports.previousIcon = previousIcon;
39
+
40
+ var nextIcon = _react["default"].createElement("svg", {
41
+ xmlns: "http://www.w3.org/2000/svg",
42
+ width: "7.41",
43
+ height: "12",
44
+ viewBox: "0 0 7.41 12"
45
+ }, _react["default"].createElement("path", {
46
+ id: "Path_2461",
47
+ "data-name": "Path 2461",
48
+ d: "M10,6,8.59,7.41,13.17,12,8.59,16.59,10,18l6-6Z",
49
+ transform: "translate(-8.59 -6)"
50
+ }));
51
+
52
+ exports.nextIcon = nextIcon;
53
+
54
+ var lastIcon = _react["default"].createElement("svg", {
55
+ xmlns: "http://www.w3.org/2000/svg",
56
+ width: "12.41",
57
+ height: "12",
58
+ viewBox: "0 0 12.41 12"
59
+ }, _react["default"].createElement("path", {
60
+ id: "Path_2465",
61
+ "data-name": "Path 2465",
62
+ d: "M5.59,7.41,10.18,12,5.59,16.59,7,18l6-6L7,6ZM16,6h2V18H16Z",
63
+ transform: "translate(-5.59 -6)"
64
+ }));
65
+
66
+ exports.lastIcon = lastIcon;
@@ -25,16 +25,22 @@ var _Button = _interopRequireDefault(require("../button/Button"));
25
25
 
26
26
  var _Select = _interopRequireDefault(require("../select/Select"));
27
27
 
28
- var _previousPage = _interopRequireDefault(require("./images/previousPage.svg"));
28
+ var _Icons = require("./Icons");
29
29
 
30
- var _previous = _interopRequireDefault(require("./images/previous.svg"));
30
+ var _BackgroundColorContext = require("../BackgroundColorContext.js");
31
31
 
32
- var _next = _interopRequireDefault(require("./images/next.svg"));
32
+ function _templateObject9() {
33
+ var data = (0, _taggedTemplateLiteral2["default"])([""]);
33
34
 
34
- var _nextPage = _interopRequireDefault(require("./images/nextPage.svg"));
35
+ _templateObject9 = function _templateObject9() {
36
+ return data;
37
+ };
38
+
39
+ return data;
40
+ }
35
41
 
36
42
  function _templateObject8() {
37
- var data = (0, _taggedTemplateLiteral2["default"])([""]);
43
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n margin-right: ", ";\n margin-left: ", ";\n\n label {\n height: 0px;\n }\n label + .MuiInput-formControl {\n margin-top: 0px;\n }\n"]);
38
44
 
39
45
  _templateObject8 = function _templateObject8() {
40
46
  return data;
@@ -44,7 +50,7 @@ function _templateObject8() {
44
50
  }
45
51
 
46
52
  function _templateObject7() {
47
- var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n margin-right: 30px;\n label {\n height: 0px;\n }\n\n label + .MuiInput-formControl {\n margin-top: 0px;\n }\n"]);
53
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n width: 100%;\n justify-content: flex-end;\n align-items: center;\n margin: 0 ", " 0 ", ";\n"]);
48
54
 
49
55
  _templateObject7 = function _templateObject7() {
50
56
  return data;
@@ -54,7 +60,7 @@ function _templateObject7() {
54
60
  }
55
61
 
56
62
  function _templateObject6() {
57
- var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n width: 100%;\n justify-content: flex-end;\n align-items: center;\n margin: 0 40px 0 20px;\n font-size: ", ";\n"]);
63
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n margin-right: ", ";\n margin-left: ", ";\n"]);
58
64
 
59
65
  _templateObject6 = function _templateObject6() {
60
66
  return data;
@@ -64,7 +70,7 @@ function _templateObject6() {
64
70
  }
65
71
 
66
72
  function _templateObject5() {
67
- var data = (0, _taggedTemplateLiteral2["default"])(["\n margin-right: 30px;\n"]);
73
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n margin-right: 10px;\n margin-left: 10px;\n"]);
68
74
 
69
75
  _templateObject5 = function _templateObject5() {
70
76
  return data;
@@ -74,7 +80,7 @@ function _templateObject5() {
74
80
  }
75
81
 
76
82
  function _templateObject4() {
77
- var data = (0, _taggedTemplateLiteral2["default"])(["\n margin-right: 10px;\n margin-left: 10px;\n"]);
83
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n margin-right: 15px;\n"]);
78
84
 
79
85
  _templateObject4 = function _templateObject4() {
80
86
  return data;
@@ -84,7 +90,7 @@ function _templateObject4() {
84
90
  }
85
91
 
86
92
  function _templateObject3() {
87
- var data = (0, _taggedTemplateLiteral2["default"])(["\n margin-right: 15px;\n"]);
93
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n margin-right: ", ";\n margin-left: ", ";\n\n label {\n height: 0px;\n }\n label + .MuiInput-formControl {\n margin-top: 0px;\n }\n"]);
88
94
 
89
95
  _templateObject3 = function _templateObject3() {
90
96
  return data;
@@ -94,7 +100,7 @@ function _templateObject3() {
94
100
  }
95
101
 
96
102
  function _templateObject2() {
97
- var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n margin-right: 30px;\n label {\n height: 0px;\n }\n\n label + .MuiInput-formControl {\n margin-top: 0px;\n }\n"]);
103
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n max-width: 100px;\n"]);
98
104
 
99
105
  _templateObject2 = function _templateObject2() {
100
106
  return data;
@@ -104,7 +110,7 @@ function _templateObject2() {
104
110
  }
105
111
 
106
112
  function _templateObject() {
107
- var data = (0, _taggedTemplateLiteral2["default"])(["\n font-size: ", ";\n display: flex;\n height: 64px;\n width: 100%;\n font-family: ", ";\n background-color: ", ";\n color: ", ";\n button {\n &:disabled {\n background-color: transparent !important;\n opacity: 0.3 !important;\n }\n }\n"]);
113
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n height: ", ";\n width: ", ";\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n font-style: ", ";\n text-transform: ", ";\n background-color: ", ";\n color: ", ";\n\n button {\n &:disabled {\n background-color: transparent !important;\n opacity: 0.3 !important;\n }\n }\n"]);
108
114
 
109
115
  _templateObject = function _templateObject() {
110
116
  return data;
@@ -133,20 +139,27 @@ var DxcPaginator = function DxcPaginator(_ref) {
133
139
  var colorsTheme = (0, _useTheme["default"])();
134
140
  return _react["default"].createElement(_styledComponents.ThemeProvider, {
135
141
  theme: colorsTheme.paginator
142
+ }, _react["default"].createElement(_BackgroundColorContext.BackgroundColorProvider, {
143
+ color: colorsTheme.paginator.backgroundColor
136
144
  }, _react["default"].createElement(DxcPaginatorContainer, {
137
145
  disabled: currentPageInternal === 1
138
- }, _react["default"].createElement(LabelsContainer, null, itemsPerPageOptions && _react["default"].createElement(ItemsPageContainer, null, _react["default"].createElement(ItemsLabel, null, "Items per page "), _react["default"].createElement(_Select["default"], {
146
+ }, _react["default"].createElement(LabelsContainer, null, itemsPerPageOptions && _react["default"].createElement(ItemsPageContainer, null, _react["default"].createElement(ItemsLabel, null, "Items per page "), _react["default"].createElement(SelectContainer, null, _react["default"].createElement(_Select["default"], {
139
147
  options: itemsPerPageOptions.map(function (num) {
140
148
  return {
141
- label: num,
142
- value: num
149
+ label: num.toString(),
150
+ value: num.toString()
143
151
  };
144
152
  }),
145
- onChange: itemsPerPageFunction,
146
- value: itemsPerPage,
147
- size: "small",
153
+ onChange: function onChange(newValue) {
154
+ itemsPerPageFunction(Number(newValue.value));
155
+ },
156
+ value: itemsPerPage.toString(),
157
+ size: "fillParent",
158
+ margin: {
159
+ top: "xsmall"
160
+ },
148
161
  tabIndex: tabIndex
149
- })), _react["default"].createElement(TotalItemsContainer, null, minItemsPerPage, " to ", maxItemsPerPage, " of ", totalItems), onPageChange && _react["default"].createElement(_Button["default"], {
162
+ }))), _react["default"].createElement(TotalItemsContainer, null, minItemsPerPage, " to ", maxItemsPerPage, " of ", totalItems), onPageChange && _react["default"].createElement(_Button["default"], {
150
163
  size: "small",
151
164
  mode: "secondary",
152
165
  disabled: currentPageInternal === 1 || currentPageInternal === 0,
@@ -154,7 +167,7 @@ var DxcPaginator = function DxcPaginator(_ref) {
154
167
  left: "xxsmall",
155
168
  right: "xxsmall"
156
169
  },
157
- iconSrc: _previousPage["default"],
170
+ icon: _Icons.firstIcon,
158
171
  tabIndex: tabIndex,
159
172
  onClick: function onClick() {
160
173
  onPageChange(1);
@@ -167,23 +180,28 @@ var DxcPaginator = function DxcPaginator(_ref) {
167
180
  left: "xxsmall",
168
181
  right: "xxsmall"
169
182
  },
170
- iconSrc: _previous["default"],
183
+ icon: _Icons.previousIcon,
171
184
  tabIndex: tabIndex,
172
185
  onClick: function onClick() {
173
186
  onPageChange(currentPage - 1);
174
187
  }
175
- }), showGoToPage && _react["default"].createElement(PageToSelectContainer, null, _react["default"].createElement(GoToLabel, null, "Go to page: "), _react["default"].createElement(_Select["default"], {
188
+ }), showGoToPage && _react["default"].createElement(PageToSelectContainer, null, _react["default"].createElement(GoToLabel, null, "Go to page: "), _react["default"].createElement(SelectContainer, null, _react["default"].createElement(_Select["default"], {
176
189
  options: (0, _toConsumableArray2["default"])(Array(totalPages).keys()).map(function (num) {
177
190
  return {
178
- label: num + 1,
179
- value: num + 1
191
+ label: (num + 1).toString(),
192
+ value: (num + 1).toString()
180
193
  };
181
194
  }),
182
- onChange: onPageChange,
183
- value: currentPage,
184
- size: "small",
195
+ onChange: function onChange(newValue) {
196
+ onPageChange(Number(newValue.value));
197
+ },
198
+ value: currentPage.toString(),
199
+ size: "fillParent",
200
+ margin: {
201
+ top: "xsmall"
202
+ },
185
203
  tabIndex: tabIndex
186
- })) || _react["default"].createElement(TextContainer, null, "Page: ", currentPageInternal, " of ", totalPages), onPageChange && _react["default"].createElement(_Button["default"], {
204
+ }))) || _react["default"].createElement(TextContainer, null, "Page: ", currentPageInternal, " of ", totalPages), onPageChange && _react["default"].createElement(_Button["default"], {
187
205
  size: "small",
188
206
  mode: "secondary",
189
207
  disabled: currentPageInternal === totalPages,
@@ -191,7 +209,7 @@ var DxcPaginator = function DxcPaginator(_ref) {
191
209
  left: "xxsmall",
192
210
  right: "xxsmall"
193
211
  },
194
- iconSrc: _next["default"],
212
+ icon: _Icons.nextIcon,
195
213
  tabIndex: tabIndex,
196
214
  onClick: function onClick() {
197
215
  onPageChange(currentPage + 1);
@@ -204,39 +222,65 @@ var DxcPaginator = function DxcPaginator(_ref) {
204
222
  left: "xxsmall",
205
223
  right: "xxsmall"
206
224
  },
207
- iconSrc: _nextPage["default"],
225
+ icon: _Icons.lastIcon,
208
226
  tabIndex: tabIndex,
209
227
  onClick: function onClick() {
210
228
  onPageChange(totalPages);
211
229
  }
212
- }))));
230
+ })))));
213
231
  };
214
232
 
215
233
  var DxcPaginatorContainer = _styledComponents["default"].div(_templateObject(), function (props) {
216
- return props.theme.fontSizeBase;
234
+ return props.theme.height;
235
+ }, function (props) {
236
+ return props.theme.width;
217
237
  }, function (props) {
218
238
  return props.theme.fontFamily;
219
239
  }, function (props) {
220
- return props.theme.paginatorBackgroundColor;
240
+ return props.theme.fontSize;
241
+ }, function (props) {
242
+ return props.theme.fontWeight;
221
243
  }, function (props) {
222
- return props.theme.paginatorFontColor;
244
+ return props.theme.fontStyle;
245
+ }, function (props) {
246
+ return props.theme.fontTextTransform;
247
+ }, function (props) {
248
+ return props.theme.backgroundColor;
249
+ }, function (props) {
250
+ return props.theme.fontColor;
223
251
  });
224
252
 
225
- var ItemsPageContainer = _styledComponents["default"].span(_templateObject2());
253
+ var SelectContainer = _styledComponents["default"].div(_templateObject2());
226
254
 
227
- var ItemsLabel = _styledComponents["default"].span(_templateObject3());
255
+ var ItemsPageContainer = _styledComponents["default"].span(_templateObject3(), function (props) {
256
+ return props.theme.itemsPerPageSelectorMarginRight;
257
+ }, function (props) {
258
+ return props.theme.itemsPerPageSelectorMarginLeft;
259
+ });
228
260
 
229
- var GoToLabel = _styledComponents["default"].span(_templateObject4());
261
+ var ItemsLabel = _styledComponents["default"].span(_templateObject4());
230
262
 
231
- var TotalItemsContainer = _styledComponents["default"].span(_templateObject5());
263
+ var GoToLabel = _styledComponents["default"].span(_templateObject5());
232
264
 
233
- var LabelsContainer = _styledComponents["default"].div(_templateObject6(), function (props) {
234
- return props.theme.fontSize;
265
+ var TotalItemsContainer = _styledComponents["default"].span(_templateObject6(), function (props) {
266
+ return props.theme.totalItemsContainerMarginRight;
267
+ }, function (props) {
268
+ return props.theme.totalItemsContainerMarginLeft;
269
+ });
270
+
271
+ var LabelsContainer = _styledComponents["default"].div(_templateObject7(), function (props) {
272
+ return props.theme.marginRight;
273
+ }, function (props) {
274
+ return props.theme.marginLeft;
235
275
  });
236
276
 
237
- var PageToSelectContainer = _styledComponents["default"].span(_templateObject7());
277
+ var PageToSelectContainer = _styledComponents["default"].span(_templateObject8(), function (props) {
278
+ return props.theme.pageSelectorMarginRight;
279
+ }, function (props) {
280
+ return props.theme.pageSelectorMarginLeft;
281
+ });
238
282
 
239
- var TextContainer = _styledComponents["default"].span(_templateObject8());
283
+ var TextContainer = _styledComponents["default"].span(_templateObject9());
240
284
 
241
285
  DxcPaginator.propTypes = {
242
286
  currentPage: _propTypes["default"].number,
@@ -0,0 +1,20 @@
1
+ type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
2
+ type Margin = {
3
+ top?: Space;
4
+ bottom?: Space;
5
+ left?: Space;
6
+ right?: Space;
7
+ };
8
+
9
+ type Props = {
10
+ currentPage?: number;
11
+ itemsPerPage?: number;
12
+ itemsPerPageOptions?: number[];
13
+ totalItems?: number
14
+ showGoToPage?: boolean,
15
+ onPageChange?: void;
16
+ itemsPerPageFunction?: void;
17
+ tabIndex?: number;
18
+ };
19
+
20
+ export default function DxcPaginator(props: Props): JSX.Element;