@dxc-technology/halstack-react 0.0.0-910214a → 0.0.0-918d2c8

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 (195) hide show
  1. package/HalstackContext.js +90 -50
  2. package/accordion/Accordion.js +117 -104
  3. package/accordion/Accordion.stories.tsx +104 -16
  4. package/accordion/Accordion.test.js +9 -10
  5. package/accordion/types.d.ts +5 -4
  6. package/accordion-group/AccordionGroup.js +2 -21
  7. package/accordion-group/AccordionGroup.stories.tsx +27 -1
  8. package/accordion-group/AccordionGroup.test.js +20 -45
  9. package/accordion-group/types.d.ts +10 -3
  10. package/alert/Alert.js +1 -1
  11. package/alert/Alert.stories.tsx +28 -0
  12. package/bleed/Bleed.stories.tsx +63 -63
  13. package/box/Box.js +1 -1
  14. package/box/Box.stories.tsx +15 -0
  15. package/box/types.d.ts +1 -0
  16. package/bulleted-list/BulletedList.d.ts +7 -0
  17. package/bulleted-list/BulletedList.js +123 -0
  18. package/bulleted-list/BulletedList.stories.tsx +200 -0
  19. package/bulleted-list/types.d.ts +11 -0
  20. package/{list → bulleted-list}/types.js +0 -0
  21. package/button/Button.js +50 -70
  22. package/button/Button.stories.tsx +159 -8
  23. package/button/types.d.ts +7 -7
  24. package/card/types.d.ts +1 -0
  25. package/checkbox/Checkbox.d.ts +2 -2
  26. package/checkbox/Checkbox.js +92 -99
  27. package/checkbox/Checkbox.stories.tsx +131 -59
  28. package/checkbox/Checkbox.test.js +93 -16
  29. package/checkbox/types.d.ts +6 -2
  30. package/chip/Chip.js +16 -22
  31. package/chip/Chip.stories.tsx +96 -9
  32. package/chip/types.d.ts +1 -1
  33. package/common/variables.js +309 -260
  34. package/date-input/Calendar.d.ts +4 -0
  35. package/date-input/Calendar.js +258 -0
  36. package/date-input/DateInput.js +134 -237
  37. package/date-input/DateInput.stories.tsx +199 -33
  38. package/date-input/DateInput.test.js +494 -138
  39. package/date-input/DatePicker.d.ts +4 -0
  40. package/date-input/DatePicker.js +146 -0
  41. package/date-input/Icons.d.ts +6 -0
  42. package/date-input/Icons.js +75 -0
  43. package/date-input/YearPicker.d.ts +4 -0
  44. package/date-input/YearPicker.js +126 -0
  45. package/date-input/types.d.ts +51 -0
  46. package/dialog/Dialog.js +50 -28
  47. package/dialog/Dialog.stories.tsx +99 -22
  48. package/dialog/Dialog.test.js +34 -4
  49. package/dialog/types.d.ts +3 -2
  50. package/dropdown/Dropdown.d.ts +1 -1
  51. package/dropdown/Dropdown.js +246 -249
  52. package/dropdown/Dropdown.stories.tsx +245 -56
  53. package/dropdown/Dropdown.test.js +504 -108
  54. package/dropdown/DropdownMenu.d.ts +4 -0
  55. package/dropdown/DropdownMenu.js +70 -0
  56. package/dropdown/DropdownMenuItem.d.ts +4 -0
  57. package/dropdown/DropdownMenuItem.js +81 -0
  58. package/dropdown/types.d.ts +25 -5
  59. package/file-input/FileInput.d.ts +2 -2
  60. package/file-input/FileInput.js +177 -219
  61. package/file-input/FileInput.stories.tsx +122 -11
  62. package/file-input/FileInput.test.js +53 -12
  63. package/file-input/FileItem.d.ts +4 -14
  64. package/file-input/FileItem.js +38 -63
  65. package/file-input/types.d.ts +17 -0
  66. package/flex/Flex.d.ts +4 -0
  67. package/flex/Flex.js +69 -0
  68. package/flex/Flex.stories.tsx +103 -0
  69. package/flex/types.d.ts +32 -0
  70. package/{row → flex}/types.js +0 -0
  71. package/footer/Footer.stories.tsx +99 -1
  72. package/footer/Icons.js +1 -1
  73. package/footer/types.d.ts +2 -1
  74. package/header/Header.js +87 -87
  75. package/header/Header.stories.tsx +152 -9
  76. package/header/Icons.js +2 -2
  77. package/header/types.d.ts +3 -2
  78. package/inset/Inset.js +1 -34
  79. package/inset/Inset.stories.tsx +36 -36
  80. package/inset/types.d.ts +1 -1
  81. package/layout/ApplicationLayout.d.ts +15 -6
  82. package/layout/ApplicationLayout.js +37 -65
  83. package/layout/ApplicationLayout.stories.tsx +80 -44
  84. package/layout/types.d.ts +17 -27
  85. package/link/Link.js +2 -2
  86. package/link/Link.stories.tsx +73 -6
  87. package/link/types.d.ts +1 -1
  88. package/main.d.ts +5 -8
  89. package/main.js +28 -52
  90. package/number-input/NumberInput.test.js +43 -7
  91. package/package.json +16 -20
  92. package/paginator/Icons.d.ts +5 -0
  93. package/paginator/Icons.js +16 -28
  94. package/paginator/Paginator.js +6 -12
  95. package/paginator/Paginator.stories.tsx +24 -0
  96. package/paginator/Paginator.test.js +50 -1
  97. package/paragraph/Paragraph.d.ts +6 -0
  98. package/paragraph/Paragraph.js +38 -0
  99. package/paragraph/Paragraph.stories.tsx +44 -0
  100. package/password-input/PasswordInput.test.js +13 -12
  101. package/progress-bar/ProgressBar.d.ts +2 -2
  102. package/progress-bar/ProgressBar.js +59 -53
  103. package/progress-bar/ProgressBar.stories.jsx +38 -3
  104. package/progress-bar/ProgressBar.test.js +67 -22
  105. package/progress-bar/types.d.ts +3 -4
  106. package/quick-nav/QuickNav.js +25 -20
  107. package/quick-nav/QuickNav.stories.tsx +145 -26
  108. package/radio-group/Radio.d.ts +1 -1
  109. package/radio-group/Radio.js +43 -28
  110. package/radio-group/RadioGroup.js +23 -22
  111. package/radio-group/RadioGroup.stories.tsx +132 -18
  112. package/radio-group/RadioGroup.test.js +123 -96
  113. package/radio-group/types.d.ts +2 -2
  114. package/resultsetTable/Icons.d.ts +7 -0
  115. package/resultsetTable/Icons.js +51 -0
  116. package/resultsetTable/ResultsetTable.js +48 -107
  117. package/resultsetTable/ResultsetTable.stories.tsx +50 -25
  118. package/resultsetTable/ResultsetTable.test.js +60 -41
  119. package/resultsetTable/types.d.ts +2 -2
  120. package/select/Listbox.d.ts +1 -1
  121. package/select/Listbox.js +33 -16
  122. package/select/Option.js +11 -24
  123. package/select/Select.js +79 -60
  124. package/select/Select.stories.tsx +513 -136
  125. package/select/Select.test.js +358 -250
  126. package/select/types.d.ts +3 -6
  127. package/sidenav/Sidenav.d.ts +6 -5
  128. package/sidenav/Sidenav.js +174 -55
  129. package/sidenav/Sidenav.stories.tsx +249 -149
  130. package/sidenav/Sidenav.test.js +25 -37
  131. package/sidenav/types.d.ts +50 -27
  132. package/slider/Slider.d.ts +2 -2
  133. package/slider/Slider.js +120 -95
  134. package/slider/Slider.stories.tsx +64 -1
  135. package/slider/Slider.test.js +121 -21
  136. package/slider/types.d.ts +6 -2
  137. package/spinner/Spinner.js +2 -2
  138. package/spinner/Spinner.stories.jsx +27 -1
  139. package/switch/Switch.d.ts +2 -2
  140. package/switch/Switch.js +135 -68
  141. package/switch/Switch.stories.tsx +41 -30
  142. package/switch/Switch.test.js +144 -17
  143. package/switch/types.d.ts +6 -2
  144. package/table/Table.js +1 -1
  145. package/table/Table.stories.jsx +80 -1
  146. package/table/Table.test.js +1 -1
  147. package/tabs/Tab.d.ts +4 -0
  148. package/tabs/Tab.js +133 -0
  149. package/tabs/Tabs.js +360 -104
  150. package/tabs/Tabs.stories.tsx +119 -5
  151. package/tabs/Tabs.test.js +217 -6
  152. package/tabs/types.d.ts +15 -5
  153. package/tabs-nav/NavTabs.js +5 -5
  154. package/tabs-nav/NavTabs.stories.tsx +8 -6
  155. package/tabs-nav/Tab.js +8 -12
  156. package/tabs-nav/types.d.ts +1 -1
  157. package/tag/Tag.js +1 -1
  158. package/tag/Tag.stories.tsx +14 -1
  159. package/tag/types.d.ts +1 -1
  160. package/text-input/Icons.d.ts +8 -0
  161. package/text-input/Icons.js +60 -0
  162. package/text-input/Suggestion.js +38 -9
  163. package/text-input/Suggestions.d.ts +4 -0
  164. package/text-input/Suggestions.js +134 -0
  165. package/text-input/TextInput.js +195 -292
  166. package/text-input/TextInput.stories.tsx +280 -185
  167. package/text-input/TextInput.test.js +737 -725
  168. package/text-input/types.d.ts +22 -3
  169. package/textarea/Textarea.stories.jsx +60 -1
  170. package/toggle-group/ToggleGroup.stories.tsx +42 -0
  171. package/toggle-group/types.d.ts +1 -1
  172. package/typography/Typography.d.ts +4 -0
  173. package/typography/Typography.js +131 -0
  174. package/typography/Typography.stories.tsx +198 -0
  175. package/typography/types.d.ts +18 -0
  176. package/{stack → typography}/types.js +0 -0
  177. package/wizard/Wizard.js +9 -16
  178. package/wizard/Wizard.stories.tsx +40 -1
  179. package/wizard/types.d.ts +5 -4
  180. package/common/RequiredComponent.js +0 -32
  181. package/list/List.d.ts +0 -4
  182. package/list/List.js +0 -47
  183. package/list/List.stories.tsx +0 -95
  184. package/list/types.d.ts +0 -7
  185. package/row/Row.d.ts +0 -3
  186. package/row/Row.js +0 -127
  187. package/row/Row.stories.tsx +0 -237
  188. package/row/types.d.ts +0 -28
  189. package/stack/Stack.d.ts +0 -3
  190. package/stack/Stack.js +0 -97
  191. package/stack/Stack.stories.tsx +0 -164
  192. package/stack/types.d.ts +0 -24
  193. package/text/Text.d.ts +0 -7
  194. package/text/Text.js +0 -30
  195. package/text/Text.stories.tsx +0 -19
@@ -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,16 +20,99 @@ 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: (
46
+ <svg xmlns="http://www.w3.org/2000/svg" width="73" height="40" viewBox="0 0 73 40">
47
+ <g id="g10" transform="translate(0)">
48
+ <g id="g12">
49
+ <path
50
+ id="path14"
51
+ 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"
52
+ transform="translate(-21.028 65.555)"
53
+ fill="#100f0d"
54
+ />
55
+ <path
56
+ id="path16"
57
+ 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"
58
+ transform="translate(-21.049 88.739)"
59
+ fill="#5f249f"
60
+ />
61
+ </g>
62
+ </g>
63
+ </svg>
64
+ ),
65
+ logoResponsive: (
66
+ <svg xmlns="http://www.w3.org/2000/svg" width="73" height="40" viewBox="0 0 73 40">
67
+ <g id="g10" transform="translate(0)">
68
+ <g id="g12">
69
+ <path
70
+ id="path14"
71
+ 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"
72
+ transform="translate(-21.028 65.555)"
73
+ fill="#100f0d"
74
+ />
75
+ <path
76
+ id="path16"
77
+ 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"
78
+ transform="translate(-21.049 88.739)"
79
+ fill="#5f249f"
80
+ />
81
+ </g>
82
+ </g>
83
+ </svg>
84
+ ),
85
+ contentColor: "#000000",
86
+ overlayColor: "#000000b3",
87
+ },
88
+ };
89
+
19
90
  export const Chromatic = () => (
20
91
  <>
21
92
  <ExampleContainer>
22
93
  <Title title="Default with dropdown" theme="light" level={4} />
23
- <DxcHeader content={<DxcHeader.Dropdown options={options} label="Default Dropdown" />} />
94
+ <DxcHeader
95
+ content={<DxcHeader.Dropdown options={options} label="Default Dropdown" onSelectOption={() => {}} />}
96
+ />
24
97
  </ExampleContainer>
25
98
  <ExampleContainer>
26
99
  <Title title="Underlined with text" theme="light" level={4} />
27
100
  <DxcHeader underlined content={<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Cras felis.</p>} />
28
101
  </ExampleContainer>
102
+ <ExampleContainer>
103
+ <Title title="Underlined, dropdown and links" theme="light" level={4} />
104
+ <DxcHeader
105
+ content={
106
+ <DxcFlex alignItems="center" gap="4rem">
107
+ <DxcLink>Link 1</DxcLink>
108
+ <DxcLink>Link 2</DxcLink>
109
+ <DxcLink>Link 3</DxcLink>
110
+ <DxcHeader.Dropdown options={options2} label="Label" onSelectOption={() => {}} />
111
+ </DxcFlex>
112
+ }
113
+ underlined
114
+ />
115
+ </ExampleContainer>
29
116
  <Title title="Margins" theme="light" level={2} />
30
117
  <ExampleContainer>
31
118
  <Title title="Xxsmall margin" theme="light" level={4} />
@@ -62,7 +149,6 @@ export const Chromatic = () => (
62
149
  <DxcHeader underlined margin="xxlarge" />
63
150
  <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Cras felis.</p>
64
151
  </ExampleContainer>
65
-
66
152
  <Title title="Paddings" theme="light" level={2} />
67
153
  <ExampleContainer>
68
154
  <Title title="Xxsmall padding" theme="light" level={4} />
@@ -92,6 +178,21 @@ export const Chromatic = () => (
92
178
  <Title title="Xxlarge padding" theme="light" level={4} />
93
179
  <DxcHeader underlined padding="xxlarge" />
94
180
  </ExampleContainer>
181
+ <Title title="Opinionated theme" theme="light" level={2} />
182
+ <ExampleContainer>
183
+ <HalstackProvider theme={opinionatedTheme}>
184
+ <DxcHeader
185
+ underlined
186
+ content={<DxcButton label={"Custom Button"} />}
187
+ responsiveContent={(closeHandler) => (
188
+ <>
189
+ <DxcButton label={"Custom Button"} onClick={closeHandler} />
190
+ Custom content
191
+ </>
192
+ )}
193
+ />
194
+ </HalstackProvider>
195
+ </ExampleContainer>
95
196
  </>
96
197
  );
97
198
 
@@ -120,18 +221,34 @@ const RespHeaderHover = () => (
120
221
  </ExampleContainer>
121
222
  );
122
223
 
123
- const RespHeaderMenu = () => (
224
+ const RespHeaderMenuMobile = () => (
225
+ <ExampleContainer>
226
+ <Title title="Responsive menu" theme="light" level={4} />
227
+ <DxcHeader responsiveContent={(closeHandler) => <p>Lorem ipsum dolor sit amet.</p>} underlined />
228
+ </ExampleContainer>
229
+ );
230
+
231
+ const RespHeaderMenuTablet = () => (
124
232
  <ExampleContainer>
125
233
  <Title title="Responsive menu" theme="light" level={4} />
126
234
  <DxcHeader responsiveContent={(closeHandler) => <p>Lorem ipsum dolor sit amet.</p>} underlined />
127
235
  </ExampleContainer>
128
236
  );
129
237
 
238
+ const RespHeaderMenuOpinionated = () => (
239
+ <ExampleContainer>
240
+ <Title title="Responsive menu" theme="light" level={4} />
241
+ <HalstackProvider theme={opinionatedTheme}>
242
+ <DxcHeader responsiveContent={(closeHandler) => <p>Lorem ipsum dolor sit amet.</p>} underlined />
243
+ </HalstackProvider>
244
+ </ExampleContainer>
245
+ );
246
+
130
247
  ResponsiveHeader.parameters = {
131
248
  viewport: {
132
249
  defaultViewport: "iphonex",
133
250
  },
134
- chromatic: { viewports: [720] },
251
+ chromatic: { viewports: [375] },
135
252
  };
136
253
 
137
254
  export const ResponsiveHeaderFocus = RespHeaderFocus.bind({});
@@ -139,7 +256,7 @@ ResponsiveHeaderFocus.parameters = {
139
256
  viewport: {
140
257
  defaultViewport: "iphonex",
141
258
  },
142
- chromatic: { viewports: [720] },
259
+ chromatic: { viewports: [375] },
143
260
  };
144
261
  ResponsiveHeaderFocus.play = async ({ canvasElement }) => {
145
262
  const canvas = within(canvasElement);
@@ -151,21 +268,47 @@ ResponsiveHeaderHover.parameters = {
151
268
  viewport: {
152
269
  defaultViewport: "iphonex",
153
270
  },
154
- chromatic: { viewports: [720] },
271
+ chromatic: { viewports: [375] },
155
272
  };
156
273
  ResponsiveHeaderHover.play = async ({ canvasElement }) => {
157
274
  const canvas = within(canvasElement);
158
275
  await waitFor(() => canvas.findByText("Menu"));
159
276
  };
160
277
 
161
- export const ResponsiveHeaderMenu = RespHeaderMenu.bind({});
162
- ResponsiveHeaderMenu.parameters = {
278
+ export const ResponsiveHeaderMenuMobile = RespHeaderMenuMobile.bind({});
279
+ ResponsiveHeaderMenuMobile.parameters = {
163
280
  viewport: {
164
281
  defaultViewport: "iphonex",
165
282
  },
283
+ chromatic: { viewports: [375] },
284
+ };
285
+ ResponsiveHeaderMenuMobile.play = async ({ canvasElement }) => {
286
+ const canvas = within(canvasElement);
287
+ await waitFor(() => canvas.findByText("Menu"));
288
+ await userEvent.click(canvas.getByText("Menu"));
289
+ };
290
+
291
+ export const ResponsiveHeaderMenuTablet = RespHeaderMenuTablet.bind({});
292
+ ResponsiveHeaderMenuTablet.parameters = {
293
+ viewport: {
294
+ defaultViewport: "pixelxl",
295
+ },
296
+ chromatic: { viewports: [720] },
297
+ };
298
+ ResponsiveHeaderMenuTablet.play = async ({ canvasElement }) => {
299
+ const canvas = within(canvasElement);
300
+ await waitFor(() => canvas.findByText("Menu"));
301
+ await userEvent.click(canvas.getByText("Menu"));
302
+ };
303
+
304
+ export const ResponsiveHeaderMenuOpinionated = RespHeaderMenuOpinionated.bind({});
305
+ ResponsiveHeaderMenuOpinionated.parameters = {
306
+ viewport: {
307
+ defaultViewport: "pixelxl",
308
+ },
166
309
  chromatic: { viewports: [720] },
167
310
  };
168
- ResponsiveHeaderMenu.play = async ({ canvasElement }) => {
311
+ ResponsiveHeaderMenuOpinionated.play = async ({ canvasElement }) => {
169
312
  const canvas = within(canvasElement);
170
313
  await waitFor(() => canvas.findByText("Menu"));
171
314
  await userEvent.click(canvas.getByText("Menu"));
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,6 +1,6 @@
1
1
  /// <reference types="react" />
2
- declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
- declare type Padding = {
2
+ export declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
+ export declare type Padding = {
4
4
  top?: Space;
5
5
  bottom?: Space;
6
6
  left?: Space;
@@ -32,6 +32,7 @@ declare type Props = {
32
32
  */
33
33
  margin?: Space;
34
34
  /**
35
+ * @deprecated This prop will be removed shortly, consider using the Inset component for this purpose.
35
36
  * Size of the padding to be applied to the custom area of the component
36
37
  * ('xxsmall' | 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge' | 'xxlarge').
37
38
  * You can pass an object with 'top', 'bottom', 'left' and 'right' properties in
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) {
@@ -1,7 +1,7 @@
1
1
  import React from "react";
2
2
  import Title from "../../.storybook/components/Title";
3
3
  import styled from "styled-components";
4
- import DxcStack from "./../stack/Stack";
4
+ import DxcFlex from "./../flex/Flex";
5
5
  import DxcInset from "./Inset";
6
6
 
7
7
  export default {
@@ -19,199 +19,199 @@ 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
- <Title title="Inside a stack" level={4} />
206
+ <Title title="Inside a flex column" level={4} />
207
207
  <Container>
208
- <DxcStack gutter="medium" divider>
208
+ <DxcFlex direction="column" gap="0.75rem">
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>
214
- </DxcStack>
214
+ </DxcFlex>
215
215
  </Container>
216
216
  </>
217
217
  );
package/inset/types.d.ts CHANGED
@@ -1,5 +1,5 @@
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
4
  /**
5
5
  * Applies the spacing scale to all sides.
@@ -1,11 +1,20 @@
1
- /// <reference types="react" />
2
- import AppLayoutPropsType, { AppLayoutSidenavPropsType, AppLayoutFooterPropsType, AppLayoutMainPropsType, AppLayoutHeaderPropsType } from "./types";
1
+ import React from "react";
2
+ import AppLayoutPropsType, { AppLayoutMainPropsType } from "./types";
3
3
  declare const DxcApplicationLayout: {
4
- ({ visibilityToggleLabel, children }: AppLayoutPropsType): JSX.Element;
5
- Header: ({ children }: AppLayoutHeaderPropsType) => JSX.Element;
4
+ ({ visibilityToggleLabel, header, sidenav, footer, children, }: AppLayoutPropsType): JSX.Element;
5
+ Header: {
6
+ ({ underlined, content, responsiveContent, onClick, margin, padding, tabIndex, }: import("../header/types").default): JSX.Element;
7
+ Dropdown: (props: any) => JSX.Element;
8
+ };
6
9
  Main: ({ children }: AppLayoutMainPropsType) => JSX.Element;
7
- Footer: ({ children }: AppLayoutFooterPropsType) => JSX.Element;
8
- SideNav: ({ ...childProps }: AppLayoutSidenavPropsType) => JSX.Element;
10
+ Footer: ({ socialLinks, bottomLinks, copyright, children, padding, margin, tabIndex, }: import("../footer/types").default) => JSX.Element;
11
+ SideNav: {
12
+ ({ children, title }: import("../sidenav/types").default): JSX.Element;
13
+ Section: ({ children }: import("../sidenav/types").SidenavSectionPropsType) => JSX.Element;
14
+ Group: ({ children, title, collapsable, icon }: import("../sidenav/types").SidenavGroupPropsType) => JSX.Element;
15
+ Link: React.ForwardRefExoticComponent<import("../sidenav/types").SidenavLinkPropsType & React.RefAttributes<HTMLAnchorElement>>;
16
+ Title: ({ children }: import("../sidenav/types").SidenavTitlePropsType) => JSX.Element;
17
+ };
9
18
  useResponsiveSidenavVisibility: () => (isSidenavVisible: boolean) => void;
10
19
  };
11
20
  export default DxcApplicationLayout;