@dxc-technology/halstack-react 0.0.0-e628009 → 0.0.0-e690193

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 (136) hide show
  1. package/README.md +27 -47
  2. package/dist/index.d.mts +3923 -0
  3. package/dist/index.d.ts +3923 -0
  4. package/dist/index.js +14133 -0
  5. package/dist/index.mjs +14045 -0
  6. package/package.json +92 -68
  7. package/babel.config.js +0 -8
  8. package/dist/BackgroundColorContext.js +0 -46
  9. package/dist/ThemeContext.js +0 -248
  10. package/dist/V3Textarea/V3Textarea.js +0 -264
  11. package/dist/accordion/Accordion.js +0 -353
  12. package/dist/accordion-group/AccordionGroup.js +0 -186
  13. package/dist/alert/Alert.js +0 -403
  14. package/dist/alert/index.d.ts +0 -51
  15. package/dist/badge/Badge.js +0 -63
  16. package/dist/box/Box.js +0 -156
  17. package/dist/button/Button.js +0 -238
  18. package/dist/card/Card.js +0 -254
  19. package/dist/checkbox/Checkbox.js +0 -300
  20. package/dist/chip/Chip.js +0 -265
  21. package/dist/common/OpenSans.css +0 -81
  22. package/dist/common/RequiredComponent.js +0 -40
  23. package/dist/common/fonts/OpenSans-Bold.ttf +0 -0
  24. package/dist/common/fonts/OpenSans-BoldItalic.ttf +0 -0
  25. package/dist/common/fonts/OpenSans-ExtraBold.ttf +0 -0
  26. package/dist/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  27. package/dist/common/fonts/OpenSans-Italic.ttf +0 -0
  28. package/dist/common/fonts/OpenSans-Light.ttf +0 -0
  29. package/dist/common/fonts/OpenSans-LightItalic.ttf +0 -0
  30. package/dist/common/fonts/OpenSans-Regular.ttf +0 -0
  31. package/dist/common/fonts/OpenSans-SemiBold.ttf +0 -0
  32. package/dist/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  33. package/dist/common/utils.js +0 -22
  34. package/dist/common/variables.js +0 -1569
  35. package/dist/date/Date.js +0 -379
  36. package/dist/date-input/DateInput.js +0 -400
  37. package/dist/date-input/index.d.ts +0 -95
  38. package/dist/dialog/Dialog.js +0 -218
  39. package/dist/dropdown/Dropdown.js +0 -544
  40. package/dist/file-input/FileInput.js +0 -644
  41. package/dist/file-input/FileItem.js +0 -280
  42. package/dist/file-input/index.d.ts +0 -81
  43. package/dist/footer/Footer.js +0 -421
  44. package/dist/footer/Icons.js +0 -77
  45. package/dist/header/Header.js +0 -434
  46. package/dist/header/Icons.js +0 -59
  47. package/dist/heading/Heading.js +0 -230
  48. package/dist/input-text/Icons.js +0 -22
  49. package/dist/input-text/InputText.js +0 -705
  50. package/dist/layout/ApplicationLayout.js +0 -327
  51. package/dist/layout/Icons.js +0 -55
  52. package/dist/link/Link.js +0 -237
  53. package/dist/main.d.ts +0 -8
  54. package/dist/main.js +0 -367
  55. package/dist/new-select/NewSelect.js +0 -836
  56. package/dist/new-select/index.d.ts +0 -53
  57. package/dist/number-input/NumberInput.js +0 -136
  58. package/dist/number-input/NumberInputContext.js +0 -16
  59. package/dist/number-input/index.d.ts +0 -113
  60. package/dist/paginator/Icons.js +0 -66
  61. package/dist/paginator/Paginator.js +0 -283
  62. package/dist/password-input/PasswordInput.js +0 -198
  63. package/dist/password-input/index.d.ts +0 -94
  64. package/dist/progress-bar/ProgressBar.js +0 -242
  65. package/dist/radio/Radio.js +0 -209
  66. package/dist/resultsetTable/ResultsetTable.js +0 -358
  67. package/dist/select/Select.js +0 -549
  68. package/dist/sidenav/Sidenav.js +0 -179
  69. package/dist/slider/Slider.js +0 -404
  70. package/dist/spinner/Spinner.js +0 -381
  71. package/dist/switch/Switch.js +0 -222
  72. package/dist/table/Table.js +0 -132
  73. package/dist/tabs/Tabs.js +0 -343
  74. package/dist/tabs-for-sections/TabsForSections.js +0 -92
  75. package/dist/tag/Tag.js +0 -282
  76. package/dist/text-input/TextInput.js +0 -971
  77. package/dist/text-input/index.d.ts +0 -135
  78. package/dist/textarea/Textarea.js +0 -369
  79. package/dist/textarea/index.d.ts +0 -117
  80. package/dist/toggle/Toggle.js +0 -220
  81. package/dist/toggle-group/ToggleGroup.js +0 -327
  82. package/dist/upload/Upload.js +0 -205
  83. package/dist/upload/buttons-upload/ButtonsUpload.js +0 -135
  84. package/dist/upload/buttons-upload/Icons.js +0 -40
  85. package/dist/upload/dragAndDropArea/DragAndDropArea.js +0 -329
  86. package/dist/upload/dragAndDropArea/Icons.js +0 -39
  87. package/dist/upload/file-upload/FileToUpload.js +0 -189
  88. package/dist/upload/file-upload/Icons.js +0 -66
  89. package/dist/upload/files-upload/FilesToUpload.js +0 -123
  90. package/dist/upload/transaction/Icons.js +0 -160
  91. package/dist/upload/transaction/Transaction.js +0 -148
  92. package/dist/upload/transactions/Transactions.js +0 -138
  93. package/dist/useTheme.js +0 -22
  94. package/dist/wizard/Icons.js +0 -65
  95. package/dist/wizard/Wizard.js +0 -405
  96. package/test/Accordion.test.js +0 -33
  97. package/test/AccordionGroup.test.js +0 -125
  98. package/test/Alert.test.js +0 -53
  99. package/test/Box.test.js +0 -10
  100. package/test/Button.test.js +0 -18
  101. package/test/Card.test.js +0 -30
  102. package/test/Checkbox.test.js +0 -45
  103. package/test/Chip.test.js +0 -25
  104. package/test/Date.test.js +0 -397
  105. package/test/DateInput.test.js +0 -242
  106. package/test/Dialog.test.js +0 -23
  107. package/test/Dropdown.test.js +0 -145
  108. package/test/FileInput.test.js +0 -201
  109. package/test/Footer.test.js +0 -94
  110. package/test/Header.test.js +0 -34
  111. package/test/Heading.test.js +0 -83
  112. package/test/InputText.test.js +0 -248
  113. package/test/Link.test.js +0 -43
  114. package/test/NumberInput.test.js +0 -259
  115. package/test/Paginator.test.js +0 -177
  116. package/test/PasswordInput.test.js +0 -83
  117. package/test/ProgressBar.test.js +0 -35
  118. package/test/Radio.test.js +0 -37
  119. package/test/ResultsetTable.test.js +0 -329
  120. package/test/Select.test.js +0 -212
  121. package/test/Sidenav.test.js +0 -45
  122. package/test/Slider.test.js +0 -74
  123. package/test/Spinner.test.js +0 -32
  124. package/test/Switch.test.js +0 -45
  125. package/test/Table.test.js +0 -36
  126. package/test/Tabs.test.js +0 -109
  127. package/test/TabsForSections.test.js +0 -34
  128. package/test/Tag.test.js +0 -32
  129. package/test/TextInput.test.js +0 -732
  130. package/test/Textarea.test.js +0 -193
  131. package/test/ToggleGroup.test.js +0 -85
  132. package/test/Upload.test.js +0 -60
  133. package/test/V3TextArea.test.js +0 -51
  134. package/test/Wizard.test.js +0 -130
  135. package/test/mocks/pngMock.js +0 -1
  136. package/test/mocks/svgMock.js +0 -1
@@ -1,53 +0,0 @@
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;
@@ -1,136 +0,0 @@
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;
@@ -1,16 +0,0 @@
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;
@@ -1,113 +0,0 @@
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;
@@ -1,66 +0,0 @@
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;
@@ -1,283 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
4
-
5
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
6
-
7
- Object.defineProperty(exports, "__esModule", {
8
- value: true
9
- });
10
- exports["default"] = void 0;
11
-
12
- var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
13
-
14
- var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
15
-
16
- var _react = _interopRequireDefault(require("react"));
17
-
18
- var _styledComponents = _interopRequireWildcard(require("styled-components"));
19
-
20
- var _propTypes = _interopRequireDefault(require("prop-types"));
21
-
22
- var _useTheme = _interopRequireDefault(require("../useTheme.js"));
23
-
24
- var _Button = _interopRequireDefault(require("../button/Button"));
25
-
26
- var _Select = _interopRequireDefault(require("../select/Select"));
27
-
28
- var _Icons = require("./Icons");
29
-
30
- var _BackgroundColorContext = require("../BackgroundColorContext.js");
31
-
32
- function _templateObject8() {
33
- var data = (0, _taggedTemplateLiteral2["default"])([""]);
34
-
35
- _templateObject8 = function _templateObject8() {
36
- return data;
37
- };
38
-
39
- return data;
40
- }
41
-
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"]);
44
-
45
- _templateObject7 = function _templateObject7() {
46
- return data;
47
- };
48
-
49
- return data;
50
- }
51
-
52
- function _templateObject6() {
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"]);
54
-
55
- _templateObject6 = function _templateObject6() {
56
- return data;
57
- };
58
-
59
- return data;
60
- }
61
-
62
- function _templateObject5() {
63
- var data = (0, _taggedTemplateLiteral2["default"])(["\n margin-right: ", ";\n margin-left: ", ";\n"]);
64
-
65
- _templateObject5 = function _templateObject5() {
66
- return data;
67
- };
68
-
69
- return data;
70
- }
71
-
72
- function _templateObject4() {
73
- var data = (0, _taggedTemplateLiteral2["default"])(["\n margin-right: 10px;\n margin-left: 10px;\n"]);
74
-
75
- _templateObject4 = function _templateObject4() {
76
- return data;
77
- };
78
-
79
- return data;
80
- }
81
-
82
- function _templateObject3() {
83
- var data = (0, _taggedTemplateLiteral2["default"])(["\n margin-right: 15px;\n"]);
84
-
85
- _templateObject3 = function _templateObject3() {
86
- return data;
87
- };
88
-
89
- return data;
90
- }
91
-
92
- function _templateObject2() {
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"]);
94
-
95
- _templateObject2 = function _templateObject2() {
96
- return data;
97
- };
98
-
99
- return data;
100
- }
101
-
102
- function _templateObject() {
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"]);
104
-
105
- _templateObject = function _templateObject() {
106
- return data;
107
- };
108
-
109
- return data;
110
- }
111
-
112
- var DxcPaginator = function DxcPaginator(_ref) {
113
- var _ref$currentPage = _ref.currentPage,
114
- currentPage = _ref$currentPage === void 0 ? 1 : _ref$currentPage,
115
- _ref$itemsPerPage = _ref.itemsPerPage,
116
- itemsPerPage = _ref$itemsPerPage === void 0 ? 5 : _ref$itemsPerPage,
117
- itemsPerPageOptions = _ref.itemsPerPageOptions,
118
- _ref$totalItems = _ref.totalItems,
119
- totalItems = _ref$totalItems === void 0 ? 1 : _ref$totalItems,
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;
125
- var totalPages = Math.ceil(totalItems / itemsPerPage);
126
- var currentPageInternal = currentPage === -1 ? totalPages : currentPage;
127
- var minItemsPerPage = currentPageInternal === 1 || currentPageInternal === 0 ? currentPageInternal : (currentPageInternal - 1) * itemsPerPage + 1;
128
- var maxItemsPerPage = minItemsPerPage - 1 + itemsPerPage > totalItems ? totalItems : minItemsPerPage - 1 + itemsPerPage;
129
- var colorsTheme = (0, _useTheme["default"])();
130
- return _react["default"].createElement(_styledComponents.ThemeProvider, {
131
- theme: colorsTheme.paginator
132
- }, _react["default"].createElement(_BackgroundColorContext.BackgroundColorProvider, {
133
- color: colorsTheme.paginator.backgroundColor
134
- }, _react["default"].createElement(DxcPaginatorContainer, {
135
- disabled: currentPageInternal === 1
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"], {
137
- options: itemsPerPageOptions.map(function (num) {
138
- return {
139
- label: num,
140
- value: num
141
- };
142
- }),
143
- onChange: itemsPerPageFunction,
144
- value: itemsPerPage,
145
- size: "small",
146
- tabIndex: tabIndex
147
- })), _react["default"].createElement(TotalItemsContainer, null, minItemsPerPage, " to ", maxItemsPerPage, " of ", totalItems), onPageChange && _react["default"].createElement(_Button["default"], {
148
- size: "small",
149
- mode: "secondary",
150
- disabled: currentPageInternal === 1 || currentPageInternal === 0,
151
- margin: {
152
- left: "xxsmall",
153
- right: "xxsmall"
154
- },
155
- icon: _Icons.firstIcon,
156
- tabIndex: tabIndex,
157
- onClick: function onClick() {
158
- onPageChange(1);
159
- }
160
- }), onPageChange && _react["default"].createElement(_Button["default"], {
161
- size: "small",
162
- mode: "secondary",
163
- disabled: currentPageInternal === 1 || currentPageInternal === 0,
164
- margin: {
165
- left: "xxsmall",
166
- right: "xxsmall"
167
- },
168
- icon: _Icons.previousIcon,
169
- tabIndex: tabIndex,
170
- onClick: function onClick() {
171
- onPageChange(currentPage - 1);
172
- }
173
- }), showGoToPage && _react["default"].createElement(PageToSelectContainer, null, _react["default"].createElement(GoToLabel, null, "Go to page: "), _react["default"].createElement(_Select["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"], {
185
- size: "small",
186
- mode: "secondary",
187
- disabled: currentPageInternal === totalPages,
188
- margin: {
189
- left: "xxsmall",
190
- right: "xxsmall"
191
- },
192
- icon: _Icons.nextIcon,
193
- tabIndex: tabIndex,
194
- onClick: function onClick() {
195
- onPageChange(currentPage + 1);
196
- }
197
- }), onPageChange && _react["default"].createElement(_Button["default"], {
198
- size: "small",
199
- mode: "secondary",
200
- disabled: currentPageInternal === totalPages,
201
- margin: {
202
- left: "xxsmall",
203
- right: "xxsmall"
204
- },
205
- icon: _Icons.lastIcon,
206
- tabIndex: tabIndex,
207
- onClick: function onClick() {
208
- onPageChange(totalPages);
209
- }
210
- })))));
211
- };
212
-
213
- var DxcPaginatorContainer = _styledComponents["default"].div(_templateObject(), function (props) {
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;
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;
231
- });
232
-
233
- var ItemsPageContainer = _styledComponents["default"].span(_templateObject2(), function (props) {
234
- return props.theme.itemsPerPageSelectorMarginRight;
235
- }, function (props) {
236
- return props.theme.itemsPerPageSelectorMarginLeft;
237
- });
238
-
239
- var ItemsLabel = _styledComponents["default"].span(_templateObject3());
240
-
241
- var GoToLabel = _styledComponents["default"].span(_templateObject4());
242
-
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
- });
260
-
261
- var TextContainer = _styledComponents["default"].span(_templateObject8());
262
-
263
- DxcPaginator.propTypes = {
264
- currentPage: _propTypes["default"].number,
265
- itemsPerPage: _propTypes["default"].number,
266
- itemsPerPageOptions: _propTypes["default"].arrayOf(_propTypes["default"].number),
267
- totalItems: _propTypes["default"].number.isRequired,
268
- showGoToPage: _propTypes["default"].bool,
269
- onPageChange: _propTypes["default"].func,
270
- itemsPerPageFunction: _propTypes["default"].func,
271
- tabIndex: _propTypes["default"].number
272
- };
273
- DxcPaginator.defaultProps = {
274
- currentPage: 1,
275
- itemsPerPage: 5,
276
- itemsPerPageOptions: null,
277
- showGoToPage: false,
278
- onPageChange: null,
279
- itemsPerPageFunction: null,
280
- tabIndex: 0
281
- };
282
- var _default = DxcPaginator;
283
- exports["default"] = _default;