@dxc-technology/halstack-react 0.0.0-e792e0c → 0.0.0-e832ef8

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 (170) hide show
  1. package/babel.config.js +6 -2
  2. package/dist/BackgroundColorContext.js +46 -0
  3. package/dist/ThemeContext.js +235 -2
  4. package/dist/V3Textarea/V3Textarea.js +264 -0
  5. package/dist/accordion/Accordion.js +170 -81
  6. package/dist/accordion-group/AccordionGroup.js +186 -0
  7. package/dist/alert/Alert.js +184 -83
  8. package/dist/alert/index.d.ts +51 -0
  9. package/dist/badge/Badge.js +63 -0
  10. package/dist/box/Box.js +31 -23
  11. package/dist/button/Button.js +82 -27
  12. package/dist/card/Card.js +72 -35
  13. package/dist/checkbox/Checkbox.js +108 -32
  14. package/dist/chip/Chip.js +129 -35
  15. package/dist/common/RequiredComponent.js +2 -8
  16. package/dist/common/utils.js +2 -22
  17. package/dist/common/variables.js +1459 -197
  18. package/dist/date/Date.js +86 -64
  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 +226 -94
  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 +122 -47
  27. package/dist/footer/Icons.js +77 -0
  28. package/dist/header/Header.js +171 -91
  29. package/dist/header/Icons.js +59 -0
  30. package/dist/heading/Heading.js +81 -22
  31. package/dist/input-text/Icons.js +22 -0
  32. package/dist/input-text/InputText.js +293 -107
  33. package/dist/layout/ApplicationLayout.js +327 -0
  34. package/dist/layout/Icons.js +55 -0
  35. package/dist/link/Link.js +136 -35
  36. package/dist/main.d.ts +8 -0
  37. package/dist/main.js +111 -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 +162 -57
  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 +97 -44
  48. package/dist/radio/Radio.js +39 -21
  49. package/dist/resultsetTable/ResultsetTable.js +93 -69
  50. package/dist/select/Select.js +250 -143
  51. package/dist/sidenav/Sidenav.js +85 -143
  52. package/dist/slider/Slider.js +219 -73
  53. package/dist/spinner/Spinner.js +249 -64
  54. package/dist/switch/Switch.js +51 -26
  55. package/dist/table/Table.js +63 -15
  56. package/dist/tabs/Tabs.js +208 -35
  57. package/dist/tabs-for-sections/TabsForSections.js +1 -16
  58. package/dist/tag/Tag.js +100 -35
  59. package/dist/text-input/TextInput.js +971 -0
  60. package/dist/text-input/index.d.ts +135 -0
  61. package/dist/textarea/Textarea.js +250 -107
  62. package/dist/textarea/index.d.ts +117 -0
  63. package/dist/toggle/Toggle.js +16 -19
  64. package/dist/toggle-group/ToggleGroup.js +327 -0
  65. package/dist/upload/Upload.js +16 -11
  66. package/dist/upload/buttons-upload/ButtonsUpload.js +35 -25
  67. package/dist/upload/buttons-upload/Icons.js +40 -0
  68. package/dist/upload/dragAndDropArea/DragAndDropArea.js +78 -31
  69. package/dist/upload/file-upload/FileToUpload.js +64 -33
  70. package/dist/upload/file-upload/Icons.js +66 -0
  71. package/dist/upload/files-upload/FilesToUpload.js +16 -16
  72. package/dist/upload/readme.md +2 -2
  73. package/dist/upload/transaction/Icons.js +160 -0
  74. package/dist/upload/transaction/Transaction.js +42 -49
  75. package/dist/upload/transactions/Transactions.js +38 -20
  76. package/dist/useTheme.js +22 -0
  77. package/dist/wizard/Icons.js +65 -0
  78. package/dist/wizard/Wizard.js +141 -56
  79. package/package.json +14 -6
  80. package/test/AccordionGroup.test.js +125 -0
  81. package/test/Date.test.js +49 -45
  82. package/test/DateInput.test.js +242 -0
  83. package/test/Dropdown.test.js +19 -4
  84. package/test/FileInput.test.js +201 -0
  85. package/test/Footer.test.js +2 -7
  86. package/test/Header.test.js +5 -10
  87. package/test/InputText.test.js +53 -41
  88. package/test/Link.test.js +25 -7
  89. package/test/NumberInput.test.js +259 -0
  90. package/test/Paginator.test.js +72 -60
  91. package/test/PasswordInput.test.js +83 -0
  92. package/test/ResultsetTable.test.js +66 -19
  93. package/test/Select.test.js +55 -34
  94. package/test/Sidenav.test.js +22 -64
  95. package/test/Slider.test.js +24 -15
  96. package/test/Spinner.test.js +5 -0
  97. package/test/Tabs.test.js +21 -0
  98. package/test/TextInput.test.js +732 -0
  99. package/test/Textarea.test.js +193 -0
  100. package/test/ToggleGroup.test.js +85 -0
  101. package/test/Upload.test.js +5 -5
  102. package/test/{TextArea.test.js → V3TextArea.test.js} +6 -7
  103. package/dist/accordion/Accordion.stories.js +0 -207
  104. package/dist/accordion/readme.md +0 -96
  105. package/dist/alert/Alert.stories.js +0 -158
  106. package/dist/alert/close.svg +0 -4
  107. package/dist/alert/error.svg +0 -4
  108. package/dist/alert/info.svg +0 -4
  109. package/dist/alert/readme.md +0 -43
  110. package/dist/alert/success.svg +0 -4
  111. package/dist/alert/warning.svg +0 -4
  112. package/dist/button/Button.stories.js +0 -224
  113. package/dist/button/readme.md +0 -93
  114. package/dist/common/services/example-service.js +0 -10
  115. package/dist/common/services/example-service.test.js +0 -12
  116. package/dist/date/calendar.svg +0 -1
  117. package/dist/date/calendar_dark.svg +0 -1
  118. package/dist/dialog/Dialog.stories.js +0 -217
  119. package/dist/dialog/readme.md +0 -32
  120. package/dist/dropdown/Dropdown.stories.js +0 -249
  121. package/dist/dropdown/baseline-arrow_drop_down.svg +0 -1
  122. package/dist/dropdown/baseline-arrow_drop_down_wh.svg +0 -4
  123. package/dist/dropdown/baseline-arrow_drop_up.svg +0 -1
  124. package/dist/dropdown/baseline-arrow_drop_up_wh.svg +0 -4
  125. package/dist/dropdown/readme.md +0 -69
  126. package/dist/footer/Footer.stories.js +0 -94
  127. package/dist/footer/dxc_logo_wht.png +0 -0
  128. package/dist/footer/readme.md +0 -41
  129. package/dist/header/Header.stories.js +0 -176
  130. package/dist/header/close_icon.svg +0 -1
  131. package/dist/header/dxc_logo_black.png +0 -0
  132. package/dist/header/dxc_logo_white.png +0 -0
  133. package/dist/header/hamb_menu_black.svg +0 -1
  134. package/dist/header/hamb_menu_white.svg +0 -1
  135. package/dist/header/readme.md +0 -33
  136. package/dist/input-text/InputText.stories.js +0 -209
  137. package/dist/input-text/error.svg +0 -1
  138. package/dist/input-text/readme.md +0 -91
  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/resultsetTable/arrow_downward-24px_wht.svg +0 -1
  145. package/dist/resultsetTable/arrow_upward-24px_wht.svg +0 -1
  146. package/dist/resultsetTable/unfold_more-24px_wht.svg +0 -1
  147. package/dist/select/Select.stories.js +0 -235
  148. package/dist/select/readme.md +0 -72
  149. package/dist/sidenav/arrow_icon.svg +0 -3
  150. package/dist/slider/Slider.stories.js +0 -241
  151. package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
  152. package/dist/upload/buttons-upload/upload-button.svg +0 -1
  153. package/dist/upload/file-upload/audio-icon.svg +0 -4
  154. package/dist/upload/file-upload/close.svg +0 -4
  155. package/dist/upload/file-upload/file-icon.svg +0 -4
  156. package/dist/upload/file-upload/video-icon.svg +0 -4
  157. package/dist/upload/transaction/audio-icon-err.svg +0 -4
  158. package/dist/upload/transaction/audio-icon.svg +0 -4
  159. package/dist/upload/transaction/error-icon.svg +0 -4
  160. package/dist/upload/transaction/file-icon-err.svg +0 -4
  161. package/dist/upload/transaction/file-icon.svg +0 -4
  162. package/dist/upload/transaction/image-icon-err.svg +0 -4
  163. package/dist/upload/transaction/image-icon.svg +0 -4
  164. package/dist/upload/transaction/success-icon.svg +0 -4
  165. package/dist/upload/transaction/video-icon-err.svg +0 -4
  166. package/dist/upload/transaction/video-icon.svg +0 -4
  167. package/dist/wizard/invalid_icon.svg +0 -6
  168. package/dist/wizard/valid_icon.svg +0 -6
  169. package/dist/wizard/validation-wrong.svg +0 -6
  170. package/test/Toggle.test.js +0 -43
@@ -0,0 +1,327 @@
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 _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
15
+
16
+ var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
17
+
18
+ var _react = _interopRequireWildcard(require("react"));
19
+
20
+ var _main = require("../main");
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 _Icons = require("./Icons");
29
+
30
+ var _useTheme = _interopRequireDefault(require("../useTheme.js"));
31
+
32
+ function _templateObject10() {
33
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n justify-content: center;\n position: sticky;\n top: 45vh;\n width: 42px;\n min-height: 42px;\n background-color: ", ";\n border-radius: 50%;\n transform: ", ";\n transition: transform 0.4s ease-in-out;\n z-index: 1250;\n cursor: pointer;\n & > svg {\n fill: ", ";\n }\n"]);
34
+
35
+ _templateObject10 = function _templateObject10() {
36
+ return data;
37
+ };
38
+
39
+ return data;
40
+ }
41
+
42
+ function _templateObject9() {
43
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n position: absolute;\n height: calc(100vh - 64px);\n left: 279px;\n"]);
44
+
45
+ _templateObject9 = function _templateObject9() {
46
+ return data;
47
+ };
48
+
49
+ return data;
50
+ }
51
+
52
+ function _templateObject8() {
53
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: row;\n z-index: 1200;\n transform: ", ";\n transition: transform 0.4s ease-in-out;\n height: calc(100vh - 64px);\n position: sticky;\n top: 64px;\n"]);
54
+
55
+ _templateObject8 = function _templateObject8() {
56
+ return data;
57
+ };
58
+
59
+ return data;
60
+ }
61
+
62
+ function _templateObject7() {
63
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n flex-grow: 1;\n position: relative;\n min-height: calc(100vh - 184px);\n margin-left: ", ";\n transition: margin 0.4s ease-in-out;\n"]);
64
+
65
+ _templateObject7 = function _templateObject7() {
66
+ return data;
67
+ };
68
+
69
+ return data;
70
+ }
71
+
72
+ function _templateObject6() {
73
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n margin-left: ", ";\n transition: margin 0.4s ease-in-out;\n"]);
74
+
75
+ _templateObject6 = function _templateObject6() {
76
+ return data;
77
+ };
78
+
79
+ return data;
80
+ }
81
+
82
+ function _templateObject5() {
83
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n width: 100%;\n min-width: 0;\n display: flex;\n flex-direction: column;\n"]);
84
+
85
+ _templateObject5 = function _templateObject5() {
86
+ return data;
87
+ };
88
+
89
+ return data;
90
+ }
91
+
92
+ function _templateObject4() {
93
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex: 1 1 auto;\n align-items: flex-start;\n"]);
94
+
95
+ _templateObject4 = function _templateObject4() {
96
+ return data;
97
+ };
98
+
99
+ return data;
100
+ }
101
+
102
+ function _templateObject3() {
103
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n flex: 1;\n display: flex;\n flex-direction: column;\n"]);
104
+
105
+ _templateObject3 = function _templateObject3() {
106
+ return data;
107
+ };
108
+
109
+ return data;
110
+ }
111
+
112
+ function _templateObject2() {
113
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n z-index: 1250;\n position: fixed;\n top: 0;\n left: 0;\n right: 0;\n"]);
114
+
115
+ _templateObject2 = function _templateObject2() {
116
+ return data;
117
+ };
118
+
119
+ return data;
120
+ }
121
+
122
+ function _templateObject() {
123
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n position: absolute;\n top: 64px;\n bottom: 0;\n left: 0;\n right: 0;\n"]);
124
+
125
+ _templateObject = function _templateObject() {
126
+ return data;
127
+ };
128
+
129
+ return data;
130
+ }
131
+
132
+ var year = new Date().getFullYear();
133
+
134
+ var Header = function Header(_ref) {
135
+ var children = _ref.children;
136
+ return _react["default"].createElement(_react["default"].Fragment, null, children);
137
+ };
138
+
139
+ var Main = function Main(_ref2) {
140
+ var children = _ref2.children;
141
+ return _react["default"].createElement(_react["default"].Fragment, null, children);
142
+ };
143
+
144
+ var Footer = function Footer(_ref3) {
145
+ var children = _ref3.children;
146
+ return _react["default"].createElement(_react["default"].Fragment, null, children);
147
+ };
148
+
149
+ var SideNav = function SideNav(props) {
150
+ var displayArrow = props.displayArrow,
151
+ mode = props.mode,
152
+ childProps = (0, _objectWithoutProperties2["default"])(props, ["displayArrow", "mode"]);
153
+ return _react["default"].createElement(_main.DxcSidenav, childProps, childProps.children);
154
+ };
155
+
156
+ SideNav.propTypes = {
157
+ mode: _propTypes["default"].oneOf(["overlay", "push", ""]),
158
+ displayArrow: _propTypes["default"].bool,
159
+ padding: _propTypes["default"].oneOfType([_propTypes["default"].shape({
160
+ top: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
161
+ bottom: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
162
+ left: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
163
+ right: _propTypes["default"].oneOf(Object.keys(_variables.spaces))
164
+ })])
165
+ };
166
+
167
+ var defaultFooter = function defaultFooter() {
168
+ return _react["default"].createElement(_main.DxcFooter, {
169
+ copyright: "\xA9 DXC Technology ".concat(year, "\u200B\u200B\u200B\u200B. All rights reserved."),
170
+ bottomLinks: [{
171
+ href: "https://www.linkedin.com/company/dxctechnology",
172
+ text: "Linkedin"
173
+ }, {
174
+ href: "https://twitter.com/dxctechnology",
175
+ text: "Twitter"
176
+ }, {
177
+ href: "https://www.facebook.com/DXCTechnology/",
178
+ text: "Facebook"
179
+ }],
180
+ socialLinks: [{
181
+ href: "https://www.linkedin.com/company/dxctechnology",
182
+ logo: _Icons.linkedinLogo
183
+ }, {
184
+ href: "https://twitter.com/dxctechnology",
185
+ logo: _Icons.twitterLogo
186
+ }, {
187
+ href: "https://www.facebook.com/DXCTechnology/",
188
+ logo: _Icons.facebookLogo
189
+ }]
190
+ });
191
+ };
192
+
193
+ var defaultHeader = function defaultHeader() {
194
+ return _react["default"].createElement(_main.DxcHeader, {
195
+ underlined: true
196
+ });
197
+ };
198
+
199
+ var childTypeExists = function childTypeExists(children, childType) {
200
+ return children.find(function (child) {
201
+ return child && child.type && child.type === childType;
202
+ });
203
+ };
204
+
205
+ var DxcApplicationLayout = function DxcApplicationLayout(_ref4) {
206
+ var children = _ref4.children;
207
+ var ref = (0, _react.useRef)(null);
208
+ var colorsTheme = (0, _useTheme["default"])();
209
+
210
+ var _useState = (0, _react.useState)(true),
211
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
212
+ isSideNavVisible = _useState2[0],
213
+ setIsSideNavVisible = _useState2[1];
214
+
215
+ var _useState3 = (0, _react.useState)(),
216
+ _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
217
+ isResponsive = _useState4[0],
218
+ setIsResponsive = _useState4[1];
219
+
220
+ var childrenArray = _react["default"].Children.toArray(children);
221
+
222
+ var header = childTypeExists(childrenArray, _main.DxcHeader) || childTypeExists(childrenArray, Header) || defaultHeader();
223
+ var footer = childTypeExists(childrenArray, _main.DxcFooter) || childTypeExists(childrenArray, Footer) || defaultFooter();
224
+ var sideNav = childTypeExists(childrenArray, SideNav);
225
+ var main = childTypeExists(childrenArray, Main);
226
+ var displayArrow = sideNav && sideNav.props && sideNav.props.displayArrow;
227
+ var sideNavMode = sideNav && sideNav.props && sideNav.props.mode;
228
+
229
+ var ArrowIcon = function ArrowIcon() {
230
+ return _react["default"].createElement("svg", {
231
+ xmlns: "http://www.w3.org/2000/svg",
232
+ width: "15.995",
233
+ height: "10.01",
234
+ viewBox: "0 0 15.995 10.01"
235
+ }, _react["default"].createElement("path", {
236
+ "data-testid": "arrow-to-right",
237
+ d: "M17.71,11.29l-4-4a1,1,0,0,0-1.42,1.42L14.59,11H3a1,1,0,0,0,0,2H14.59l-2.3,2.29a1,1,0,1,0,1.42,1.42l4-4a1.034,1.034,0,0,0,0-1.42Z",
238
+ transform: "translate(-2 -6.996)"
239
+ }));
240
+ };
241
+
242
+ var handleResize = function handleResize(width) {
243
+ if (width) {
244
+ if (width <= _variables.responsiveSizes.tablet ? setIsResponsive(true) : setIsResponsive(false)) ;
245
+ setIsSideNavVisible(true);
246
+ }
247
+ };
248
+
249
+ var handleEventListener = function handleEventListener() {
250
+ handleResize(ref.current.offsetWidth);
251
+ };
252
+
253
+ (0, _react.useEffect)(function () {
254
+ if (ref.current) {
255
+ window.addEventListener("resize", handleEventListener);
256
+ handleResize(ref.current.offsetWidth);
257
+ }
258
+
259
+ return function () {
260
+ window.removeEventListener("resize", handleEventListener);
261
+ };
262
+ }, []);
263
+
264
+ var handleSidenav = function handleSidenav() {
265
+ setIsSideNavVisible(!isSideNavVisible);
266
+ };
267
+
268
+ return _react["default"].createElement(_styledComponents.ThemeProvider, {
269
+ theme: colorsTheme.sidenav
270
+ }, _react["default"].createElement(ApplicationLayoutContainer, {
271
+ ref: ref
272
+ }, _react["default"].createElement(HeaderContainer, null, header), _react["default"].createElement(BodyContainer, null, _react["default"].createElement(ContentContainer, null, _react["default"].createElement(SideNavArrowContainer, {
273
+ isSideNavVisible: isSideNavVisible
274
+ }, sideNav, _react["default"].createElement(ArrowContainer, null, sideNav && (displayArrow || isResponsive) && _react["default"].createElement(ArrowTrigger, {
275
+ tabIndex: 0,
276
+ onClick: handleSidenav,
277
+ isSideNavVisible: isSideNavVisible
278
+ }, _react["default"].createElement(ArrowIcon, null)))), _react["default"].createElement(MainBodyContainer, null, _react["default"].createElement(MainContent, {
279
+ sideNav: sideNav,
280
+ mode: isResponsive ? "overlay" : sideNavMode,
281
+ isSideNavVisible: isSideNavVisible
282
+ }, main), _react["default"].createElement(FooterContainer, {
283
+ sideNav: sideNav,
284
+ mode: isResponsive ? "overlay" : sideNavMode,
285
+ isSideNavVisible: isSideNavVisible
286
+ }, footer))))));
287
+ };
288
+
289
+ DxcApplicationLayout.Header = Header;
290
+ DxcApplicationLayout.Main = Main;
291
+ DxcApplicationLayout.Footer = Footer;
292
+ DxcApplicationLayout.SideNav = SideNav;
293
+
294
+ var ApplicationLayoutContainer = _styledComponents["default"].div(_templateObject());
295
+
296
+ var HeaderContainer = _styledComponents["default"].div(_templateObject2());
297
+
298
+ var BodyContainer = _styledComponents["default"].div(_templateObject3());
299
+
300
+ var ContentContainer = _styledComponents["default"].div(_templateObject4());
301
+
302
+ var MainBodyContainer = _styledComponents["default"].div(_templateObject5());
303
+
304
+ var FooterContainer = _styledComponents["default"].div(_templateObject6(), function (props) {
305
+ return props.sideNav ? props.mode === "push" && !props.isSideNavVisible || props.mode === "overlay" ? "-300px" : "" : "";
306
+ });
307
+
308
+ var MainContent = _styledComponents["default"].div(_templateObject7(), function (props) {
309
+ return props.sideNav ? props.mode === "push" && props.isSideNavVisible ? "" : "-297px" : "";
310
+ });
311
+
312
+ var SideNavArrowContainer = _styledComponents["default"].div(_templateObject8(), function (props) {
313
+ return props.isSideNavVisible ? "translateX(0)" : !props.isSideNavVisible ? "translateX(-100%)" : "";
314
+ });
315
+
316
+ var ArrowContainer = _styledComponents["default"].div(_templateObject9());
317
+
318
+ var ArrowTrigger = _styledComponents["default"].div(_templateObject10(), function (props) {
319
+ return "".concat(props.theme.arrowContainerColor);
320
+ }, function (props) {
321
+ return props.isSideNavVisible ? "rotate(-180deg)" : "rotate(0deg)";
322
+ }, function (props) {
323
+ return props.theme.arrowColor;
324
+ });
325
+
326
+ var _default = DxcApplicationLayout;
327
+ exports["default"] = _default;
@@ -0,0 +1,55 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.linkedinLogo = exports.twitterLogo = exports.facebookLogo = void 0;
9
+
10
+ var _react = _interopRequireDefault(require("react"));
11
+
12
+ var facebookLogo = _react["default"].createElement("svg", {
13
+ version: "1.1",
14
+ id: "Capa_1",
15
+ x: "0px",
16
+ y: "0px",
17
+ width: "438.536px",
18
+ height: "438.536px",
19
+ viewBox: "0 0 438.536 438.536",
20
+ fill: "#FFFFFF"
21
+ }, _react["default"].createElement("g", null, _react["default"].createElement("path", {
22
+ d: "M414.41,24.123C398.333,8.042,378.963,0,356.315,0H82.228C59.58,0,40.21,8.042,24.126,24.123 C8.045,40.207,0.003,59.576,0.003,82.225v274.084c0,22.647,8.042,42.018,24.123,58.102c16.084,16.084,35.454,24.126,58.102,24.126 h274.084c22.648,0,42.018-8.042,58.095-24.126c16.084-16.084,24.126-35.454,24.126-58.102V82.225 C438.532,59.576,430.49,40.204,414.41,24.123z M373.155,225.548h-49.963V406.84h-74.802V225.548H210.99V163.02h37.401v-37.402 c0-26.838,6.283-47.107,18.843-60.813c12.559-13.706,33.304-20.555,62.242-20.555h49.963v62.526h-31.401 c-10.663,0-17.467,1.853-20.417,5.568c-2.949,3.711-4.428,10.23-4.428,19.558v31.119h56.534L373.155,225.548z"
23
+ })));
24
+
25
+ exports.facebookLogo = facebookLogo;
26
+
27
+ var twitterLogo = _react["default"].createElement("svg", {
28
+ version: "1.1",
29
+ id: "Capa_1",
30
+ x: "0px",
31
+ y: "0px",
32
+ width: "438.536px",
33
+ height: "438.536px",
34
+ viewBox: "0 0 438.536 438.536",
35
+ fill: "#FFFFFF"
36
+ }, _react["default"].createElement("g", null, _react["default"].createElement("path", {
37
+ d: "M414.41,24.123C398.333,8.042,378.963,0,356.315,0H82.228C59.58,0,40.21,8.042,24.126,24.123 C8.045,40.207,0.003,59.576,0.003,82.225v274.084c0,22.647,8.042,42.018,24.123,58.102c16.084,16.084,35.454,24.126,58.102,24.126 h274.084c22.648,0,42.018-8.042,58.095-24.126c16.084-16.084,24.126-35.454,24.126-58.102V82.225 C438.532,59.576,430.49,40.204,414.41,24.123z M335.471,168.735c0.191,1.713,0.288,4.278,0.288,7.71 c0,15.989-2.334,32.025-6.995,48.104c-4.661,16.087-11.8,31.504-21.416,46.254c-9.606,14.749-21.074,27.791-34.396,39.115 c-13.325,11.32-29.311,20.365-47.968,27.117c-18.648,6.762-38.637,10.143-59.953,10.143c-33.116,0-63.76-8.952-91.931-26.836 c4.568,0.568,9.329,0.855,14.275,0.855c27.6,0,52.439-8.565,74.519-25.7c-12.941-0.185-24.506-4.179-34.688-11.991 c-10.185-7.803-17.273-17.699-21.271-29.691c4.947,0.76,8.658,1.137,11.132,1.137c4.187,0,9.042-0.76,14.56-2.279 c-13.894-2.669-25.598-9.562-35.115-20.697c-9.519-11.136-14.277-23.84-14.277-38.114v-0.571 c10.085,4.755,19.602,7.229,28.549,7.422c-17.321-11.613-25.981-28.265-25.981-49.963c0-10.66,2.758-20.747,8.278-30.264 c15.035,18.464,33.311,33.213,54.816,44.252c21.507,11.038,44.54,17.227,69.092,18.558c-0.95-3.616-1.427-8.186-1.427-13.704 c0-16.562,5.853-30.692,17.56-42.399c11.703-11.706,25.837-17.561,42.394-17.561c17.515,0,32.079,6.283,43.688,18.846 c13.134-2.474,25.892-7.33,38.26-14.56c-4.757,14.652-13.613,25.788-26.55,33.402c12.368-1.716,23.88-4.95,34.537-9.708 C357.458,149.793,347.462,160.166,335.471,168.735z"
38
+ })));
39
+
40
+ exports.twitterLogo = twitterLogo;
41
+
42
+ var linkedinLogo = _react["default"].createElement("svg", {
43
+ version: "1.1",
44
+ id: "Capa_1",
45
+ x: "0px",
46
+ y: "0px",
47
+ width: "438.536px",
48
+ height: "438.536px",
49
+ viewBox: "0 0 438.536 438.536",
50
+ fill: "#FFFFFF"
51
+ }, _react["default"].createElement("g", null, _react["default"].createElement("path", {
52
+ d: "M414.41,24.123C398.333,8.042,378.963,0,356.315,0H82.228C59.58,0,40.21,8.042,24.126,24.123 C8.045,40.207,0.003,59.576,0.003,82.225v274.084c0,22.647,8.042,42.018,24.123,58.102c16.084,16.084,35.454,24.126,58.102,24.126 h274.084c22.648,0,42.018-8.042,58.095-24.126c16.084-16.084,24.126-35.454,24.126-58.102V82.225 C438.532,59.576,430.49,40.204,414.41,24.123z M133.618,367.157H67.666V169.016h65.952V367.157z M127.626,132.332 c-6.851,6.567-15.893,9.851-27.124,9.851h-0.288c-10.848,0-19.648-3.284-26.407-9.851c-6.76-6.567-10.138-14.703-10.138-24.41 c0-9.897,3.476-18.083,10.421-24.556c6.95-6.471,15.942-9.708,26.98-9.708c11.039,0,19.89,3.237,26.553,9.708 c6.661,6.473,10.088,14.659,10.277,24.556C137.899,117.625,134.477,125.761,127.626,132.332z M370.873,367.157h-65.952v-105.92 c0-29.879-11.036-44.823-33.116-44.823c-8.374,0-15.42,2.331-21.128,6.995c-5.715,4.661-9.996,10.324-12.847,16.991 c-1.335,3.422-1.999,8.75-1.999,15.981v110.775h-65.952c0.571-119.529,0.571-185.579,0-198.142h65.952v27.974 c13.867-21.681,33.558-32.544,59.101-32.544c22.84,0,41.21,7.52,55.104,22.554c13.895,15.037,20.841,37.214,20.841,66.519v113.64 H370.873z"
53
+ })));
54
+
55
+ exports.linkedinLogo = linkedinLogo;
package/dist/link/Link.js CHANGED
@@ -11,11 +11,11 @@ exports["default"] = void 0;
11
11
 
12
12
  var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
13
13
 
14
- var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
15
-
16
14
  var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
17
15
 
18
- var _react = _interopRequireWildcard(require("react"));
16
+ var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
17
+
18
+ var _react = _interopRequireDefault(require("react"));
19
19
 
20
20
  var _styledComponents = _interopRequireWildcard(require("styled-components"));
21
21
 
@@ -23,12 +23,50 @@ var _propTypes = _interopRequireDefault(require("prop-types"));
23
23
 
24
24
  var _variables = require("../common/variables.js");
25
25
 
26
- var _utils = require("../common/utils.js");
26
+ var _useTheme = _interopRequireDefault(require("../useTheme.js"));
27
+
28
+ function _templateObject6() {
29
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n width: ", ";\n height: ", ";\n ", ";\n overflow: hidden;\n \n img,\n svg {\n height: 100%;\n width: 100%;\n }\n"]);
27
30
 
28
- var _ThemeContext = _interopRequireDefault(require("../ThemeContext.js"));
31
+ _templateObject6 = function _templateObject6() {
32
+ return data;
33
+ };
34
+
35
+ return data;
36
+ }
37
+
38
+ function _templateObject5() {
39
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n width: ", ";\n height: ", ";\n ", ";\n"]);
40
+
41
+ _templateObject5 = function _templateObject5() {
42
+ return data;
43
+ };
44
+
45
+ return data;
46
+ }
47
+
48
+ function _templateObject4() {
49
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n font-size: ", ";\n font-weight: ", ";\n font-style: ", ";\n font-family: ", ";\n display: inline-flex;\n flex-direction: ", ";\n justify-content: ", ";\n align-items: center;\n max-width: 100%;\n"]);
50
+
51
+ _templateObject4 = function _templateObject4() {
52
+ return data;
53
+ };
54
+
55
+ return data;
56
+ }
57
+
58
+ function _templateObject3() {
59
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n background: none;\n border: none;\n padding: 0;\n cursor: pointer;\n font-family: inherit;\n text-decoration-color: transparent;\n\n ", "\n ", "\n color: ", ";\n ", "\n\n &:hover {\n ", "\n }\n &:focus {\n outline-color: ", ";\n outline-width: 2px;\n outline-offset: 1px;\n ", "\n }\n &:active {\n ", "\n }\n"]);
60
+
61
+ _templateObject3 = function _templateObject3() {
62
+ return data;
63
+ };
64
+
65
+ return data;
66
+ }
29
67
 
30
68
  function _templateObject2() {
31
- var data = (0, _taggedTemplateLiteral2["default"])(["\n width: 16px;\n height: 16px;\n ", ": 6px;\n"]);
69
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n ", "\n\n text-decoration-color: transparent;\n ", "\n\n &:visited {\n color: ", ";\n &:hover {\n ", "\n }\n }\n &:hover {\n ", "\n }\n &:focus {\n outline-color: ", ";\n outline-width: 2px;\n ", "\n }\n &:active {\n ", "\n }\n"]);
32
70
 
33
71
  _templateObject2 = function _templateObject2() {
34
72
  return data;
@@ -38,7 +76,7 @@ function _templateObject2() {
38
76
  }
39
77
 
40
78
  function _templateObject() {
41
- var data = (0, _taggedTemplateLiteral2["default"])(["\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n\n ", ";\n\n color: ", ";\n ", "\n ", "\n \n display: inline-flex;\n flex-direction: ", ";\n justify-content: ", ";\n align-items: center;\n\n max-width: 100%;\n font-size: 16px;\n padding-bottom: 2px;\n\n &:hover {\n color: ", " !important;\n text-decoration: none;\n padding-bottom: 1px !important;\n border-bottom: 1px solid;\n\n cursor: pointer;\n }\n\n &:visited {\n ", "\n }\n"]);
79
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n"]);
42
80
 
43
81
  _templateObject = function _templateObject() {
44
82
  return data;
@@ -48,43 +86,56 @@ function _templateObject() {
48
86
  }
49
87
 
50
88
  var DxcLink = function DxcLink(_ref) {
51
- var _ref$underlined = _ref.underlined,
52
- underlined = _ref$underlined === void 0 ? true : _ref$underlined,
53
- _ref$inheritColor = _ref.inheritColor,
89
+ var _ref$inheritColor = _ref.inheritColor,
54
90
  inheritColor = _ref$inheritColor === void 0 ? false : _ref$inheritColor,
55
91
  _ref$disabled = _ref.disabled,
56
92
  disabled = _ref$disabled === void 0 ? false : _ref$disabled,
57
93
  iconSrc = _ref.iconSrc,
94
+ icon = _ref.icon,
58
95
  _ref$iconPosition = _ref.iconPosition,
59
96
  iconPosition = _ref$iconPosition === void 0 ? "before" : _ref$iconPosition,
60
97
  _ref$href = _ref.href,
61
98
  href = _ref$href === void 0 ? "" : _ref$href,
62
99
  _ref$newWindow = _ref.newWindow,
63
100
  newWindow = _ref$newWindow === void 0 ? false : _ref$newWindow,
101
+ onClick = _ref.onClick,
64
102
  _ref$text = _ref.text,
65
103
  text = _ref$text === void 0 ? "" : _ref$text,
66
- margin = _ref.margin;
67
- var customTheme = (0, _react.useContext)(_ThemeContext["default"]);
68
- var colorsTheme = (0, _react.useMemo)(function () {
69
- return (0, _utils.getCustomTheme)(_variables.theme, (0, _utils.getCustomTheme)(_variables.defaultTheme, customTheme));
70
- }, [customTheme]);
104
+ margin = _ref.margin,
105
+ _ref$tabIndex = _ref.tabIndex,
106
+ tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
107
+ var colorsTheme = (0, _useTheme["default"])();
108
+
109
+ var linkContent = _react["default"].createElement(LinkText, {
110
+ iconPosition: iconPosition
111
+ }, text, icon ? _react["default"].createElement(LinkIconContainer, {
112
+ iconPosition: iconPosition
113
+ }, (0, _typeof2["default"])(icon) === "object" ? icon : _react["default"].createElement(icon)) : iconSrc && _react["default"].createElement(LinkIcon, {
114
+ src: iconSrc,
115
+ iconPosition: iconPosition
116
+ }));
117
+
71
118
  return _react["default"].createElement(_styledComponents.ThemeProvider, {
72
119
  theme: colorsTheme.link
73
- }, _react["default"].createElement(LinkText, {
74
- underlined: underlined,
75
- inheritColor: inheritColor,
120
+ }, _react["default"].createElement(DxcLinkContainer, {
121
+ margin: margin
122
+ }, onClick ? _react["default"].createElement(StyledButton, {
123
+ type: "button",
124
+ onClick: !disabled && onClick,
125
+ margin: margin,
76
126
  disabled: disabled,
77
- href: href,
127
+ inheritColor: inheritColor
128
+ }, linkContent) : _react["default"].createElement(StyledLink, {
129
+ tabIndex: tabIndex,
130
+ href: !disabled && href,
131
+ target: newWindow ? "_blank" : "_self",
78
132
  margin: margin,
79
- iconPosition: iconPosition,
80
- target: newWindow ? "_blank" : "_self"
81
- }, text, iconSrc ? _react["default"].createElement(LinkIcon, {
82
- src: iconSrc,
83
- iconPosition: iconPosition
84
- }) : ""));
133
+ disabled: disabled,
134
+ inheritColor: inheritColor
135
+ }, linkContent)));
85
136
  };
86
137
 
87
- var LinkText = _styledComponents["default"].a(_templateObject(), function (props) {
138
+ var DxcLinkContainer = _styledComponents["default"].div(_templateObject(), function (props) {
88
139
  return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
89
140
  }, function (props) {
90
141
  return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.top ? _variables.spaces[props.margin.top] : "";
@@ -94,35 +145,84 @@ var LinkText = _styledComponents["default"].a(_templateObject(), function (props
94
145
  return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.bottom ? _variables.spaces[props.margin.bottom] : "";
95
146
  }, function (props) {
96
147
  return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.left ? _variables.spaces[props.margin.left] : "";
148
+ });
149
+
150
+ var StyledLink = _styledComponents["default"].a(_templateObject2(), function (props) {
151
+ return props.inheritColor ? "inherit" : !props.disabled ? props.theme.fontColor : props.theme.disabledColor;
152
+ }, function (props) {
153
+ return props.disabled ? "pointer-events: none;" : "";
154
+ }, function (props) {
155
+ return "padding-bottom: ".concat(props.theme.underlineSpacing, ";\n border-bottom: ").concat(props.theme.underlineThickness, " ").concat(props.theme.underlineStyle, " transparent;");
97
156
  }, function (props) {
98
- return props.underlined ? !props.disabled ? "text-decoration: none;\n padding-bottom: 1px !important;\n border-bottom: 1px solid ".concat(props.theme.underlinedBackgroundColor) : "text-decoration: none;\n padding-bottom: 1px !important;\n border-bottom: 1px solid ".concat(props.theme.disabledUnderlinedBackgroundColor) : "text-decoration: none";
157
+ return !props.inheritColor ? props.theme.visitedFontColor : "";
99
158
  }, function (props) {
100
- return !props.disabled ? props.theme.textColor : props.theme.disabledColor;
159
+ return "color: ".concat(props.theme.visitedFontColor, ";\n border-bottom-color: ").concat(props.theme.visitedUnderlineColor, ";");
101
160
  }, function (props) {
102
- return !props.underlined ? "text-decoration-color: transparent;" : "";
161
+ return "color: ".concat(props.theme.hoverFontColor, ";\n border-bottom-color: ").concat(props.theme.hoverUnderlineColor, ";\n cursor: pointer;");
162
+ }, function (props) {
163
+ return props.theme.focusColor;
164
+ }, function (props) {
165
+ return props.disabled && "outline: none";
166
+ }, function (props) {
167
+ return "color: ".concat(props.theme.activeFontColor, " !important;\n border-bottom-color: ").concat(props.theme.activeUnderlineColor, " !important;");
168
+ });
169
+
170
+ var StyledButton = _styledComponents["default"].button(_templateObject3(), function (props) {
171
+ return "padding-bottom: ".concat(props.theme.underlineSpacing, ";\n border-bottom: ").concat(props.theme.underlineThickness, " ").concat(props.theme.underlineStyle, " transparent;");
172
+ }, function (props) {
173
+ return props.disabled && "cursor: default;";
174
+ }, function (props) {
175
+ return props.inheritColor ? "inherit" : !props.disabled ? props.theme.fontColor : props.theme.disabledColor;
103
176
  }, function (props) {
104
177
  return props.disabled ? "pointer-events: none;" : "";
178
+ }, function (props) {
179
+ return "color: ".concat(props.theme.hoverFontColor, ";\n border-bottom-color: ").concat(props.theme.hoverUnderlineColor, ";\n cursor: pointer;");
180
+ }, function (props) {
181
+ return props.theme.focusColor;
182
+ }, function (props) {
183
+ return props.disabled && "outline: none";
184
+ }, function (props) {
185
+ return "color: ".concat(props.theme.activeFontColor, " !important;\n border-bottom-color: ").concat(props.theme.activeUnderlineColor, " !important;");
186
+ });
187
+
188
+ var LinkText = _styledComponents["default"].div(_templateObject4(), function (props) {
189
+ return props.theme.fontSize;
190
+ }, function (props) {
191
+ return props.theme.fontWeight;
192
+ }, function (props) {
193
+ return props.theme.fontStyle;
194
+ }, function (props) {
195
+ return props.theme.fontFamily;
105
196
  }, function (props) {
106
197
  return props.iconPosition === "after" ? "row" : "row-reverse";
107
198
  }, function (props) {
108
199
  return props.iconPosition === "after" ? "flex-start" : "flex-end";
200
+ });
201
+
202
+ var LinkIcon = _styledComponents["default"].img(_templateObject5(), function (props) {
203
+ return props.theme.iconSize;
109
204
  }, function (props) {
110
- return props.theme.hoverTextColor;
205
+ return props.theme.iconSize;
111
206
  }, function (props) {
112
- return props.underlined ? !props.disabled ? "color: ".concat(props.theme.visitedtextColor, " !important; border-bottom: 1px solid ").concat(props.theme.visitedUnderlinedBackgroundColor) : "" : "";
207
+ return "".concat(props.iconPosition === "before" ? "margin-right" : "margin-left", ": ").concat(props.theme.iconSpacing);
113
208
  });
114
209
 
115
- var LinkIcon = _styledComponents["default"].img(_templateObject2(), function (props) {
116
- return props.iconPosition === "before" ? "margin-right" : "margin-left";
210
+ var LinkIconContainer = _styledComponents["default"].div(_templateObject6(), function (props) {
211
+ return props.theme.iconSize;
212
+ }, function (props) {
213
+ return props.theme.iconSize;
214
+ }, function (props) {
215
+ return "".concat(props.iconPosition === "before" ? "margin-right" : "margin-left", ": ").concat(props.theme.iconSpacing);
117
216
  });
118
217
 
119
218
  DxcLink.propTypes = {
120
- underlined: _propTypes["default"].bool,
121
219
  inheritColor: _propTypes["default"].bool,
122
220
  disabled: _propTypes["default"].bool,
221
+ icon: _propTypes["default"].oneOfType([_propTypes["default"].element, _propTypes["default"].func]),
123
222
  iconSrc: _propTypes["default"].string,
124
223
  iconPosition: _propTypes["default"].oneOf(["after", "before"]),
125
224
  href: _propTypes["default"].string,
225
+ onClick: _propTypes["default"].func,
126
226
  margin: _propTypes["default"].oneOfType([_propTypes["default"].shape({
127
227
  top: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
128
228
  bottom: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
@@ -130,7 +230,8 @@ DxcLink.propTypes = {
130
230
  right: _propTypes["default"].oneOf(Object.keys(_variables.spaces))
131
231
  }), _propTypes["default"].oneOf((0, _toConsumableArray2["default"])(Object.keys(_variables.spaces)))]),
132
232
  newWindow: _propTypes["default"].bool,
133
- text: _propTypes["default"].string
233
+ text: _propTypes["default"].string,
234
+ tabIndex: _propTypes["default"].number
134
235
  };
135
236
  var _default = DxcLink;
136
237
  exports["default"] = _default;
package/dist/main.d.ts ADDED
@@ -0,0 +1,8 @@
1
+ export { default as DxcAlert } from "./alert/index";
2
+ export { default as DxcNewSelect } from "./new-select/index";
3
+ export { default as DxcTextInput } from "./text-input/index";
4
+ export { default as DxcDateInput } from "./date-input/index";
5
+ export { default as DxcTextarea } from "./textarea/index";
6
+ export { default as DxcNumberInput } from "./number-input/index";
7
+ export { default as DxcPasswordInput } from "./password-input/index";
8
+ export { default as DxcFileInput } from "./file-input/index";