@dxc-technology/halstack-react 0.0.0-933ff75 → 0.0.0-936a23d

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