@dxc-technology/halstack-react 0.0.0-d238e47 → 0.0.0-d291075

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 (264) hide show
  1. package/BackgroundColorContext.d.ts +10 -0
  2. package/BackgroundColorContext.js +1 -4
  3. package/HalstackContext.d.ts +12 -0
  4. package/HalstackContext.js +295 -0
  5. package/accordion/Accordion.d.ts +1 -1
  6. package/accordion/Accordion.js +15 -47
  7. package/accordion/Accordion.stories.tsx +307 -0
  8. package/accordion/Accordion.test.js +72 -0
  9. package/accordion/types.d.ts +8 -8
  10. package/accordion-group/AccordionGroup.d.ts +1 -1
  11. package/accordion-group/AccordionGroup.js +15 -17
  12. package/accordion-group/AccordionGroup.stories.tsx +225 -0
  13. package/accordion-group/AccordionGroup.test.js +151 -0
  14. package/accordion-group/types.d.ts +8 -8
  15. package/alert/Alert.js +6 -3
  16. package/alert/Alert.test.js +92 -0
  17. package/badge/Badge.d.ts +4 -0
  18. package/badge/Badge.js +6 -4
  19. package/badge/types.d.ts +5 -0
  20. package/{radio → badge}/types.js +0 -0
  21. package/bleed/Bleed.d.ts +3 -0
  22. package/bleed/Bleed.js +51 -0
  23. package/bleed/Bleed.stories.tsx +341 -0
  24. package/bleed/types.d.ts +37 -0
  25. package/bleed/types.js +5 -0
  26. package/box/Box.js +24 -34
  27. package/box/Box.test.js +18 -0
  28. package/button/Button.d.ts +1 -1
  29. package/button/Button.js +21 -26
  30. package/button/Button.stories.tsx +6 -8
  31. package/button/Button.test.js +35 -0
  32. package/button/types.d.ts +3 -7
  33. package/card/Card.js +25 -28
  34. package/card/Card.stories.tsx +1 -1
  35. package/card/Card.test.js +50 -0
  36. package/checkbox/Checkbox.d.ts +1 -1
  37. package/checkbox/Checkbox.js +45 -41
  38. package/checkbox/Checkbox.stories.tsx +124 -128
  39. package/checkbox/Checkbox.test.js +78 -0
  40. package/checkbox/types.d.ts +8 -4
  41. package/chip/Chip.d.ts +4 -0
  42. package/chip/Chip.js +16 -76
  43. package/chip/Chip.stories.tsx +6 -8
  44. package/chip/Chip.test.js +56 -0
  45. package/chip/types.d.ts +45 -0
  46. package/chip/types.js +5 -0
  47. package/common/variables.js +234 -341
  48. package/date-input/DateInput.js +63 -52
  49. package/date-input/DateInput.stories.tsx +7 -7
  50. package/date-input/DateInput.test.js +479 -0
  51. package/date-input/types.d.ts +16 -9
  52. package/dialog/Dialog.js +8 -35
  53. package/dialog/Dialog.test.js +40 -0
  54. package/dropdown/Dropdown.d.ts +1 -1
  55. package/dropdown/Dropdown.js +22 -48
  56. package/dropdown/Dropdown.stories.tsx +249 -0
  57. package/dropdown/Dropdown.test.js +189 -0
  58. package/dropdown/types.d.ts +6 -15
  59. package/file-input/FileInput.d.ts +1 -1
  60. package/file-input/FileInput.js +165 -83
  61. package/file-input/FileInput.stories.tsx +507 -0
  62. package/file-input/FileInput.test.js +457 -0
  63. package/file-input/FileItem.js +12 -8
  64. package/file-input/types.d.ts +32 -7
  65. package/footer/Footer.d.ts +1 -1
  66. package/footer/Footer.js +32 -113
  67. package/footer/{Footer.stories.jsx → Footer.stories.tsx} +1 -22
  68. package/footer/Footer.test.js +109 -0
  69. package/footer/Icons.d.ts +2 -0
  70. package/footer/Icons.js +4 -4
  71. package/footer/types.d.ts +21 -17
  72. package/header/Header.js +29 -50
  73. package/header/Header.stories.tsx +46 -36
  74. package/header/Header.test.js +79 -0
  75. package/header/Icons.d.ts +2 -0
  76. package/heading/Heading.js +1 -1
  77. package/heading/Heading.stories.tsx +3 -2
  78. package/heading/Heading.test.js +186 -0
  79. package/inline/Inline.d.ts +4 -0
  80. package/inline/Inline.js +54 -0
  81. package/inline/Inline.stories.tsx +240 -0
  82. package/inline/types.d.ts +32 -0
  83. package/inline/types.js +5 -0
  84. package/inset/Inset.d.ts +3 -0
  85. package/inset/Inset.js +51 -0
  86. package/inset/Inset.stories.tsx +229 -0
  87. package/inset/types.d.ts +37 -0
  88. package/inset/types.js +5 -0
  89. package/layout/ApplicationLayout.d.ts +11 -0
  90. package/layout/ApplicationLayout.js +84 -120
  91. package/layout/ApplicationLayout.stories.tsx +126 -0
  92. package/layout/Icons.d.ts +5 -0
  93. package/layout/Icons.js +13 -2
  94. package/layout/SidenavContext.d.ts +5 -0
  95. package/layout/SidenavContext.js +19 -0
  96. package/layout/types.d.ts +52 -0
  97. package/layout/types.js +5 -0
  98. package/link/Link.d.ts +3 -2
  99. package/link/Link.js +61 -86
  100. package/link/Link.stories.tsx +91 -51
  101. package/link/Link.test.js +83 -0
  102. package/link/types.d.ts +9 -29
  103. package/list/List.d.ts +4 -0
  104. package/list/List.js +47 -0
  105. package/list/List.stories.tsx +89 -0
  106. package/list/types.d.ts +7 -0
  107. package/list/types.js +5 -0
  108. package/main.d.ts +13 -9
  109. package/main.js +80 -42
  110. package/number-input/NumberInput.js +14 -24
  111. package/number-input/NumberInput.stories.tsx +5 -5
  112. package/number-input/NumberInput.test.js +506 -0
  113. package/number-input/types.d.ts +17 -10
  114. package/package.json +10 -6
  115. package/paginator/Paginator.js +19 -46
  116. package/paginator/Paginator.test.js +308 -0
  117. package/password-input/PasswordInput.js +23 -19
  118. package/password-input/PasswordInput.stories.tsx +3 -3
  119. package/password-input/PasswordInput.test.js +180 -0
  120. package/password-input/types.d.ts +26 -21
  121. package/progress-bar/ProgressBar.js +5 -5
  122. package/progress-bar/ProgressBar.stories.jsx +11 -11
  123. package/progress-bar/ProgressBar.test.js +65 -0
  124. package/quick-nav/QuickNav.d.ts +4 -0
  125. package/quick-nav/QuickNav.js +112 -0
  126. package/quick-nav/QuickNav.stories.tsx +237 -0
  127. package/quick-nav/types.d.ts +21 -0
  128. package/quick-nav/types.js +5 -0
  129. package/radio-group/Radio.d.ts +4 -0
  130. package/radio-group/Radio.js +141 -0
  131. package/radio-group/RadioGroup.d.ts +4 -0
  132. package/radio-group/RadioGroup.js +282 -0
  133. package/radio-group/RadioGroup.stories.tsx +100 -0
  134. package/radio-group/RadioGroup.test.js +695 -0
  135. package/radio-group/types.d.ts +114 -0
  136. package/radio-group/types.js +5 -0
  137. package/resultsetTable/ResultsetTable.d.ts +1 -1
  138. package/resultsetTable/ResultsetTable.js +9 -4
  139. package/resultsetTable/ResultsetTable.stories.tsx +275 -0
  140. package/resultsetTable/ResultsetTable.test.js +348 -0
  141. package/resultsetTable/types.d.ts +6 -2
  142. package/row/Row.d.ts +3 -0
  143. package/row/Row.js +127 -0
  144. package/row/Row.stories.tsx +237 -0
  145. package/row/types.d.ts +28 -0
  146. package/row/types.js +5 -0
  147. package/select/Icons.d.ts +10 -0
  148. package/select/Icons.js +93 -0
  149. package/select/Listbox.d.ts +4 -0
  150. package/select/Listbox.js +175 -0
  151. package/select/Option.d.ts +4 -0
  152. package/select/Option.js +110 -0
  153. package/select/Select.d.ts +4 -0
  154. package/select/Select.js +161 -366
  155. package/select/Select.stories.tsx +230 -176
  156. package/select/Select.test.js +2162 -0
  157. package/select/types.d.ts +212 -0
  158. package/select/types.js +5 -0
  159. package/sidenav/Sidenav.d.ts +1 -1
  160. package/sidenav/Sidenav.js +22 -11
  161. package/sidenav/Sidenav.stories.tsx +18 -1
  162. package/sidenav/Sidenav.test.js +56 -0
  163. package/slider/Slider.d.ts +1 -1
  164. package/slider/Slider.js +4 -3
  165. package/slider/Slider.stories.tsx +8 -8
  166. package/slider/Slider.test.js +150 -0
  167. package/slider/types.d.ts +4 -0
  168. package/spinner/Spinner.js +3 -3
  169. package/spinner/Spinner.stories.jsx +1 -0
  170. package/spinner/Spinner.test.js +64 -0
  171. package/stack/Stack.d.ts +4 -0
  172. package/stack/Stack.js +50 -0
  173. package/stack/Stack.stories.tsx +203 -0
  174. package/stack/types.d.ts +28 -0
  175. package/stack/types.js +5 -0
  176. package/switch/Switch.d.ts +1 -1
  177. package/switch/Switch.js +37 -21
  178. package/switch/Switch.stories.tsx +15 -15
  179. package/switch/Switch.test.js +98 -0
  180. package/switch/types.d.ts +6 -2
  181. package/table/Table.js +2 -2
  182. package/table/Table.stories.jsx +2 -1
  183. package/table/Table.test.js +26 -0
  184. package/tabs/Tabs.d.ts +1 -1
  185. package/tabs/Tabs.js +17 -19
  186. package/tabs/Tabs.stories.tsx +112 -0
  187. package/tabs/Tabs.test.js +140 -0
  188. package/tabs/types.d.ts +27 -15
  189. package/tabs-nav/NavTabs.d.ts +8 -0
  190. package/tabs-nav/NavTabs.js +125 -0
  191. package/tabs-nav/NavTabs.stories.tsx +170 -0
  192. package/tabs-nav/NavTabs.test.js +82 -0
  193. package/tabs-nav/Tab.d.ts +4 -0
  194. package/tabs-nav/Tab.js +132 -0
  195. package/tabs-nav/types.d.ts +53 -0
  196. package/tabs-nav/types.js +5 -0
  197. package/tag/Tag.d.ts +1 -1
  198. package/tag/Tag.js +18 -28
  199. package/tag/Tag.stories.tsx +26 -29
  200. package/tag/Tag.test.js +60 -0
  201. package/tag/types.d.ts +23 -14
  202. package/text/Text.d.ts +7 -0
  203. package/text/Text.js +30 -0
  204. package/text/Text.stories.tsx +19 -0
  205. package/text-input/Suggestion.d.ts +4 -0
  206. package/text-input/Suggestion.js +55 -0
  207. package/text-input/TextInput.js +88 -103
  208. package/text-input/TextInput.stories.tsx +474 -0
  209. package/text-input/TextInput.test.js +1712 -0
  210. package/text-input/types.d.ts +44 -23
  211. package/textarea/Textarea.d.ts +4 -0
  212. package/textarea/Textarea.js +39 -79
  213. package/textarea/Textarea.stories.jsx +37 -15
  214. package/textarea/Textarea.test.js +437 -0
  215. package/textarea/types.d.ts +137 -0
  216. package/textarea/types.js +5 -0
  217. package/toggle-group/ToggleGroup.d.ts +4 -0
  218. package/toggle-group/ToggleGroup.js +18 -46
  219. package/toggle-group/ToggleGroup.stories.tsx +27 -32
  220. package/toggle-group/ToggleGroup.test.js +156 -0
  221. package/toggle-group/types.d.ts +105 -0
  222. package/toggle-group/types.js +5 -0
  223. package/useTheme.d.ts +2 -0
  224. package/useTheme.js +2 -2
  225. package/useTranslatedLabels.d.ts +2 -0
  226. package/useTranslatedLabels.js +20 -0
  227. package/wizard/Wizard.d.ts +1 -1
  228. package/wizard/Wizard.js +107 -46
  229. package/wizard/{Wizard.stories.jsx → Wizard.stories.tsx} +13 -23
  230. package/wizard/Wizard.test.js +141 -0
  231. package/wizard/types.d.ts +9 -9
  232. package/ThemeContext.js +0 -246
  233. package/V3Select/V3Select.js +0 -455
  234. package/V3Select/index.d.ts +0 -27
  235. package/V3Textarea/V3Textarea.js +0 -260
  236. package/V3Textarea/index.d.ts +0 -27
  237. package/chip/index.d.ts +0 -22
  238. package/date/Date.js +0 -373
  239. package/date/index.d.ts +0 -27
  240. package/input-text/Icons.js +0 -22
  241. package/input-text/InputText.js +0 -611
  242. package/input-text/index.d.ts +0 -36
  243. package/radio/Radio.d.ts +0 -4
  244. package/radio/Radio.js +0 -174
  245. package/radio/Radio.stories.tsx +0 -192
  246. package/radio/types.d.ts +0 -54
  247. package/select/index.d.ts +0 -131
  248. package/textarea/index.d.ts +0 -117
  249. package/toggle/Toggle.js +0 -186
  250. package/toggle/index.d.ts +0 -21
  251. package/toggle-group/index.d.ts +0 -21
  252. package/upload/Upload.js +0 -201
  253. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  254. package/upload/buttons-upload/Icons.js +0 -40
  255. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  256. package/upload/dragAndDropArea/Icons.js +0 -39
  257. package/upload/file-upload/FileToUpload.js +0 -115
  258. package/upload/file-upload/Icons.js +0 -66
  259. package/upload/files-upload/FilesToUpload.js +0 -109
  260. package/upload/index.d.ts +0 -15
  261. package/upload/transaction/Icons.js +0 -160
  262. package/upload/transaction/Transaction.js +0 -104
  263. package/upload/transactions/Transactions.js +0 -94
  264. package/wizard/Icons.js +0 -65
package/header/Header.js CHANGED
@@ -27,9 +27,11 @@ var _Icons = require("./Icons");
27
27
 
28
28
  var _variables = require("../common/variables.js");
29
29
 
30
- var _useTheme = _interopRequireDefault(require("../useTheme.js"));
30
+ var _useTheme = _interopRequireDefault(require("../useTheme"));
31
31
 
32
- var _BackgroundColorContext = _interopRequireWildcard(require("../BackgroundColorContext.js"));
32
+ var _useTranslatedLabels = _interopRequireDefault(require("../useTranslatedLabels"));
33
+
34
+ var _BackgroundColorContext = _interopRequireWildcard(require("../BackgroundColorContext"));
33
35
 
34
36
  var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8, _templateObject9, _templateObject10, _templateObject11, _templateObject12, _templateObject13, _templateObject14, _templateObject15;
35
37
 
@@ -64,14 +66,14 @@ var Dropdown = function Dropdown(props) {
64
66
 
65
67
  var HeaderDropdown = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n button {\n background-color: transparent;\n :hover {\n background-color: transparent;\n }\n }\n"])));
66
68
 
67
- var getLogoElement = function getLogoElement(themeInput) {
69
+ var getLogoElement = function getLogoElement(themeInput, logoLabel) {
68
70
  if (!themeInput) {
69
71
  return _Icons.dxcLogo;
70
72
  }
71
73
 
72
74
  if (typeof themeInput === "string") {
73
75
  return /*#__PURE__*/_react["default"].createElement(LogoImg, {
74
- alt: "Logo",
76
+ alt: logoLabel,
75
77
  src: themeInput
76
78
  });
77
79
  }
@@ -90,33 +92,21 @@ var DxcHeader = function DxcHeader(_ref) {
90
92
  _ref$tabIndex = _ref.tabIndex,
91
93
  tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
92
94
  var colorsTheme = (0, _useTheme["default"])();
95
+ var translatedLabels = (0, _useTranslatedLabels["default"])();
93
96
  var ref = (0, _react.useRef)(null);
94
97
 
95
- var _useState = (0, _react.useState)(),
98
+ var _useState = (0, _react.useState)(false),
96
99
  _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
97
- refSize = _useState2[0],
98
- setRefSize = _useState2[1];
100
+ isResponsive = _useState2[0],
101
+ setIsResponsive = _useState2[1];
99
102
 
100
103
  var _useState3 = (0, _react.useState)(false),
101
104
  _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
102
- isResponsive = _useState4[0],
103
- setIsResponsive = _useState4[1];
104
-
105
- var _useState5 = (0, _react.useState)(false),
106
- _useState6 = (0, _slicedToArray2["default"])(_useState5, 2),
107
- isMenuVisible = _useState6[0],
108
- setIsMenuVisible = _useState6[1];
109
-
110
- var handleResize = function handleResize(refWidth) {
111
- if (refWidth) {
112
- setRefSize(refWidth);
113
-
114
- if (refWidth <= _variables.responsiveSizes.tablet && !isResponsive) {
115
- setIsResponsive(true);
116
- } else {
117
- setIsResponsive(false);
118
- }
119
- }
105
+ isMenuVisible = _useState4[0],
106
+ setIsMenuVisible = _useState4[1];
107
+
108
+ var handleResize = function handleResize() {
109
+ setIsResponsive(window.matchMedia("(max-width: ".concat(_variables.responsiveSizes.medium, "rem)")).matches && !isResponsive);
120
110
  };
121
111
 
122
112
  var ContentContainerComponent = function ContentContainerComponent() {
@@ -138,24 +128,19 @@ var DxcHeader = function DxcHeader(_ref) {
138
128
  };
139
129
 
140
130
  var headerLogo = (0, _react.useMemo)(function () {
141
- return getLogoElement(colorsTheme.header.logo);
131
+ return getLogoElement(colorsTheme.header.logo, translatedLabels.formFields.logoAlternativeText);
142
132
  }, [colorsTheme.header.logo]);
143
133
  var headerResponsiveLogo = (0, _react.useMemo)(function () {
144
- return getLogoElement(colorsTheme.header.logoResponsive);
134
+ return getLogoElement(colorsTheme.header.logoResponsive, translatedLabels.formFields.logoAlternativeText);
145
135
  }, [colorsTheme.header.logoResponsive]);
146
-
147
- var handleEventListener = function handleEventListener() {
148
- handleResize(ref.current.offsetWidth);
149
- };
150
-
151
136
  (0, _react.useEffect)(function () {
152
137
  if (ref.current) {
153
- window.addEventListener("resize", handleEventListener);
154
- handleResize(ref.current.offsetWidth);
138
+ window.addEventListener("resize", handleResize);
139
+ handleResize();
155
140
  }
156
141
 
157
142
  return function () {
158
- window.removeEventListener("resize", handleEventListener);
143
+ window.removeEventListener("resize", handleResize);
159
144
  };
160
145
  }, []);
161
146
  return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
@@ -176,8 +161,7 @@ var DxcHeader = function DxcHeader(_ref) {
176
161
  underlined: underlined,
177
162
  onClick: handleMenu
178
163
  }, hamburgerIcon, /*#__PURE__*/_react["default"].createElement(HamburguerTitle, null, "Menu"))), /*#__PURE__*/_react["default"].createElement("div", null, /*#__PURE__*/_react["default"].createElement(ResponsiveMenu, {
179
- hasVisibility: isMenuVisible,
180
- refSize: refSize
164
+ hasVisibility: isMenuVisible
181
165
  }, /*#__PURE__*/_react["default"].createElement(ResponsiveLogoContainer, null, headerResponsiveLogo), /*#__PURE__*/_react["default"].createElement(_BackgroundColorContext.BackgroundColorProvider, {
182
166
  color: colorsTheme.header.menuBackgroundColor
183
167
  }, /*#__PURE__*/_react["default"].createElement(ContentContainerComponent, null)), /*#__PURE__*/_react["default"].createElement(CloseContainer, {
@@ -186,8 +170,7 @@ var DxcHeader = function DxcHeader(_ref) {
186
170
  className: "closeIcon"
187
171
  }, closeIcon)), /*#__PURE__*/_react["default"].createElement(Overlay, {
188
172
  onClick: handleMenu,
189
- hasVisibility: isMenuVisible,
190
- refSize: refSize
173
+ hasVisibility: isMenuVisible
191
174
  }))), !isResponsive && /*#__PURE__*/_react["default"].createElement(_BackgroundColorContext.BackgroundColorProvider, {
192
175
  color: colorsTheme.header.backgroundColor
193
176
  }, /*#__PURE__*/_react["default"].createElement(ContentContainerComponent, null))));
@@ -276,16 +259,14 @@ var HamburguerTitle = _styledComponents["default"].span(_templateObject9 || (_te
276
259
 
277
260
  var MainContainer = _styledComponents["default"].div(_templateObject10 || (_templateObject10 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-grow: 1;\n"])));
278
261
 
279
- var ResponsiveMenu = _styledComponents["default"].div(_templateObject11 || (_templateObject11 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n justify-content: space-evenly;\n background-color: ", ";\n position: fixed;\n top: 0;\n right: 0;\n z-index: ", ";\n width: ", ";\n height: 100vh;\n padding: 20px;\n transform: ", ";\n opacity: ", ";\n transition-property: transform, opacity;\n transition-duration: 0.6s;\n transition-timing-function: ease-in-out;\n box-sizing: border-box;\n"])), function (props) {
262
+ var ResponsiveMenu = _styledComponents["default"].div(_templateObject11 || (_templateObject11 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n justify-content: space-evenly;\n background-color: ", ";\n position: fixed;\n top: 0;\n right: 0;\n z-index: ", ";\n\n @media (max-width: ", "rem) and (min-width: ", "rem) {\n //tablet\n width: ", ";\n }\n\n @media not((max-width: ", "rem) and (min-width: ", "rem)) {\n //mobile phones\n width: ", ";\n }\n\n height: 100vh;\n padding: 20px;\n transform: ", ";\n opacity: ", ";\n transition-property: transform, opacity;\n transition-duration: 0.6s;\n transition-timing-function: ease-in-out;\n box-sizing: border-box;\n"])), function (props) {
280
263
  return props.theme.menuBackgroundColor;
281
264
  }, function (props) {
282
265
  return props.theme.menuZindex;
283
- }, function (props) {
284
- return props.refSize <= _variables.responsiveSizes.laptop && props.refSize > _variables.responsiveSizes.mobileLarge ? "".concat(function (props) {
285
- return props.theme.menuTabletWidth;
286
- }) : "".concat(function (props) {
287
- return props.theme.menuMobileWidth;
288
- });
266
+ }, _variables.responsiveSizes.large, _variables.responsiveSizes.small, function (props) {
267
+ return props.theme.menuTabletWidth;
268
+ }, _variables.responsiveSizes.large, _variables.responsiveSizes.small, function (props) {
269
+ return props.theme.menuMobileWidth;
289
270
  }, function (props) {
290
271
  return props.hasVisibility ? "translateX(0)" : "translateX(100vw)";
291
272
  }, function (props) {
@@ -306,7 +287,7 @@ var MenuContent = _styledComponents["default"].div(_templateObject14 || (_templa
306
287
  return props.backgroundType === "dark" ? props.theme.contentColorOnDark : props.theme.contentColor;
307
288
  });
308
289
 
309
- var Overlay = _styledComponents["default"].div(_templateObject15 || (_templateObject15 = (0, _taggedTemplateLiteral2["default"])(["\n position: fixed;\n top: 0;\n left: 0;\n width: 100vw;\n height: 100vh;\n background-color: ", ";\n opacity: ", " !important;\n visibility: ", ";\n opacity: ", ";\n display: ", ";\n transition: opacity 0.2s 0.2s ease-in-out;\n z-index: ", ";\n"])), function (props) {
290
+ var Overlay = _styledComponents["default"].div(_templateObject15 || (_templateObject15 = (0, _taggedTemplateLiteral2["default"])(["\n position: fixed;\n top: 0;\n left: 0;\n width: 100vw;\n height: 100vh;\n background-color: ", ";\n opacity: ", " !important;\n visibility: ", ";\n opacity: ", ";\n\n @media (max-width: ", "rem) {\n //mobile phones\n display: none;\n }\n\n transition: opacity 0.2s 0.2s ease-in-out;\n z-index: ", ";\n"])), function (props) {
310
291
  return props.theme.overlayColor;
311
292
  }, function (props) {
312
293
  return props.theme.overlayOpacity;
@@ -314,9 +295,7 @@ var Overlay = _styledComponents["default"].div(_templateObject15 || (_templateOb
314
295
  return props.hasVisibility ? "visible" : "hidden";
315
296
  }, function (props) {
316
297
  return props.hasVisibility ? "1" : "0";
317
- }, function (props) {
318
- return props.refSize <= _variables.responsiveSizes.mobileLarge ? "none" : "";
319
- }, function (props) {
298
+ }, _variables.responsiveSizes.small, function (props) {
320
299
  return props.theme.overlayZindex;
321
300
  });
322
301
 
@@ -26,15 +26,6 @@ export const Chromatic = () => (
26
26
  <Title title="Underlined with text" theme="light" level={4} />
27
27
  <DxcHeader underlined content={<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Cras felis.</p>} />
28
28
  </ExampleContainer>
29
- <ExampleContainer>
30
- <Title title="Responsive" theme="light" level={4} />
31
- <div style={{ width: "400px" }}>
32
- <DxcHeader
33
- responsiveContent={(closeHandler) => <DxcHeader.Dropdown options={options} label="Default Dropdown" />}
34
- underlined
35
- />
36
- </div>
37
- </ExampleContainer>
38
29
  <Title title="Margins" theme="light" level={2} />
39
30
  <ExampleContainer>
40
31
  <Title title="Xxsmall margin" theme="light" level={4} />
@@ -104,59 +95,78 @@ export const Chromatic = () => (
104
95
  </>
105
96
  );
106
97
 
107
- const RespHeader = () => (
98
+ export const ResponsiveHeader = () => (
108
99
  <ExampleContainer>
109
100
  <Title title="Responsive" theme="light" level={4} />
110
- <div style={{ maxWidth: "400px" }}>
111
- <DxcHeader
112
- responsiveContent={(closeHandler) => <DxcHeader.Dropdown options={options} label="Default Dropdown" />}
113
- underlined
114
- />
115
- </div>
101
+ <DxcHeader
102
+ content={<DxcHeader.Dropdown options={options} label="Default Dropdown" />}
103
+ responsiveContent={(closeHandler) => <DxcHeader.Dropdown options={options} label="Default Dropdown" />}
104
+ underlined
105
+ />
116
106
  </ExampleContainer>
117
107
  );
118
108
 
119
109
  const RespHeaderFocus = () => (
120
110
  <ExampleContainer pseudoState="pseudo-focus">
121
- <Title title="Responsive" theme="light" level={4} />
122
- <div style={{ maxWidth: "400px" }}>
123
- <DxcHeader
124
- responsiveContent={(closeHandler) => <p>Lorem ipsum dolor sit amet.</p>}
125
- underlined
126
- />
127
- </div>
111
+ <Title title="Responsive focus" theme="light" level={4} />
112
+ <DxcHeader responsiveContent={(closeHandler) => <p>Lorem ipsum dolor sit amet.</p>} underlined />
128
113
  </ExampleContainer>
129
114
  );
130
115
 
131
116
  const RespHeaderHover = () => (
132
117
  <ExampleContainer pseudoState="pseudo-hover">
133
- <Title title="Responsive" theme="light" level={4} />
134
- <div style={{ maxWidth: "400px" }}>
135
- <DxcHeader
136
- responsiveContent={(closeHandler) => <p>Lorem ipsum dolor sit amet.</p>}
137
- underlined
138
- />
139
- </div>
118
+ <Title title="Responsive hover" theme="light" level={4} />
119
+ <DxcHeader responsiveContent={(closeHandler) => <p>Lorem ipsum dolor sit amet.</p>} underlined />
140
120
  </ExampleContainer>
141
121
  );
142
122
 
143
- export const ResponsiveHeader = RespHeader.bind({});
144
- ResponsiveHeader.play = async ({ canvasElement }) => {
145
- const canvas = within(canvasElement);
146
- await waitFor(() => canvas.findByText("Menu"));
147
- await userEvent.click(canvas.getByText("Menu"));
123
+ const RespHeaderMenu = () => (
124
+ <ExampleContainer>
125
+ <Title title="Responsive menu" theme="light" level={4} />
126
+ <DxcHeader responsiveContent={(closeHandler) => <p>Lorem ipsum dolor sit amet.</p>} underlined />
127
+ </ExampleContainer>
128
+ );
129
+
130
+ ResponsiveHeader.parameters = {
131
+ viewport: {
132
+ defaultViewport: "iphonex",
133
+ },
134
+ chromatic: { viewports: [720] },
148
135
  };
149
136
 
150
137
  export const ResponsiveHeaderFocus = RespHeaderFocus.bind({});
138
+ ResponsiveHeaderFocus.parameters = {
139
+ viewport: {
140
+ defaultViewport: "iphonex",
141
+ },
142
+ chromatic: { viewports: [720] },
143
+ };
151
144
  ResponsiveHeaderFocus.play = async ({ canvasElement }) => {
152
145
  const canvas = within(canvasElement);
153
146
  await waitFor(() => canvas.findByText("Menu"));
154
- await userEvent.click(canvas.getByText("Menu"));
155
147
  };
156
148
 
157
149
  export const ResponsiveHeaderHover = RespHeaderHover.bind({});
150
+ ResponsiveHeaderHover.parameters = {
151
+ viewport: {
152
+ defaultViewport: "iphonex",
153
+ },
154
+ chromatic: { viewports: [720] },
155
+ };
158
156
  ResponsiveHeaderHover.play = async ({ canvasElement }) => {
159
157
  const canvas = within(canvasElement);
160
158
  await waitFor(() => canvas.findByText("Menu"));
159
+ };
160
+
161
+ export const ResponsiveHeaderMenu = RespHeaderMenu.bind({});
162
+ ResponsiveHeaderMenu.parameters = {
163
+ viewport: {
164
+ defaultViewport: "iphonex",
165
+ },
166
+ chromatic: { viewports: [720] },
167
+ };
168
+ ResponsiveHeaderMenu.play = async ({ canvasElement }) => {
169
+ const canvas = within(canvasElement);
170
+ await waitFor(() => canvas.findByText("Menu"));
161
171
  await userEvent.click(canvas.getByText("Menu"));
162
172
  };
@@ -0,0 +1,79 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _react = _interopRequireDefault(require("react"));
6
+
7
+ var _react2 = require("@testing-library/react");
8
+
9
+ var _Header = _interopRequireDefault(require("./Header"));
10
+
11
+ describe("Header component tests", function () {
12
+ beforeAll(function () {
13
+ Object.defineProperty(window, "matchMedia", {
14
+ writable: true,
15
+ value: jest.fn().mockImplementation(function () {
16
+ return {
17
+ matches: false
18
+ };
19
+ })
20
+ });
21
+ });
22
+ test("Header renders with default logo", function () {
23
+ var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Header["default"], null)),
24
+ getByTitle = _render.getByTitle;
25
+
26
+ expect(getByTitle("DXC Logo")).toBeTruthy();
27
+ });
28
+ test("Call correct function on logo click", function () {
29
+ var onClick = jest.fn();
30
+
31
+ var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Header["default"], {
32
+ onClick: onClick
33
+ })),
34
+ getByTitle = _render2.getByTitle;
35
+
36
+ var logo = getByTitle("DXC Logo");
37
+
38
+ _react2.fireEvent.click(logo);
39
+
40
+ expect(onClick).toHaveBeenCalled();
41
+ });
42
+ test("Header renders with correct children", function () {
43
+ // We need to force the offsetWidth value
44
+ Object.defineProperty(HTMLElement.prototype, "offsetWidth", {
45
+ configurable: true,
46
+ value: 1024
47
+ });
48
+
49
+ var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Header["default"], {
50
+ content: /*#__PURE__*/_react["default"].createElement("p", null, "header-child-text")
51
+ })),
52
+ getByText = _render3.getByText;
53
+
54
+ expect(getByText("header-child-text")).toBeTruthy();
55
+ });
56
+ test("Header renders menu button in mobile", function () {
57
+ Object.defineProperty(HTMLElement.prototype, "offsetWidth", {
58
+ configurable: true,
59
+ value: 425
60
+ });
61
+ Object.defineProperty(window, "matchMedia", {
62
+ writable: true,
63
+ value: jest.fn().mockImplementation(function () {
64
+ return {
65
+ matches: true
66
+ };
67
+ })
68
+ });
69
+
70
+ var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Header["default"], {
71
+ responsiveContent: function responsiveContent(closeMenu) {
72
+ return /*#__PURE__*/_react["default"].createElement("p", null, "header-child-text");
73
+ }
74
+ })),
75
+ getByText = _render4.getByText;
76
+
77
+ expect(getByText("Menu")).toBeTruthy();
78
+ });
79
+ });
@@ -0,0 +1,2 @@
1
+ /// <reference types="react" />
2
+ export declare const dxcLogo: JSX.Element;
@@ -19,7 +19,7 @@ var _styledComponents = _interopRequireWildcard(require("styled-components"));
19
19
 
20
20
  var _variables = require("../common/variables.js");
21
21
 
22
- var _useTheme = _interopRequireDefault(require("../useTheme.js"));
22
+ var _useTheme = _interopRequireDefault(require("../useTheme"));
23
23
 
24
24
  var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6;
25
25
 
@@ -28,9 +28,9 @@ export const Chromatic = () => (
28
28
  <Title title="'light' Weight" theme="light" level={4} />
29
29
  <DxcHeading text="Heading for sections within the page" level={2} weight="light" />
30
30
  <Title title="'normal' Weight" theme="light" level={4} />
31
- <DxcHeading text="Heading for sections within the page" level={4} weight="normal" />
31
+ <DxcHeading text="Heading for sections within the page" level={2} weight="normal" />
32
32
  <Title title="'bold' Weight" theme="light" level={4} />
33
- <DxcHeading text="Heading for sections within the page" weight="bold" />
33
+ <DxcHeading text="Heading for sections within the page" level={2} weight="bold" />
34
34
  </ExampleContainer>
35
35
  <Title title="Margins" theme="light" level={2} />
36
36
  <ExampleContainer>
@@ -48,6 +48,7 @@ export const Chromatic = () => (
48
48
  <DxcHeading text="Xlarge" margin="xlarge" />
49
49
  <Title title="Xxlarge" theme="light" level={4} />
50
50
  <DxcHeading text="Xxlarge" margin="xxlarge" />
51
+ <hr />
51
52
  </ExampleContainer>
52
53
  </>
53
54
  );
@@ -0,0 +1,186 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _react = _interopRequireDefault(require("react"));
6
+
7
+ var _react2 = require("@testing-library/react");
8
+
9
+ var _Heading = _interopRequireDefault(require("./Heading"));
10
+
11
+ describe("Heading component tests", function () {
12
+ test("Heading renders with default level", function () {
13
+ var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Heading["default"], {
14
+ text: "my-heading-test"
15
+ })),
16
+ getByText = _render.getByText,
17
+ getByRole = _render.getByRole;
18
+
19
+ expect(getByText("my-heading-test")).toBeTruthy();
20
+ expect(getByRole("heading", {
21
+ level: 1
22
+ })).toBeTruthy();
23
+ });
24
+ test("Heading renders with level 1", function () {
25
+ var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Heading["default"], {
26
+ text: "my-heading-test",
27
+ level: 1
28
+ })),
29
+ getByText = _render2.getByText,
30
+ getByRole = _render2.getByRole;
31
+
32
+ expect(getByText("my-heading-test")).toBeTruthy();
33
+ expect(getByRole("heading", {
34
+ level: 1
35
+ })).toBeTruthy();
36
+ });
37
+ test("Heading renders with level 2", function () {
38
+ var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Heading["default"], {
39
+ text: "my-heading-test",
40
+ level: 2
41
+ })),
42
+ getByText = _render3.getByText,
43
+ getByRole = _render3.getByRole;
44
+
45
+ expect(getByText("my-heading-test")).toBeTruthy();
46
+ expect(getByRole("heading", {
47
+ level: 2
48
+ })).toBeTruthy();
49
+ });
50
+ test("Heading renders with level 3", function () {
51
+ var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Heading["default"], {
52
+ text: "my-heading-test",
53
+ level: 3
54
+ })),
55
+ getByText = _render4.getByText,
56
+ getByRole = _render4.getByRole;
57
+
58
+ expect(getByText("my-heading-test")).toBeTruthy();
59
+ expect(getByRole("heading", {
60
+ level: 3
61
+ })).toBeTruthy();
62
+ });
63
+ test("Heading renders with level 4", function () {
64
+ var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Heading["default"], {
65
+ text: "my-heading-test",
66
+ level: 4
67
+ })),
68
+ getByText = _render5.getByText,
69
+ getByRole = _render5.getByRole;
70
+
71
+ expect(getByText("my-heading-test")).toBeTruthy();
72
+ expect(getByRole("heading", {
73
+ level: 4
74
+ })).toBeTruthy();
75
+ });
76
+ test("Heading renders with level 5", function () {
77
+ var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Heading["default"], {
78
+ text: "my-heading-test",
79
+ level: 5
80
+ })),
81
+ getByText = _render6.getByText,
82
+ getByRole = _render6.getByRole;
83
+
84
+ expect(getByText("my-heading-test")).toBeTruthy();
85
+ expect(getByRole("heading", {
86
+ level: 5
87
+ })).toBeTruthy();
88
+ });
89
+ test("Heading renders with default level and as h5", function () {
90
+ var _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Heading["default"], {
91
+ text: "my-heading-test",
92
+ as: "h5"
93
+ })),
94
+ getByText = _render7.getByText,
95
+ getByRole = _render7.getByRole;
96
+
97
+ expect(getByText("my-heading-test")).toBeTruthy();
98
+ expect(getByRole("heading", {
99
+ level: 5
100
+ })).toBeTruthy();
101
+ });
102
+ test("Heading renders with level 1 and as h5", function () {
103
+ var _render8 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Heading["default"], {
104
+ text: "my-heading-test",
105
+ level: 1,
106
+ as: "h5"
107
+ })),
108
+ getByText = _render8.getByText,
109
+ getByRole = _render8.getByRole;
110
+
111
+ expect(getByText("my-heading-test")).toBeTruthy();
112
+ expect(getByRole("heading", {
113
+ level: 5
114
+ })).toBeTruthy();
115
+ });
116
+ test("Heading renders with level 2 and as h4", function () {
117
+ var _render9 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Heading["default"], {
118
+ text: "my-heading-test",
119
+ level: 2,
120
+ as: "h4"
121
+ })),
122
+ getByText = _render9.getByText,
123
+ getByRole = _render9.getByRole;
124
+
125
+ expect(getByText("my-heading-test")).toBeTruthy();
126
+ expect(getByRole("heading", {
127
+ level: 4
128
+ })).toBeTruthy();
129
+ });
130
+ test("Heading renders with level 3 and as h2", function () {
131
+ var _render10 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Heading["default"], {
132
+ text: "my-heading-test",
133
+ level: 3,
134
+ as: "h2"
135
+ })),
136
+ getByText = _render10.getByText,
137
+ getByRole = _render10.getByRole;
138
+
139
+ expect(getByText("my-heading-test")).toBeTruthy();
140
+ expect(getByRole("heading", {
141
+ level: 2
142
+ })).toBeTruthy();
143
+ });
144
+ test("Heading renders with level 4 and as h3", function () {
145
+ var _render11 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Heading["default"], {
146
+ text: "my-heading-test",
147
+ level: 4,
148
+ as: "h3"
149
+ })),
150
+ getByText = _render11.getByText,
151
+ getByRole = _render11.getByRole;
152
+
153
+ expect(getByText("my-heading-test")).toBeTruthy();
154
+ expect(getByRole("heading", {
155
+ level: 3
156
+ })).toBeTruthy();
157
+ });
158
+ test("Heading renders with level 5 as h4", function () {
159
+ var _render12 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Heading["default"], {
160
+ text: "my-heading-test",
161
+ level: 5,
162
+ as: "h4"
163
+ })),
164
+ getByText = _render12.getByText,
165
+ getByRole = _render12.getByRole;
166
+
167
+ expect(getByText("my-heading-test")).toBeTruthy();
168
+ expect(getByRole("heading", {
169
+ level: 4
170
+ })).toBeTruthy();
171
+ });
172
+ test("Heading renders with level 5 and invalid as", function () {
173
+ var _render13 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Heading["default"], {
174
+ text: "my-heading-test",
175
+ level: 5,
176
+ as: "h4afdssf"
177
+ })),
178
+ getByText = _render13.getByText,
179
+ getByRole = _render13.getByRole;
180
+
181
+ expect(getByText("my-heading-test")).toBeTruthy();
182
+ expect(getByRole("heading", {
183
+ level: 5
184
+ })).toBeTruthy();
185
+ });
186
+ });
@@ -0,0 +1,4 @@
1
+ /// <reference types="react" />
2
+ import InlineProps from "./types";
3
+ declare const DxcInline: ({ alignX, alignY, as, divider, gutter, reverse, children, }: InlineProps) => JSX.Element;
4
+ export default DxcInline;
@@ -0,0 +1,54 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports["default"] = void 0;
9
+
10
+ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
11
+
12
+ var _react = _interopRequireDefault(require("react"));
13
+
14
+ var _styledComponents = _interopRequireDefault(require("styled-components"));
15
+
16
+ var _templateObject, _templateObject2;
17
+
18
+ var DxcInline = function DxcInline(_ref) {
19
+ var _ref$alignX = _ref.alignX,
20
+ alignX = _ref$alignX === void 0 ? "start" : _ref$alignX,
21
+ _ref$alignY = _ref.alignY,
22
+ alignY = _ref$alignY === void 0 ? "stretch" : _ref$alignY,
23
+ _ref$as = _ref.as,
24
+ as = _ref$as === void 0 ? "div" : _ref$as,
25
+ _ref$divider = _ref.divider,
26
+ divider = _ref$divider === void 0 ? false : _ref$divider,
27
+ _ref$gutter = _ref.gutter,
28
+ gutter = _ref$gutter === void 0 ? "0rem" : _ref$gutter,
29
+ _ref$reverse = _ref.reverse,
30
+ reverse = _ref$reverse === void 0 ? false : _ref$reverse,
31
+ children = _ref.children;
32
+ return /*#__PURE__*/_react["default"].createElement(Inline, {
33
+ as: as,
34
+ alignX: alignX,
35
+ alignY: alignY,
36
+ gutter: gutter,
37
+ reverse: reverse
38
+ }, _react["default"].Children.map(children, function (child, index) {
39
+ return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, child, divider && index !== _react["default"].Children.count(children) - 1 && /*#__PURE__*/_react["default"].createElement(Divider, null));
40
+ }));
41
+ };
42
+
43
+ var Inline = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n ", "\n flex-wrap: wrap;\n"])), function (_ref2) {
44
+ var alignX = _ref2.alignX,
45
+ alignY = _ref2.alignY,
46
+ gutter = _ref2.gutter,
47
+ reverse = _ref2.reverse;
48
+ return "\n flex-direction: ".concat(reverse ? "row-reverse" : "row", ";\n align-items: ").concat(alignY === "start" || alignY === "end" ? "flex-".concat(alignY) : alignY, ";\n justify-content: ").concat(alignX === "start" || alignX === "end" ? "flex-".concat(alignX) : alignX, ";\n gap: ").concat(gutter, ";\n ");
49
+ });
50
+
51
+ var Divider = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n width: 1px;\n background-color: #999999;\n"])));
52
+
53
+ var _default = DxcInline;
54
+ exports["default"] = _default;