@dxc-technology/halstack-react 0.0.0-a01a65d → 0.0.0-a0543ea

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 (126) 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/accordion/Accordion.js +168 -63
  5. package/dist/accordion-group/AccordionGroup.js +186 -0
  6. package/dist/alert/Alert.js +183 -84
  7. package/dist/alert/index.d.ts +51 -0
  8. package/dist/badge/Badge.js +63 -0
  9. package/dist/box/Box.js +31 -23
  10. package/dist/button/Button.js +83 -26
  11. package/dist/card/Card.js +72 -35
  12. package/dist/checkbox/Checkbox.js +98 -38
  13. package/dist/chip/Chip.js +128 -36
  14. package/dist/common/RequiredComponent.js +2 -8
  15. package/dist/common/utils.js +2 -22
  16. package/dist/common/variables.js +1439 -308
  17. package/dist/date/Date.js +75 -52
  18. package/dist/dialog/Dialog.js +58 -37
  19. package/dist/dropdown/Dropdown.js +199 -71
  20. package/dist/file-input/FileInput.js +644 -0
  21. package/dist/file-input/FileItem.js +280 -0
  22. package/dist/file-input/index.d.ts +81 -0
  23. package/dist/footer/Footer.js +85 -36
  24. package/dist/footer/dxc_logo.svg +15 -0
  25. package/dist/header/Header.js +111 -68
  26. package/dist/header/dxc_logo_black.svg +8 -0
  27. package/dist/heading/Heading.js +81 -16
  28. package/dist/input-text/InputText.js +288 -100
  29. package/dist/layout/ApplicationLayout.js +50 -39
  30. package/dist/link/Link.js +136 -35
  31. package/dist/main.d.ts +8 -0
  32. package/dist/main.js +89 -1
  33. package/dist/new-date/NewDate.js +400 -0
  34. package/dist/new-date/index.d.ts +95 -0
  35. package/dist/new-input-text/NewInputText.js +971 -0
  36. package/dist/new-input-text/index.d.ts +135 -0
  37. package/dist/new-select/NewSelect.js +836 -0
  38. package/dist/new-select/index.d.ts +53 -0
  39. package/dist/new-textarea/NewTextarea.js +369 -0
  40. package/dist/new-textarea/index.d.ts +117 -0
  41. package/dist/number/Number.js +136 -0
  42. package/dist/number/NumberContext.js +16 -0
  43. package/dist/number/index.d.ts +113 -0
  44. package/dist/paginator/Paginator.js +149 -56
  45. package/dist/password/Password.js +200 -0
  46. package/dist/password/index.d.ts +94 -0
  47. package/dist/password/styles.css +3 -0
  48. package/dist/progress-bar/ProgressBar.js +95 -38
  49. package/dist/radio/Radio.js +31 -17
  50. package/dist/resultsetTable/ResultsetTable.js +93 -68
  51. package/dist/select/Select.js +244 -146
  52. package/dist/sidenav/Sidenav.js +86 -129
  53. package/dist/slider/Slider.js +206 -70
  54. package/dist/spinner/Spinner.js +247 -59
  55. package/dist/switch/Switch.js +50 -27
  56. package/dist/table/Table.js +52 -13
  57. package/dist/tabs/Tabs.js +206 -35
  58. package/dist/tabs-for-sections/TabsForSections.js +1 -16
  59. package/dist/tag/Tag.js +100 -35
  60. package/dist/textarea/Textarea.js +77 -40
  61. package/dist/toggle/Toggle.js +16 -19
  62. package/dist/toggle-group/ToggleGroup.js +159 -46
  63. package/dist/upload/Upload.js +13 -8
  64. package/dist/upload/buttons-upload/ButtonsUpload.js +31 -14
  65. package/dist/upload/dragAndDropArea/DragAndDropArea.js +78 -28
  66. package/dist/upload/file-upload/FileToUpload.js +50 -24
  67. package/dist/upload/files-upload/FilesToUpload.js +16 -16
  68. package/dist/upload/transaction/Transaction.js +44 -24
  69. package/dist/upload/transactions/Transactions.js +38 -20
  70. package/dist/useTheme.js +22 -0
  71. package/dist/wizard/Wizard.js +139 -55
  72. package/dist/wizard/invalid_icon.svg +4 -5
  73. package/dist/wizard/valid_icon.svg +4 -5
  74. package/package.json +13 -5
  75. package/test/AccordionGroup.test.js +125 -0
  76. package/test/Date.test.js +13 -13
  77. package/test/Dropdown.test.js +15 -0
  78. package/test/FileInput.test.js +201 -0
  79. package/test/InputText.test.js +30 -26
  80. package/test/Link.test.js +25 -7
  81. package/test/NewDate.test.js +232 -0
  82. package/test/NewInputText.test.js +734 -0
  83. package/test/NewTextarea.test.js +195 -0
  84. package/test/Number.test.js +257 -0
  85. package/test/Paginator.test.js +72 -60
  86. package/test/Password.test.js +83 -0
  87. package/test/ResultsetTable.test.js +66 -19
  88. package/test/Select.test.js +55 -34
  89. package/test/Sidenav.test.js +22 -64
  90. package/test/Slider.test.js +17 -0
  91. package/test/Spinner.test.js +5 -0
  92. package/test/Tabs.test.js +21 -0
  93. package/test/ToggleGroup.test.js +5 -1
  94. package/dist/accordion/Accordion.stories.js +0 -207
  95. package/dist/accordion/readme.md +0 -96
  96. package/dist/alert/Alert.stories.js +0 -158
  97. package/dist/alert/close.svg +0 -4
  98. package/dist/alert/error.svg +0 -4
  99. package/dist/alert/info.svg +0 -4
  100. package/dist/alert/readme.md +0 -43
  101. package/dist/alert/success.svg +0 -4
  102. package/dist/alert/warning.svg +0 -4
  103. package/dist/button/Button.stories.js +0 -224
  104. package/dist/button/readme.md +0 -93
  105. package/dist/common/services/example-service.js +0 -10
  106. package/dist/common/services/example-service.test.js +0 -12
  107. package/dist/date/calendar.svg +0 -1
  108. package/dist/date/calendar_dark.svg +0 -1
  109. package/dist/dialog/Dialog.stories.js +0 -217
  110. package/dist/dialog/readme.md +0 -32
  111. package/dist/dropdown/Dropdown.stories.js +0 -249
  112. package/dist/dropdown/baseline-arrow_drop_down.svg +0 -1
  113. package/dist/dropdown/baseline-arrow_drop_down_wh.svg +0 -4
  114. package/dist/dropdown/baseline-arrow_drop_up.svg +0 -1
  115. package/dist/dropdown/baseline-arrow_drop_up_wh.svg +0 -4
  116. package/dist/dropdown/readme.md +0 -69
  117. package/dist/footer/dxc_logo_wht.png +0 -0
  118. package/dist/header/dxc_logo_black.png +0 -0
  119. package/dist/header/dxc_logo_blk_rgb.svg +0 -6
  120. package/dist/header/dxc_logo_white.png +0 -0
  121. package/dist/layout/SideNav.js +0 -67
  122. package/dist/select/Select.stories.js +0 -235
  123. package/dist/select/readme.md +0 -72
  124. package/dist/sidenav/arrow_icon.svg +0 -3
  125. package/dist/toggle-group/readme.md +0 -82
  126. package/test/Toggle.test.js +0 -43
@@ -17,14 +17,12 @@ var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/h
17
17
 
18
18
  var _react = _interopRequireWildcard(require("react"));
19
19
 
20
- var _halstackReact = require("@dxc-technology/halstack-react");
20
+ var _main = require("../main");
21
21
 
22
22
  var _styledComponents = _interopRequireWildcard(require("styled-components"));
23
23
 
24
24
  var _propTypes = _interopRequireDefault(require("prop-types"));
25
25
 
26
- var _SideNav = _interopRequireDefault(require("./SideNav"));
27
-
28
26
  var _variables = require("../common/variables.js");
29
27
 
30
28
  var _linkedin = _interopRequireDefault(require("./linkedin.svg"));
@@ -33,12 +31,20 @@ var _twitter = _interopRequireDefault(require("./twitter.svg"));
33
31
 
34
32
  var _facebook = _interopRequireDefault(require("./facebook.svg"));
35
33
 
36
- var _utils = require("../common/utils.js");
34
+ var _useTheme = _interopRequireDefault(require("../useTheme.js"));
35
+
36
+ function _templateObject10() {
37
+ 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"]);
37
38
 
38
- var _ThemeContext = _interopRequireDefault(require("../ThemeContext.js"));
39
+ _templateObject10 = function _templateObject10() {
40
+ return data;
41
+ };
42
+
43
+ return data;
44
+ }
39
45
 
40
46
  function _templateObject9() {
41
- 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: 10;\n cursor: pointer;\n & > svg {\n fill: ", ";\n }\n"]);
47
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n position: absolute;\n height: calc(100vh - 64px);\n left: 279px;\n"]);
42
48
 
43
49
  _templateObject9 = function _templateObject9() {
44
50
  return data;
@@ -48,7 +54,7 @@ function _templateObject9() {
48
54
  }
49
55
 
50
56
  function _templateObject8() {
51
- var data = (0, _taggedTemplateLiteral2["default"])(["\n position: absolute;\n height: 100vh;\n left: 279px;\n"]);
57
+ 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"]);
52
58
 
53
59
  _templateObject8 = function _templateObject8() {
54
60
  return data;
@@ -58,7 +64,7 @@ function _templateObject8() {
58
64
  }
59
65
 
60
66
  function _templateObject7() {
61
- var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: row;\n z-index: 1;\n transform: ", ";\n transition: transform 0.4s ease-in-out;\n"]);
67
+ 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"]);
62
68
 
63
69
  _templateObject7 = function _templateObject7() {
64
70
  return data;
@@ -68,7 +74,7 @@ function _templateObject7() {
68
74
  }
69
75
 
70
76
  function _templateObject6() {
71
- var data = (0, _taggedTemplateLiteral2["default"])(["\n flex-grow: 1;\n overflow: hidden;\n padding: 20px 50px;\n position: relative;\n min-height: 500px;\n margin-top: 64px;\n margin-bottom: 80px;\n margin-right: ", ";\n margin-left: ", ";\n transition: margin 0.4s ease-in-out;\n"]);
77
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n margin-left: ", ";\n transition: margin 0.4s ease-in-out;\n"]);
72
78
 
73
79
  _templateObject6 = function _templateObject6() {
74
80
  return data;
@@ -78,7 +84,7 @@ function _templateObject6() {
78
84
  }
79
85
 
80
86
  function _templateObject5() {
81
- var data = (0, _taggedTemplateLiteral2["default"])([""]);
87
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n width: 100%;\n min-width: 0;\n display: flex;\n flex-direction: column;\n"]);
82
88
 
83
89
  _templateObject5 = function _templateObject5() {
84
90
  return data;
@@ -88,7 +94,7 @@ function _templateObject5() {
88
94
  }
89
95
 
90
96
  function _templateObject4() {
91
- var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex: 1 1 auto;\n"]);
97
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex: 1 1 auto;\n align-items: flex-start;\n"]);
92
98
 
93
99
  _templateObject4 = function _templateObject4() {
94
100
  return data;
@@ -98,7 +104,7 @@ function _templateObject4() {
98
104
  }
99
105
 
100
106
  function _templateObject3() {
101
- var data = (0, _taggedTemplateLiteral2["default"])(["\n flex: 1;\n display: flex;\n flex-direction: column;\n overflow: auto;\n"]);
107
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n flex: 1;\n display: flex;\n flex-direction: column;\n"]);
102
108
 
103
109
  _templateObject3 = function _templateObject3() {
104
110
  return data;
@@ -108,7 +114,7 @@ function _templateObject3() {
108
114
  }
109
115
 
110
116
  function _templateObject2() {
111
- var data = (0, _taggedTemplateLiteral2["default"])(["\n position: fixed;\n top: 0;\n left: 0;\n right: 0;\n"]);
117
+ var data = (0, _taggedTemplateLiteral2["default"])(["\n z-index: 1250;\n position: fixed;\n top: 0;\n left: 0;\n right: 0;\n"]);
112
118
 
113
119
  _templateObject2 = function _templateObject2() {
114
120
  return data;
@@ -131,24 +137,24 @@ var year = new Date().getFullYear();
131
137
 
132
138
  var Header = function Header(_ref) {
133
139
  var children = _ref.children;
134
- return _react["default"].createElement("div", null, children);
140
+ return _react["default"].createElement(_react["default"].Fragment, null, children);
135
141
  };
136
142
 
137
143
  var Main = function Main(_ref2) {
138
144
  var children = _ref2.children;
139
- return _react["default"].createElement("div", null, children);
145
+ return _react["default"].createElement(_react["default"].Fragment, null, children);
140
146
  };
141
147
 
142
148
  var Footer = function Footer(_ref3) {
143
149
  var children = _ref3.children;
144
- return _react["default"].createElement("div", null, children);
150
+ return _react["default"].createElement(_react["default"].Fragment, null, children);
145
151
  };
146
152
 
147
153
  var SideNav = function SideNav(props) {
148
154
  var displayArrow = props.displayArrow,
149
155
  mode = props.mode,
150
156
  childProps = (0, _objectWithoutProperties2["default"])(props, ["displayArrow", "mode"]);
151
- return _react["default"].createElement(_SideNav["default"], childProps, childProps.children);
157
+ return _react["default"].createElement(_main.DxcSidenav, childProps, childProps.children);
152
158
  };
153
159
 
154
160
  SideNav.propTypes = {
@@ -163,7 +169,7 @@ SideNav.propTypes = {
163
169
  };
164
170
 
165
171
  var defaultFooter = function defaultFooter() {
166
- return _react["default"].createElement(_halstackReact.DxcFooter, {
172
+ return _react["default"].createElement(_main.DxcFooter, {
167
173
  copyright: "\xA9 DXC Technology ".concat(year, "\u200B\u200B\u200B\u200B. All rights reserved."),
168
174
  bottomLinks: [{
169
175
  href: "https://www.linkedin.com/company/dxctechnology",
@@ -189,7 +195,7 @@ var defaultFooter = function defaultFooter() {
189
195
  };
190
196
 
191
197
  var defaultHeader = function defaultHeader() {
192
- return _react["default"].createElement(_halstackReact.DxcHeader, {
198
+ return _react["default"].createElement(_main.DxcHeader, {
193
199
  underlined: true
194
200
  });
195
201
  };
@@ -203,10 +209,7 @@ var childTypeExists = function childTypeExists(children, childType) {
203
209
  var DxcApplicationLayout = function DxcApplicationLayout(_ref4) {
204
210
  var children = _ref4.children;
205
211
  var ref = (0, _react.useRef)(null);
206
- var customTheme = (0, _react.useContext)(_ThemeContext["default"]);
207
- var colorsTheme = (0, _react.useMemo)(function () {
208
- return (0, _utils.getCustomTheme)(_variables.theme, (0, _utils.getCustomTheme)(_variables.defaultTheme, customTheme));
209
- }, [customTheme]);
212
+ var colorsTheme = (0, _useTheme["default"])();
210
213
 
211
214
  var _useState = (0, _react.useState)(true),
212
215
  _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
@@ -220,8 +223,8 @@ var DxcApplicationLayout = function DxcApplicationLayout(_ref4) {
220
223
 
221
224
  var childrenArray = _react["default"].Children.toArray(children);
222
225
 
223
- var header = childTypeExists(childrenArray, _halstackReact.DxcHeader) || childTypeExists(childrenArray, Header) || defaultHeader();
224
- var footer = childTypeExists(childrenArray, _halstackReact.DxcFooter) || childTypeExists(childrenArray, Footer) || defaultFooter();
226
+ var header = childTypeExists(childrenArray, _main.DxcHeader) || childTypeExists(childrenArray, Header) || defaultHeader();
227
+ var footer = childTypeExists(childrenArray, _main.DxcFooter) || childTypeExists(childrenArray, Footer) || defaultFooter();
225
228
  var sideNav = childTypeExists(childrenArray, SideNav);
226
229
  var main = childTypeExists(childrenArray, Main);
227
230
  var displayArrow = sideNav && sideNav.props && sideNav.props.displayArrow;
@@ -243,6 +246,7 @@ var DxcApplicationLayout = function DxcApplicationLayout(_ref4) {
243
246
  var handleResize = function handleResize(width) {
244
247
  if (width) {
245
248
  if (width <= _variables.responsiveSizes.tablet ? setIsResponsive(true) : setIsResponsive(false)) ;
249
+ setIsSideNavVisible(true);
246
250
  }
247
251
  };
248
252
 
@@ -266,19 +270,24 @@ var DxcApplicationLayout = function DxcApplicationLayout(_ref4) {
266
270
  };
267
271
 
268
272
  return _react["default"].createElement(_styledComponents.ThemeProvider, {
269
- theme: colorsTheme.applicationLayout
273
+ theme: colorsTheme.sidenav
270
274
  }, _react["default"].createElement(ApplicationLayoutContainer, {
271
275
  ref: ref
272
- }, _react["default"].createElement(HeaderContainer, null, header), _react["default"].createElement(BodyContainer, null, _react["default"].createElement(MainBodyContainer, null, _react["default"].createElement(SideNavArrowContainer, {
276
+ }, _react["default"].createElement(HeaderContainer, null, header), _react["default"].createElement(BodyContainer, null, _react["default"].createElement(ContentContainer, null, _react["default"].createElement(SideNavArrowContainer, {
273
277
  isSideNavVisible: isSideNavVisible
274
278
  }, sideNav, _react["default"].createElement(ArrowContainer, null, sideNav && (displayArrow || isResponsive) && _react["default"].createElement(ArrowTrigger, {
279
+ tabIndex: 0,
275
280
  onClick: handleSidenav,
276
281
  isSideNavVisible: isSideNavVisible
277
- }, _react["default"].createElement(ArrowIcon, null)))), _react["default"].createElement(MainContent, {
282
+ }, _react["default"].createElement(ArrowIcon, null)))), _react["default"].createElement(MainBodyContainer, null, _react["default"].createElement(MainContent, {
278
283
  sideNav: sideNav,
279
284
  mode: isResponsive ? "overlay" : sideNavMode,
280
285
  isSideNavVisible: isSideNavVisible
281
- }, main)), _react["default"].createElement(FooterContainer, null, footer))));
286
+ }, main), _react["default"].createElement(FooterContainer, {
287
+ sideNav: sideNav,
288
+ mode: isResponsive ? "overlay" : sideNavMode,
289
+ isSideNavVisible: isSideNavVisible
290
+ }, footer))))));
282
291
  };
283
292
 
284
293
  DxcApplicationLayout.Header = Header;
@@ -292,24 +301,26 @@ var HeaderContainer = _styledComponents["default"].div(_templateObject2());
292
301
 
293
302
  var BodyContainer = _styledComponents["default"].div(_templateObject3());
294
303
 
295
- var MainBodyContainer = _styledComponents["default"].div(_templateObject4());
304
+ var ContentContainer = _styledComponents["default"].div(_templateObject4());
296
305
 
297
- var FooterContainer = _styledComponents["default"].div(_templateObject5());
306
+ var MainBodyContainer = _styledComponents["default"].div(_templateObject5());
298
307
 
299
- var MainContent = _styledComponents["default"].div(_templateObject6(), function (props) {
300
- return props.mode === "push" && props.isSideNavVisible ? "8.6%" : "15.6%";
301
- }, function (props) {
302
- return props.sideNav ? props.mode === "push" && props.isSideNavVisible ? "5.4%" : "calc(15.6% - 297px)" : "15.6%";
308
+ var FooterContainer = _styledComponents["default"].div(_templateObject6(), function (props) {
309
+ return props.sideNav ? props.mode === "push" && !props.isSideNavVisible || props.mode === "overlay" ? "-300px" : "" : "";
310
+ });
311
+
312
+ var MainContent = _styledComponents["default"].div(_templateObject7(), function (props) {
313
+ return props.sideNav ? props.mode === "push" && props.isSideNavVisible ? "" : "-297px" : "";
303
314
  });
304
315
 
305
- var SideNavArrowContainer = _styledComponents["default"].div(_templateObject7(), function (props) {
316
+ var SideNavArrowContainer = _styledComponents["default"].div(_templateObject8(), function (props) {
306
317
  return props.isSideNavVisible ? "translateX(0)" : !props.isSideNavVisible ? "translateX(-100%)" : "";
307
318
  });
308
319
 
309
- var ArrowContainer = _styledComponents["default"].div(_templateObject8());
320
+ var ArrowContainer = _styledComponents["default"].div(_templateObject9());
310
321
 
311
- var ArrowTrigger = _styledComponents["default"].div(_templateObject9(), function (props) {
312
- return "".concat(props.theme.arrowContainerColor).concat(props.theme.arrowContainerOpacity);
322
+ var ArrowTrigger = _styledComponents["default"].div(_templateObject10(), function (props) {
323
+ return "".concat(props.theme.arrowContainerColor);
313
324
  }, function (props) {
314
325
  return props.isSideNavVisible ? "rotate(-180deg)" : "rotate(0deg)";
315
326
  }, function (props) {
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.fontColor : 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.hoverFontColor;
205
+ return props.theme.iconSize;
111
206
  }, function (props) {
112
- return props.underlined ? !props.disabled ? "color: ".concat(props.theme.visitedFontColor, " !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 DxcNewInputText } from "./new-input-text/index";
4
+ export { default as DxcNewDate } from "./new-date/index";
5
+ export { default as DxcNewTextarea } from "./new-textarea/index";
6
+ export { default as DxcNumber } from "./number/index";
7
+ export { default as DxcPassword } from "./password/index";
8
+ export { default as DxcFileInput } from "./file-input/index";
package/dist/main.js CHANGED
@@ -1,5 +1,7 @@
1
1
  "use strict";
2
2
 
3
+ var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
4
+
3
5
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
6
 
5
7
  Object.defineProperty(exports, "__esModule", {
@@ -203,12 +205,78 @@ Object.defineProperty(exports, "DxcToggleGroup", {
203
205
  return _ToggleGroup["default"];
204
206
  }
205
207
  });
208
+ Object.defineProperty(exports, "DxcAccordionGroup", {
209
+ enumerable: true,
210
+ get: function get() {
211
+ return _AccordionGroup["default"];
212
+ }
213
+ });
214
+ Object.defineProperty(exports, "DxcBadge", {
215
+ enumerable: true,
216
+ get: function get() {
217
+ return _Badge["default"];
218
+ }
219
+ });
220
+ Object.defineProperty(exports, "DxcNewInputText", {
221
+ enumerable: true,
222
+ get: function get() {
223
+ return _NewInputText["default"];
224
+ }
225
+ });
226
+ Object.defineProperty(exports, "DxcPassword", {
227
+ enumerable: true,
228
+ get: function get() {
229
+ return _Password["default"];
230
+ }
231
+ });
232
+ Object.defineProperty(exports, "DxcNewDate", {
233
+ enumerable: true,
234
+ get: function get() {
235
+ return _NewDate["default"];
236
+ }
237
+ });
238
+ Object.defineProperty(exports, "DxcNumber", {
239
+ enumerable: true,
240
+ get: function get() {
241
+ return _Number["default"];
242
+ }
243
+ });
244
+ Object.defineProperty(exports, "DxcNewTextarea", {
245
+ enumerable: true,
246
+ get: function get() {
247
+ return _NewTextarea["default"];
248
+ }
249
+ });
250
+ Object.defineProperty(exports, "DxcNewSelect", {
251
+ enumerable: true,
252
+ get: function get() {
253
+ return _NewSelect["default"];
254
+ }
255
+ });
256
+ Object.defineProperty(exports, "DxcFileInput", {
257
+ enumerable: true,
258
+ get: function get() {
259
+ return _FileInput["default"];
260
+ }
261
+ });
206
262
  Object.defineProperty(exports, "ThemeContext", {
207
263
  enumerable: true,
208
264
  get: function get() {
209
265
  return _ThemeContext["default"];
210
266
  }
211
267
  });
268
+ Object.defineProperty(exports, "ThemeProvider", {
269
+ enumerable: true,
270
+ get: function get() {
271
+ return _ThemeContext.ThemeProvider;
272
+ }
273
+ });
274
+ Object.defineProperty(exports, "BackgroundColorProvider", {
275
+ enumerable: true,
276
+ get: function get() {
277
+ return _BackgroundColorContext.BackgroundColorProvider;
278
+ }
279
+ });
212
280
 
213
281
  var _Alert = _interopRequireDefault(require("./alert/Alert"));
214
282
 
@@ -276,4 +344,24 @@ var _ApplicationLayout = _interopRequireDefault(require("./layout/ApplicationLay
276
344
 
277
345
  var _ToggleGroup = _interopRequireDefault(require("./toggle-group/ToggleGroup"));
278
346
 
279
- var _ThemeContext = _interopRequireDefault(require("./ThemeContext.js"));
347
+ var _AccordionGroup = _interopRequireDefault(require("./accordion-group/AccordionGroup"));
348
+
349
+ var _Badge = _interopRequireDefault(require("./badge/Badge"));
350
+
351
+ var _NewInputText = _interopRequireDefault(require("./new-input-text/NewInputText"));
352
+
353
+ var _Password = _interopRequireDefault(require("./password/Password"));
354
+
355
+ var _NewDate = _interopRequireDefault(require("./new-date/NewDate"));
356
+
357
+ var _Number = _interopRequireDefault(require("./number/Number"));
358
+
359
+ var _NewTextarea = _interopRequireDefault(require("./new-textarea/NewTextarea"));
360
+
361
+ var _NewSelect = _interopRequireDefault(require("./new-select/NewSelect"));
362
+
363
+ var _FileInput = _interopRequireDefault(require("./file-input/FileInput"));
364
+
365
+ var _ThemeContext = _interopRequireWildcard(require("./ThemeContext.js"));
366
+
367
+ var _BackgroundColorContext = require("./BackgroundColorContext.js");