@dxc-technology/halstack-react 0.0.0-c7d5596 → 0.0.0-c7ec4d1

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 (199) hide show
  1. package/README.md +1 -1
  2. package/babel.config.js +6 -2
  3. package/dist/BackgroundColorContext.js +46 -0
  4. package/dist/ThemeContext.js +237 -2
  5. package/dist/V3Select/V3Select.js +549 -0
  6. package/dist/V3Textarea/V3Textarea.js +264 -0
  7. package/dist/accordion/Accordion.js +152 -67
  8. package/dist/accordion-group/AccordionGroup.js +186 -0
  9. package/dist/alert/Alert.js +183 -84
  10. package/dist/alert/index.d.ts +51 -0
  11. package/dist/badge/Badge.js +63 -0
  12. package/dist/box/Box.js +31 -23
  13. package/dist/button/Button.js +63 -27
  14. package/dist/card/Card.js +72 -35
  15. package/dist/checkbox/Checkbox.js +99 -40
  16. package/dist/chip/Chip.js +97 -40
  17. package/dist/common/RequiredComponent.js +2 -8
  18. package/dist/common/utils.js +2 -22
  19. package/dist/common/variables.js +1452 -304
  20. package/dist/date/Date.js +80 -57
  21. package/dist/date-input/DateInput.js +400 -0
  22. package/dist/date-input/index.d.ts +95 -0
  23. package/dist/dialog/Dialog.js +58 -37
  24. package/dist/dropdown/Dropdown.js +177 -82
  25. package/dist/file-input/FileInput.js +644 -0
  26. package/dist/file-input/FileItem.js +287 -0
  27. package/dist/file-input/index.d.ts +81 -0
  28. package/dist/footer/Footer.js +90 -40
  29. package/dist/footer/Icons.js +77 -0
  30. package/dist/header/Header.js +192 -95
  31. package/dist/header/Icons.js +59 -0
  32. package/dist/heading/Heading.js +93 -16
  33. package/dist/input-text/Icons.js +22 -0
  34. package/dist/input-text/InputText.js +251 -116
  35. package/dist/layout/ApplicationLayout.js +18 -26
  36. package/dist/layout/Icons.js +55 -0
  37. package/dist/link/Link.js +89 -41
  38. package/dist/main.d.ts +8 -0
  39. package/dist/main.js +98 -18
  40. package/dist/number-input/NumberInput.js +136 -0
  41. package/dist/number-input/NumberInputContext.js +16 -0
  42. package/dist/number-input/index.d.ts +113 -0
  43. package/dist/paginator/Icons.js +66 -0
  44. package/dist/paginator/Paginator.js +122 -66
  45. package/dist/password-input/PasswordInput.js +203 -0
  46. package/dist/password-input/index.d.ts +94 -0
  47. package/dist/progress-bar/ProgressBar.js +95 -38
  48. package/dist/radio/Radio.js +31 -17
  49. package/dist/resultsetTable/ResultsetTable.js +82 -65
  50. package/dist/select/Select.js +896 -284
  51. package/dist/select/index.d.ts +53 -0
  52. package/dist/sidenav/Sidenav.js +66 -15
  53. package/dist/slider/Slider.js +211 -73
  54. package/dist/spinner/Spinner.js +247 -59
  55. package/dist/switch/Switch.js +50 -27
  56. package/dist/table/Table.js +51 -24
  57. package/dist/tabs/Tabs.js +193 -35
  58. package/dist/tag/Tag.js +68 -35
  59. package/dist/text-input/TextInput.js +974 -0
  60. package/dist/text-input/index.d.ts +135 -0
  61. package/dist/textarea/Textarea.js +248 -106
  62. package/dist/textarea/index.d.ts +117 -0
  63. package/dist/toggle/Toggle.js +16 -19
  64. package/dist/toggle-group/ToggleGroup.js +142 -41
  65. package/dist/upload/Upload.js +16 -11
  66. package/dist/upload/buttons-upload/ButtonsUpload.js +32 -19
  67. package/dist/upload/buttons-upload/Icons.js +40 -0
  68. package/dist/upload/dragAndDropArea/DragAndDropArea.js +84 -34
  69. package/dist/upload/dragAndDropArea/Icons.js +39 -0
  70. package/dist/upload/file-upload/FileToUpload.js +64 -33
  71. package/dist/upload/file-upload/Icons.js +66 -0
  72. package/dist/upload/files-upload/FilesToUpload.js +16 -16
  73. package/dist/upload/transaction/Icons.js +160 -0
  74. package/dist/upload/transaction/Transaction.js +42 -49
  75. package/dist/upload/transactions/Transactions.js +38 -20
  76. package/dist/useTheme.js +22 -0
  77. package/dist/wizard/Icons.js +65 -0
  78. package/dist/wizard/Wizard.js +125 -60
  79. package/package.json +14 -11
  80. package/test/AccordionGroup.test.js +125 -0
  81. package/test/Date.test.js +49 -45
  82. package/test/DateInput.test.js +242 -0
  83. package/test/Dropdown.test.js +15 -0
  84. package/test/FileInput.test.js +201 -0
  85. package/test/Footer.test.js +2 -7
  86. package/test/Header.test.js +5 -10
  87. package/test/Heading.test.js +60 -12
  88. package/test/InputText.test.js +53 -41
  89. package/test/Link.test.js +12 -2
  90. package/test/NumberInput.test.js +259 -0
  91. package/test/Paginator.test.js +50 -77
  92. package/test/PasswordInput.test.js +83 -0
  93. package/test/ResultsetTable.test.js +61 -25
  94. package/test/Slider.test.js +9 -17
  95. package/test/Spinner.test.js +5 -0
  96. package/test/Tabs.test.js +21 -0
  97. package/test/TextInput.test.js +732 -0
  98. package/test/Textarea.test.js +193 -0
  99. package/test/ToggleGroup.test.js +5 -1
  100. package/test/Upload.test.js +5 -5
  101. package/test/{Select.test.js → V3Select.test.js} +67 -46
  102. package/test/{TextArea.test.js → V3TextArea.test.js} +6 -7
  103. package/dist/accordion/Accordion.stories.js +0 -207
  104. package/dist/accordion/readme.md +0 -96
  105. package/dist/alert/Alert.stories.js +0 -158
  106. package/dist/alert/close.svg +0 -4
  107. package/dist/alert/error.svg +0 -4
  108. package/dist/alert/info.svg +0 -4
  109. package/dist/alert/readme.md +0 -43
  110. package/dist/alert/success.svg +0 -4
  111. package/dist/alert/warning.svg +0 -4
  112. package/dist/button/Button.stories.js +0 -224
  113. package/dist/button/readme.md +0 -93
  114. package/dist/checkbox/Checkbox.stories.js +0 -144
  115. package/dist/checkbox/readme.md +0 -116
  116. package/dist/common/services/example-service.js +0 -10
  117. package/dist/common/services/example-service.test.js +0 -12
  118. package/dist/date/Date.stories.js +0 -205
  119. package/dist/date/calendar.svg +0 -1
  120. package/dist/date/calendar_dark.svg +0 -1
  121. package/dist/date/readme.md +0 -73
  122. package/dist/dialog/Dialog.stories.js +0 -217
  123. package/dist/dialog/readme.md +0 -32
  124. package/dist/dropdown/Dropdown.stories.js +0 -249
  125. package/dist/dropdown/baseline-arrow_drop_down.svg +0 -1
  126. package/dist/dropdown/baseline-arrow_drop_down_wh.svg +0 -4
  127. package/dist/dropdown/baseline-arrow_drop_up.svg +0 -1
  128. package/dist/dropdown/baseline-arrow_drop_up_wh.svg +0 -4
  129. package/dist/dropdown/readme.md +0 -69
  130. package/dist/footer/Footer.stories.js +0 -94
  131. package/dist/footer/dxc_logo_wht.png +0 -0
  132. package/dist/footer/readme.md +0 -41
  133. package/dist/header/Header.stories.js +0 -176
  134. package/dist/header/close_icon.svg +0 -1
  135. package/dist/header/dxc_logo_black.png +0 -0
  136. package/dist/header/dxc_logo_blk_rgb.svg +0 -6
  137. package/dist/header/dxc_logo_white.png +0 -0
  138. package/dist/header/hamb_menu_black.svg +0 -1
  139. package/dist/header/hamb_menu_white.svg +0 -1
  140. package/dist/header/readme.md +0 -33
  141. package/dist/input-text/InputText.stories.js +0 -209
  142. package/dist/input-text/error.svg +0 -1
  143. package/dist/input-text/readme.md +0 -91
  144. package/dist/layout/facebook.svg +0 -45
  145. package/dist/layout/linkedin.svg +0 -50
  146. package/dist/layout/twitter.svg +0 -53
  147. package/dist/link/readme.md +0 -51
  148. package/dist/paginator/images/next.svg +0 -3
  149. package/dist/paginator/images/nextPage.svg +0 -3
  150. package/dist/paginator/images/previous.svg +0 -3
  151. package/dist/paginator/images/previousPage.svg +0 -3
  152. package/dist/paginator/readme.md +0 -50
  153. package/dist/progress-bar/ProgressBar.stories.js +0 -280
  154. package/dist/progress-bar/readme.md +0 -63
  155. package/dist/radio/Radio.stories.js +0 -166
  156. package/dist/radio/readme.md +0 -70
  157. package/dist/resultsetTable/arrow_downward-24px_wht.svg +0 -1
  158. package/dist/resultsetTable/arrow_upward-24px_wht.svg +0 -1
  159. package/dist/resultsetTable/unfold_more-24px_wht.svg +0 -1
  160. package/dist/select/Select.stories.js +0 -235
  161. package/dist/select/readme.md +0 -72
  162. package/dist/slider/Slider.stories.js +0 -241
  163. package/dist/slider/readme.md +0 -64
  164. package/dist/spinner/Spinner.stories.js +0 -183
  165. package/dist/spinner/readme.md +0 -65
  166. package/dist/switch/Switch.stories.js +0 -134
  167. package/dist/switch/readme.md +0 -133
  168. package/dist/tabs/Tabs.stories.js +0 -130
  169. package/dist/tabs/readme.md +0 -78
  170. package/dist/tabs-for-sections/TabsForSections.js +0 -92
  171. package/dist/tabs-for-sections/readme.md +0 -78
  172. package/dist/toggle/Toggle.stories.js +0 -297
  173. package/dist/toggle/readme.md +0 -80
  174. package/dist/toggle-group/readme.md +0 -82
  175. package/dist/upload/Upload.stories.js +0 -72
  176. package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
  177. package/dist/upload/buttons-upload/upload-button.svg +0 -1
  178. package/dist/upload/dragAndDropArea/upload_drop.svg +0 -4
  179. package/dist/upload/dragAndDropArea/upload_file.svg +0 -4
  180. package/dist/upload/file-upload/audio-icon.svg +0 -4
  181. package/dist/upload/file-upload/close.svg +0 -4
  182. package/dist/upload/file-upload/file-icon.svg +0 -4
  183. package/dist/upload/file-upload/video-icon.svg +0 -4
  184. package/dist/upload/readme.md +0 -37
  185. package/dist/upload/transaction/audio-icon-err.svg +0 -4
  186. package/dist/upload/transaction/audio-icon.svg +0 -4
  187. package/dist/upload/transaction/error-icon.svg +0 -4
  188. package/dist/upload/transaction/file-icon-err.svg +0 -4
  189. package/dist/upload/transaction/file-icon.svg +0 -4
  190. package/dist/upload/transaction/image-icon-err.svg +0 -4
  191. package/dist/upload/transaction/image-icon.svg +0 -4
  192. package/dist/upload/transaction/success-icon.svg +0 -4
  193. package/dist/upload/transaction/video-icon-err.svg +0 -4
  194. package/dist/upload/transaction/video-icon.svg +0 -4
  195. package/dist/wizard/invalid_icon.svg +0 -6
  196. package/dist/wizard/valid_icon.svg +0 -6
  197. package/dist/wizard/validation-wrong.svg +0 -6
  198. package/test/TabsForSections.test.js +0 -34
  199. package/test/Toggle.test.js +0 -43
@@ -0,0 +1,136 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports["default"] = void 0;
9
+
10
+ var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
11
+
12
+ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
13
+
14
+ var _react = _interopRequireDefault(require("react"));
15
+
16
+ var _propTypes = _interopRequireDefault(require("prop-types"));
17
+
18
+ var _styledComponents = _interopRequireDefault(require("styled-components"));
19
+
20
+ var _TextInput = _interopRequireDefault(require("../text-input/TextInput"));
21
+
22
+ var _NumberInputContext = _interopRequireDefault(require("./NumberInputContext"));
23
+
24
+ var _variables = require("../common/variables.js");
25
+
26
+ function _templateObject() {
27
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n // Chrome, Safari, Edge, Opera\n input::-webkit-outer-spin-button,\n input::-webkit-inner-spin-button {\n -webkit-appearance: none;\n margin: 0;\n }\n\n // Firefox\n input[type=\"number\"] {\n -moz-appearance: textfield;\n }\n"]);
28
+
29
+ _templateObject = function _templateObject() {
30
+ return data;
31
+ };
32
+
33
+ return data;
34
+ }
35
+
36
+ var DxcNumberInput = _react["default"].forwardRef(function (_ref, ref) {
37
+ var _ref$label = _ref.label,
38
+ label = _ref$label === void 0 ? "" : _ref$label,
39
+ _ref$name = _ref.name,
40
+ name = _ref$name === void 0 ? "" : _ref$name,
41
+ value = _ref.value,
42
+ _ref$helperText = _ref.helperText,
43
+ helperText = _ref$helperText === void 0 ? "" : _ref$helperText,
44
+ _ref$placeholder = _ref.placeholder,
45
+ placeholder = _ref$placeholder === void 0 ? "" : _ref$placeholder,
46
+ _ref$disabled = _ref.disabled,
47
+ disabled = _ref$disabled === void 0 ? false : _ref$disabled,
48
+ _ref$optional = _ref.optional,
49
+ optional = _ref$optional === void 0 ? false : _ref$optional,
50
+ _ref$prefix = _ref.prefix,
51
+ prefix = _ref$prefix === void 0 ? "" : _ref$prefix,
52
+ _ref$suffix = _ref.suffix,
53
+ suffix = _ref$suffix === void 0 ? "" : _ref$suffix,
54
+ min = _ref.min,
55
+ max = _ref.max,
56
+ step = _ref.step,
57
+ onChange = _ref.onChange,
58
+ onBlur = _ref.onBlur,
59
+ _ref$error = _ref.error,
60
+ error = _ref$error === void 0 ? "" : _ref$error,
61
+ _ref$autocomplete = _ref.autocomplete,
62
+ autocomplete = _ref$autocomplete === void 0 ? "off" : _ref$autocomplete,
63
+ margin = _ref.margin,
64
+ _ref$size = _ref.size,
65
+ size = _ref$size === void 0 ? "medium" : _ref$size,
66
+ _ref$tabIndex = _ref.tabIndex,
67
+ tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
68
+ return _react["default"].createElement(_NumberInputContext["default"].Provider, {
69
+ value: {
70
+ typeNumber: "number",
71
+ minNumber: min,
72
+ maxNumber: max,
73
+ stepNumber: step
74
+ }
75
+ }, _react["default"].createElement(NumberInputContainer, null, _react["default"].createElement(_TextInput["default"], {
76
+ label: label,
77
+ name: name,
78
+ value: value,
79
+ helperText: helperText,
80
+ placeholder: placeholder,
81
+ disabled: disabled,
82
+ optional: optional,
83
+ prefix: prefix,
84
+ suffix: suffix,
85
+ error: error,
86
+ onChange: onChange,
87
+ onBlur: onBlur,
88
+ autocomplete: autocomplete,
89
+ margin: margin,
90
+ size: size,
91
+ tabIndex: tabIndex,
92
+ ref: ref
93
+ })));
94
+ });
95
+
96
+ var sizes = {
97
+ small: "240px",
98
+ medium: "360px",
99
+ large: "480px",
100
+ fillParent: "100%"
101
+ };
102
+
103
+ var NumberInputContainer = _styledComponents["default"].div(_templateObject());
104
+
105
+ DxcNumberInput.propTypes = {
106
+ label: _propTypes["default"].string,
107
+ name: _propTypes["default"].string,
108
+ value: _propTypes["default"].string,
109
+ helperText: _propTypes["default"].string,
110
+ placeholder: _propTypes["default"].string,
111
+ error: _propTypes["default"].string,
112
+ disabled: _propTypes["default"].bool,
113
+ optional: _propTypes["default"].bool,
114
+ prefix: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].shape({
115
+ type: _propTypes["default"].oneOf(["svg"])
116
+ })]),
117
+ suffix: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].shape({
118
+ type: _propTypes["default"].oneOf(["svg"])
119
+ })]),
120
+ min: _propTypes["default"].number,
121
+ max: _propTypes["default"].number,
122
+ step: _propTypes["default"].number,
123
+ onChange: _propTypes["default"].func,
124
+ onBlur: _propTypes["default"].func,
125
+ autocomplete: _propTypes["default"].string,
126
+ margin: _propTypes["default"].oneOfType([_propTypes["default"].shape({
127
+ top: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
128
+ bottom: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
129
+ left: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
130
+ right: _propTypes["default"].oneOf(Object.keys(_variables.spaces))
131
+ }), _propTypes["default"].oneOf((0, _toConsumableArray2["default"])(Object.keys(_variables.spaces)))]),
132
+ size: _propTypes["default"].oneOf((0, _toConsumableArray2["default"])(Object.keys(sizes))),
133
+ tabIndex: _propTypes["default"].number
134
+ };
135
+ var _default = DxcNumberInput;
136
+ exports["default"] = _default;
@@ -0,0 +1,16 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports["default"] = void 0;
9
+
10
+ var _react = _interopRequireDefault(require("react"));
11
+
12
+ /* eslint-disable prefer-template */
13
+ var NumberInputContext = _react["default"].createContext();
14
+
15
+ var _default = NumberInputContext;
16
+ exports["default"] = _default;
@@ -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;
@@ -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;
@@ -11,34 +11,46 @@ exports["default"] = void 0;
11
11
 
12
12
  var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
13
13
 
14
- var _react = _interopRequireWildcard(require("react"));
14
+ var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
15
+
16
+ var _react = _interopRequireDefault(require("react"));
15
17
 
16
18
  var _styledComponents = _interopRequireWildcard(require("styled-components"));
17
19
 
18
- var _variables = require("../common/variables.js");
20
+ var _propTypes = _interopRequireDefault(require("prop-types"));
19
21
 
20
- var _ThemeContext = _interopRequireDefault(require("../ThemeContext.js"));
22
+ var _useTheme = _interopRequireDefault(require("../useTheme.js"));
21
23
 
22
- var _utils = require("../common/utils.js");
24
+ var _Button = _interopRequireDefault(require("../button/Button"));
23
25
 
24
- var _propTypes = _interopRequireDefault(require("prop-types"));
26
+ var _V3Select = _interopRequireDefault(require("../V3Select/V3Select"));
25
27
 
26
- var _Button = _interopRequireDefault(require("../button/Button"));
28
+ var _Icons = require("./Icons");
27
29
 
28
- var _Select = _interopRequireDefault(require("../select/Select"));
30
+ var _BackgroundColorContext = require("../BackgroundColorContext.js");
29
31
 
30
- var _previousPage = _interopRequireDefault(require("./images/previousPage.svg"));
32
+ function _templateObject8() {
33
+ var data = (0, _taggedTemplateLiteral2["default"])([""]);
34
+
35
+ _templateObject8 = function _templateObject8() {
36
+ return data;
37
+ };
31
38
 
32
- var _previous = _interopRequireDefault(require("./images/previous.svg"));
39
+ return data;
40
+ }
33
41
 
34
- var _next = _interopRequireDefault(require("./images/next.svg"));
42
+ function _templateObject7() {
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"]);
35
44
 
36
- var _nextPage = _interopRequireDefault(require("./images/nextPage.svg"));
45
+ _templateObject7 = function _templateObject7() {
46
+ return data;
47
+ };
37
48
 
38
- require("../common/OpenSans.css");
49
+ return data;
50
+ }
39
51
 
40
52
  function _templateObject6() {
41
- var data = (0, _taggedTemplateLiteral2["default"])([""]);
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"]);
42
54
 
43
55
  _templateObject6 = function _templateObject6() {
44
56
  return data;
@@ -48,7 +60,7 @@ function _templateObject6() {
48
60
  }
49
61
 
50
62
  function _templateObject5() {
51
- 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: 14px;\n"]);
63
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n margin-right: ", ";\n margin-left: ", ";\n"]);
52
64
 
53
65
  _templateObject5 = function _templateObject5() {
54
66
  return data;
@@ -58,7 +70,7 @@ function _templateObject5() {
58
70
  }
59
71
 
60
72
  function _templateObject4() {
61
- 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"]);
62
74
 
63
75
  _templateObject4 = function _templateObject4() {
64
76
  return data;
@@ -78,7 +90,7 @@ function _templateObject3() {
78
90
  }
79
91
 
80
92
  function _templateObject2() {
81
- 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"]);
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"]);
82
94
 
83
95
  _templateObject2 = function _templateObject2() {
84
96
  return data;
@@ -88,7 +100,7 @@ function _templateObject2() {
88
100
  }
89
101
 
90
102
  function _templateObject() {
91
- var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n height: 64px;\n width: 100%;\n background-color: ", ";\n color: ", ";\n button {\n &:disabled {\n background-color: transparent !important;\n opacity: 0.3 !important;\n }\n }\n"]);
103
+ 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"]);
92
104
 
93
105
  _templateObject = function _templateObject() {
94
106
  return data;
@@ -105,29 +117,34 @@ var DxcPaginator = function DxcPaginator(_ref) {
105
117
  itemsPerPageOptions = _ref.itemsPerPageOptions,
106
118
  _ref$totalItems = _ref.totalItems,
107
119
  totalItems = _ref$totalItems === void 0 ? 1 : _ref$totalItems,
108
- nextFunction = _ref.nextFunction,
109
- prevFunction = _ref.prevFunction,
110
- lastFunction = _ref.lastFunction,
111
- firstFunction = _ref.firstFunction,
112
- itemsPerPageFunction = _ref.itemsPerPageFunction;
120
+ showGoToPage = _ref.showGoToPage,
121
+ onPageChange = _ref.onPageChange,
122
+ itemsPerPageFunction = _ref.itemsPerPageFunction,
123
+ _ref$tabIndex = _ref.tabIndex,
124
+ tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
113
125
  var totalPages = Math.ceil(totalItems / itemsPerPage);
114
126
  var currentPageInternal = currentPage === -1 ? totalPages : currentPage;
115
127
  var minItemsPerPage = currentPageInternal === 1 || currentPageInternal === 0 ? currentPageInternal : (currentPageInternal - 1) * itemsPerPage + 1;
116
128
  var maxItemsPerPage = minItemsPerPage - 1 + itemsPerPage > totalItems ? totalItems : minItemsPerPage - 1 + itemsPerPage;
117
- var customTheme = (0, _react.useContext)(_ThemeContext["default"]);
118
- var colorsTheme = (0, _react.useMemo)(function () {
119
- return (0, _utils.getCustomTheme)(_variables.theme, (0, _utils.getCustomTheme)(_variables.defaultTheme, customTheme));
120
- }, [customTheme]);
129
+ var colorsTheme = (0, _useTheme["default"])();
121
130
  return _react["default"].createElement(_styledComponents.ThemeProvider, {
122
131
  theme: colorsTheme.paginator
132
+ }, _react["default"].createElement(_BackgroundColorContext.BackgroundColorProvider, {
133
+ color: colorsTheme.paginator.backgroundColor
123
134
  }, _react["default"].createElement(DxcPaginatorContainer, {
124
135
  disabled: currentPageInternal === 1
125
- }, _react["default"].createElement(LabelsContainer, null, itemsPerPageOptions && _react["default"].createElement(ItemsPageContainer, null, _react["default"].createElement(ItemsLabel, null, "Items per page "), _react["default"].createElement(_Select["default"], {
126
- options: itemsPerPageOptions,
136
+ }, _react["default"].createElement(LabelsContainer, null, itemsPerPageOptions && _react["default"].createElement(ItemsPageContainer, null, _react["default"].createElement(ItemsLabel, null, "Items per page "), _react["default"].createElement(_V3Select["default"], {
137
+ options: itemsPerPageOptions.map(function (num) {
138
+ return {
139
+ label: num,
140
+ value: num
141
+ };
142
+ }),
127
143
  onChange: itemsPerPageFunction,
128
144
  value: itemsPerPage,
129
- size: "small"
130
- })), _react["default"].createElement(TotalItemsContainer, null, minItemsPerPage, " to ", maxItemsPerPage, " of ", totalItems), firstFunction && _react["default"].createElement(_Button["default"], {
145
+ size: "small",
146
+ tabIndex: tabIndex
147
+ })), _react["default"].createElement(TotalItemsContainer, null, minItemsPerPage, " to ", maxItemsPerPage, " of ", totalItems), onPageChange && _react["default"].createElement(_Button["default"], {
131
148
  size: "small",
132
149
  mode: "secondary",
133
150
  disabled: currentPageInternal === 1 || currentPageInternal === 0,
@@ -135,13 +152,12 @@ var DxcPaginator = function DxcPaginator(_ref) {
135
152
  left: "xxsmall",
136
153
  right: "xxsmall"
137
154
  },
138
- iconSrc: _previousPage["default"],
155
+ icon: _Icons.firstIcon,
156
+ tabIndex: tabIndex,
139
157
  onClick: function onClick() {
140
- if (firstFunction) {
141
- firstFunction();
142
- }
158
+ onPageChange(1);
143
159
  }
144
- }), prevFunction && _react["default"].createElement(_Button["default"], {
160
+ }), onPageChange && _react["default"].createElement(_Button["default"], {
145
161
  size: "small",
146
162
  mode: "secondary",
147
163
  disabled: currentPageInternal === 1 || currentPageInternal === 0,
@@ -149,13 +165,23 @@ var DxcPaginator = function DxcPaginator(_ref) {
149
165
  left: "xxsmall",
150
166
  right: "xxsmall"
151
167
  },
152
- iconSrc: _previous["default"],
168
+ icon: _Icons.previousIcon,
169
+ tabIndex: tabIndex,
153
170
  onClick: function onClick() {
154
- if (prevFunction) {
155
- prevFunction();
156
- }
171
+ onPageChange(currentPage - 1);
157
172
  }
158
- }), _react["default"].createElement(TextContainer, null, "Page: ", currentPageInternal, " of ", totalPages), nextFunction && _react["default"].createElement(_Button["default"], {
173
+ }), showGoToPage && _react["default"].createElement(PageToSelectContainer, null, _react["default"].createElement(GoToLabel, null, "Go to page: "), _react["default"].createElement(_V3Select["default"], {
174
+ options: (0, _toConsumableArray2["default"])(Array(totalPages).keys()).map(function (num) {
175
+ return {
176
+ label: num + 1,
177
+ value: num + 1
178
+ };
179
+ }),
180
+ onChange: onPageChange,
181
+ value: currentPage,
182
+ size: "small",
183
+ tabIndex: tabIndex
184
+ })) || _react["default"].createElement(TextContainer, null, "Page: ", currentPageInternal, " of ", totalPages), onPageChange && _react["default"].createElement(_Button["default"], {
159
185
  size: "small",
160
186
  mode: "secondary",
161
187
  disabled: currentPageInternal === totalPages,
@@ -163,13 +189,12 @@ var DxcPaginator = function DxcPaginator(_ref) {
163
189
  left: "xxsmall",
164
190
  right: "xxsmall"
165
191
  },
166
- iconSrc: _next["default"],
192
+ icon: _Icons.nextIcon,
193
+ tabIndex: tabIndex,
167
194
  onClick: function onClick() {
168
- if (nextFunction) {
169
- nextFunction();
170
- }
195
+ onPageChange(currentPage + 1);
171
196
  }
172
- }), lastFunction && _react["default"].createElement(_Button["default"], {
197
+ }), onPageChange && _react["default"].createElement(_Button["default"], {
173
198
  size: "small",
174
199
  mode: "secondary",
175
200
  disabled: currentPageInternal === totalPages,
@@ -177,51 +202,82 @@ var DxcPaginator = function DxcPaginator(_ref) {
177
202
  left: "xxsmall",
178
203
  right: "xxsmall"
179
204
  },
180
- iconSrc: _nextPage["default"],
205
+ icon: _Icons.lastIcon,
206
+ tabIndex: tabIndex,
181
207
  onClick: function onClick() {
182
- if (lastFunction) {
183
- lastFunction(totalPages);
184
- }
208
+ onPageChange(totalPages);
185
209
  }
186
- }))));
210
+ })))));
187
211
  };
188
212
 
189
213
  var DxcPaginatorContainer = _styledComponents["default"].div(_templateObject(), function (props) {
190
- return props.theme.paginatorBackgroundColor;
214
+ return props.theme.height;
191
215
  }, function (props) {
192
- return props.theme.paginatorFontColor;
216
+ return props.theme.width;
217
+ }, function (props) {
218
+ return props.theme.fontFamily;
219
+ }, function (props) {
220
+ return props.theme.fontSize;
221
+ }, function (props) {
222
+ return props.theme.fontWeight;
223
+ }, function (props) {
224
+ return props.theme.fontStyle;
225
+ }, function (props) {
226
+ return props.theme.fontTextTransform;
227
+ }, function (props) {
228
+ return props.theme.backgroundColor;
229
+ }, function (props) {
230
+ return props.theme.fontColor;
193
231
  });
194
232
 
195
- var ItemsPageContainer = _styledComponents["default"].span(_templateObject2());
233
+ var ItemsPageContainer = _styledComponents["default"].span(_templateObject2(), function (props) {
234
+ return props.theme.itemsPerPageSelectorMarginRight;
235
+ }, function (props) {
236
+ return props.theme.itemsPerPageSelectorMarginLeft;
237
+ });
196
238
 
197
239
  var ItemsLabel = _styledComponents["default"].span(_templateObject3());
198
240
 
199
- var TotalItemsContainer = _styledComponents["default"].span(_templateObject4());
241
+ var GoToLabel = _styledComponents["default"].span(_templateObject4());
200
242
 
201
- var LabelsContainer = _styledComponents["default"].div(_templateObject5());
243
+ var TotalItemsContainer = _styledComponents["default"].span(_templateObject5(), function (props) {
244
+ return props.theme.totalItemsContainerMarginRight;
245
+ }, function (props) {
246
+ return props.theme.totalItemsContainerMarginLeft;
247
+ });
248
+
249
+ var LabelsContainer = _styledComponents["default"].div(_templateObject6(), function (props) {
250
+ return props.theme.marginRight;
251
+ }, function (props) {
252
+ return props.theme.marginLeft;
253
+ });
254
+
255
+ var PageToSelectContainer = _styledComponents["default"].span(_templateObject7(), function (props) {
256
+ return props.theme.pageSelectorMarginRight;
257
+ }, function (props) {
258
+ return props.theme.pageSelectorMarginLeft;
259
+ });
202
260
 
203
- var TextContainer = _styledComponents["default"].span(_templateObject6());
261
+ var TextContainer = _styledComponents["default"].span(_templateObject8());
204
262
 
205
263
  DxcPaginator.propTypes = {
206
264
  currentPage: _propTypes["default"].number,
207
265
  itemsPerPage: _propTypes["default"].number,
208
266
  itemsPerPageOptions: _propTypes["default"].arrayOf(_propTypes["default"].number),
209
267
  totalItems: _propTypes["default"].number.isRequired,
210
- nextFunction: _propTypes["default"].func,
211
- prevFunction: _propTypes["default"].func,
212
- lastFunction: _propTypes["default"].func,
213
- firstFunction: _propTypes["default"].func,
214
- itemsPerPageFunction: _propTypes["default"].func
268
+ showGoToPage: _propTypes["default"].bool,
269
+ onPageChange: _propTypes["default"].func,
270
+ itemsPerPageFunction: _propTypes["default"].func,
271
+ tabIndex: _propTypes["default"].number
215
272
  };
216
273
  DxcPaginator.defaultProps = {
217
274
  currentPage: 1,
218
275
  itemsPerPage: 5,
219
276
  itemsPerPageOptions: null,
220
- nextFunction: null,
221
- prevFunction: null,
222
- lastFunction: null,
223
- firstFunction: null,
224
- itemsPerPageFunction: null
277
+ showGoToPage: false,
278
+ onPageChange: null,
279
+ itemsPerPageFunction: null,
280
+ tabIndex: 0
225
281
  };
226
282
  var _default = DxcPaginator;
227
283
  exports["default"] = _default;