@dxc-technology/halstack-react 0.0.0-c680086 → 0.0.0-c6bd008

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 (202) hide show
  1. package/HalstackContext.d.ts +12 -0
  2. package/HalstackContext.js +295 -0
  3. package/accordion/Accordion.d.ts +1 -1
  4. package/accordion/Accordion.js +7 -28
  5. package/accordion/Accordion.stories.tsx +11 -11
  6. package/accordion/Accordion.test.js +72 -0
  7. package/accordion/types.d.ts +4 -0
  8. package/accordion-group/AccordionGroup.d.ts +1 -1
  9. package/accordion-group/AccordionGroup.js +14 -15
  10. package/accordion-group/AccordionGroup.stories.tsx +1 -1
  11. package/accordion-group/AccordionGroup.test.js +151 -0
  12. package/accordion-group/types.d.ts +4 -0
  13. package/alert/Alert.js +4 -1
  14. package/alert/Alert.test.js +92 -0
  15. package/badge/Badge.d.ts +4 -0
  16. package/badge/Badge.js +5 -3
  17. package/badge/types.d.ts +5 -0
  18. package/{radio → badge}/types.js +0 -0
  19. package/bleed/Bleed.js +1 -34
  20. package/bleed/Bleed.stories.tsx +62 -63
  21. package/bleed/types.d.ts +25 -1
  22. package/box/Box.js +22 -32
  23. package/box/Box.test.js +18 -0
  24. package/button/Button.js +14 -11
  25. package/button/Button.test.js +35 -0
  26. package/card/Card.js +24 -27
  27. package/card/Card.test.js +50 -0
  28. package/checkbox/Checkbox.d.ts +1 -1
  29. package/checkbox/Checkbox.js +43 -39
  30. package/checkbox/Checkbox.stories.tsx +124 -128
  31. package/checkbox/Checkbox.test.js +78 -0
  32. package/checkbox/types.d.ts +7 -3
  33. package/chip/Chip.test.js +56 -0
  34. package/common/variables.js +181 -322
  35. package/date-input/DateInput.js +53 -39
  36. package/date-input/DateInput.stories.tsx +7 -7
  37. package/date-input/DateInput.test.js +479 -0
  38. package/date-input/types.d.ts +16 -9
  39. package/dialog/Dialog.js +4 -32
  40. package/dialog/Dialog.test.js +40 -0
  41. package/dropdown/Dropdown.js +13 -17
  42. package/dropdown/Dropdown.test.js +189 -0
  43. package/file-input/FileInput.js +9 -6
  44. package/file-input/FileInput.test.js +457 -0
  45. package/file-input/FileItem.js +7 -5
  46. package/footer/Footer.js +15 -88
  47. package/footer/Footer.test.js +109 -0
  48. package/footer/Icons.js +1 -1
  49. package/header/Header.js +27 -48
  50. package/header/Header.stories.tsx +46 -36
  51. package/header/Header.test.js +79 -0
  52. package/heading/Heading.test.js +186 -0
  53. package/inline/Inline.d.ts +4 -0
  54. package/inline/Inline.js +56 -0
  55. package/inline/Inline.stories.tsx +264 -0
  56. package/inline/types.d.ts +32 -0
  57. package/inline/types.js +5 -0
  58. package/inset/Inset.js +1 -34
  59. package/inset/Inset.stories.tsx +33 -33
  60. package/inset/types.d.ts +25 -1
  61. package/layout/ApplicationLayout.d.ts +4 -3
  62. package/layout/ApplicationLayout.js +84 -110
  63. package/layout/ApplicationLayout.stories.tsx +14 -59
  64. package/layout/Icons.d.ts +5 -0
  65. package/layout/Icons.js +13 -2
  66. package/layout/SidenavContext.d.ts +5 -0
  67. package/layout/SidenavContext.js +19 -0
  68. package/layout/types.d.ts +5 -10
  69. package/link/Link.d.ts +3 -2
  70. package/link/Link.js +57 -74
  71. package/link/Link.stories.tsx +87 -52
  72. package/link/Link.test.js +83 -0
  73. package/link/types.d.ts +7 -23
  74. package/list/List.js +1 -1
  75. package/list/List.stories.tsx +16 -22
  76. package/list/types.d.ts +1 -1
  77. package/main.d.ts +7 -8
  78. package/main.js +39 -41
  79. package/number-input/NumberInput.js +11 -18
  80. package/number-input/NumberInput.stories.tsx +5 -5
  81. package/number-input/NumberInput.test.js +506 -0
  82. package/number-input/types.d.ts +17 -10
  83. package/package.json +7 -5
  84. package/paginator/Paginator.js +17 -38
  85. package/paginator/Paginator.test.js +308 -0
  86. package/password-input/PasswordInput.js +7 -4
  87. package/password-input/PasswordInput.test.js +180 -0
  88. package/password-input/types.d.ts +14 -11
  89. package/progress-bar/ProgressBar.js +1 -1
  90. package/progress-bar/ProgressBar.stories.jsx +11 -11
  91. package/progress-bar/ProgressBar.test.js +65 -0
  92. package/quick-nav/QuickNav.d.ts +4 -0
  93. package/quick-nav/QuickNav.js +116 -0
  94. package/quick-nav/QuickNav.stories.tsx +237 -0
  95. package/quick-nav/types.d.ts +21 -0
  96. package/quick-nav/types.js +5 -0
  97. package/radio-group/Radio.d.ts +1 -1
  98. package/radio-group/Radio.js +25 -24
  99. package/radio-group/RadioGroup.js +46 -37
  100. package/radio-group/RadioGroup.stories.tsx +60 -39
  101. package/radio-group/RadioGroup.test.js +530 -83
  102. package/radio-group/types.d.ts +80 -2
  103. package/resultsetTable/ResultsetTable.test.js +348 -0
  104. package/row/types.d.ts +18 -0
  105. package/select/Icons.d.ts +10 -0
  106. package/select/Icons.js +93 -0
  107. package/select/Listbox.d.ts +4 -0
  108. package/select/Listbox.js +175 -0
  109. package/select/Option.d.ts +4 -0
  110. package/select/Option.js +110 -0
  111. package/select/Select.js +148 -351
  112. package/select/Select.stories.tsx +230 -176
  113. package/select/Select.test.js +2162 -0
  114. package/select/types.d.ts +53 -11
  115. package/sidenav/Sidenav.d.ts +1 -1
  116. package/sidenav/Sidenav.js +20 -9
  117. package/sidenav/Sidenav.test.js +56 -0
  118. package/slider/Slider.d.ts +1 -1
  119. package/slider/Slider.js +2 -1
  120. package/slider/Slider.stories.tsx +8 -8
  121. package/slider/Slider.test.js +150 -0
  122. package/slider/types.d.ts +4 -0
  123. package/spinner/Spinner.js +1 -1
  124. package/spinner/Spinner.test.js +64 -0
  125. package/stack/Stack.d.ts +2 -1
  126. package/stack/Stack.js +26 -71
  127. package/stack/Stack.stories.tsx +139 -78
  128. package/stack/types.d.ts +23 -4
  129. package/switch/Switch.d.ts +1 -1
  130. package/switch/Switch.js +35 -19
  131. package/switch/Switch.stories.tsx +14 -14
  132. package/switch/Switch.test.js +98 -0
  133. package/switch/types.d.ts +6 -2
  134. package/table/Table.test.js +26 -0
  135. package/tabs/Tabs.d.ts +1 -1
  136. package/tabs/Tabs.js +9 -11
  137. package/tabs/Tabs.stories.tsx +0 -8
  138. package/tabs/Tabs.test.js +140 -0
  139. package/tabs/types.d.ts +4 -0
  140. package/tabs-nav/NavTabs.d.ts +8 -0
  141. package/tabs-nav/NavTabs.js +125 -0
  142. package/tabs-nav/NavTabs.stories.tsx +170 -0
  143. package/tabs-nav/NavTabs.test.js +82 -0
  144. package/tabs-nav/Tab.d.ts +4 -0
  145. package/tabs-nav/Tab.js +132 -0
  146. package/tabs-nav/types.d.ts +53 -0
  147. package/tabs-nav/types.js +5 -0
  148. package/tag/Tag.js +14 -19
  149. package/tag/Tag.stories.tsx +12 -8
  150. package/tag/Tag.test.js +60 -0
  151. package/text-input/Suggestion.d.ts +4 -0
  152. package/text-input/Suggestion.js +55 -0
  153. package/text-input/TextInput.js +56 -80
  154. package/text-input/TextInput.stories.tsx +30 -12
  155. package/text-input/TextInput.test.js +1712 -0
  156. package/text-input/types.d.ts +31 -12
  157. package/textarea/Textarea.js +20 -27
  158. package/textarea/Textarea.stories.jsx +33 -12
  159. package/textarea/Textarea.test.js +437 -0
  160. package/textarea/types.d.ts +18 -11
  161. package/toggle-group/ToggleGroup.d.ts +1 -1
  162. package/toggle-group/ToggleGroup.js +5 -4
  163. package/toggle-group/ToggleGroup.stories.tsx +4 -4
  164. package/toggle-group/ToggleGroup.test.js +156 -0
  165. package/toggle-group/types.d.ts +8 -0
  166. package/useTheme.js +2 -2
  167. package/useTranslatedLabels.d.ts +2 -0
  168. package/useTranslatedLabels.js +20 -0
  169. package/wizard/Wizard.d.ts +1 -1
  170. package/wizard/Wizard.js +55 -44
  171. package/wizard/Wizard.stories.tsx +13 -23
  172. package/wizard/Wizard.test.js +141 -0
  173. package/wizard/types.d.ts +6 -2
  174. package/ThemeContext.d.ts +0 -15
  175. package/ThemeContext.js +0 -243
  176. package/V3Select/V3Select.js +0 -455
  177. package/V3Select/index.d.ts +0 -27
  178. package/V3Textarea/V3Textarea.js +0 -260
  179. package/V3Textarea/index.d.ts +0 -27
  180. package/date/Date.js +0 -373
  181. package/date/index.d.ts +0 -27
  182. package/input-text/Icons.js +0 -22
  183. package/input-text/InputText.js +0 -611
  184. package/input-text/index.d.ts +0 -36
  185. package/radio/Radio.d.ts +0 -4
  186. package/radio/Radio.js +0 -174
  187. package/radio/Radio.stories.tsx +0 -192
  188. package/radio/types.d.ts +0 -54
  189. package/toggle/Toggle.js +0 -186
  190. package/toggle/index.d.ts +0 -21
  191. package/upload/Upload.js +0 -201
  192. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  193. package/upload/buttons-upload/Icons.js +0 -40
  194. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  195. package/upload/dragAndDropArea/Icons.js +0 -39
  196. package/upload/file-upload/FileToUpload.js +0 -115
  197. package/upload/file-upload/Icons.js +0 -66
  198. package/upload/files-upload/FilesToUpload.js +0 -109
  199. package/upload/index.d.ts +0 -15
  200. package/upload/transaction/Icons.js +0 -160
  201. package/upload/transaction/Transaction.js +0 -104
  202. package/upload/transactions/Transactions.js +0 -94
@@ -19,195 +19,195 @@ export const Chromatic = () => (
19
19
  </Container>
20
20
  <Title title="space = none" level={4} />
21
21
  <Container>
22
- <DxcInset space="none">
22
+ <DxcInset space="0rem">
23
23
  <Placeholder></Placeholder>
24
24
  </DxcInset>
25
25
  </Container>
26
26
  <Title title="space = xxxsmall" level={4} />
27
27
  <Container>
28
- <DxcInset space="xxxsmall">
28
+ <DxcInset space="0.125rem">
29
29
  <Placeholder></Placeholder>
30
30
  </DxcInset>
31
31
  </Container>
32
32
  <Title title="space = xxsmall" level={4} />
33
33
  <Container>
34
- <DxcInset space="xxsmall">
34
+ <DxcInset space="0.25rem">
35
35
  <Placeholder></Placeholder>
36
36
  </DxcInset>
37
37
  </Container>
38
38
  <Title title="space = xsmall" level={4} />
39
39
  <Container>
40
- <DxcInset space="xsmall">
40
+ <DxcInset space="0.5rem">
41
41
  <Placeholder></Placeholder>
42
42
  </DxcInset>
43
43
  </Container>
44
44
  <Title title="space = small" level={4} />
45
45
  <Container>
46
- <DxcInset space="small">
46
+ <DxcInset space="1rem">
47
47
  <Placeholder></Placeholder>
48
48
  </DxcInset>
49
49
  </Container>
50
50
  <Title title="space = medium" level={4} />
51
51
  <Container>
52
- <DxcInset space="medium">
52
+ <DxcInset space="1.5rem">
53
53
  <Placeholder></Placeholder>
54
54
  </DxcInset>
55
55
  </Container>
56
56
  <Title title="space = large" level={4} />
57
57
  <Container>
58
- <DxcInset space="large">
58
+ <DxcInset space="2rem">
59
59
  <Placeholder></Placeholder>
60
60
  </DxcInset>
61
61
  </Container>
62
62
  <Title title="space = xlarge" level={4} />
63
63
  <Container>
64
- <DxcInset space="xlarge">
64
+ <DxcInset space="3rem">
65
65
  <Placeholder></Placeholder>
66
66
  </DxcInset>
67
67
  </Container>
68
68
  <Title title="space = xxlarge" level={4} />
69
69
  <Container>
70
- <DxcInset space="xxlarge">
70
+ <DxcInset space="4rem">
71
71
  <Placeholder></Placeholder>
72
72
  </DxcInset>
73
73
  </Container>
74
74
  <Title title="space = xxxlarge" level={4} />
75
75
  <Container>
76
- <DxcInset space="xxxlarge">
76
+ <DxcInset space="5rem">
77
77
  <Placeholder></Placeholder>
78
78
  </DxcInset>
79
79
  </Container>
80
80
  <Title title="horizontal = none" level={4} />
81
81
  <Container>
82
- <DxcInset horizontal="none">
82
+ <DxcInset horizontal="0rem">
83
83
  <Placeholder></Placeholder>
84
84
  </DxcInset>
85
85
  </Container>
86
86
  <Title title="horizontal = xxxsmall" level={4} />
87
87
  <Container>
88
- <DxcInset horizontal="xxxsmall">
88
+ <DxcInset horizontal="0.125rem">
89
89
  <Placeholder></Placeholder>
90
90
  </DxcInset>
91
91
  </Container>
92
92
  <Title title="horizontal = xxsmall" level={4} />
93
93
  <Container>
94
- <DxcInset horizontal="xxsmall">
94
+ <DxcInset horizontal="0.25rem">
95
95
  <Placeholder></Placeholder>
96
96
  </DxcInset>
97
97
  </Container>
98
98
  <Title title="horizontal = xsmall" level={4} />
99
99
  <Container>
100
- <DxcInset horizontal="xsmall">
100
+ <DxcInset horizontal="0.5rem">
101
101
  <Placeholder></Placeholder>
102
102
  </DxcInset>
103
103
  </Container>
104
104
  <Title title="horizontal = small" level={4} />
105
105
  <Container>
106
- <DxcInset horizontal="small">
106
+ <DxcInset horizontal="1rem">
107
107
  <Placeholder></Placeholder>
108
108
  </DxcInset>
109
109
  </Container>
110
110
  <Title title="horizontal = medium" level={4} />
111
111
  <Container>
112
- <DxcInset horizontal="medium">
112
+ <DxcInset horizontal="1.5rem">
113
113
  <Placeholder></Placeholder>
114
114
  </DxcInset>
115
115
  </Container>
116
116
  <Title title="horizontal = large" level={4} />
117
117
  <Container>
118
- <DxcInset horizontal="large">
118
+ <DxcInset horizontal="2rem">
119
119
  <Placeholder></Placeholder>
120
120
  </DxcInset>
121
121
  </Container>
122
122
  <Title title="horizontal = xlarge" level={4} />
123
123
  <Container>
124
- <DxcInset horizontal="xlarge">
124
+ <DxcInset horizontal="3rem">
125
125
  <Placeholder></Placeholder>
126
126
  </DxcInset>
127
127
  </Container>
128
128
  <Title title="horizontal = xxlarge" level={4} />
129
129
  <Container>
130
- <DxcInset horizontal="xxlarge">
130
+ <DxcInset horizontal="4rem">
131
131
  <Placeholder></Placeholder>
132
132
  </DxcInset>
133
133
  </Container>
134
134
  <Title title="horizontal = xxxlarge" level={4} />
135
135
  <Container>
136
- <DxcInset horizontal="xxxlarge">
136
+ <DxcInset horizontal="5rem">
137
137
  <Placeholder></Placeholder>
138
138
  </DxcInset>
139
139
  </Container>
140
140
  <Title title="vertical = none" level={4} />
141
141
  <Container>
142
- <DxcInset vertical="none">
142
+ <DxcInset vertical="0rem">
143
143
  <Placeholder></Placeholder>
144
144
  </DxcInset>
145
145
  </Container>
146
146
  <Title title="vertical = xxxsmall" level={4} />
147
147
  <Container>
148
- <DxcInset vertical="xxxsmall">
148
+ <DxcInset vertical="0.125rem">
149
149
  <Placeholder></Placeholder>
150
150
  </DxcInset>
151
151
  </Container>
152
152
  <Title title="vertical = xxsmall" level={4} />
153
153
  <Container>
154
- <DxcInset vertical="xxsmall">
154
+ <DxcInset vertical="0.25rem">
155
155
  <Placeholder></Placeholder>
156
156
  </DxcInset>
157
157
  </Container>
158
158
  <Title title="vertical = xsmall" level={4} />
159
159
  <Container>
160
- <DxcInset vertical="xsmall">
160
+ <DxcInset vertical="0.5rem">
161
161
  <Placeholder></Placeholder>
162
162
  </DxcInset>
163
163
  </Container>
164
164
  <Title title="vertical = small" level={4} />
165
165
  <Container>
166
- <DxcInset vertical="small">
166
+ <DxcInset vertical="1rem">
167
167
  <Placeholder></Placeholder>
168
168
  </DxcInset>
169
169
  </Container>
170
170
  <Title title="vertical = medium" level={4} />
171
171
  <Container>
172
- <DxcInset vertical="medium">
172
+ <DxcInset vertical="1.5rem">
173
173
  <Placeholder></Placeholder>
174
174
  </DxcInset>
175
175
  </Container>
176
176
  <Title title="vertical = large" level={4} />
177
177
  <Container>
178
- <DxcInset vertical="large">
178
+ <DxcInset vertical="2rem">
179
179
  <Placeholder></Placeholder>
180
180
  </DxcInset>
181
181
  </Container>
182
182
  <Title title="vertical = xlarge" level={4} />
183
183
  <Container>
184
- <DxcInset vertical="xlarge">
184
+ <DxcInset vertical="3rem">
185
185
  <Placeholder></Placeholder>
186
186
  </DxcInset>
187
187
  </Container>
188
188
  <Title title="vertical = xxlarge" level={4} />
189
189
  <Container>
190
- <DxcInset vertical="xxlarge">
190
+ <DxcInset vertical="4rem">
191
191
  <Placeholder></Placeholder>
192
192
  </DxcInset>
193
193
  </Container>
194
194
  <Title title="vertical = xxxlarge" level={4} />
195
195
  <Container>
196
- <DxcInset vertical="xxxlarge">
196
+ <DxcInset vertical="5rem">
197
197
  <Placeholder></Placeholder>
198
198
  </DxcInset>
199
199
  </Container>
200
200
  <Title title="top = xxsmall, right= medium, bottom = large and left = xxlarge" level={4} />
201
201
  <Container>
202
- <DxcInset top="xxsmall" right="medium" bottom="large" left="xxlarge">
202
+ <DxcInset top="0.25rem" right="1.5rem" bottom="2rem" left="4rem">
203
203
  <Placeholder></Placeholder>
204
204
  </DxcInset>
205
205
  </Container>
206
206
  <Title title="Inside a stack" level={4} />
207
207
  <Container>
208
- <DxcStack gutter="medium" divider>
208
+ <DxcStack gutter="0.75rem" divider>
209
209
  <Placeholder></Placeholder>
210
- <DxcInset top="xxsmall" right="medium" bottom="large" left="xxlarge">
210
+ <DxcInset top="0.25rem" right="1.5rem" bottom="2rem" left="4rem">
211
211
  <Placeholder></Placeholder>
212
212
  </DxcInset>
213
213
  <Placeholder></Placeholder>
package/inset/types.d.ts CHANGED
@@ -1,13 +1,37 @@
1
1
  /// <reference types="react" />
2
- declare type Spacing = "none" | "xxxsmall" | "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge" | "xxxlarge";
2
+ declare type Spacing = "0rem" | "0.125rem" | "0.25rem" | "0.5rem" | "1rem" | "1.5rem" | "2rem" | "3rem" | "4rem" | "5rem";
3
3
  declare type Props = {
4
+ /**
5
+ * Applies the spacing scale to all sides.
6
+ */
4
7
  space?: Spacing;
8
+ /**
9
+ * Applies the spacing scale to the left and right sides.
10
+ */
5
11
  horizontal?: Spacing;
12
+ /**
13
+ * Applies the spacing scale to the top and bottom sides.
14
+ */
6
15
  vertical?: Spacing;
16
+ /**
17
+ * Applies the spacing scale to the top side.
18
+ */
7
19
  top?: Spacing;
20
+ /**
21
+ * Applies the spacing scale to the right side.
22
+ */
8
23
  right?: Spacing;
24
+ /**
25
+ * Applies the spacing scale to the bottom side.
26
+ */
9
27
  bottom?: Spacing;
28
+ /**
29
+ * Applies the spacing scale to the left side.
30
+ */
10
31
  left?: Spacing;
32
+ /**
33
+ * Custom content inside the inset.
34
+ */
11
35
  children: React.ReactNode;
12
36
  };
13
37
  export default Props;
@@ -1,10 +1,11 @@
1
1
  /// <reference types="react" />
2
- import AppLayoutPropsType, { AppLayoutFooterPropsType, AppLayoutMainPropsType, AppLayoutHeaderPropsType } from "./types";
2
+ import AppLayoutPropsType, { AppLayoutSidenavPropsType, AppLayoutFooterPropsType, AppLayoutMainPropsType, AppLayoutHeaderPropsType } from "./types";
3
3
  declare const DxcApplicationLayout: {
4
- ({ children }: AppLayoutPropsType): JSX.Element;
4
+ ({ visibilityToggleLabel, children }: AppLayoutPropsType): JSX.Element;
5
5
  Header: ({ children }: AppLayoutHeaderPropsType) => JSX.Element;
6
6
  Main: ({ children }: AppLayoutMainPropsType) => JSX.Element;
7
7
  Footer: ({ children }: AppLayoutFooterPropsType) => JSX.Element;
8
- SideNav: (props: any) => JSX.Element;
8
+ SideNav: ({ ...childProps }: AppLayoutSidenavPropsType) => JSX.Element;
9
+ useResponsiveSidenavVisibility: () => (isSidenavVisible: boolean) => void;
9
10
  };
10
11
  export default DxcApplicationLayout;
@@ -13,23 +13,29 @@ 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"));
16
+ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
17
17
 
18
18
  var _react = _interopRequireWildcard(require("react"));
19
19
 
20
- var _main = require("../main");
20
+ var _Header = _interopRequireDefault(require("../header/Header"));
21
21
 
22
- var _styledComponents = _interopRequireWildcard(require("styled-components"));
22
+ var _Footer = _interopRequireDefault(require("../footer/Footer"));
23
+
24
+ var _Sidenav = _interopRequireDefault(require("../sidenav/Sidenav"));
25
+
26
+ var _styledComponents = _interopRequireDefault(require("styled-components"));
23
27
 
24
28
  var _variables = require("../common/variables.js");
25
29
 
26
30
  var _Icons = require("./Icons");
27
31
 
28
- var _useTheme = _interopRequireDefault(require("../useTheme"));
32
+ var _uuid = require("uuid");
29
33
 
30
- var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8, _templateObject9, _templateObject10;
34
+ var _SidenavContext = require("./SidenavContext");
31
35
 
32
- var _excluded = ["displayArrow", "mode"];
36
+ var _useTranslatedLabels = _interopRequireDefault(require("../useTranslatedLabels"));
37
+
38
+ var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8, _templateObject9;
33
39
 
34
40
  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
41
 
@@ -52,17 +58,13 @@ var Footer = function Footer(_ref3) {
52
58
  return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, children);
53
59
  };
54
60
 
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);
61
+ var Sidenav = function Sidenav(_ref4) {
62
+ var childProps = (0, _extends2["default"])({}, _ref4);
63
+ return /*#__PURE__*/_react["default"].createElement(_Sidenav["default"], childProps, childProps.children);
62
64
  };
63
65
 
64
66
  var defaultFooter = function defaultFooter() {
65
- return /*#__PURE__*/_react["default"].createElement(_main.DxcFooter, {
67
+ return /*#__PURE__*/_react["default"].createElement(_Footer["default"], {
66
68
  copyright: "\xA9 DXC Technology ".concat(year, "\u200B\u200B\u200B\u200B. All rights reserved."),
67
69
  bottomLinks: [{
68
70
  href: "https://www.linkedin.com/company/dxctechnology",
@@ -88,138 +90,110 @@ var defaultFooter = function defaultFooter() {
88
90
  };
89
91
 
90
92
  var defaultHeader = function defaultHeader() {
91
- return /*#__PURE__*/_react["default"].createElement(_main.DxcHeader, {
93
+ return /*#__PURE__*/_react["default"].createElement(_Header["default"], {
92
94
  underlined: true
93
95
  });
94
96
  };
95
97
 
96
98
  var childTypeExists = function childTypeExists(children, childType) {
97
99
  return children.find(function (child) {
98
- return child && child.type && child.type === childType;
100
+ return (child === null || child === void 0 ? void 0 : child.type) === childType;
99
101
  });
100
102
  };
101
103
 
102
- var DxcApplicationLayout = function DxcApplicationLayout(_ref4) {
103
- var children = _ref4.children;
104
- var ref = (0, _react.useRef)(null);
105
- var colorsTheme = (0, _useTheme["default"])();
104
+ var DxcApplicationLayout = function DxcApplicationLayout(_ref5) {
105
+ var _ref5$visibilityToggl = _ref5.visibilityToggleLabel,
106
+ visibilityToggleLabel = _ref5$visibilityToggl === void 0 ? "" : _ref5$visibilityToggl,
107
+ children = _ref5.children;
106
108
 
107
- var _useState = (0, _react.useState)(true),
108
- _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
109
- isSideNavVisible = _useState2[0],
110
- setIsSideNavVisible = _useState2[1];
109
+ var _useState = (0, _react.useState)("appLayout-".concat((0, _uuid.v4)())),
110
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 1),
111
+ appLayoutId = _useState2[0];
112
+
113
+ var visibilityToggleLabelId = "label-".concat(appLayoutId);
111
114
 
112
115
  var _useState3 = (0, _react.useState)(false),
113
116
  _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
114
- isResponsive = _useState4[0],
115
- setIsResponsive = _useState4[1];
117
+ isSidenavVisibleResponsive = _useState4[0],
118
+ setIsSidenavVisibleResponsive = _useState4[1];
119
+
120
+ var _useState5 = (0, _react.useState)(false),
121
+ _useState6 = (0, _slicedToArray2["default"])(_useState5, 2),
122
+ isResponsive = _useState6[0],
123
+ setIsResponsive = _useState6[1];
124
+
125
+ var ref = (0, _react.useRef)(null);
126
+ var translatedLabels = (0, _useTranslatedLabels["default"])();
116
127
 
117
128
  var childrenArray = _react["default"].Children.toArray(children);
118
129
 
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);
130
+ var header = childTypeExists(childrenArray, _Header["default"]) || childTypeExists(childrenArray, Header) || defaultHeader();
131
+ var footer = childTypeExists(childrenArray, _Footer["default"]) || childTypeExists(childrenArray, Footer) || defaultFooter();
132
+ var sidenav = childTypeExists(childrenArray, Sidenav);
122
133
  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
134
 
139
- var handleResize = function handleResize(width) {
140
- if (width) {
141
- setIsResponsive(width <= _variables.responsiveSizes.tablet);
142
- setIsSideNavVisible(true);
143
- }
135
+ var handleResize = function handleResize() {
136
+ setIsResponsive(window.matchMedia("(max-width: ".concat(_variables.responsiveSizes.medium, "rem)")).matches);
144
137
  };
145
138
 
146
- var handleEventListener = function handleEventListener() {
147
- handleResize(ref.current.offsetWidth);
139
+ var handleSidenavVisibility = function handleSidenavVisibility() {
140
+ setIsSidenavVisibleResponsive(function (isSidenavVisibleResponsive) {
141
+ return !isSidenavVisibleResponsive;
142
+ });
148
143
  };
149
144
 
150
145
  (0, _react.useEffect)(function () {
151
- if (ref.current) {
152
- window.addEventListener("resize", handleEventListener);
153
- handleResize(ref.current.offsetWidth);
154
- }
155
-
146
+ handleResize();
147
+ window.addEventListener("resize", handleResize);
156
148
  return function () {
157
- window.removeEventListener("resize", handleEventListener);
149
+ window.removeEventListener("resize", handleResize);
158
150
  };
159
- }, []);
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, {
151
+ }, [setIsResponsive]);
152
+ (0, _react.useEffect)(function () {
153
+ !isResponsive && setIsSidenavVisibleResponsive(false);
154
+ }, [isResponsive, setIsSidenavVisibleResponsive]);
155
+ return /*#__PURE__*/_react["default"].createElement(ApplicationLayoutContainer, {
156
+ hasSidenav: sidenav ? true : false,
157
+ isSidenavVisible: isSidenavVisibleResponsive,
168
158
  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))))));
159
+ }, /*#__PURE__*/_react["default"].createElement(HeaderContainer, null, header), sidenav && isResponsive && /*#__PURE__*/_react["default"].createElement(VisibilityToggle, null, /*#__PURE__*/_react["default"].createElement(HamburgerTrigger, {
160
+ onClick: handleSidenavVisibility,
161
+ "aria-labelledby": visibilityToggleLabel ? visibilityToggleLabelId : undefined,
162
+ "aria-label": visibilityToggleLabel ? undefined : translatedLabels.applicationLayout.visibilityToggleTitle,
163
+ title: translatedLabels.applicationLayout.visibilityToggleTitle
164
+ }, _Icons.hamburgerIcon, visibilityToggleLabel && /*#__PURE__*/_react["default"].createElement(VisibilityToggleLabel, {
165
+ id: visibilityToggleLabelId
166
+ }, visibilityToggleLabel))), /*#__PURE__*/_react["default"].createElement(BodyContainer, null, /*#__PURE__*/_react["default"].createElement(_SidenavContext.SidenavContextProvider, {
167
+ value: setIsSidenavVisibleResponsive
168
+ }, sidenav && (isResponsive ? isSidenavVisibleResponsive : true) && /*#__PURE__*/_react["default"].createElement(SidenavContainer, null, sidenav)), /*#__PURE__*/_react["default"].createElement(MainContainer, null, /*#__PURE__*/_react["default"].createElement(MainContentContainer, null, main), footer)));
185
169
  };
186
170
 
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"])));
171
+ 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) {
172
+ return props.hasSidenav && "top: 112px";
173
+ }, function (props) {
174
+ return props.isSidenavVisible && "overflow: hidden;";
175
+ });
193
176
 
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"])));
177
+ 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"])));
195
178
 
196
- var BodyContainer = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n flex: 1;\n display: flex;\n flex-direction: column;\n"])));
179
+ 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"])));
197
180
 
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"])));
181
+ var HamburgerTrigger = _styledComponents["default"].button(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n gap: 10px;\n flex-wrap: wrap;\n align-content: center;\n border: 0px solid transparent;\n border-radius: 2px;\n padding: 15px 3px;\n background-color: transparent;\n box-shadow: 0 0 0 2px transparent;\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"])));
199
182
 
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"])));
183
+ var VisibilityToggleLabel = _styledComponents["default"].span(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n font-family: Open Sans, sans-serif;\n font-weight: 600;\n font-size: 14px;\n"])));
201
184
 
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
- });
185
+ var BodyContainer = _styledComponents["default"].div(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: row;\n flex: 1;\n"])));
205
186
 
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
- });
187
+ var SidenavContainer = _styledComponents["default"].div(_templateObject7 || (_templateObject7 = (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: fixed;\n top: 112px;\n }\n"])), _variables.responsiveSizes.medium);
209
188
 
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
- });
189
+ var MainContainer = _styledComponents["default"].div(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n width: 100%;\n"])));
213
190
 
214
- var ArrowContainer = _styledComponents["default"].div(_templateObject9 || (_templateObject9 = (0, _taggedTemplateLiteral2["default"])(["\n position: absolute;\n height: calc(100vh - 64px);\n left: 279px;\n"])));
215
-
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 :focus {\n outline: #0095ff auto 1px;\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
- });
191
+ var MainContentContainer = _styledComponents["default"].div(_templateObject9 || (_templateObject9 = (0, _taggedTemplateLiteral2["default"])(["\n flex: 1;\n"])));
223
192
 
193
+ DxcApplicationLayout.Header = Header;
194
+ DxcApplicationLayout.Main = Main;
195
+ DxcApplicationLayout.Footer = Footer;
196
+ DxcApplicationLayout.SideNav = Sidenav;
197
+ DxcApplicationLayout.useResponsiveSidenavVisibility = _SidenavContext.useResponsiveSidenavVisibility;
224
198
  var _default = DxcApplicationLayout;
225
199
  exports["default"] = _default;