@dxc-technology/halstack-react 0.0.0-961ed8e → 0.0.0-994f952

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 (147) 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 +215 -32
  5. package/dist/V3Textarea/V3Textarea.js +264 -0
  6. package/dist/accordion/Accordion.js +131 -46
  7. package/dist/accordion-group/AccordionGroup.js +36 -9
  8. package/dist/alert/Alert.js +183 -84
  9. package/dist/alert/index.d.ts +51 -0
  10. package/dist/badge/Badge.js +23 -18
  11. package/dist/box/Box.js +31 -23
  12. package/dist/button/Button.js +61 -25
  13. package/dist/card/Card.js +72 -35
  14. package/dist/checkbox/Checkbox.js +97 -37
  15. package/dist/chip/Chip.js +97 -40
  16. package/dist/common/utils.js +2 -22
  17. package/dist/common/variables.js +1415 -276
  18. package/dist/date/Date.js +74 -52
  19. package/dist/date-input/DateInput.js +400 -0
  20. package/dist/date-input/index.d.ts +95 -0
  21. package/dist/dialog/Dialog.js +58 -37
  22. package/dist/dropdown/Dropdown.js +175 -80
  23. package/dist/file-input/FileInput.js +644 -0
  24. package/dist/file-input/FileItem.js +280 -0
  25. package/dist/file-input/index.d.ts +81 -0
  26. package/dist/footer/Footer.js +90 -40
  27. package/dist/footer/Icons.js +77 -0
  28. package/dist/header/Header.js +154 -93
  29. package/dist/header/Icons.js +59 -0
  30. package/dist/heading/Heading.js +81 -16
  31. package/dist/input-text/Icons.js +22 -0
  32. package/dist/input-text/InputText.js +251 -116
  33. package/dist/layout/ApplicationLayout.js +18 -26
  34. package/dist/layout/Icons.js +55 -0
  35. package/dist/link/Link.js +86 -41
  36. package/dist/main.d.ts +8 -0
  37. package/dist/main.js +71 -7
  38. package/dist/new-select/NewSelect.js +836 -0
  39. package/dist/new-select/index.d.ts +53 -0
  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 +69 -40
  45. package/dist/password-input/PasswordInput.js +198 -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 +79 -48
  50. package/dist/select/Select.js +226 -150
  51. package/dist/sidenav/Sidenav.js +66 -15
  52. package/dist/slider/Slider.js +211 -73
  53. package/dist/spinner/Spinner.js +247 -59
  54. package/dist/switch/Switch.js +50 -27
  55. package/dist/table/Table.js +51 -24
  56. package/dist/tabs/Tabs.js +58 -17
  57. package/dist/tag/Tag.js +68 -35
  58. package/dist/text-input/TextInput.js +971 -0
  59. package/dist/text-input/index.d.ts +135 -0
  60. package/dist/textarea/Textarea.js +248 -106
  61. package/dist/textarea/index.d.ts +117 -0
  62. package/dist/toggle/Toggle.js +16 -19
  63. package/dist/toggle-group/ToggleGroup.js +142 -41
  64. package/dist/upload/Upload.js +16 -11
  65. package/dist/upload/buttons-upload/ButtonsUpload.js +31 -14
  66. package/dist/upload/dragAndDropArea/DragAndDropArea.js +78 -28
  67. package/dist/upload/file-upload/FileToUpload.js +50 -24
  68. package/dist/upload/files-upload/FilesToUpload.js +16 -16
  69. package/dist/upload/readme.md +2 -2
  70. package/dist/upload/transaction/Transaction.js +44 -24
  71. package/dist/upload/transactions/Transactions.js +38 -20
  72. package/dist/wizard/Wizard.js +127 -47
  73. package/dist/wizard/invalid_icon.svg +4 -5
  74. package/dist/wizard/valid_icon.svg +4 -5
  75. package/package.json +7 -2
  76. package/test/AccordionGroup.test.js +16 -0
  77. package/test/Date.test.js +49 -45
  78. package/test/DateInput.test.js +242 -0
  79. package/test/Dropdown.test.js +15 -0
  80. package/test/FileInput.test.js +201 -0
  81. package/test/Footer.test.js +2 -7
  82. package/test/Header.test.js +5 -10
  83. package/test/InputText.test.js +25 -17
  84. package/test/Link.test.js +3 -2
  85. package/test/NumberInput.test.js +259 -0
  86. package/test/Paginator.test.js +1 -1
  87. package/test/PasswordInput.test.js +83 -0
  88. package/test/ResultsetTable.test.js +1 -2
  89. package/test/Select.test.js +44 -24
  90. package/test/Slider.test.js +9 -17
  91. package/test/Spinner.test.js +5 -0
  92. package/test/TextInput.test.js +732 -0
  93. package/test/Textarea.test.js +193 -0
  94. package/test/ToggleGroup.test.js +5 -1
  95. package/test/Upload.test.js +5 -5
  96. package/test/{TextArea.test.js → V3TextArea.test.js} +6 -7
  97. package/dist/accordion/Accordion.stories.js +0 -207
  98. package/dist/accordion/readme.md +0 -96
  99. package/dist/accordion-group/AccordionGroup.stories.js +0 -207
  100. package/dist/accordion-group/readme.md +0 -70
  101. package/dist/alert/Alert.stories.js +0 -158
  102. package/dist/alert/close.svg +0 -4
  103. package/dist/alert/error.svg +0 -4
  104. package/dist/alert/info.svg +0 -4
  105. package/dist/alert/readme.md +0 -43
  106. package/dist/alert/success.svg +0 -4
  107. package/dist/alert/warning.svg +0 -4
  108. package/dist/button/Button.stories.js +0 -224
  109. package/dist/button/readme.md +0 -93
  110. package/dist/common/services/example-service.js +0 -10
  111. package/dist/common/services/example-service.test.js +0 -12
  112. package/dist/date/calendar.svg +0 -1
  113. package/dist/date/calendar_dark.svg +0 -1
  114. package/dist/dialog/Dialog.stories.js +0 -217
  115. package/dist/dialog/readme.md +0 -32
  116. package/dist/dropdown/Dropdown.stories.js +0 -249
  117. package/dist/dropdown/baseline-arrow_drop_down.svg +0 -1
  118. package/dist/dropdown/baseline-arrow_drop_down_wh.svg +0 -4
  119. package/dist/dropdown/baseline-arrow_drop_up.svg +0 -1
  120. package/dist/dropdown/baseline-arrow_drop_up_wh.svg +0 -4
  121. package/dist/dropdown/readme.md +0 -69
  122. package/dist/footer/Footer.stories.js +0 -94
  123. package/dist/footer/dxc_logo_wht.png +0 -0
  124. package/dist/footer/readme.md +0 -41
  125. package/dist/header/Header.stories.js +0 -176
  126. package/dist/header/close_icon.svg +0 -1
  127. package/dist/header/dxc_logo_black.png +0 -0
  128. package/dist/header/dxc_logo_blk_rgb.svg +0 -6
  129. package/dist/header/dxc_logo_white.png +0 -0
  130. package/dist/header/hamb_menu_black.svg +0 -1
  131. package/dist/header/hamb_menu_white.svg +0 -1
  132. package/dist/header/readme.md +0 -33
  133. package/dist/input-text/InputText.stories.js +0 -209
  134. package/dist/input-text/error.svg +0 -1
  135. package/dist/input-text/readme.md +0 -91
  136. package/dist/layout/facebook.svg +0 -45
  137. package/dist/layout/linkedin.svg +0 -50
  138. package/dist/layout/twitter.svg +0 -53
  139. package/dist/paginator/images/next.svg +0 -3
  140. package/dist/paginator/images/nextPage.svg +0 -3
  141. package/dist/paginator/images/previous.svg +0 -3
  142. package/dist/paginator/images/previousPage.svg +0 -3
  143. package/dist/paginator/readme.md +0 -50
  144. package/dist/select/Select.stories.js +0 -235
  145. package/dist/select/readme.md +0 -72
  146. package/dist/slider/Slider.stories.js +0 -241
  147. package/dist/toggle-group/readme.md +0 -82
@@ -0,0 +1,53 @@
1
+ type SVG = string | (HTMLElement & SVGElement);
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
+
10
+ type OptionGroup = {
11
+ label: string;
12
+ options: Option[];
13
+ };
14
+ type Option = {
15
+ icon?: string | SVG;
16
+ label: string;
17
+ value: string;
18
+ };
19
+
20
+ type Props = {
21
+ label?: string;
22
+ name?: string;
23
+ value?: string | string[];
24
+ options?: Option[] | OptionGroup[];
25
+ helperText?: string;
26
+ placeholder?: string;
27
+ disabled?: boolean;
28
+ optional?: boolean;
29
+ searchable?: boolean;
30
+ multiple?: boolean;
31
+ onChange?: (value: string | string[]) => void;
32
+ onBlur?: (val: { value: string | string[]; error: string }) => void;
33
+ error?: string;
34
+ /**
35
+ * Size of the margin to be applied to the component ('xxsmall' | 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge' | 'xxlarge').
36
+ * You can pass an object with 'top', 'bottom', 'left' and 'right' properties in order to specify different margin sizes.
37
+ */
38
+ margin?: Space | Margin;
39
+ /**
40
+ * Size of the component ('small' | 'medium' | 'large' | 'fillParent').
41
+ */
42
+ size?: "small" | "medium" | "large" | "fillParent";
43
+ /**
44
+ * Value of the tabindex attribute.
45
+ */
46
+ tabIndex?: number;
47
+ /**
48
+ * Reference to the component.
49
+ */
50
+ ref?: React.RefObject<HTMLDivElement>;
51
+ };
52
+
53
+ export default function DxcNewSelect(props: Props): JSX.Element;
@@ -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;
@@ -13,31 +13,21 @@ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/hel
13
13
 
14
14
  var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
15
15
 
16
- var _react = _interopRequireWildcard(require("react"));
16
+ var _react = _interopRequireDefault(require("react"));
17
17
 
18
18
  var _styledComponents = _interopRequireWildcard(require("styled-components"));
19
19
 
20
- var _variables = require("../common/variables.js");
21
-
22
- var _ThemeContext = _interopRequireDefault(require("../ThemeContext.js"));
23
-
24
- var _utils = require("../common/utils.js");
25
-
26
20
  var _propTypes = _interopRequireDefault(require("prop-types"));
27
21
 
22
+ var _useTheme = _interopRequireDefault(require("../useTheme.js"));
23
+
28
24
  var _Button = _interopRequireDefault(require("../button/Button"));
29
25
 
30
26
  var _Select = _interopRequireDefault(require("../select/Select"));
31
27
 
32
- var _previousPage = _interopRequireDefault(require("./images/previousPage.svg"));
33
-
34
- var _previous = _interopRequireDefault(require("./images/previous.svg"));
35
-
36
- var _next = _interopRequireDefault(require("./images/next.svg"));
28
+ var _Icons = require("./Icons");
37
29
 
38
- var _nextPage = _interopRequireDefault(require("./images/nextPage.svg"));
39
-
40
- require("../common/OpenSans.css");
30
+ var _BackgroundColorContext = require("../BackgroundColorContext.js");
41
31
 
42
32
  function _templateObject8() {
43
33
  var data = (0, _taggedTemplateLiteral2["default"])([""]);
@@ -50,7 +40,7 @@ function _templateObject8() {
50
40
  }
51
41
 
52
42
  function _templateObject7() {
53
- 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"]);
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"]);
54
44
 
55
45
  _templateObject7 = function _templateObject7() {
56
46
  return data;
@@ -60,7 +50,7 @@ function _templateObject7() {
60
50
  }
61
51
 
62
52
  function _templateObject6() {
63
- 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"]);
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"]);
64
54
 
65
55
  _templateObject6 = function _templateObject6() {
66
56
  return data;
@@ -70,7 +60,7 @@ function _templateObject6() {
70
60
  }
71
61
 
72
62
  function _templateObject5() {
73
- var data = (0, _taggedTemplateLiteral2["default"])(["\n margin-right: 30px;\n"]);
63
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n margin-right: ", ";\n margin-left: ", ";\n"]);
74
64
 
75
65
  _templateObject5 = function _templateObject5() {
76
66
  return data;
@@ -100,7 +90,7 @@ function _templateObject3() {
100
90
  }
101
91
 
102
92
  function _templateObject2() {
103
- 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"]);
104
94
 
105
95
  _templateObject2 = function _templateObject2() {
106
96
  return data;
@@ -110,7 +100,7 @@ function _templateObject2() {
110
100
  }
111
101
 
112
102
  function _templateObject() {
113
- 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"]);
114
104
 
115
105
  _templateObject = function _templateObject() {
116
106
  return data;
@@ -129,17 +119,18 @@ var DxcPaginator = function DxcPaginator(_ref) {
129
119
  totalItems = _ref$totalItems === void 0 ? 1 : _ref$totalItems,
130
120
  showGoToPage = _ref.showGoToPage,
131
121
  onPageChange = _ref.onPageChange,
132
- itemsPerPageFunction = _ref.itemsPerPageFunction;
122
+ itemsPerPageFunction = _ref.itemsPerPageFunction,
123
+ _ref$tabIndex = _ref.tabIndex,
124
+ tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
133
125
  var totalPages = Math.ceil(totalItems / itemsPerPage);
134
126
  var currentPageInternal = currentPage === -1 ? totalPages : currentPage;
135
127
  var minItemsPerPage = currentPageInternal === 1 || currentPageInternal === 0 ? currentPageInternal : (currentPageInternal - 1) * itemsPerPage + 1;
136
128
  var maxItemsPerPage = minItemsPerPage - 1 + itemsPerPage > totalItems ? totalItems : minItemsPerPage - 1 + itemsPerPage;
137
- var customTheme = (0, _react.useContext)(_ThemeContext["default"]);
138
- var colorsTheme = (0, _react.useMemo)(function () {
139
- return (0, _utils.getCustomTheme)(_variables.componentTokens, (0, _utils.getCustomTheme)(_variables.defaultTheme, customTheme));
140
- }, [customTheme]);
129
+ var colorsTheme = (0, _useTheme["default"])();
141
130
  return _react["default"].createElement(_styledComponents.ThemeProvider, {
142
131
  theme: colorsTheme.paginator
132
+ }, _react["default"].createElement(_BackgroundColorContext.BackgroundColorProvider, {
133
+ color: colorsTheme.paginator.backgroundColor
143
134
  }, _react["default"].createElement(DxcPaginatorContainer, {
144
135
  disabled: currentPageInternal === 1
145
136
  }, _react["default"].createElement(LabelsContainer, null, itemsPerPageOptions && _react["default"].createElement(ItemsPageContainer, null, _react["default"].createElement(ItemsLabel, null, "Items per page "), _react["default"].createElement(_Select["default"], {
@@ -151,7 +142,8 @@ var DxcPaginator = function DxcPaginator(_ref) {
151
142
  }),
152
143
  onChange: itemsPerPageFunction,
153
144
  value: itemsPerPage,
154
- size: "small"
145
+ size: "small",
146
+ tabIndex: tabIndex
155
147
  })), _react["default"].createElement(TotalItemsContainer, null, minItemsPerPage, " to ", maxItemsPerPage, " of ", totalItems), onPageChange && _react["default"].createElement(_Button["default"], {
156
148
  size: "small",
157
149
  mode: "secondary",
@@ -160,7 +152,8 @@ var DxcPaginator = function DxcPaginator(_ref) {
160
152
  left: "xxsmall",
161
153
  right: "xxsmall"
162
154
  },
163
- iconSrc: _previousPage["default"],
155
+ icon: _Icons.firstIcon,
156
+ tabIndex: tabIndex,
164
157
  onClick: function onClick() {
165
158
  onPageChange(1);
166
159
  }
@@ -172,7 +165,8 @@ var DxcPaginator = function DxcPaginator(_ref) {
172
165
  left: "xxsmall",
173
166
  right: "xxsmall"
174
167
  },
175
- iconSrc: _previous["default"],
168
+ icon: _Icons.previousIcon,
169
+ tabIndex: tabIndex,
176
170
  onClick: function onClick() {
177
171
  onPageChange(currentPage - 1);
178
172
  }
@@ -185,7 +179,8 @@ var DxcPaginator = function DxcPaginator(_ref) {
185
179
  }),
186
180
  onChange: onPageChange,
187
181
  value: currentPage,
188
- size: "small"
182
+ size: "small",
183
+ tabIndex: tabIndex
189
184
  })) || _react["default"].createElement(TextContainer, null, "Page: ", currentPageInternal, " of ", totalPages), onPageChange && _react["default"].createElement(_Button["default"], {
190
185
  size: "small",
191
186
  mode: "secondary",
@@ -194,7 +189,8 @@ var DxcPaginator = function DxcPaginator(_ref) {
194
189
  left: "xxsmall",
195
190
  right: "xxsmall"
196
191
  },
197
- iconSrc: _next["default"],
192
+ icon: _Icons.nextIcon,
193
+ tabIndex: tabIndex,
198
194
  onClick: function onClick() {
199
195
  onPageChange(currentPage + 1);
200
196
  }
@@ -206,30 +202,61 @@ var DxcPaginator = function DxcPaginator(_ref) {
206
202
  left: "xxsmall",
207
203
  right: "xxsmall"
208
204
  },
209
- iconSrc: _nextPage["default"],
205
+ icon: _Icons.lastIcon,
206
+ tabIndex: tabIndex,
210
207
  onClick: function onClick() {
211
208
  onPageChange(totalPages);
212
209
  }
213
- }))));
210
+ })))));
214
211
  };
215
212
 
216
213
  var DxcPaginatorContainer = _styledComponents["default"].div(_templateObject(), function (props) {
217
- return props.theme.paginatorBackgroundColor;
214
+ return props.theme.height;
215
+ }, function (props) {
216
+ return props.theme.width;
217
+ }, function (props) {
218
+ return props.theme.fontFamily;
219
+ }, function (props) {
220
+ return props.theme.fontSize;
218
221
  }, function (props) {
219
- return props.theme.paginatorFontColor;
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;
220
231
  });
221
232
 
222
- 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
+ });
223
238
 
224
239
  var ItemsLabel = _styledComponents["default"].span(_templateObject3());
225
240
 
226
241
  var GoToLabel = _styledComponents["default"].span(_templateObject4());
227
242
 
228
- var TotalItemsContainer = _styledComponents["default"].span(_templateObject5());
243
+ var TotalItemsContainer = _styledComponents["default"].span(_templateObject5(), function (props) {
244
+ return props.theme.totalItemsContainerMarginRight;
245
+ }, function (props) {
246
+ return props.theme.totalItemsContainerMarginLeft;
247
+ });
229
248
 
230
- var LabelsContainer = _styledComponents["default"].div(_templateObject6());
249
+ var LabelsContainer = _styledComponents["default"].div(_templateObject6(), function (props) {
250
+ return props.theme.marginRight;
251
+ }, function (props) {
252
+ return props.theme.marginLeft;
253
+ });
231
254
 
232
- var PageToSelectContainer = _styledComponents["default"].span(_templateObject7());
255
+ var PageToSelectContainer = _styledComponents["default"].span(_templateObject7(), function (props) {
256
+ return props.theme.pageSelectorMarginRight;
257
+ }, function (props) {
258
+ return props.theme.pageSelectorMarginLeft;
259
+ });
233
260
 
234
261
  var TextContainer = _styledComponents["default"].span(_templateObject8());
235
262
 
@@ -240,7 +267,8 @@ DxcPaginator.propTypes = {
240
267
  totalItems: _propTypes["default"].number.isRequired,
241
268
  showGoToPage: _propTypes["default"].bool,
242
269
  onPageChange: _propTypes["default"].func,
243
- itemsPerPageFunction: _propTypes["default"].func
270
+ itemsPerPageFunction: _propTypes["default"].func,
271
+ tabIndex: _propTypes["default"].number
244
272
  };
245
273
  DxcPaginator.defaultProps = {
246
274
  currentPage: 1,
@@ -248,7 +276,8 @@ DxcPaginator.defaultProps = {
248
276
  itemsPerPageOptions: null,
249
277
  showGoToPage: false,
250
278
  onPageChange: null,
251
- itemsPerPageFunction: null
279
+ itemsPerPageFunction: null,
280
+ tabIndex: 0
252
281
  };
253
282
  var _default = DxcPaginator;
254
283
  exports["default"] = _default;