@dxc-technology/halstack-react 0.0.0-9d82cb9 → 0.0.0-9e54008

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 (307) hide show
  1. package/BackgroundColorContext.d.ts +2 -2
  2. package/BackgroundColorContext.js +1 -1
  3. package/HalstackContext.d.ts +1336 -0
  4. package/HalstackContext.js +335 -0
  5. package/accordion/Accordion.d.ts +1 -1
  6. package/accordion/Accordion.js +110 -146
  7. package/accordion/Accordion.stories.tsx +108 -118
  8. package/accordion/Accordion.test.js +71 -0
  9. package/accordion/types.d.ts +7 -18
  10. package/accordion-group/AccordionGroup.d.ts +5 -4
  11. package/accordion-group/AccordionGroup.js +34 -76
  12. package/accordion-group/AccordionGroup.stories.tsx +94 -67
  13. package/accordion-group/AccordionGroup.test.js +116 -0
  14. package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
  15. package/accordion-group/AccordionGroupAccordion.js +43 -0
  16. package/accordion-group/types.d.ts +13 -18
  17. package/alert/Alert.js +9 -10
  18. package/alert/Alert.stories.tsx +28 -0
  19. package/alert/Alert.test.js +92 -0
  20. package/badge/Badge.d.ts +4 -0
  21. package/badge/Badge.js +5 -3
  22. package/badge/types.d.ts +5 -0
  23. package/bleed/Bleed.d.ts +2 -2
  24. package/bleed/Bleed.js +1 -34
  25. package/bleed/Bleed.stories.tsx +95 -95
  26. package/bleed/types.d.ts +25 -1
  27. package/box/Box.d.ts +1 -1
  28. package/box/Box.js +19 -48
  29. package/box/Box.stories.tsx +38 -51
  30. package/box/Box.test.js +18 -0
  31. package/box/types.d.ts +0 -11
  32. package/bulleted-list/BulletedList.d.ts +7 -0
  33. package/bulleted-list/BulletedList.js +125 -0
  34. package/bulleted-list/BulletedList.stories.tsx +206 -0
  35. package/bulleted-list/types.d.ts +38 -0
  36. package/bulleted-list/types.js +5 -0
  37. package/button/Button.js +52 -70
  38. package/button/Button.stories.tsx +159 -8
  39. package/button/Button.test.js +35 -0
  40. package/button/types.d.ts +5 -5
  41. package/card/Card.d.ts +1 -1
  42. package/card/Card.js +37 -58
  43. package/card/Card.stories.tsx +12 -42
  44. package/card/Card.test.js +50 -0
  45. package/card/types.d.ts +1 -6
  46. package/checkbox/Checkbox.d.ts +2 -2
  47. package/checkbox/Checkbox.js +107 -110
  48. package/checkbox/Checkbox.stories.tsx +198 -130
  49. package/checkbox/Checkbox.test.js +155 -0
  50. package/checkbox/types.d.ts +11 -3
  51. package/chip/Chip.d.ts +1 -1
  52. package/chip/Chip.js +36 -95
  53. package/chip/Chip.stories.tsx +123 -30
  54. package/chip/Chip.test.js +54 -0
  55. package/chip/types.d.ts +5 -13
  56. package/common/OpenSans.css +68 -80
  57. package/common/coreTokens.d.ts +146 -0
  58. package/common/coreTokens.js +167 -0
  59. package/common/utils.d.ts +1 -0
  60. package/common/utils.js +4 -4
  61. package/common/variables.d.ts +1482 -0
  62. package/common/variables.js +1097 -1348
  63. package/date-input/Calendar.d.ts +4 -0
  64. package/date-input/Calendar.js +258 -0
  65. package/date-input/DateInput.js +169 -258
  66. package/date-input/DateInput.stories.tsx +199 -33
  67. package/date-input/DateInput.test.js +835 -0
  68. package/date-input/DatePicker.d.ts +4 -0
  69. package/date-input/DatePicker.js +146 -0
  70. package/date-input/Icons.d.ts +6 -0
  71. package/date-input/Icons.js +75 -0
  72. package/date-input/YearPicker.d.ts +4 -0
  73. package/date-input/YearPicker.js +126 -0
  74. package/date-input/types.d.ts +67 -9
  75. package/dialog/Dialog.d.ts +1 -1
  76. package/dialog/Dialog.js +68 -103
  77. package/dialog/Dialog.stories.tsx +154 -171
  78. package/dialog/Dialog.test.js +369 -0
  79. package/dialog/types.d.ts +0 -12
  80. package/dropdown/Dropdown.d.ts +1 -1
  81. package/dropdown/Dropdown.js +248 -277
  82. package/dropdown/Dropdown.stories.tsx +255 -64
  83. package/dropdown/Dropdown.test.js +586 -0
  84. package/dropdown/DropdownMenu.d.ts +4 -0
  85. package/dropdown/DropdownMenu.js +74 -0
  86. package/dropdown/DropdownMenuItem.d.ts +4 -0
  87. package/dropdown/DropdownMenuItem.js +79 -0
  88. package/dropdown/types.d.ts +27 -16
  89. package/file-input/FileInput.d.ts +2 -2
  90. package/file-input/FileInput.js +180 -223
  91. package/file-input/FileInput.stories.tsx +122 -11
  92. package/file-input/FileInput.test.js +457 -0
  93. package/file-input/FileItem.d.ts +4 -14
  94. package/file-input/FileItem.js +44 -66
  95. package/file-input/types.d.ts +18 -1
  96. package/flex/Flex.d.ts +4 -0
  97. package/flex/Flex.js +71 -0
  98. package/flex/Flex.stories.tsx +112 -0
  99. package/flex/types.d.ts +97 -0
  100. package/flex/types.js +5 -0
  101. package/footer/Footer.d.ts +1 -1
  102. package/footer/Footer.js +26 -116
  103. package/footer/Footer.stories.tsx +26 -16
  104. package/footer/Footer.test.js +97 -0
  105. package/footer/Icons.js +1 -1
  106. package/footer/types.d.ts +1 -6
  107. package/grid/Grid.d.ts +7 -0
  108. package/grid/Grid.js +91 -0
  109. package/grid/Grid.stories.tsx +219 -0
  110. package/grid/types.d.ts +115 -0
  111. package/grid/types.js +5 -0
  112. package/header/Header.d.ts +4 -3
  113. package/header/Header.js +102 -150
  114. package/header/Header.stories.tsx +152 -63
  115. package/header/Header.test.js +79 -0
  116. package/header/Icons.js +2 -2
  117. package/header/types.d.ts +0 -13
  118. package/heading/Heading.js +1 -1
  119. package/heading/Heading.test.js +186 -0
  120. package/inset/Inset.js +1 -34
  121. package/inset/Inset.stories.tsx +37 -36
  122. package/inset/types.d.ts +25 -1
  123. package/layout/ApplicationLayout.d.ts +16 -6
  124. package/layout/ApplicationLayout.js +72 -126
  125. package/layout/ApplicationLayout.stories.tsx +84 -93
  126. package/layout/Icons.d.ts +5 -0
  127. package/layout/Icons.js +13 -2
  128. package/layout/SidenavContext.d.ts +5 -0
  129. package/layout/SidenavContext.js +19 -0
  130. package/layout/types.d.ts +19 -35
  131. package/link/Link.d.ts +3 -2
  132. package/link/Link.js +63 -88
  133. package/link/Link.stories.tsx +159 -52
  134. package/link/Link.test.js +81 -0
  135. package/link/types.d.ts +7 -27
  136. package/main.d.ts +12 -15
  137. package/main.js +57 -75
  138. package/nav-tabs/NavTabs.d.ts +8 -0
  139. package/nav-tabs/NavTabs.js +122 -0
  140. package/nav-tabs/NavTabs.stories.tsx +274 -0
  141. package/nav-tabs/NavTabs.test.js +82 -0
  142. package/nav-tabs/Tab.d.ts +4 -0
  143. package/nav-tabs/Tab.js +146 -0
  144. package/nav-tabs/types.d.ts +52 -0
  145. package/nav-tabs/types.js +5 -0
  146. package/number-input/NumberInput.js +11 -18
  147. package/number-input/NumberInput.stories.tsx +5 -5
  148. package/number-input/NumberInput.test.js +542 -0
  149. package/number-input/types.d.ts +17 -10
  150. package/package.json +20 -23
  151. package/paginator/Icons.d.ts +5 -0
  152. package/paginator/Icons.js +16 -28
  153. package/paginator/Paginator.js +20 -49
  154. package/paginator/Paginator.stories.tsx +24 -0
  155. package/paginator/Paginator.test.js +318 -0
  156. package/paragraph/Paragraph.d.ts +5 -0
  157. package/paragraph/Paragraph.js +38 -0
  158. package/paragraph/Paragraph.stories.tsx +44 -0
  159. package/password-input/PasswordInput.js +7 -4
  160. package/password-input/PasswordInput.test.js +181 -0
  161. package/password-input/types.d.ts +14 -11
  162. package/progress-bar/ProgressBar.js +61 -55
  163. package/progress-bar/ProgressBar.stories.jsx +47 -12
  164. package/progress-bar/ProgressBar.test.js +110 -0
  165. package/quick-nav/QuickNav.d.ts +4 -0
  166. package/quick-nav/QuickNav.js +117 -0
  167. package/quick-nav/QuickNav.stories.tsx +356 -0
  168. package/quick-nav/types.d.ts +21 -0
  169. package/quick-nav/types.js +5 -0
  170. package/radio-group/Radio.d.ts +1 -1
  171. package/radio-group/Radio.js +60 -34
  172. package/radio-group/RadioGroup.js +81 -68
  173. package/radio-group/RadioGroup.stories.tsx +171 -36
  174. package/radio-group/RadioGroup.test.js +722 -0
  175. package/radio-group/types.d.ts +81 -3
  176. package/resultsetTable/Icons.d.ts +7 -0
  177. package/resultsetTable/Icons.js +51 -0
  178. package/resultsetTable/ResultsetTable.js +50 -106
  179. package/resultsetTable/ResultsetTable.stories.tsx +50 -25
  180. package/resultsetTable/ResultsetTable.test.js +325 -0
  181. package/resultsetTable/types.d.ts +1 -1
  182. package/select/Icons.d.ts +10 -0
  183. package/select/Icons.js +93 -0
  184. package/select/Listbox.d.ts +4 -0
  185. package/select/Listbox.js +169 -0
  186. package/select/Option.d.ts +4 -0
  187. package/select/Option.js +97 -0
  188. package/select/Select.js +189 -386
  189. package/select/Select.stories.tsx +600 -201
  190. package/select/Select.test.js +2228 -0
  191. package/select/types.d.ts +53 -13
  192. package/sidenav/Icons.d.ts +7 -0
  193. package/sidenav/Icons.js +51 -0
  194. package/sidenav/Sidenav.d.ts +6 -5
  195. package/sidenav/Sidenav.js +146 -44
  196. package/sidenav/Sidenav.stories.tsx +251 -151
  197. package/sidenav/Sidenav.test.js +44 -0
  198. package/sidenav/types.d.ts +52 -26
  199. package/slider/Slider.d.ts +2 -2
  200. package/slider/Slider.js +123 -98
  201. package/slider/Slider.stories.tsx +72 -9
  202. package/slider/Slider.test.js +250 -0
  203. package/slider/types.d.ts +8 -0
  204. package/spinner/Spinner.js +18 -24
  205. package/spinner/Spinner.stories.jsx +53 -27
  206. package/spinner/Spinner.test.js +64 -0
  207. package/switch/Switch.d.ts +2 -2
  208. package/switch/Switch.js +152 -69
  209. package/switch/Switch.stories.tsx +53 -42
  210. package/switch/Switch.test.js +225 -0
  211. package/switch/types.d.ts +10 -2
  212. package/table/Table.js +3 -3
  213. package/table/Table.stories.jsx +80 -1
  214. package/table/Table.test.js +26 -0
  215. package/tabs/Tab.d.ts +4 -0
  216. package/tabs/Tab.js +132 -0
  217. package/tabs/Tabs.d.ts +1 -1
  218. package/tabs/Tabs.js +362 -114
  219. package/tabs/Tabs.stories.tsx +122 -18
  220. package/tabs/Tabs.test.js +350 -0
  221. package/tabs/types.d.ts +37 -15
  222. package/tag/Tag.d.ts +1 -1
  223. package/tag/Tag.js +24 -36
  224. package/tag/Tag.stories.tsx +37 -27
  225. package/tag/Tag.test.js +60 -0
  226. package/tag/types.d.ts +23 -14
  227. package/text-input/Icons.d.ts +8 -0
  228. package/text-input/Icons.js +60 -0
  229. package/text-input/Suggestion.d.ts +4 -0
  230. package/text-input/Suggestion.js +84 -0
  231. package/text-input/Suggestions.d.ts +4 -0
  232. package/text-input/Suggestions.js +134 -0
  233. package/text-input/TextInput.js +225 -346
  234. package/text-input/TextInput.stories.tsx +310 -197
  235. package/text-input/TextInput.test.js +1723 -0
  236. package/text-input/types.d.ts +50 -12
  237. package/textarea/Textarea.js +22 -30
  238. package/textarea/Textarea.stories.jsx +93 -13
  239. package/textarea/Textarea.test.js +435 -0
  240. package/textarea/types.d.ts +18 -11
  241. package/toggle-group/ToggleGroup.d.ts +2 -2
  242. package/toggle-group/ToggleGroup.js +12 -8
  243. package/toggle-group/ToggleGroup.stories.tsx +46 -4
  244. package/toggle-group/ToggleGroup.test.js +156 -0
  245. package/toggle-group/types.d.ts +10 -2
  246. package/typography/Typography.d.ts +4 -0
  247. package/typography/Typography.js +32 -0
  248. package/typography/Typography.stories.tsx +198 -0
  249. package/typography/types.d.ts +18 -0
  250. package/typography/types.js +5 -0
  251. package/useTheme.d.ts +1234 -1
  252. package/useTheme.js +3 -3
  253. package/useTranslatedLabels.d.ts +85 -0
  254. package/useTranslatedLabels.js +20 -0
  255. package/utils/BaseTypography.d.ts +21 -0
  256. package/utils/BaseTypography.js +108 -0
  257. package/utils/FocusLock.d.ts +13 -0
  258. package/utils/FocusLock.js +138 -0
  259. package/wizard/Wizard.d.ts +1 -1
  260. package/wizard/Wizard.js +59 -55
  261. package/wizard/Wizard.stories.tsx +48 -19
  262. package/wizard/Wizard.test.js +141 -0
  263. package/wizard/types.d.ts +8 -4
  264. package/ThemeContext.d.ts +0 -15
  265. package/ThemeContext.js +0 -243
  266. package/V3Select/V3Select.js +0 -455
  267. package/V3Select/index.d.ts +0 -27
  268. package/V3Textarea/V3Textarea.js +0 -260
  269. package/V3Textarea/index.d.ts +0 -27
  270. package/card/ice-cream.jpg +0 -0
  271. package/common/RequiredComponent.js +0 -32
  272. package/date/Date.js +0 -373
  273. package/date/index.d.ts +0 -27
  274. package/input-text/Icons.js +0 -22
  275. package/input-text/InputText.js +0 -611
  276. package/input-text/index.d.ts +0 -36
  277. package/list/List.d.ts +0 -8
  278. package/list/List.js +0 -47
  279. package/list/List.stories.tsx +0 -95
  280. package/radio/Radio.d.ts +0 -4
  281. package/radio/Radio.js +0 -174
  282. package/radio/Radio.stories.tsx +0 -192
  283. package/radio/types.d.ts +0 -54
  284. package/row/Row.d.ts +0 -11
  285. package/row/Row.js +0 -127
  286. package/row/Row.stories.tsx +0 -239
  287. package/stack/Stack.d.ts +0 -10
  288. package/stack/Stack.js +0 -97
  289. package/stack/Stack.stories.tsx +0 -166
  290. package/text/Text.d.ts +0 -7
  291. package/text/Text.js +0 -30
  292. package/text/Text.stories.tsx +0 -19
  293. package/toggle/Toggle.js +0 -186
  294. package/toggle/index.d.ts +0 -21
  295. package/upload/Upload.js +0 -201
  296. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  297. package/upload/buttons-upload/Icons.js +0 -40
  298. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  299. package/upload/dragAndDropArea/Icons.js +0 -39
  300. package/upload/file-upload/FileToUpload.js +0 -115
  301. package/upload/file-upload/Icons.js +0 -66
  302. package/upload/files-upload/FilesToUpload.js +0 -109
  303. package/upload/index.d.ts +0 -15
  304. package/upload/transaction/Icons.js +0 -160
  305. package/upload/transaction/Transaction.js +0 -104
  306. package/upload/transactions/Transactions.js +0 -94
  307. /package/{radio → badge}/types.js +0 -0
@@ -1,8 +1,12 @@
1
1
  import React from "react";
2
2
  import DxcHeader from "./Header";
3
+ import DxcButton from "../button/Button";
3
4
  import Title from "../../.storybook/components/Title";
4
5
  import ExampleContainer from "../../.storybook/components/ExampleContainer";
5
6
  import { userEvent, waitFor, within } from "@storybook/testing-library";
7
+ import DxcFlex from "../flex/Flex";
8
+ import DxcLink from "../link/Link";
9
+ import { HalstackProvider } from "../HalstackContext";
6
10
 
7
11
  export default {
8
12
  title: "Header",
@@ -16,24 +20,61 @@ const options: any = [
16
20
  },
17
21
  ];
18
22
 
23
+ const options2: any = [
24
+ {
25
+ value: 1,
26
+ label: "Home",
27
+ },
28
+ {
29
+ value: 2,
30
+ label: "Release notes",
31
+ },
32
+ {
33
+ value: 3,
34
+ label: "Sign out",
35
+ },
36
+ ];
37
+
38
+ const opinionatedTheme = {
39
+ header: {
40
+ baseColor: "#ffffff",
41
+ accentColor: "#000000",
42
+ fontColor: "#000000",
43
+ menuBaseColor: "#ffffff",
44
+ hamburguerColor: "#000000",
45
+ logo: "https://upload.wikimedia.org/wikipedia/commons/thumb/b/b8/2021_Facebook_icon.svg/2048px-2021_Facebook_icon.svg.png",
46
+ logoResponsive:
47
+ "https://upload.wikimedia.org/wikipedia/commons/thumb/b/b8/2021_Facebook_icon.svg/2048px-2021_Facebook_icon.svg.png",
48
+ contentColor: "#000000",
49
+ overlayColor: "#000000b3",
50
+ },
51
+ };
52
+
19
53
  export const Chromatic = () => (
20
54
  <>
21
55
  <ExampleContainer>
22
56
  <Title title="Default with dropdown" theme="light" level={4} />
23
- <DxcHeader content={<DxcHeader.Dropdown options={options} label="Default Dropdown" />} />
57
+ <DxcHeader
58
+ content={<DxcHeader.Dropdown options={options} label="Default Dropdown" onSelectOption={() => {}} />}
59
+ />
24
60
  </ExampleContainer>
25
61
  <ExampleContainer>
26
62
  <Title title="Underlined with text" theme="light" level={4} />
27
63
  <DxcHeader underlined content={<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Cras felis.</p>} />
28
64
  </ExampleContainer>
29
65
  <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>
66
+ <Title title="Underlined, dropdown and links" theme="light" level={4} />
67
+ <DxcHeader
68
+ content={
69
+ <DxcFlex alignItems="center" gap="4rem">
70
+ <DxcLink>Link 1</DxcLink>
71
+ <DxcLink>Link 2</DxcLink>
72
+ <DxcLink>Link 3</DxcLink>
73
+ <DxcHeader.Dropdown options={options2} label="Label" onSelectOption={() => {}} />
74
+ </DxcFlex>
75
+ }
76
+ underlined
77
+ />
37
78
  </ExampleContainer>
38
79
  <Title title="Margins" theme="light" level={2} />
39
80
  <ExampleContainer>
@@ -71,92 +112,140 @@ export const Chromatic = () => (
71
112
  <DxcHeader underlined margin="xxlarge" />
72
113
  <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Cras felis.</p>
73
114
  </ExampleContainer>
74
-
75
- <Title title="Paddings" theme="light" level={2} />
76
- <ExampleContainer>
77
- <Title title="Xxsmall padding" theme="light" level={4} />
78
- <DxcHeader underlined padding="xxsmall" />
79
- </ExampleContainer>
80
- <ExampleContainer>
81
- <Title title="Xsmall padding" theme="light" level={4} />
82
- <DxcHeader underlined padding="xsmall" />
83
- </ExampleContainer>
84
- <ExampleContainer>
85
- <Title title="Small padding" theme="light" level={4} />
86
- <DxcHeader underlined padding="small" />
87
- </ExampleContainer>
88
- <ExampleContainer>
89
- <Title title="Medium padding" theme="light" level={4} />
90
- <DxcHeader underlined padding="medium" />
91
- </ExampleContainer>
92
- <ExampleContainer>
93
- <Title title="Large padding" theme="light" level={4} />
94
- <DxcHeader underlined padding="large" />
95
- </ExampleContainer>
96
- <ExampleContainer>
97
- <Title title="Xlarge padding" theme="light" level={4} />
98
- <DxcHeader underlined padding="xlarge" />
99
- </ExampleContainer>
115
+ <Title title="Opinionated theme" theme="light" level={2} />
100
116
  <ExampleContainer>
101
- <Title title="Xxlarge padding" theme="light" level={4} />
102
- <DxcHeader underlined padding="xxlarge" />
117
+ <HalstackProvider theme={opinionatedTheme}>
118
+ <DxcHeader
119
+ underlined
120
+ content={<DxcButton label={"Custom Button"} />}
121
+ responsiveContent={(closeHandler) => (
122
+ <>
123
+ <DxcButton label={"Custom Button"} onClick={closeHandler} />
124
+ Custom content
125
+ </>
126
+ )}
127
+ />
128
+ </HalstackProvider>
103
129
  </ExampleContainer>
104
130
  </>
105
131
  );
106
132
 
107
- const RespHeader = () => (
133
+ export const ResponsiveHeader = () => (
108
134
  <ExampleContainer>
109
135
  <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>
136
+ <DxcHeader
137
+ content={<DxcHeader.Dropdown options={options} label="Default Dropdown" onSelectOption={() => {}} />}
138
+ responsiveContent={(closeHandler) => (
139
+ <DxcHeader.Dropdown options={options} label="Default Dropdown" onSelectOption={() => {}} />
140
+ )}
141
+ underlined
142
+ />
116
143
  </ExampleContainer>
117
144
  );
118
145
 
119
146
  const RespHeaderFocus = () => (
120
147
  <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>
148
+ <Title title="Responsive focus" theme="light" level={4} />
149
+ <DxcHeader responsiveContent={(closeHandler) => <p>Lorem ipsum dolor sit amet.</p>} underlined />
128
150
  </ExampleContainer>
129
151
  );
130
152
 
131
153
  const RespHeaderHover = () => (
132
154
  <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>
155
+ <Title title="Responsive hover" theme="light" level={4} />
156
+ <DxcHeader responsiveContent={(closeHandler) => <p>Lorem ipsum dolor sit amet.</p>} underlined />
140
157
  </ExampleContainer>
141
158
  );
142
159
 
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"));
160
+ const RespHeaderMenuMobile = () => (
161
+ <ExampleContainer>
162
+ <Title title="Responsive menu" theme="light" level={4} />
163
+ <DxcHeader responsiveContent={(closeHandler) => <p>Lorem ipsum dolor sit amet.</p>} underlined />
164
+ </ExampleContainer>
165
+ );
166
+
167
+ const RespHeaderMenuTablet = () => (
168
+ <ExampleContainer>
169
+ <Title title="Responsive menu" theme="light" level={4} />
170
+ <DxcHeader responsiveContent={(closeHandler) => <p>Lorem ipsum dolor sit amet.</p>} underlined />
171
+ </ExampleContainer>
172
+ );
173
+
174
+ const RespHeaderMenuOpinionated = () => (
175
+ <ExampleContainer>
176
+ <Title title="Responsive menu" theme="light" level={4} />
177
+ <HalstackProvider theme={opinionatedTheme}>
178
+ <DxcHeader responsiveContent={(closeHandler) => <p>Lorem ipsum dolor sit amet.</p>} underlined />
179
+ </HalstackProvider>
180
+ </ExampleContainer>
181
+ );
182
+
183
+ ResponsiveHeader.parameters = {
184
+ viewport: {
185
+ defaultViewport: "iphonex",
186
+ },
187
+ chromatic: { viewports: [375] },
148
188
  };
149
189
 
150
190
  export const ResponsiveHeaderFocus = RespHeaderFocus.bind({});
191
+ ResponsiveHeaderFocus.parameters = {
192
+ viewport: {
193
+ defaultViewport: "iphonex",
194
+ },
195
+ chromatic: { viewports: [375] },
196
+ };
151
197
  ResponsiveHeaderFocus.play = async ({ canvasElement }) => {
152
198
  const canvas = within(canvasElement);
153
199
  await waitFor(() => canvas.findByText("Menu"));
154
- await userEvent.click(canvas.getByText("Menu"));
155
200
  };
156
201
 
157
202
  export const ResponsiveHeaderHover = RespHeaderHover.bind({});
203
+ ResponsiveHeaderHover.parameters = {
204
+ viewport: {
205
+ defaultViewport: "iphonex",
206
+ },
207
+ chromatic: { viewports: [375] },
208
+ };
158
209
  ResponsiveHeaderHover.play = async ({ canvasElement }) => {
159
210
  const canvas = within(canvasElement);
160
211
  await waitFor(() => canvas.findByText("Menu"));
212
+ };
213
+
214
+ export const ResponsiveHeaderMenuMobile = RespHeaderMenuMobile.bind({});
215
+ ResponsiveHeaderMenuMobile.parameters = {
216
+ viewport: {
217
+ defaultViewport: "iphonex",
218
+ },
219
+ chromatic: { viewports: [375] },
220
+ };
221
+ ResponsiveHeaderMenuMobile.play = async ({ canvasElement }) => {
222
+ const canvas = within(canvasElement);
223
+ await waitFor(() => canvas.findByText("Menu"));
224
+ await userEvent.click(canvas.getByText("Menu"));
225
+ };
226
+
227
+ export const ResponsiveHeaderMenuTablet = RespHeaderMenuTablet.bind({});
228
+ ResponsiveHeaderMenuTablet.parameters = {
229
+ viewport: {
230
+ defaultViewport: "pixelxl",
231
+ },
232
+ chromatic: { viewports: [720] },
233
+ };
234
+ ResponsiveHeaderMenuTablet.play = async ({ canvasElement }) => {
235
+ const canvas = within(canvasElement);
236
+ await waitFor(() => canvas.findByText("Menu"));
237
+ await userEvent.click(canvas.getByText("Menu"));
238
+ };
239
+
240
+ export const ResponsiveHeaderMenuOpinionated = RespHeaderMenuOpinionated.bind({});
241
+ ResponsiveHeaderMenuOpinionated.parameters = {
242
+ viewport: {
243
+ defaultViewport: "pixelxl",
244
+ },
245
+ chromatic: { viewports: [720] },
246
+ };
247
+ ResponsiveHeaderMenuOpinionated.play = async ({ canvasElement }) => {
248
+ const canvas = within(canvasElement);
249
+ await waitFor(() => canvas.findByText("Menu"));
161
250
  await userEvent.click(canvas.getByText("Menu"));
162
251
  };
@@ -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.tsx"));
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() {
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
+ });
package/header/Icons.js CHANGED
@@ -23,12 +23,12 @@ var dxcLogo = /*#__PURE__*/_react["default"].createElement("svg", {
23
23
  id: "path14",
24
24
  d: "M91.613-28.177v2.514H90.231V-28.15l-2.415-3.82h1.616l1.5,2.532,1.526-2.532h1.571ZM83.9-25.555A3.15,3.15,0,0,1,80.6-28.8v-.018a3.231,3.231,0,0,1,3.294-3.262,3.442,3.442,0,0,1,2.469.865l-.87,1.054a2.311,2.311,0,0,0-1.643-.64,1.891,1.891,0,0,0-1.8,1.964v.018a1.886,1.886,0,0,0,1.9,2,2.2,2.2,0,0,0,1.3-.378v-.9H83.858v-1.2h2.729v2.738A4.071,4.071,0,0,1,83.9-25.555Zm-6.416-3.261a1.913,1.913,0,0,0-1.9-1.982A1.883,1.883,0,0,0,73.7-28.835v.018a1.913,1.913,0,0,0,1.9,1.982A1.883,1.883,0,0,0,77.486-28.8Zm-1.9,3.261a3.225,3.225,0,0,1-3.33-3.243v-.018A3.255,3.255,0,0,1,75.6-32.078a3.225,3.225,0,0,1,3.331,3.243v.018A3.255,3.255,0,0,1,75.583-25.555Zm-9.173-.108V-31.97h1.382v5.045h3.133v1.261Zm-3.433-3.153a1.913,1.913,0,0,0-1.9-1.982,1.883,1.883,0,0,0-1.886,1.964v.018a1.913,1.913,0,0,0,1.9,1.982A1.883,1.883,0,0,0,62.978-28.8Zm-1.9,3.261a3.225,3.225,0,0,1-3.33-3.243v-.018a3.255,3.255,0,0,1,3.348-3.262,3.225,3.225,0,0,1,3.331,3.243v.018A3.255,3.255,0,0,1,61.075-25.555Zm-6.508-.108-3.043-4.009v4.009H50.159V-31.97h1.275l2.944,3.883V-31.97h1.364v6.306Zm-8.246,0v-2.531h-2.55v2.531H42.389V-31.97h1.382v2.5h2.55v-2.5H47.7v6.306Zm-8.432.108A3.178,3.178,0,0,1,34.666-28.8v-.018a3.2,3.2,0,0,1,3.276-3.262,3.237,3.237,0,0,1,2.478.973l-.88,1.018a2.315,2.315,0,0,0-1.606-.712,1.866,1.866,0,0,0-1.822,1.964v.018a1.87,1.87,0,0,0,1.822,1.982,2.265,2.265,0,0,0,1.651-.739l.88.891A3.206,3.206,0,0,1,37.889-25.555Zm-9.805-.108V-31.97h4.739v1.235H29.458v1.279h2.962v1.234H29.458V-26.9h3.411v1.234ZM24.322-30.69v5.027H22.939V-30.69H21.028v-1.28h5.206v1.28H24.322",
25
25
  transform: "translate(-21.028 65.555)",
26
- fill: "#100f0d"
26
+ fill: "#010101"
27
27
  }), /*#__PURE__*/_react["default"].createElement("path", {
28
28
  id: "path16",
29
29
  d: "M75.836-76.712a8.975,8.975,0,0,1,2.246-3.9,8.393,8.393,0,0,1,6.058-2.457h9.824v-5.67H84.139a14.611,14.611,0,0,0-10.232,4.221,14.509,14.509,0,0,0-3.076,4.536,11.913,11.913,0,0,0-.973,3.271Zm0,4.325a8.978,8.978,0,0,0,2.246,3.9,8.394,8.394,0,0,0,6.058,2.457h9.824v5.67H84.139A14.611,14.611,0,0,1,73.907-64.58a14.506,14.506,0,0,1-3.076-4.536,11.91,11.91,0,0,1-.973-3.271ZM57.522-69.832l-7.5,9.473H42.581L53.818-74.55,42.581-88.739H50.02l7.5,9.472,7.5-9.472h7.439L61.225-74.55l11.237,14.19H65.023Zm-12.336-6.88a11.935,11.935,0,0,0-.973-3.271,14.515,14.515,0,0,0-3.076-4.536A14.612,14.612,0,0,0,30.9-88.739H21.081v5.67H30.9a8.394,8.394,0,0,1,6.058,2.457,8.978,8.978,0,0,1,2.246,3.9Zm0,4.325a11.932,11.932,0,0,1-.973,3.271,14.511,14.511,0,0,1-3.076,4.536A14.611,14.611,0,0,1,30.9-60.359H21.081v-5.67H30.9a8.4,8.4,0,0,0,6.058-2.457,8.981,8.981,0,0,0,2.246-3.9h5.978",
30
30
  transform: "translate(-21.049 88.739)",
31
- fill: "#100f0d"
31
+ fill: "#603494"
32
32
  }))));
33
33
 
34
34
  exports.dxcLogo = dxcLogo;
package/header/types.d.ts CHANGED
@@ -1,11 +1,5 @@
1
1
  /// <reference types="react" />
2
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
3
  declare type Props = {
10
4
  /**
11
5
  * Wether a contrast line should appear at the bottom of the header.
@@ -31,13 +25,6 @@ declare type Props = {
31
25
  * ('xxsmall' | 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge' | 'xxlarge').
32
26
  */
33
27
  margin?: Space;
34
- /**
35
- * Size of the padding to be applied to the custom area of the component
36
- * ('xxsmall' | 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge' | 'xxlarge').
37
- * You can pass an object with 'top', 'bottom', 'left' and 'right' properties in
38
- * order to specify different padding sizes.
39
- */
40
- padding?: Space | Padding;
41
28
  /**
42
29
  * Value of the tabindex for all interactuable elements, except those inside the
43
30
  * custom area.
@@ -17,7 +17,7 @@ var _react = _interopRequireDefault(require("react"));
17
17
 
18
18
  var _styledComponents = _interopRequireWildcard(require("styled-components"));
19
19
 
20
- var _variables = require("../common/variables.js");
20
+ var _variables = require("../common/variables");
21
21
 
22
22
  var _useTheme = _interopRequireDefault(require("../useTheme"));
23
23
 
@@ -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.tsx"));
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
+ });
package/inset/Inset.js CHANGED
@@ -36,40 +36,7 @@ function Inset(_ref) {
36
36
  }
37
37
 
38
38
  function getSpacingValue(spacingName) {
39
- switch (spacingName) {
40
- case "none":
41
- return "0rem";
42
-
43
- case "xxxsmall":
44
- return "0.125rem";
45
-
46
- case "xxsmall":
47
- return "0.25rem";
48
-
49
- case "xsmall":
50
- return "0.5rem";
51
-
52
- case "small":
53
- return "1rem";
54
-
55
- case "medium":
56
- return "1.5rem";
57
-
58
- case "large":
59
- return "2rem";
60
-
61
- case "xlarge":
62
- return "3rem";
63
-
64
- case "xxlarge":
65
- return "4rem";
66
-
67
- case "xxxlarge":
68
- return "5rem";
69
-
70
- default:
71
- return "0rem";
72
- }
39
+ return spacingName ? spacingName : "0rem";
73
40
  }
74
41
 
75
42
  var StyledInset = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n ", "\n"])), function (_ref2) {