@dxc-technology/halstack-react 0.0.0-eca8a89 → 0.0.0-ecc45e2

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 (266) hide show
  1. package/BackgroundColorContext.js +0 -1
  2. package/HalstackContext.d.ts +12 -0
  3. package/HalstackContext.js +295 -0
  4. package/accordion/Accordion.d.ts +1 -1
  5. package/accordion/Accordion.js +13 -45
  6. package/accordion/Accordion.stories.tsx +20 -13
  7. package/accordion/Accordion.test.js +72 -0
  8. package/accordion/types.d.ts +7 -7
  9. package/accordion-group/AccordionGroup.d.ts +1 -1
  10. package/accordion-group/AccordionGroup.js +14 -15
  11. package/accordion-group/AccordionGroup.stories.tsx +1 -1
  12. package/accordion-group/AccordionGroup.test.js +151 -0
  13. package/accordion-group/types.d.ts +7 -7
  14. package/alert/Alert.js +4 -1
  15. package/alert/Alert.test.js +92 -0
  16. package/badge/Badge.d.ts +4 -0
  17. package/badge/Badge.js +5 -3
  18. package/badge/types.d.ts +5 -0
  19. package/{radio → badge}/types.js +0 -0
  20. package/bleed/Bleed.d.ts +3 -0
  21. package/bleed/Bleed.js +51 -0
  22. package/bleed/Bleed.stories.tsx +341 -0
  23. package/bleed/types.d.ts +37 -0
  24. package/bleed/types.js +5 -0
  25. package/box/Box.js +22 -32
  26. package/box/Box.test.js +18 -0
  27. package/bulleted-list/BulletedList.d.ts +7 -0
  28. package/bulleted-list/BulletedList.js +123 -0
  29. package/bulleted-list/BulletedList.stories.tsx +200 -0
  30. package/bulleted-list/types.d.ts +11 -0
  31. package/bulleted-list/types.js +5 -0
  32. package/button/Button.d.ts +1 -1
  33. package/button/Button.js +57 -80
  34. package/button/Button.stories.tsx +15 -8
  35. package/button/Button.test.js +35 -0
  36. package/button/types.d.ts +8 -12
  37. package/card/Card.js +24 -27
  38. package/card/Card.stories.tsx +1 -1
  39. package/card/Card.test.js +50 -0
  40. package/checkbox/Checkbox.d.ts +1 -1
  41. package/checkbox/Checkbox.js +43 -39
  42. package/checkbox/Checkbox.stories.tsx +124 -128
  43. package/checkbox/Checkbox.test.js +78 -0
  44. package/checkbox/types.d.ts +8 -4
  45. package/chip/Chip.d.ts +1 -1
  46. package/chip/Chip.js +16 -54
  47. package/chip/Chip.stories.tsx +6 -8
  48. package/chip/Chip.test.js +56 -0
  49. package/chip/types.d.ts +7 -15
  50. package/common/variables.js +267 -337
  51. package/date-input/DateInput.js +62 -48
  52. package/date-input/DateInput.stories.tsx +7 -7
  53. package/date-input/DateInput.test.js +479 -0
  54. package/date-input/types.d.ts +16 -9
  55. package/dialog/Dialog.js +48 -51
  56. package/dialog/Dialog.stories.tsx +1 -2
  57. package/dialog/Dialog.test.js +70 -0
  58. package/dialog/types.d.ts +2 -2
  59. package/dropdown/Dropdown.d.ts +1 -1
  60. package/dropdown/Dropdown.js +242 -272
  61. package/dropdown/Dropdown.stories.tsx +312 -0
  62. package/dropdown/Dropdown.test.js +591 -0
  63. package/dropdown/DropdownMenu.d.ts +4 -0
  64. package/dropdown/DropdownMenu.js +80 -0
  65. package/dropdown/DropdownMenuItem.d.ts +4 -0
  66. package/dropdown/DropdownMenuItem.js +92 -0
  67. package/dropdown/types.d.ts +29 -18
  68. package/file-input/FileInput.js +111 -39
  69. package/file-input/FileInput.stories.tsx +507 -0
  70. package/file-input/FileInput.test.js +457 -0
  71. package/file-input/FileItem.js +7 -5
  72. package/flex/Flex.d.ts +4 -0
  73. package/flex/Flex.js +57 -0
  74. package/flex/Flex.stories.tsx +103 -0
  75. package/flex/types.d.ts +21 -0
  76. package/flex/types.js +5 -0
  77. package/footer/Footer.js +24 -99
  78. package/footer/Footer.test.js +109 -0
  79. package/footer/Icons.js +1 -1
  80. package/footer/types.d.ts +1 -1
  81. package/header/Header.js +95 -114
  82. package/header/Header.stories.tsx +46 -36
  83. package/header/Header.test.js +79 -0
  84. package/header/Icons.js +2 -2
  85. package/header/types.d.ts +2 -2
  86. package/heading/Heading.stories.tsx +3 -2
  87. package/heading/Heading.test.js +186 -0
  88. package/inset/Inset.d.ts +3 -0
  89. package/inset/Inset.js +51 -0
  90. package/inset/Inset.stories.tsx +229 -0
  91. package/inset/types.d.ts +37 -0
  92. package/inset/types.js +5 -0
  93. package/layout/ApplicationLayout.d.ts +16 -6
  94. package/layout/ApplicationLayout.js +71 -125
  95. package/layout/ApplicationLayout.stories.tsx +83 -93
  96. package/layout/Icons.d.ts +5 -0
  97. package/layout/Icons.js +13 -2
  98. package/layout/SidenavContext.d.ts +5 -0
  99. package/layout/SidenavContext.js +19 -0
  100. package/layout/types.d.ts +18 -33
  101. package/link/Link.d.ts +3 -2
  102. package/link/Link.js +60 -85
  103. package/link/Link.stories.tsx +99 -52
  104. package/link/Link.test.js +83 -0
  105. package/link/types.d.ts +9 -29
  106. package/main.d.ts +11 -15
  107. package/main.js +53 -79
  108. package/number-input/NumberInput.js +11 -18
  109. package/number-input/NumberInput.stories.tsx +5 -5
  110. package/number-input/NumberInput.test.js +506 -0
  111. package/number-input/types.d.ts +17 -10
  112. package/package.json +14 -10
  113. package/paginator/Paginator.js +17 -38
  114. package/paginator/Paginator.test.js +308 -0
  115. package/paragraph/Paragraph.d.ts +6 -0
  116. package/paragraph/Paragraph.js +38 -0
  117. package/paragraph/Paragraph.stories.tsx +44 -0
  118. package/password-input/PasswordInput.js +7 -4
  119. package/password-input/PasswordInput.stories.tsx +3 -3
  120. package/password-input/PasswordInput.test.js +180 -0
  121. package/password-input/types.d.ts +14 -11
  122. package/progress-bar/ProgressBar.d.ts +2 -2
  123. package/progress-bar/ProgressBar.js +57 -51
  124. package/progress-bar/ProgressBar.stories.jsx +13 -11
  125. package/progress-bar/ProgressBar.test.js +110 -0
  126. package/progress-bar/types.d.ts +3 -4
  127. package/quick-nav/QuickNav.d.ts +4 -0
  128. package/quick-nav/QuickNav.js +118 -0
  129. package/quick-nav/QuickNav.stories.tsx +264 -0
  130. package/quick-nav/types.d.ts +21 -0
  131. package/quick-nav/types.js +5 -0
  132. package/radio-group/Radio.d.ts +4 -0
  133. package/radio-group/Radio.js +141 -0
  134. package/radio-group/RadioGroup.d.ts +4 -0
  135. package/radio-group/RadioGroup.js +281 -0
  136. package/radio-group/RadioGroup.stories.tsx +100 -0
  137. package/radio-group/RadioGroup.test.js +695 -0
  138. package/radio-group/types.d.ts +114 -0
  139. package/radio-group/types.js +5 -0
  140. package/resultsetTable/ResultsetTable.js +5 -2
  141. package/resultsetTable/ResultsetTable.stories.tsx +7 -8
  142. package/resultsetTable/ResultsetTable.test.js +348 -0
  143. package/select/Icons.d.ts +10 -0
  144. package/select/Icons.js +93 -0
  145. package/select/Listbox.d.ts +4 -0
  146. package/select/Listbox.js +199 -0
  147. package/select/Option.d.ts +4 -0
  148. package/select/Option.js +110 -0
  149. package/select/Select.d.ts +4 -0
  150. package/select/Select.js +146 -366
  151. package/select/Select.stories.tsx +231 -176
  152. package/select/Select.test.js +2175 -0
  153. package/select/types.d.ts +210 -0
  154. package/select/types.js +5 -0
  155. package/sidenav/Sidenav.d.ts +6 -5
  156. package/sidenav/Sidenav.js +184 -52
  157. package/sidenav/Sidenav.stories.tsx +154 -139
  158. package/sidenav/Sidenav.test.js +44 -0
  159. package/sidenav/types.d.ts +50 -27
  160. package/slider/Slider.d.ts +1 -1
  161. package/slider/Slider.js +5 -4
  162. package/slider/Slider.stories.tsx +8 -8
  163. package/slider/Slider.test.js +187 -0
  164. package/slider/types.d.ts +4 -0
  165. package/spinner/Spinner.js +1 -1
  166. package/spinner/Spinner.stories.jsx +1 -0
  167. package/spinner/Spinner.test.js +64 -0
  168. package/switch/Switch.d.ts +2 -2
  169. package/switch/Switch.js +127 -55
  170. package/switch/Switch.stories.tsx +21 -43
  171. package/switch/Switch.test.js +212 -0
  172. package/switch/types.d.ts +9 -6
  173. package/table/Table.stories.jsx +2 -1
  174. package/table/Table.test.js +26 -0
  175. package/tabs/Tabs.d.ts +1 -1
  176. package/tabs/Tabs.js +16 -18
  177. package/tabs/Tabs.stories.tsx +7 -16
  178. package/tabs/Tabs.test.js +140 -0
  179. package/tabs/types.d.ts +27 -15
  180. package/tabs-nav/NavTabs.d.ts +8 -0
  181. package/tabs-nav/NavTabs.js +125 -0
  182. package/tabs-nav/NavTabs.stories.tsx +170 -0
  183. package/tabs-nav/NavTabs.test.js +82 -0
  184. package/tabs-nav/Tab.d.ts +4 -0
  185. package/tabs-nav/Tab.js +130 -0
  186. package/tabs-nav/types.d.ts +53 -0
  187. package/tabs-nav/types.js +5 -0
  188. package/tag/Tag.d.ts +1 -1
  189. package/tag/Tag.js +17 -27
  190. package/tag/Tag.stories.tsx +26 -29
  191. package/tag/Tag.test.js +60 -0
  192. package/tag/types.d.ts +23 -14
  193. package/text-input/Suggestion.d.ts +4 -0
  194. package/text-input/Suggestion.js +55 -0
  195. package/text-input/TextInput.js +80 -105
  196. package/text-input/TextInput.stories.tsx +35 -18
  197. package/text-input/TextInput.test.js +1712 -0
  198. package/text-input/types.d.ts +32 -13
  199. package/textarea/Textarea.d.ts +4 -0
  200. package/textarea/Textarea.js +19 -56
  201. package/textarea/Textarea.stories.jsx +37 -15
  202. package/textarea/Textarea.test.js +437 -0
  203. package/textarea/types.d.ts +137 -0
  204. package/textarea/types.js +5 -0
  205. package/toggle-group/ToggleGroup.d.ts +1 -1
  206. package/toggle-group/ToggleGroup.js +12 -14
  207. package/toggle-group/ToggleGroup.stories.tsx +27 -32
  208. package/toggle-group/ToggleGroup.test.js +156 -0
  209. package/toggle-group/types.d.ts +46 -25
  210. package/typography/Typography.d.ts +4 -0
  211. package/typography/Typography.js +131 -0
  212. package/typography/Typography.stories.tsx +198 -0
  213. package/typography/types.d.ts +18 -0
  214. package/typography/types.js +5 -0
  215. package/useTheme.js +2 -2
  216. package/useTranslatedLabels.d.ts +2 -0
  217. package/useTranslatedLabels.js +20 -0
  218. package/wizard/Wizard.d.ts +1 -1
  219. package/wizard/Wizard.js +111 -57
  220. package/wizard/{Wizard.stories.jsx → Wizard.stories.tsx} +33 -24
  221. package/wizard/Wizard.test.js +141 -0
  222. package/wizard/types.d.ts +12 -11
  223. package/ThemeContext.d.ts +0 -15
  224. package/ThemeContext.js +0 -243
  225. package/V3Select/V3Select.js +0 -455
  226. package/V3Select/index.d.ts +0 -27
  227. package/V3Textarea/V3Textarea.js +0 -260
  228. package/V3Textarea/index.d.ts +0 -27
  229. package/date/Date.js +0 -373
  230. package/date/index.d.ts +0 -27
  231. package/input-text/Icons.js +0 -22
  232. package/input-text/InputText.js +0 -611
  233. package/input-text/index.d.ts +0 -36
  234. package/list/List.d.ts +0 -7
  235. package/list/List.js +0 -37
  236. package/list/List.stories.tsx +0 -70
  237. package/radio/Radio.d.ts +0 -4
  238. package/radio/Radio.js +0 -174
  239. package/radio/Radio.stories.tsx +0 -192
  240. package/radio/types.d.ts +0 -54
  241. package/row/Row.d.ts +0 -11
  242. package/row/Row.js +0 -124
  243. package/row/Row.stories.tsx +0 -223
  244. package/select/index.d.ts +0 -131
  245. package/stack/Stack.d.ts +0 -10
  246. package/stack/Stack.js +0 -94
  247. package/stack/Stack.stories.tsx +0 -150
  248. package/text/Text.d.ts +0 -7
  249. package/text/Text.js +0 -30
  250. package/text/Text.stories.tsx +0 -19
  251. package/textarea/index.d.ts +0 -127
  252. package/toggle/Toggle.js +0 -186
  253. package/toggle/index.d.ts +0 -21
  254. package/upload/Upload.js +0 -201
  255. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  256. package/upload/buttons-upload/Icons.js +0 -40
  257. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  258. package/upload/dragAndDropArea/Icons.js +0 -39
  259. package/upload/file-upload/FileToUpload.js +0 -115
  260. package/upload/file-upload/Icons.js +0 -66
  261. package/upload/files-upload/FilesToUpload.js +0 -109
  262. package/upload/index.d.ts +0 -15
  263. package/upload/transaction/Icons.js +0 -160
  264. package/upload/transaction/Transaction.js +0 -104
  265. package/upload/transactions/Transactions.js +0 -94
  266. package/wizard/Icons.js +0 -65
@@ -13,23 +13,25 @@ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/hel
13
13
 
14
14
  var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
15
15
 
16
- var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
17
-
18
16
  var _react = _interopRequireWildcard(require("react"));
19
17
 
20
- var _main = require("../main");
18
+ var _Header = _interopRequireDefault(require("../header/Header"));
19
+
20
+ var _Footer = _interopRequireDefault(require("../footer/Footer"));
21
+
22
+ var _Sidenav = _interopRequireDefault(require("../sidenav/Sidenav"));
21
23
 
22
- var _styledComponents = _interopRequireWildcard(require("styled-components"));
24
+ var _styledComponents = _interopRequireDefault(require("styled-components"));
23
25
 
24
26
  var _variables = require("../common/variables.js");
25
27
 
26
28
  var _Icons = require("./Icons");
27
29
 
28
- var _useTheme = _interopRequireDefault(require("../useTheme"));
30
+ var _SidenavContext = require("./SidenavContext");
29
31
 
30
- var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8, _templateObject9, _templateObject10;
32
+ var _useTranslatedLabels = _interopRequireDefault(require("../useTranslatedLabels"));
31
33
 
32
- var _excluded = ["displayArrow", "mode"];
34
+ var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8;
33
35
 
34
36
  function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
35
37
 
@@ -37,32 +39,19 @@ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj &&
37
39
 
38
40
  var year = new Date().getFullYear();
39
41
 
40
- var Header = function Header(_ref) {
42
+ var Main = function Main(_ref) {
41
43
  var children = _ref.children;
42
44
  return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, children);
43
45
  };
44
46
 
45
- var Main = function Main(_ref2) {
46
- var children = _ref2.children;
47
- return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, children);
48
- };
49
-
50
- var Footer = function Footer(_ref3) {
51
- var children = _ref3.children;
52
- return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, children);
53
- };
54
-
55
- var SideNav = function SideNav(props) {
56
- var _props$displayArrow = props.displayArrow,
57
- displayArrow = _props$displayArrow === void 0 ? true : _props$displayArrow,
58
- _props$mode = props.mode,
59
- mode = _props$mode === void 0 ? "overlay" : _props$mode,
60
- childProps = (0, _objectWithoutProperties2["default"])(props, _excluded);
61
- return /*#__PURE__*/_react["default"].createElement(_main.DxcSidenav, childProps, childProps.children);
47
+ var defaultHeader = function defaultHeader() {
48
+ return /*#__PURE__*/_react["default"].createElement(_Header["default"], {
49
+ underlined: true
50
+ });
62
51
  };
63
52
 
64
53
  var defaultFooter = function defaultFooter() {
65
- return /*#__PURE__*/_react["default"].createElement(_main.DxcFooter, {
54
+ return /*#__PURE__*/_react["default"].createElement(_Footer["default"], {
66
55
  copyright: "\xA9 DXC Technology ".concat(year, "\u200B\u200B\u200B\u200B. All rights reserved."),
67
56
  bottomLinks: [{
68
57
  href: "https://www.linkedin.com/company/dxctechnology",
@@ -87,139 +76,96 @@ var defaultFooter = function defaultFooter() {
87
76
  });
88
77
  };
89
78
 
90
- var defaultHeader = function defaultHeader() {
91
- return /*#__PURE__*/_react["default"].createElement(_main.DxcHeader, {
92
- underlined: true
93
- });
94
- };
95
-
96
79
  var childTypeExists = function childTypeExists(children, childType) {
97
80
  return children.find(function (child) {
98
- return child && child.type && child.type === childType;
81
+ return (child === null || child === void 0 ? void 0 : child.type) === childType;
99
82
  });
100
83
  };
101
84
 
102
- var DxcApplicationLayout = function DxcApplicationLayout(_ref4) {
103
- var children = _ref4.children;
104
- var ref = (0, _react.useRef)(null);
105
- var colorsTheme = (0, _useTheme["default"])();
85
+ var DxcApplicationLayout = function DxcApplicationLayout(_ref2) {
86
+ var _ref2$visibilityToggl = _ref2.visibilityToggleLabel,
87
+ visibilityToggleLabel = _ref2$visibilityToggl === void 0 ? "" : _ref2$visibilityToggl,
88
+ header = _ref2.header,
89
+ sidenav = _ref2.sidenav,
90
+ footer = _ref2.footer,
91
+ children = _ref2.children;
106
92
 
107
- var _useState = (0, _react.useState)(true),
93
+ var _useState = (0, _react.useState)(false),
108
94
  _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
109
- isSideNavVisible = _useState2[0],
110
- setIsSideNavVisible = _useState2[1];
95
+ isSidenavVisibleResponsive = _useState2[0],
96
+ setIsSidenavVisibleResponsive = _useState2[1];
111
97
 
112
98
  var _useState3 = (0, _react.useState)(false),
113
99
  _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
114
100
  isResponsive = _useState4[0],
115
101
  setIsResponsive = _useState4[1];
116
102
 
103
+ var ref = (0, _react.useRef)(null);
104
+ var translatedLabels = (0, _useTranslatedLabels["default"])();
105
+
117
106
  var childrenArray = _react["default"].Children.toArray(children);
118
107
 
119
- var header = childTypeExists(childrenArray, _main.DxcHeader) || childTypeExists(childrenArray, Header) || defaultHeader();
120
- var footer = childTypeExists(childrenArray, _main.DxcFooter) || childTypeExists(childrenArray, Footer) || defaultFooter();
121
- var sideNav = childTypeExists(childrenArray, SideNav);
108
+ var headerContent = header || defaultHeader();
109
+ var footerContent = footer || defaultFooter();
122
110
  var main = childTypeExists(childrenArray, Main);
123
- var displayArrow = sideNav && sideNav.props && sideNav.props.displayArrow;
124
- var sideNavMode = sideNav && sideNav.props && sideNav.props.mode;
125
-
126
- var ArrowIcon = function ArrowIcon() {
127
- return /*#__PURE__*/_react["default"].createElement("svg", {
128
- xmlns: "http://www.w3.org/2000/svg",
129
- width: "15.995",
130
- height: "10.01",
131
- viewBox: "0 0 15.995 10.01"
132
- }, /*#__PURE__*/_react["default"].createElement("path", {
133
- "data-testid": "arrow-to-right",
134
- 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",
135
- transform: "translate(-2 -6.996)"
136
- }));
137
- };
138
111
 
139
- var handleResize = function handleResize(width) {
140
- if (width) {
141
- setIsResponsive(width <= _variables.responsiveSizes.tablet);
142
- setIsSideNavVisible(true);
143
- }
112
+ var handleResize = function handleResize() {
113
+ setIsResponsive(window.matchMedia("(max-width: ".concat(_variables.responsiveSizes.medium, "rem)")).matches);
144
114
  };
145
115
 
146
- var handleEventListener = function handleEventListener() {
147
- handleResize(ref.current.offsetWidth);
116
+ var handleSidenavVisibility = function handleSidenavVisibility() {
117
+ setIsSidenavVisibleResponsive(function (isSidenavVisibleResponsive) {
118
+ return !isSidenavVisibleResponsive;
119
+ });
148
120
  };
149
121
 
150
- (0, _react.useEffect)(function () {
151
- if (ref.current) {
152
- window.addEventListener("resize", handleEventListener);
153
- handleResize(ref.current.offsetWidth);
154
- }
155
-
122
+ (0, _react.useLayoutEffect)(function () {
123
+ handleResize();
124
+ window.addEventListener("resize", handleResize);
156
125
  return function () {
157
- window.removeEventListener("resize", handleEventListener);
126
+ window.removeEventListener("resize", handleResize);
158
127
  };
159
128
  }, []);
160
-
161
- var handleSidenav = function handleSidenav() {
162
- setIsSideNavVisible(!isSideNavVisible);
163
- };
164
-
165
- return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
166
- theme: colorsTheme.sidenav
167
- }, /*#__PURE__*/_react["default"].createElement(ApplicationLayoutContainer, {
129
+ (0, _react.useEffect)(function () {
130
+ !isResponsive && setIsSidenavVisibleResponsive(false);
131
+ }, [isResponsive]);
132
+ return /*#__PURE__*/_react["default"].createElement(ApplicationLayoutContainer, {
133
+ hasSidenav: sidenav ? true : false,
134
+ isSidenavVisible: isSidenavVisibleResponsive,
168
135
  ref: ref
169
- }, /*#__PURE__*/_react["default"].createElement(HeaderContainer, null, header), /*#__PURE__*/_react["default"].createElement(BodyContainer, null, /*#__PURE__*/_react["default"].createElement(ContentContainer, null, /*#__PURE__*/_react["default"].createElement(SideNavArrowContainer, {
170
- isSideNavVisible: isSideNavVisible
171
- }, sideNav, /*#__PURE__*/_react["default"].createElement(ArrowContainer, null, sideNav && (displayArrow || isResponsive) && /*#__PURE__*/_react["default"].createElement(ArrowTrigger, {
172
- role: "button",
173
- tabIndex: 0,
174
- onClick: handleSidenav,
175
- isSideNavVisible: isSideNavVisible
176
- }, /*#__PURE__*/_react["default"].createElement(ArrowIcon, null)))), /*#__PURE__*/_react["default"].createElement(MainBodyContainer, null, /*#__PURE__*/_react["default"].createElement(MainContent, {
177
- sideNav: sideNav,
178
- mode: isResponsive ? "overlay" : sideNavMode,
179
- isSideNavVisible: isSideNavVisible
180
- }, main), /*#__PURE__*/_react["default"].createElement(FooterContainer, {
181
- sideNav: sideNav,
182
- mode: isResponsive ? "overlay" : sideNavMode,
183
- isSideNavVisible: isSideNavVisible
184
- }, footer))))));
136
+ }, /*#__PURE__*/_react["default"].createElement(HeaderContainer, null, headerContent), sidenav && isResponsive && /*#__PURE__*/_react["default"].createElement(VisibilityToggle, null, /*#__PURE__*/_react["default"].createElement(HamburgerTrigger, {
137
+ onClick: handleSidenavVisibility,
138
+ "aria-label": visibilityToggleLabel ? undefined : translatedLabels.applicationLayout.visibilityToggleTitle,
139
+ title: translatedLabels.applicationLayout.visibilityToggleTitle
140
+ }, _Icons.hamburgerIcon, visibilityToggleLabel)), /*#__PURE__*/_react["default"].createElement(BodyContainer, null, /*#__PURE__*/_react["default"].createElement(_SidenavContext.SidenavContextProvider, {
141
+ value: setIsSidenavVisibleResponsive
142
+ }, sidenav && (isResponsive ? isSidenavVisibleResponsive : true) && /*#__PURE__*/_react["default"].createElement(SidenavContainer, null, sidenav)), /*#__PURE__*/_react["default"].createElement(MainContainer, null, /*#__PURE__*/_react["default"].createElement(MainContentContainer, null, main), footerContent)));
185
143
  };
186
144
 
187
- DxcApplicationLayout.Header = Header;
188
- DxcApplicationLayout.Main = Main;
189
- DxcApplicationLayout.Footer = Footer;
190
- DxcApplicationLayout.SideNav = SideNav;
191
-
192
- var ApplicationLayoutContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (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"])));
193
-
194
- var HeaderContainer = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n z-index: 1250;\n position: fixed;\n top: 0;\n left: 0;\n right: 0;\n"])));
145
+ var ApplicationLayoutContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n position: absolute;\n top: 64px;\n bottom: 0;\n left: 0;\n right: 0;\n display: flex;\n flex-direction: column;\n\n @media (max-width: ", "rem) {\n ", ";\n ", "\n }\n"])), _variables.responsiveSizes.medium, function (props) {
146
+ return props.hasSidenav && "top: 116px";
147
+ }, function (props) {
148
+ return props.isSidenavVisible && "overflow: hidden;";
149
+ });
195
150
 
196
- var BodyContainer = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n flex: 1;\n display: flex;\n flex-direction: column;\n"])));
151
+ var HeaderContainer = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n position: fixed;\n top: 0;\n left: 0;\n right: 0;\n z-index: 3;\n"])));
197
152
 
198
- var ContentContainer = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex: 1 1 auto;\n align-items: flex-start;\n"])));
153
+ var VisibilityToggle = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n position: fixed;\n top: 64px;\n left: 0;\n right: 0;\n box-sizing: border-box;\n display: flex;\n align-items: center;\n padding: 4px 16px;\n width: 100%;\n background-color: #f2f2f2;\n user-select: none;\n z-index: 2;\n"])));
199
154
 
200
- var MainBodyContainer = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n width: 100%;\n min-width: 0;\n display: flex;\n flex-direction: column;\n"])));
155
+ var HamburgerTrigger = _styledComponents["default"].button(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-wrap: wrap;\n gap: 10px;\n border: 0px solid transparent;\n border-radius: 2px;\n padding: 12px 4px;\n background-color: transparent;\n box-shadow: 0 0 0 2px transparent;\n font-family: Open Sans, sans-serif;\n font-weight: 600;\n font-size: 14px;\n color: #000;\n cursor: pointer;\n :active {\n background-color: #cccccc;\n }\n :focus,\n :focus-visible {\n outline: none;\n box-shadow: 0 0 0 2px #0095ff;\n }\n & > svg {\n height: 20px;\n width: 20px;\n }\n"])));
201
156
 
202
- var FooterContainer = _styledComponents["default"].div(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n margin-left: ", ";\n transition: margin 0.4s ease-in-out;\n"])), function (props) {
203
- return props.sideNav ? props.mode === "push" && !props.isSideNavVisible || props.mode === "overlay" ? "-300px" : "" : "";
204
- });
205
-
206
- var MainContent = _styledComponents["default"].div(_templateObject7 || (_templateObject7 = (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"])), function (props) {
207
- return props.sideNav ? props.mode === "push" && props.isSideNavVisible ? "" : "-297px" : "";
208
- });
157
+ var BodyContainer = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: row;\n flex: 1;\n"])));
209
158
 
210
- var SideNavArrowContainer = _styledComponents["default"].div(_templateObject8 || (_templateObject8 = (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"])), function (props) {
211
- return props.isSideNavVisible ? "translateX(0)" : !props.isSideNavVisible ? "translateX(-100%)" : "";
212
- });
159
+ var SidenavContainer = _styledComponents["default"].div(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n position: sticky;\n top: 64px;\n display: flex;\n height: calc(100vh - 64px);\n z-index: 1;\n\n @media (max-width: ", "rem) {\n position: absolute;\n top: 0px;\n height: 100%;\n }\n"])), _variables.responsiveSizes.medium);
213
160
 
214
- var ArrowContainer = _styledComponents["default"].div(_templateObject9 || (_templateObject9 = (0, _taggedTemplateLiteral2["default"])(["\n position: absolute;\n height: calc(100vh - 64px);\n left: 279px;\n"])));
161
+ var MainContainer = _styledComponents["default"].div(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n width: 100%;\n"])));
215
162
 
216
- var ArrowTrigger = _styledComponents["default"].div(_templateObject10 || (_templateObject10 = (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"])), function (props) {
217
- return "".concat(props.theme.arrowContainerColor);
218
- }, function (props) {
219
- return props.isSideNavVisible ? "rotate(-180deg)" : "rotate(0deg)";
220
- }, function (props) {
221
- return props.theme.arrowColor;
222
- });
163
+ var MainContentContainer = _styledComponents["default"].div(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])(["\n flex: 1;\n"])));
223
164
 
165
+ DxcApplicationLayout.Header = _Header["default"];
166
+ DxcApplicationLayout.Main = Main;
167
+ DxcApplicationLayout.Footer = _Footer["default"];
168
+ DxcApplicationLayout.SideNav = _Sidenav["default"];
169
+ DxcApplicationLayout.useResponsiveSidenavVisibility = _SidenavContext.useResponsiveSidenavVisibility;
224
170
  var _default = DxcApplicationLayout;
225
171
  exports["default"] = _default;
@@ -1,9 +1,7 @@
1
1
  import React from "react";
2
2
  import DxcApplicationLayout from "./ApplicationLayout";
3
- import DxcSidenav from "../sidenav/Sidenav";
4
3
  import Title from "../../.storybook/components/Title";
5
- import { INITIAL_VIEWPORTS } from '@storybook/addon-viewport';
6
- import { userEvent, within, waitFor } from "@storybook/testing-library";
4
+ import { INITIAL_VIEWPORTS } from "@storybook/addon-viewport";
7
5
 
8
6
  export default {
9
7
  title: "Application Layout ",
@@ -11,8 +9,8 @@ export default {
11
9
  parameters: {
12
10
  viewport: {
13
11
  viewports: INITIAL_VIEWPORTS,
14
- }
15
- }
12
+ },
13
+ },
16
14
  };
17
15
 
18
16
  export const DefaultApplicationLayout = () => (
@@ -31,57 +29,25 @@ export const DefaultApplicationLayout = () => (
31
29
 
32
30
  export const ApplicationLayoutWithDefaultSidenav = () => (
33
31
  <>
34
- <DxcApplicationLayout>
35
- <DxcApplicationLayout.SideNav>
36
- <DxcSidenav.Title>Application layout with sidenav</DxcSidenav.Title>
37
- <p>SideNav Content</p>
38
- <p>SideNav Content</p>
39
- <p>SideNav Content</p>
40
- <p>SideNav Content</p>
41
- <p>SideNav Content</p>
42
- </DxcApplicationLayout.SideNav>
43
- <DxcApplicationLayout.Main>
44
- <p>Main Content</p>
45
- <p>Main Content</p>
46
- <p>Main Content</p>
47
- <p>Main Content</p>
48
- </DxcApplicationLayout.Main>
49
- </DxcApplicationLayout>
50
- </>
51
- );
52
-
53
- export const ApplicationLayoutWithPushSidenav = () => (
54
- <>
55
- <DxcApplicationLayout>
56
- <DxcApplicationLayout.SideNav mode="push">
57
- <DxcSidenav.Title>Application layout with push sidenav</DxcSidenav.Title>
58
- <p>SideNav Content</p>
59
- <p>SideNav Content</p>
60
- <p>SideNav Content</p>
61
- <p>SideNav Content</p>
62
- <p>SideNav Content</p>
63
- </DxcApplicationLayout.SideNav>
64
- <DxcApplicationLayout.Main>
65
- <p>Main Content</p>
66
- <p>Main Content</p>
67
- <p>Main Content</p>
68
- <p>Main Content</p>
69
- </DxcApplicationLayout.Main>
70
- </DxcApplicationLayout>
71
- </>
72
- );
73
-
74
- export const ApplicationLayoutWithArrowSidenav = () => (
75
- <>
76
- <DxcApplicationLayout>
77
- <DxcApplicationLayout.SideNav mode="overlay" displayArrow>
78
- <DxcSidenav.Title>Application layout with push sidenav</DxcSidenav.Title>
79
- <p>SideNav Content</p>
80
- <p>SideNav Content</p>
81
- <p>SideNav Content</p>
82
- <p>SideNav Content</p>
83
- <p>SideNav Content</p>
84
- </DxcApplicationLayout.SideNav>
32
+ <DxcApplicationLayout
33
+ sidenav={
34
+ <DxcApplicationLayout.SideNav
35
+ title={
36
+ <DxcApplicationLayout.SideNav.Title>
37
+ Application layout with push sidenav
38
+ </DxcApplicationLayout.SideNav.Title>
39
+ }
40
+ >
41
+ <DxcApplicationLayout.SideNav.Section>
42
+ <p>SideNav Content</p>
43
+ <p>SideNav Content</p>
44
+ <p>SideNav Content</p>
45
+ <p>SideNav Content</p>
46
+ <p>SideNav Content</p>
47
+ </DxcApplicationLayout.SideNav.Section>
48
+ </DxcApplicationLayout.SideNav>
49
+ }
50
+ >
85
51
  <DxcApplicationLayout.Main>
86
52
  <p>Main Content</p>
87
53
  <p>Main Content</p>
@@ -94,15 +60,26 @@ export const ApplicationLayoutWithArrowSidenav = () => (
94
60
 
95
61
  export const ApplicationLayoutWithResponsiveSidenav = () => (
96
62
  <>
97
- <DxcApplicationLayout>
98
- <DxcApplicationLayout.SideNav>
99
- <DxcSidenav.Title>Application layout with push sidenav</DxcSidenav.Title>
100
- <p>SideNav Content</p>
101
- <p>SideNav Content</p>
102
- <p>SideNav Content</p>
103
- <p>SideNav Content</p>
104
- <p>SideNav Content</p>
105
- </DxcApplicationLayout.SideNav>
63
+ <DxcApplicationLayout
64
+ visibilityToggleLabel="Example"
65
+ sidenav={
66
+ <DxcApplicationLayout.SideNav
67
+ title={
68
+ <DxcApplicationLayout.SideNav.Title>
69
+ Application layout with push sidenav
70
+ </DxcApplicationLayout.SideNav.Title>
71
+ }
72
+ >
73
+ <DxcApplicationLayout.SideNav.Section>
74
+ <p>SideNav Content</p>
75
+ <p>SideNav Content</p>
76
+ <p>SideNav Content</p>
77
+ <p>SideNav Content</p>
78
+ <p>SideNav Content</p>
79
+ </DxcApplicationLayout.SideNav.Section>
80
+ </DxcApplicationLayout.SideNav>
81
+ }
82
+ >
106
83
  <DxcApplicationLayout.Main>
107
84
  <p>Main Content</p>
108
85
  <p>Main Content</p>
@@ -115,22 +92,32 @@ export const ApplicationLayoutWithResponsiveSidenav = () => (
115
92
 
116
93
  ApplicationLayoutWithResponsiveSidenav.parameters = {
117
94
  viewport: {
118
- defaultViewport: 'pixel',
95
+ defaultViewport: "pixel",
119
96
  },
120
97
  };
121
98
 
122
99
  export const ApplicationLayoutWithCustomHeader = () => (
123
100
  <>
124
- <DxcApplicationLayout>
125
- <DxcApplicationLayout.Header> <p>Custom Header</p> </DxcApplicationLayout.Header>
126
- <DxcApplicationLayout.SideNav>
127
- <DxcSidenav.Title>Application layout with push sidenav</DxcSidenav.Title>
128
- <p>SideNav Content</p>
129
- <p>SideNav Content</p>
130
- <p>SideNav Content</p>
131
- <p>SideNav Content</p>
132
- <p>SideNav Content</p>
133
- </DxcApplicationLayout.SideNav>
101
+ <DxcApplicationLayout
102
+ header={<p>Custom Header</p>}
103
+ sidenav={
104
+ <DxcApplicationLayout.SideNav
105
+ title={
106
+ <DxcApplicationLayout.SideNav.Title>
107
+ Application layout with push sidenav
108
+ </DxcApplicationLayout.SideNav.Title>
109
+ }
110
+ >
111
+ <DxcApplicationLayout.SideNav.Section>
112
+ <p>SideNav Content</p>
113
+ <p>SideNav Content</p>
114
+ <p>SideNav Content</p>
115
+ <p>SideNav Content</p>
116
+ <p>SideNav Content</p>
117
+ </DxcApplicationLayout.SideNav.Section>
118
+ </DxcApplicationLayout.SideNav>
119
+ }
120
+ >
134
121
  <DxcApplicationLayout.Main>
135
122
  <p>Main Content</p>
136
123
  <p>Main Content</p>
@@ -143,29 +130,32 @@ export const ApplicationLayoutWithCustomHeader = () => (
143
130
 
144
131
  export const ApplicationLayoutWithCustomFooter = () => (
145
132
  <>
146
- <DxcApplicationLayout>
147
- <DxcApplicationLayout.SideNav>
148
- <DxcSidenav.Title>Application layout with push sidenav</DxcSidenav.Title>
149
- <p>SideNav Content</p>
150
- <p>SideNav Content</p>
151
- <p>SideNav Content</p>
152
- <p>SideNav Content</p>
153
- <p>SideNav Content</p>
154
- </DxcApplicationLayout.SideNav>
133
+ <DxcApplicationLayout
134
+ footer={<p>Custom Footer</p>}
135
+ sidenav={
136
+ <DxcApplicationLayout.SideNav
137
+ title={
138
+ <DxcApplicationLayout.SideNav.Title>
139
+ Application layout with push sidenav
140
+ </DxcApplicationLayout.SideNav.Title>
141
+ }
142
+ >
143
+ <DxcApplicationLayout.SideNav.Section>
144
+ <p>SideNav Content</p>
145
+ <p>SideNav Content</p>
146
+ <p>SideNav Content</p>
147
+ <p>SideNav Content</p>
148
+ <p>SideNav Content</p>
149
+ </DxcApplicationLayout.SideNav.Section>
150
+ </DxcApplicationLayout.SideNav>
151
+ }
152
+ >
155
153
  <DxcApplicationLayout.Main>
156
154
  <p>Main Content</p>
157
155
  <p>Main Content</p>
158
156
  <p>Main Content</p>
159
157
  <p>Main Content</p>
160
158
  </DxcApplicationLayout.Main>
161
- <DxcApplicationLayout.Footer> <p>Custom Footer</p> </DxcApplicationLayout.Footer>
162
159
  </DxcApplicationLayout>
163
160
  </>
164
161
  );
165
-
166
- export const ApplicationLayoutWithClosingSidenav = ApplicationLayoutWithArrowSidenav.bind({});
167
- ApplicationLayoutWithClosingSidenav.play = async ({ canvasElement }) => {
168
- const canvas = within(canvasElement);
169
- const arrow = canvas.getByRole("button");
170
- await userEvent.click(arrow);
171
- };
@@ -0,0 +1,5 @@
1
+ /// <reference types="react" />
2
+ export declare const facebookLogo: JSX.Element;
3
+ export declare const twitterLogo: JSX.Element;
4
+ export declare const linkedinLogo: JSX.Element;
5
+ export declare const hamburgerIcon: JSX.Element;
package/layout/Icons.js CHANGED
@@ -5,7 +5,7 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
5
5
  Object.defineProperty(exports, "__esModule", {
6
6
  value: true
7
7
  });
8
- exports.twitterLogo = exports.linkedinLogo = exports.facebookLogo = void 0;
8
+ exports.twitterLogo = exports.linkedinLogo = exports.hamburgerIcon = exports.facebookLogo = void 0;
9
9
 
10
10
  var _react = _interopRequireDefault(require("react"));
11
11
 
@@ -52,4 +52,15 @@ var linkedinLogo = /*#__PURE__*/_react["default"].createElement("svg", {
52
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
53
  })));
54
54
 
55
- exports.linkedinLogo = linkedinLogo;
55
+ exports.linkedinLogo = linkedinLogo;
56
+
57
+ var hamburgerIcon = /*#__PURE__*/_react["default"].createElement("svg", {
58
+ xmlns: "http://www.w3.org/2000/svg",
59
+ height: "24",
60
+ width: "24",
61
+ viewBox: "0 0 24 24"
62
+ }, /*#__PURE__*/_react["default"].createElement("path", {
63
+ d: "M3 18V16H21V18ZM3 13V11H21V13ZM3 8V6H21V8Z"
64
+ }));
65
+
66
+ exports.hamburgerIcon = hamburgerIcon;
@@ -0,0 +1,5 @@
1
+ /// <reference types="react" />
2
+ declare type SidenavContextType = (isSidenavVisible: boolean) => void;
3
+ export declare const SidenavContextProvider: import("react").Provider<SidenavContextType>;
4
+ export declare const useResponsiveSidenavVisibility: () => SidenavContextType;
5
+ export {};
@@ -0,0 +1,19 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.useResponsiveSidenavVisibility = exports.SidenavContextProvider = void 0;
7
+
8
+ var _react = require("react");
9
+
10
+ var SidenavContext = /*#__PURE__*/(0, _react.createContext)(null);
11
+ var SidenavContextProvider = SidenavContext.Provider;
12
+ exports.SidenavContextProvider = SidenavContextProvider;
13
+
14
+ var useResponsiveSidenavVisibility = function useResponsiveSidenavVisibility() {
15
+ var changeResponsiveSidenavVisibility = (0, _react.useContext)(SidenavContext);
16
+ return changeResponsiveSidenavVisibility;
17
+ };
18
+
19
+ exports.useResponsiveSidenavVisibility = useResponsiveSidenavVisibility;
package/layout/types.d.ts CHANGED
@@ -1,54 +1,39 @@
1
1
  /// <reference types="react" />
2
- declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
- declare type Padding = {
4
- top?: Space;
5
- bottom?: Space;
6
- left?: Space;
7
- right?: Space;
8
- };
9
- declare type ChildrenType = AppLayoutHeaderPropsType | AppLayoutMainPropsType | AppLayoutFooterPropsType | AppLayoutSidenavPropsType;
10
- export declare type AppLayoutHeaderPropsType = {
11
- /**
12
- * Everything between this tags will be displayed as a header, at the top of the screen.
13
- * This is optional and if it is not specified, the DxcHeader will be shown by default.
14
- */
15
- children?: React.ReactNode;
16
- };
2
+ declare type ChildrenType = AppLayoutMainPropsType | AppLayoutSidenavPropsType;
17
3
  export declare type AppLayoutMainPropsType = {
18
4
  /**
19
5
  * Everything between the tags will be displayed as the content of the main part of the application.
20
6
  */
21
7
  children: React.ReactNode;
22
8
  };
23
- export declare type AppLayoutFooterPropsType = {
9
+ export declare type AppLayoutSidenavPropsType = {
10
+ /**
11
+ * The area inside the sidenav. This area can be used to render the content inside the sidenav.
12
+ */
13
+ children: React.ReactNode;
24
14
  /**
25
- * Everything between the tags will be displayed as a footer, at the bottom of the screen.
26
- * This is optional and if it is not specified, the DxcFooter will be shown by default.
15
+ * The area assigned to render the sidenav title. It is highly recommended to use the sidenav title.
27
16
  */
28
- children?: React.ReactNode;
17
+ title?: React.ReactNode;
29
18
  };
30
- export declare type AppLayoutSidenavPropsType = {
19
+ declare type AppLayoutPropsType = {
31
20
  /**
32
- * Size of the padding to be applied to the custom area ('xxsmall' | 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge' | 'xxlarge').
33
- * You can pass an object with 'top', 'bottom', 'left' and 'right' properties in order to specify different padding sizes.
21
+ * Text to be placed next to the hamburger button that toggles the
22
+ * visibility of the sidenav.
34
23
  */
35
- padding?: Space | Padding;
24
+ visibilityToggleLabel?: string;
36
25
  /**
37
- * The area inside the sidenav. This area can be used to render custom content.
26
+ * Header content.
38
27
  */
39
- children: React.ReactNode;
28
+ header?: React.ReactNode;
40
29
  /**
41
- * If false, the arrow button is hidden.
42
- * In lower resolutions the arrow will be always displayed.
30
+ * Sidenav content
43
31
  */
44
- displayArrow?: boolean;
32
+ sidenav?: React.ReactNode;
45
33
  /**
46
- * Default action over the content of the page, overlay the content or push to the right ('push' | 'overlay').
47
- * In lower resolutions the mode will always be overlay.
34
+ * Footer content
48
35
  */
49
- mode: "push" | "overlay";
50
- };
51
- declare type AppLayoutPropsType = {
36
+ footer?: React.ReactNode;
52
37
  /**
53
38
  * The area inside the sidenav. This area can be used to render custom content.
54
39
  */