@dxc-technology/halstack-react 0.0.0-dddc3c4 → 0.0.0-de7c6b0

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 (220) hide show
  1. package/BackgroundColorContext.d.ts +2 -2
  2. package/BackgroundColorContext.js +1 -1
  3. package/HalstackContext.d.ts +1329 -5
  4. package/HalstackContext.js +117 -77
  5. package/accordion/Accordion.d.ts +1 -1
  6. package/accordion/Accordion.js +110 -114
  7. package/accordion/Accordion.stories.tsx +104 -114
  8. package/accordion/Accordion.test.js +10 -11
  9. package/accordion/types.d.ts +0 -11
  10. package/accordion-group/AccordionGroup.d.ts +4 -3
  11. package/accordion-group/AccordionGroup.js +24 -65
  12. package/accordion-group/AccordionGroup.stories.tsx +93 -66
  13. package/accordion-group/AccordionGroup.test.js +27 -62
  14. package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
  15. package/accordion-group/AccordionGroupAccordion.js +43 -0
  16. package/accordion-group/types.d.ts +6 -11
  17. package/alert/Alert.js +5 -9
  18. package/alert/Alert.stories.tsx +28 -0
  19. package/alert/Alert.test.js +1 -1
  20. package/bleed/Bleed.stories.tsx +1 -0
  21. package/box/Box.d.ts +1 -1
  22. package/box/Box.js +8 -27
  23. package/box/Box.stories.tsx +38 -51
  24. package/box/Box.test.js +1 -1
  25. package/box/types.d.ts +0 -11
  26. package/bulleted-list/BulletedList.js +4 -2
  27. package/bulleted-list/BulletedList.stories.tsx +7 -1
  28. package/bulleted-list/types.d.ts +31 -4
  29. package/button/Button.js +13 -16
  30. package/button/Button.stories.tsx +151 -9
  31. package/button/Button.test.js +1 -1
  32. package/button/types.d.ts +3 -3
  33. package/card/Card.d.ts +1 -1
  34. package/card/Card.js +27 -45
  35. package/card/Card.stories.tsx +12 -42
  36. package/card/Card.test.js +1 -1
  37. package/card/types.d.ts +1 -6
  38. package/checkbox/Checkbox.d.ts +2 -2
  39. package/checkbox/Checkbox.js +94 -101
  40. package/checkbox/Checkbox.stories.tsx +131 -59
  41. package/checkbox/Checkbox.test.js +94 -17
  42. package/checkbox/types.d.ts +4 -0
  43. package/chip/Chip.js +28 -49
  44. package/chip/Chip.stories.tsx +121 -26
  45. package/chip/Chip.test.js +3 -5
  46. package/common/OpenSans.css +68 -80
  47. package/common/coreTokens.d.ts +146 -0
  48. package/common/coreTokens.js +167 -0
  49. package/common/utils.d.ts +1 -0
  50. package/common/utils.js +4 -4
  51. package/common/variables.d.ts +1482 -0
  52. package/common/variables.js +990 -1137
  53. package/date-input/Calendar.d.ts +4 -0
  54. package/date-input/Calendar.js +258 -0
  55. package/date-input/DateInput.js +134 -237
  56. package/date-input/DateInput.stories.tsx +199 -33
  57. package/date-input/DateInput.test.js +494 -138
  58. package/date-input/DatePicker.d.ts +4 -0
  59. package/date-input/DatePicker.js +146 -0
  60. package/date-input/Icons.d.ts +6 -0
  61. package/date-input/Icons.js +75 -0
  62. package/date-input/YearPicker.d.ts +4 -0
  63. package/date-input/YearPicker.js +126 -0
  64. package/date-input/types.d.ts +51 -0
  65. package/dialog/Dialog.d.ts +1 -1
  66. package/dialog/Dialog.js +54 -85
  67. package/dialog/Dialog.stories.tsx +154 -170
  68. package/dialog/Dialog.test.js +302 -3
  69. package/dialog/types.d.ts +0 -12
  70. package/dropdown/Dropdown.js +43 -42
  71. package/dropdown/Dropdown.stories.tsx +210 -84
  72. package/dropdown/Dropdown.test.js +22 -27
  73. package/dropdown/DropdownMenu.js +12 -18
  74. package/dropdown/DropdownMenuItem.js +5 -18
  75. package/dropdown/types.d.ts +3 -3
  76. package/file-input/FileInput.d.ts +2 -2
  77. package/file-input/FileInput.js +174 -220
  78. package/file-input/FileInput.stories.tsx +122 -11
  79. package/file-input/FileInput.test.js +14 -14
  80. package/file-input/FileItem.d.ts +4 -14
  81. package/file-input/FileItem.js +39 -63
  82. package/file-input/types.d.ts +17 -0
  83. package/flex/Flex.d.ts +1 -1
  84. package/flex/Flex.js +33 -19
  85. package/flex/Flex.stories.tsx +35 -26
  86. package/flex/types.d.ts +83 -7
  87. package/footer/Footer.d.ts +1 -1
  88. package/footer/Footer.js +8 -23
  89. package/footer/Footer.stories.tsx +26 -16
  90. package/footer/Footer.test.js +14 -26
  91. package/footer/types.d.ts +0 -5
  92. package/grid/Grid.d.ts +7 -0
  93. package/grid/Grid.js +91 -0
  94. package/grid/Grid.stories.tsx +219 -0
  95. package/grid/types.d.ts +115 -0
  96. package/header/Header.d.ts +4 -3
  97. package/header/Header.js +20 -49
  98. package/header/Header.stories.tsx +115 -36
  99. package/header/Header.test.js +2 -2
  100. package/header/types.d.ts +1 -14
  101. package/heading/Heading.js +1 -1
  102. package/heading/Heading.test.js +1 -1
  103. package/inset/Inset.stories.tsx +2 -1
  104. package/layout/ApplicationLayout.d.ts +5 -5
  105. package/layout/ApplicationLayout.js +1 -1
  106. package/layout/types.d.ts +2 -3
  107. package/link/Link.js +4 -4
  108. package/link/Link.stories.tsx +60 -0
  109. package/link/Link.test.js +2 -4
  110. package/link/types.d.ts +2 -2
  111. package/main.d.ts +3 -2
  112. package/main.js +9 -1
  113. package/{tabs-nav → nav-tabs}/NavTabs.d.ts +2 -2
  114. package/{tabs-nav → nav-tabs}/NavTabs.js +8 -11
  115. package/{tabs-nav → nav-tabs}/NavTabs.stories.tsx +110 -6
  116. package/{tabs-nav → nav-tabs}/NavTabs.test.js +1 -1
  117. package/{tabs-nav → nav-tabs}/Tab.js +49 -33
  118. package/{tabs-nav → nav-tabs}/types.d.ts +8 -9
  119. package/nav-tabs/types.js +5 -0
  120. package/number-input/NumberInput.test.js +44 -8
  121. package/package.json +13 -18
  122. package/paginator/Icons.d.ts +5 -0
  123. package/paginator/Icons.js +16 -28
  124. package/paginator/Paginator.js +8 -16
  125. package/paginator/Paginator.stories.tsx +24 -0
  126. package/paginator/Paginator.test.js +58 -48
  127. package/paragraph/Paragraph.d.ts +3 -4
  128. package/paragraph/Paragraph.js +5 -5
  129. package/password-input/PasswordInput.test.js +14 -13
  130. package/progress-bar/ProgressBar.d.ts +2 -2
  131. package/progress-bar/ProgressBar.js +5 -5
  132. package/progress-bar/ProgressBar.stories.jsx +35 -2
  133. package/progress-bar/ProgressBar.test.js +1 -1
  134. package/progress-bar/types.d.ts +4 -3
  135. package/quick-nav/QuickNav.js +11 -12
  136. package/quick-nav/QuickNav.stories.tsx +111 -19
  137. package/radio-group/Radio.d.ts +1 -1
  138. package/radio-group/Radio.js +46 -31
  139. package/radio-group/RadioGroup.js +23 -23
  140. package/radio-group/RadioGroup.stories.tsx +132 -18
  141. package/radio-group/RadioGroup.test.js +124 -97
  142. package/radio-group/types.d.ts +2 -2
  143. package/resultsetTable/Icons.d.ts +7 -0
  144. package/resultsetTable/Icons.js +51 -0
  145. package/resultsetTable/ResultsetTable.js +49 -108
  146. package/resultsetTable/ResultsetTable.stories.tsx +50 -25
  147. package/resultsetTable/ResultsetTable.test.js +41 -64
  148. package/resultsetTable/types.d.ts +1 -1
  149. package/select/Listbox.d.ts +1 -1
  150. package/select/Listbox.js +5 -35
  151. package/select/Option.js +11 -24
  152. package/select/Select.js +59 -36
  153. package/select/Select.stories.tsx +494 -150
  154. package/select/Select.test.js +341 -288
  155. package/select/types.d.ts +2 -2
  156. package/sidenav/Icons.d.ts +7 -0
  157. package/sidenav/Icons.js +51 -0
  158. package/sidenav/Sidenav.d.ts +2 -2
  159. package/sidenav/Sidenav.js +66 -96
  160. package/sidenav/Sidenav.stories.tsx +165 -63
  161. package/sidenav/types.d.ts +21 -18
  162. package/slider/Slider.d.ts +2 -2
  163. package/slider/Slider.js +24 -15
  164. package/slider/Slider.stories.tsx +57 -0
  165. package/slider/Slider.test.js +1 -1
  166. package/slider/types.d.ts +6 -2
  167. package/spinner/Spinner.js +17 -23
  168. package/spinner/Spinner.stories.jsx +53 -27
  169. package/spinner/Spinner.test.js +1 -1
  170. package/switch/Switch.d.ts +3 -3
  171. package/switch/Switch.js +96 -85
  172. package/switch/Switch.stories.tsx +33 -0
  173. package/switch/Switch.test.js +27 -14
  174. package/switch/types.d.ts +8 -3
  175. package/table/Table.js +3 -3
  176. package/table/Table.stories.jsx +80 -1
  177. package/table/Table.test.js +2 -2
  178. package/tabs/Tab.js +12 -15
  179. package/tabs/Tabs.js +11 -17
  180. package/tabs/Tabs.stories.tsx +45 -5
  181. package/tabs/Tabs.test.js +4 -5
  182. package/tabs/types.d.ts +2 -2
  183. package/tag/Tag.js +8 -10
  184. package/tag/Tag.stories.tsx +14 -1
  185. package/tag/Tag.test.js +1 -1
  186. package/text-input/Icons.d.ts +8 -0
  187. package/text-input/Icons.js +60 -0
  188. package/text-input/Suggestion.js +40 -11
  189. package/text-input/Suggestions.d.ts +4 -0
  190. package/text-input/Suggestions.js +134 -0
  191. package/text-input/TextInput.js +189 -277
  192. package/text-input/TextInput.stories.tsx +280 -184
  193. package/text-input/TextInput.test.js +736 -725
  194. package/text-input/types.d.ts +21 -2
  195. package/textarea/Textarea.js +3 -4
  196. package/textarea/Textarea.stories.jsx +60 -1
  197. package/textarea/Textarea.test.js +2 -4
  198. package/toggle-group/ToggleGroup.d.ts +2 -2
  199. package/toggle-group/ToggleGroup.js +7 -4
  200. package/toggle-group/ToggleGroup.stories.tsx +42 -0
  201. package/toggle-group/ToggleGroup.test.js +1 -1
  202. package/toggle-group/types.d.ts +1 -1
  203. package/typography/Typography.d.ts +2 -2
  204. package/typography/Typography.js +14 -113
  205. package/typography/Typography.stories.tsx +1 -1
  206. package/useTheme.d.ts +1234 -1
  207. package/useTheme.js +1 -1
  208. package/useTranslatedLabels.d.ts +84 -1
  209. package/utils/BaseTypography.d.ts +21 -0
  210. package/utils/BaseTypography.js +108 -0
  211. package/utils/FocusLock.d.ts +13 -0
  212. package/utils/FocusLock.js +138 -0
  213. package/wizard/Wizard.js +2 -2
  214. package/wizard/Wizard.stories.tsx +20 -0
  215. package/wizard/Wizard.test.js +1 -1
  216. package/wizard/types.d.ts +5 -6
  217. package/card/ice-cream.jpg +0 -0
  218. package/common/RequiredComponent.js +0 -32
  219. /package/{tabs-nav → grid}/types.js +0 -0
  220. /package/{tabs-nav → nav-tabs}/Tab.d.ts +0 -0
@@ -1,8 +1,11 @@
1
1
  import React from "react";
2
2
  import DxcSidenav from "./Sidenav";
3
+ import DxcSelect from "../select/Select";
4
+ import DxcInset from "../inset/Inset";
3
5
  import Title from "../../.storybook/components/Title";
4
6
  import ExampleContainer from "../../.storybook/components/ExampleContainer";
5
7
  import { userEvent, within } from "@storybook/testing-library";
8
+ import { HalstackProvider } from "../HalstackContext";
6
9
 
7
10
  export default {
8
11
  title: "Sidenav",
@@ -10,9 +13,26 @@ export default {
10
13
  };
11
14
 
12
15
  const iconSVG = (
13
- <svg viewBox="0 0 24 24" fill="currentColor">
14
- <path d="M0 0h24v24H0z" fill="none" />
15
- <path d="M12 21.35l-1.45-1.32C5.4 15.36 2 12.28 2 8.5 2 5.42 4.42 3 7.5 3c1.74 0 3.41.81 4.5 2.09C13.09 3.81 14.76 3 16.5 3 19.58 3 22 5.42 22 8.5c0 3.78-3.4 6.86-8.55 11.54L12 21.35z" />
16
+ <svg
17
+ version="1.1"
18
+ id="Capa_1"
19
+ x="0px"
20
+ y="0px"
21
+ width="438.536px"
22
+ height="438.536px"
23
+ viewBox="0 0 438.536 438.536"
24
+ fill="currentColor"
25
+ >
26
+ <g>
27
+ <path
28
+ d="M414.41,24.123C398.333,8.042,378.963,0,356.315,0H82.228C59.58,0,40.21,8.042,24.126,24.123
29
+ C8.045,40.207,0.003,59.576,0.003,82.225v274.084c0,22.647,8.042,42.018,24.123,58.102c16.084,16.084,35.454,24.126,58.102,24.126
30
+ h274.084c22.648,0,42.018-8.042,58.095-24.126c16.084-16.084,24.126-35.454,24.126-58.102V82.225
31
+ C438.532,59.576,430.49,40.204,414.41,24.123z M373.155,225.548h-49.963V406.84h-74.802V225.548H210.99V163.02h37.401v-37.402
32
+ c0-26.838,6.283-47.107,18.843-60.813c12.559-13.706,33.304-20.555,62.242-20.555h49.963v62.526h-31.401
33
+ c-10.663,0-17.467,1.853-20.417,5.568c-2.949,3.711-4.428,10.23-4.428,19.558v31.119h56.534L373.155,225.548z"
34
+ />
35
+ </g>
16
36
  </svg>
17
37
  );
18
38
 
@@ -20,11 +40,17 @@ const TitleComponent = () => {
20
40
  return <DxcSidenav.Title>Dxc technology</DxcSidenav.Title>;
21
41
  };
22
42
 
43
+ const opinionatedTheme = {
44
+ sidenav: {
45
+ baseColor: "#f2f2f2",
46
+ },
47
+ };
48
+
23
49
  export const Chromatic = () => (
24
50
  <>
25
51
  <ExampleContainer>
26
52
  <Title title="Default sidenav" theme="light" level={4} />
27
- <DxcSidenav title={<TitleComponent />}>
53
+ <DxcSidenav title={<DxcSidenav.Title>Dxc technology</DxcSidenav.Title>}>
28
54
  <DxcSidenav.Section>
29
55
  <p>
30
56
  Lorem ipsum dolor sit amet, consectetur adipiscing elit. In ullamcorper consectetur mollis. Suspendisse
@@ -41,12 +67,18 @@ export const Chromatic = () => (
41
67
  </DxcSidenav.Group>
42
68
  </DxcSidenav.Section>
43
69
  <DxcSidenav.Section>
44
- <DxcSidenav.Group collapsable={true} title="Section Group" icon={iconSVG}>
70
+ <DxcSidenav.Group
71
+ collapsable={true}
72
+ title="Section Group"
73
+ icon="https://cdn-icons-png.flaticon.com/512/5039/5039041.png"
74
+ >
45
75
  <DxcSidenav.Link selected>Group Link</DxcSidenav.Link>
46
76
  <DxcSidenav.Link icon={iconSVG}>Group Link</DxcSidenav.Link>
47
77
  </DxcSidenav.Group>
48
- <DxcSidenav.Link icon={iconSVG}>Single Link</DxcSidenav.Link>
49
- <DxcSidenav.Link>Single Link</DxcSidenav.Link>
78
+ <DxcSidenav.Link icon="https://upload.wikimedia.org/wikipedia/commons/7/73/Flat_tick_icon.svg" newWindow>
79
+ Single Link
80
+ </DxcSidenav.Link>
81
+ <DxcSidenav.Link newWindow>Single Link</DxcSidenav.Link>
50
82
  <DxcSidenav.Group collapsable={false} title="Section Group">
51
83
  <DxcSidenav.Link>Group Link</DxcSidenav.Link>
52
84
  <DxcSidenav.Link>Group Link</DxcSidenav.Link>
@@ -55,53 +87,78 @@ export const Chromatic = () => (
55
87
  </DxcSidenav.Section>
56
88
  </DxcSidenav>
57
89
  </ExampleContainer>
90
+ <ExampleContainer pseudoState="pseudo-focus">
91
+ <Title title="Focused options sidenav" theme="light" level={4} />
92
+ <DxcSidenav title={<DxcSidenav.Title>Dxc technology</DxcSidenav.Title>}>
93
+ <DxcSidenav.Section>
94
+ <p>
95
+ Lorem ipsum dolor sit amet, consectetur adipiscing elit. In ullamcorper consectetur mollis. Suspendisse
96
+ vitae lacinia libero.
97
+ </p>
98
+ </DxcSidenav.Section>
99
+ <DxcSidenav.Section>
100
+ <DxcSidenav.Link>Single Link</DxcSidenav.Link>
101
+ <DxcSidenav.Group collapsable={true} title="Collapsable Group">
102
+ <DxcSidenav.Link icon="https://cdn-icons-png.flaticon.com/512/5039/5039041.png">Group Link</DxcSidenav.Link>
103
+ </DxcSidenav.Group>
104
+ </DxcSidenav.Section>
105
+ <DxcSidenav.Section>
106
+ <DxcSidenav.Group collapsable={true} title="Collapsable Group">
107
+ <DxcSidenav.Link selected icon={iconSVG}>
108
+ Group Link
109
+ </DxcSidenav.Link>
110
+ </DxcSidenav.Group>
111
+ <DxcSidenav.Group collapsable={false} title="Section Group">
112
+ <DxcSidenav.Link>Group Link</DxcSidenav.Link>
113
+ </DxcSidenav.Group>
114
+ </DxcSidenav.Section>
115
+ </DxcSidenav>
116
+ </ExampleContainer>
117
+ <Title title="Opinionated theme" theme="light" level={2} />
118
+ <ExampleContainer>
119
+ <HalstackProvider theme={opinionatedTheme}>
120
+ <DxcSidenav title={<TitleComponent />}>
121
+ <DxcSidenav.Section>
122
+ <p>
123
+ Lorem ipsum dolor sit amet, consectetur adipiscing elit. In ullamcorper consectetur mollis. Suspendisse
124
+ vitae lacinia libero.
125
+ </p>
126
+ </DxcSidenav.Section>
127
+ <DxcSidenav.Section>
128
+ <DxcSidenav.Link>Single Link</DxcSidenav.Link>
129
+ <DxcSidenav.Group collapsable={false} title="Single Group" icon={iconSVG}>
130
+ <DxcSidenav.Link>Group Link</DxcSidenav.Link>
131
+ <DxcSidenav.Link>Group Link</DxcSidenav.Link>
132
+ <DxcSidenav.Link>Group Link</DxcSidenav.Link>
133
+ <DxcSidenav.Link>Group Link</DxcSidenav.Link>
134
+ </DxcSidenav.Group>
135
+ </DxcSidenav.Section>
136
+ <DxcSidenav.Section>
137
+ <DxcSidenav.Group collapsable={true} title="Section Group" icon={iconSVG}>
138
+ <DxcSidenav.Link selected>Group Link</DxcSidenav.Link>
139
+ <DxcSidenav.Link icon={iconSVG}>Group Link</DxcSidenav.Link>
140
+ </DxcSidenav.Group>
141
+ <DxcSidenav.Link icon={iconSVG}>Single Link</DxcSidenav.Link>
142
+ <DxcSidenav.Link>Single Link</DxcSidenav.Link>
143
+ <DxcSidenav.Group collapsable={false} title="Section Group">
144
+ <DxcSidenav.Link>Group Link</DxcSidenav.Link>
145
+ <DxcSidenav.Link>Group Link</DxcSidenav.Link>
146
+ <DxcSidenav.Link>Group Link</DxcSidenav.Link>
147
+ </DxcSidenav.Group>
148
+ </DxcSidenav.Section>
149
+ </DxcSidenav>
150
+ </HalstackProvider>
151
+ </ExampleContainer>
58
152
  </>
59
153
  );
60
154
 
61
- export const FocusedSidenav = () => (
62
- <ExampleContainer pseudoState="pseudo-focus">
63
- <Title title="Default sidenav" theme="light" level={4} />
64
- <DxcSidenav title={<TitleComponent />}>
65
- <DxcSidenav.Section>
66
- <p>
67
- Lorem ipsum dolor sit amet, consectetur adipiscing elit. In ullamcorper consectetur mollis. Suspendisse vitae
68
- lacinia libero.
69
- </p>
70
- </DxcSidenav.Section>
71
- <DxcSidenav.Section>
72
- <DxcSidenav.Link>Single Link</DxcSidenav.Link>
73
- <DxcSidenav.Link>Single Link</DxcSidenav.Link>
74
- <DxcSidenav.Group collapsable={true} title="Collapsable Group">
75
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
76
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
77
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
78
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
79
- </DxcSidenav.Group>
80
- </DxcSidenav.Section>
81
- <DxcSidenav.Section>
82
- <DxcSidenav.Group collapsable={true} title="Collapsable Group">
83
- <DxcSidenav.Link selected>Group Link</DxcSidenav.Link>
84
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
85
- </DxcSidenav.Group>
86
- <DxcSidenav.Link>Single Link</DxcSidenav.Link>
87
- <DxcSidenav.Link>Single Link</DxcSidenav.Link>
88
- <DxcSidenav.Group collapsable={false} title="Section Group">
89
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
90
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
91
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
92
- </DxcSidenav.Group>
93
- </DxcSidenav.Section>
94
- </DxcSidenav>
95
- </ExampleContainer>
96
- );
97
-
98
- const CollapsedGroup = () => (
155
+ const CollapsedGroupSidenav = () => (
99
156
  <>
100
157
  <ExampleContainer>
101
- <Title title="Default sidenav" theme="light" level={4} />
102
- <DxcSidenav title={<TitleComponent />}>
158
+ <Title title="Collapsed group with a selected link" theme="light" level={4} />
159
+ <DxcSidenav title={<DxcSidenav.Title>Dxc technology</DxcSidenav.Title>}>
103
160
  <DxcSidenav.Section>
104
- <DxcSidenav.Group collapsable={true} title="Collapsable Group" icon={iconSVG}>
161
+ <DxcSidenav.Group collapsable={true} title="Collapsed Group" icon={iconSVG}>
105
162
  <DxcSidenav.Link>Group Link</DxcSidenav.Link>
106
163
  <DxcSidenav.Link>Group Link</DxcSidenav.Link>
107
164
  <DxcSidenav.Link>Group Link</DxcSidenav.Link>
@@ -109,11 +166,11 @@ const CollapsedGroup = () => (
109
166
  </DxcSidenav.Group>
110
167
  </DxcSidenav.Section>
111
168
  <DxcSidenav.Section>
112
- <DxcSidenav.Group collapsable={true} title="Collapsable Group">
113
- <DxcSidenav.Link selected>Group Link</DxcSidenav.Link>
169
+ <DxcSidenav.Group collapsable={true} title="Collapsed Group">
114
170
  <DxcSidenav.Link>Group Link</DxcSidenav.Link>
171
+ <DxcSidenav.Link selected>Group Link</DxcSidenav.Link>
115
172
  </DxcSidenav.Group>
116
- <DxcSidenav.Group collapsable={false} title="Section Group">
173
+ <DxcSidenav.Group collapsable={true} title="Section Group">
117
174
  <DxcSidenav.Link>Group Link</DxcSidenav.Link>
118
175
  <DxcSidenav.Link>Group Link</DxcSidenav.Link>
119
176
  <DxcSidenav.Link>Group Link</DxcSidenav.Link>
@@ -124,14 +181,14 @@ const CollapsedGroup = () => (
124
181
  </>
125
182
  );
126
183
 
127
- const HoverSidenav = () => (
184
+ const HoveredGroupSidenav = () => (
128
185
  <ExampleContainer pseudoState="pseudo-hover">
129
- <Title title="Default sidenav" theme="light" level={4} />
130
- <DxcSidenav title={<TitleComponent />}>
186
+ <Title title="Hover state for groups (selected and not)" theme="light" level={4} />
187
+ <DxcSidenav title={<DxcSidenav.Title>Dxc technology</DxcSidenav.Title>}>
131
188
  <DxcSidenav.Section>
132
189
  <DxcSidenav.Link>Single Link</DxcSidenav.Link>
133
190
  <DxcSidenav.Link>Single Link</DxcSidenav.Link>
134
- <DxcSidenav.Group collapsable={true} title="Collapsable Group">
191
+ <DxcSidenav.Group collapsable={true} title="Collapsed Group">
135
192
  <DxcSidenav.Link selected>Group Link</DxcSidenav.Link>
136
193
  <DxcSidenav.Link>Group Link</DxcSidenav.Link>
137
194
  <DxcSidenav.Link>Group Link</DxcSidenav.Link>
@@ -145,36 +202,81 @@ const HoverSidenav = () => (
145
202
  </DxcSidenav.Group>
146
203
  <DxcSidenav.Link>Single Link</DxcSidenav.Link>
147
204
  <DxcSidenav.Link>Single Link</DxcSidenav.Link>
148
- <DxcSidenav.Group collapsable={true} title="Collapsable Group">
205
+ <DxcSidenav.Group collapsable={true} title="Collapsed Group">
149
206
  <DxcSidenav.Link>Group Link</DxcSidenav.Link>
150
207
  <DxcSidenav.Link>Group Link</DxcSidenav.Link>
151
208
  <DxcSidenav.Link>Group Link</DxcSidenav.Link>
152
209
  </DxcSidenav.Group>
210
+ <DxcSidenav.Group collapsable={true} title="Collapsed Group">
211
+ <DxcSidenav.Link>Group Link</DxcSidenav.Link>
212
+ <DxcSidenav.Link>Group Link</DxcSidenav.Link>
213
+ <DxcSidenav.Link>Group Link</DxcSidenav.Link>
214
+ </DxcSidenav.Group>
215
+ </DxcSidenav.Section>
216
+ </DxcSidenav>
217
+ </ExampleContainer>
218
+ );
153
219
 
154
- <DxcSidenav.Group collapsable={true} title="Collapsable Group">
220
+ const ActiveGroupSidenav = () => (
221
+ <ExampleContainer pseudoState="pseudo-active">
222
+ <Title title="Active state for groups (selected and not)" theme="light" level={4} />
223
+ <DxcSidenav title={<DxcSidenav.Title>Dxc technology</DxcSidenav.Title>}>
224
+ <DxcSidenav.Section>
225
+ <DxcInset space="1rem">
226
+ <DxcSelect
227
+ defaultValue="1"
228
+ options={[
229
+ { label: "v1.0.0", value: "1" },
230
+ { label: "v2.0.0", value: "2" },
231
+ { label: "v3.0.0", value: "3" },
232
+ { label: "v4.0.0", value: "4" },
233
+ ]}
234
+ size="fillParent"
235
+ />
236
+ </DxcInset>
237
+ </DxcSidenav.Section>
238
+ <DxcSidenav.Section>
239
+ <DxcSidenav.Group collapsable={true} title="Collapsed Group">
240
+ <DxcSidenav.Link selected>Group Link</DxcSidenav.Link>
155
241
  <DxcSidenav.Link>Group Link</DxcSidenav.Link>
156
242
  <DxcSidenav.Link>Group Link</DxcSidenav.Link>
157
243
  <DxcSidenav.Link>Group Link</DxcSidenav.Link>
158
244
  </DxcSidenav.Group>
159
245
  </DxcSidenav.Section>
246
+ <DxcSidenav.Section>
247
+ <DxcSidenav.Group collapsable={true} title="Not Collapsed Group">
248
+ <DxcSidenav.Link selected>Group Link</DxcSidenav.Link>
249
+ <DxcSidenav.Link>Group Link</DxcSidenav.Link>
250
+ </DxcSidenav.Group>
251
+ <DxcSidenav.Link>Single Link</DxcSidenav.Link>
252
+ <DxcSidenav.Link>Single Link</DxcSidenav.Link>
253
+ </DxcSidenav.Section>
160
254
  </DxcSidenav>
161
255
  </ExampleContainer>
162
256
  );
163
257
 
164
- export const CollapseGroup = CollapsedGroup.bind({});
165
- CollapseGroup.play = async ({ canvasElement }) => {
258
+ export const CollapsableGroup = CollapsedGroupSidenav.bind({});
259
+ CollapsableGroup.play = async ({ canvasElement }) => {
166
260
  const canvas = within(canvasElement);
167
- const collapsableGroups = canvas.getAllByText("Collapsable Group");
261
+ const collapsableGroups = canvas.getAllByText("Collapsed Group");
168
262
  collapsableGroups.forEach((group) => {
169
263
  userEvent.click(group);
170
264
  });
171
265
  };
172
266
 
173
- export const CollapseHoverGroup = HoverSidenav.bind({});
174
- CollapseHoverGroup.play = async ({ canvasElement }) => {
267
+ export const CollapsedHoverGroup = HoveredGroupSidenav.bind({});
268
+ CollapsedHoverGroup.play = async ({ canvasElement }) => {
175
269
  const canvas = within(canvasElement);
176
- const collapsableGroups = canvas.getAllByText("Collapsable Group");
270
+ const collapsableGroups = canvas.getAllByText("Collapsed Group");
177
271
  collapsableGroups.forEach((group) => {
178
272
  userEvent.click(group);
179
273
  });
274
+ await new Promise((resolve) => setTimeout(resolve, 1000));
180
275
  };
276
+
277
+ export const CollapsedActiveGroup = ActiveGroupSidenav.bind({});
278
+ CollapsedActiveGroup.play = async ({ canvasElement }) => {
279
+ const canvas = within(canvasElement);
280
+ const collapsableGroups = canvas.getAllByText("Collapsed Group");
281
+ userEvent.click(collapsableGroups[0]);
282
+ };
@@ -1,14 +1,14 @@
1
1
  /// <reference types="react" />
2
2
  declare type SVG = React.ReactNode & React.SVGProps<SVGSVGElement>;
3
3
  declare type SidenavPropsType = {
4
- /**
5
- * The area inside the sidenav. This area can be used to render the content inside the sidenav.
6
- */
7
- children: React.ReactNode;
8
4
  /**
9
5
  * The area assigned to render the sidenav title. It is highly recommended to use the sidenav title.
10
6
  */
11
7
  title?: React.ReactNode;
8
+ /**
9
+ * The area inside the sidenav. This area can be used to render the content inside the sidenav.
10
+ */
11
+ children: React.ReactNode;
12
12
  };
13
13
  export declare type SidenavTitlePropsType = {
14
14
  /**
@@ -23,28 +23,25 @@ export declare type SidenavSectionPropsType = {
23
23
  children: React.ReactNode;
24
24
  };
25
25
  export declare type SidenavGroupPropsType = {
26
- /**
27
- * The area inside the sidenav group. This area can be used to render sidenav links.
28
- */
29
- children: React.ReactNode;
30
26
  /**
31
27
  * The title of the sidenav group.
32
28
  */
33
29
  title?: string;
34
30
  /**
35
- * If true the sidenav group title will be considered a button and the group will be collapsable.
31
+ * If true, the sidenav group will be a button that will allow you to collapse the links contained within it.
32
+ * In addition, if it's collapsed and contains the currently selected link, the group title will also be marked as selected.
36
33
  */
37
34
  collapsable?: boolean;
38
35
  /**
39
36
  * The icon to be displayed next to the title of the group.
40
37
  */
41
38
  icon?: string | SVG;
42
- };
43
- export declare type SidenavLinkPropsType = {
44
39
  /**
45
- * Value of the tabindex.
40
+ * The area inside the sidenav group. This area can be used to render sidenav links.
46
41
  */
47
- tabIndex?: number;
42
+ children: React.ReactNode;
43
+ };
44
+ export declare type SidenavLinkPropsType = {
48
45
  /**
49
46
  * Page to be opened when the user clicks on the link.
50
47
  */
@@ -58,16 +55,22 @@ export declare type SidenavLinkPropsType = {
58
55
  */
59
56
  icon?: string | SVG;
60
57
  /**
61
- * If true, the link will be marked as selected. This can also affect the group if it is closed to indicate that one of its links is selected.
58
+ * If true, the link will be marked as selected. Moreover, in that same case,
59
+ * if it is contained within a collapsed group, and consequently, the currently selected link is not visible,
60
+ * the group title will appear as selected too.
62
61
  */
63
62
  selected?: boolean;
64
63
  /**
65
- * The area inside the sidenav link.
64
+ * This function will be called when the user clicks the link and the event will be passed to this function.
66
65
  */
67
- children: string;
66
+ onClick?: ($event: React.MouseEvent<HTMLAnchorElement>) => void;
68
67
  /**
69
- * This function will be called when the user clicks the link.
68
+ * Value of the tabindex.
69
+ */
70
+ tabIndex?: number;
71
+ /**
72
+ * The area inside the sidenav link.
70
73
  */
71
- onClick?: ($event: any) => void;
74
+ children: React.ReactNode;
72
75
  };
73
76
  export default SidenavPropsType;
@@ -1,4 +1,4 @@
1
- /// <reference types="react" />
1
+ import React from "react";
2
2
  import SliderPropsType from "./types";
3
- declare const DxcSlider: ({ label, name, defaultValue, value, helperText, minValue, maxValue, step, showLimitsValues, showInput, disabled, marks, onChange, onDragEnd, labelFormatCallback, margin, size, }: SliderPropsType) => JSX.Element;
3
+ declare const DxcSlider: React.ForwardRefExoticComponent<SliderPropsType & React.RefAttributes<HTMLDivElement>>;
4
4
  export default DxcSlider;
package/slider/Slider.js CHANGED
@@ -21,21 +21,23 @@ var _styledComponents = _interopRequireWildcard(require("styled-components"));
21
21
 
22
22
  var _TextInput = _interopRequireDefault(require("../text-input/TextInput"));
23
23
 
24
- var _variables = require("../common/variables.js");
24
+ var _variables = require("../common/variables");
25
25
 
26
- var _utils = require("../common/utils.js");
26
+ var _utils = require("../common/utils");
27
27
 
28
28
  var _useTheme = _interopRequireDefault(require("../useTheme"));
29
29
 
30
30
  var _BackgroundColorContext = _interopRequireDefault(require("../BackgroundColorContext"));
31
31
 
32
+ var _uuid = require("uuid");
33
+
32
34
  var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8, _templateObject9, _templateObject10, _templateObject11, _templateObject12;
33
35
 
34
36
  function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
35
37
 
36
38
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof3(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
37
39
 
38
- var DxcSlider = function DxcSlider(_ref) {
40
+ var DxcSlider = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
39
41
  var _ref$label = _ref.label,
40
42
  label = _ref$label === void 0 ? "" : _ref$label,
41
43
  _ref$name = _ref.name,
@@ -77,7 +79,11 @@ var DxcSlider = function DxcSlider(_ref) {
77
79
 
78
80
  var colorsTheme = (0, _useTheme["default"])();
79
81
  var backgroundType = (0, _react.useContext)(_BackgroundColorContext["default"]);
80
- var labelId = "slider" + (0, _react.useId)();
82
+
83
+ var _useState5 = (0, _react.useState)("label-".concat((0, _uuid.v4)())),
84
+ _useState6 = (0, _slicedToArray2["default"])(_useState5, 1),
85
+ labelId = _useState6[0];
86
+
81
87
  var minLabel = (0, _react.useMemo)(function () {
82
88
  return labelFormatCallback ? labelFormatCallback(minValue) : minValue;
83
89
  }, [labelFormatCallback, minValue]);
@@ -94,8 +100,9 @@ var DxcSlider = function DxcSlider(_ref) {
94
100
  while (index <= numberOfMarks) {
95
101
  ticks.push( /*#__PURE__*/_react["default"].createElement(TickMark, {
96
102
  disabled: disabled,
97
- stepPosition: step * index / range * 100,
98
- backgroundType: backgroundType
103
+ stepPosition: step * index / range,
104
+ backgroundType: backgroundType,
105
+ stepValue: (value !== null && value !== void 0 ? value : innerValue) / maxValue
99
106
  }));
100
107
  index++;
101
108
  }
@@ -104,7 +111,7 @@ var DxcSlider = function DxcSlider(_ref) {
104
111
  } else {
105
112
  return null;
106
113
  }
107
- }, [minValue, maxValue, step]);
114
+ }, [minValue, maxValue, step, value, innerValue]);
108
115
 
109
116
  var handleSliderChange = function handleSliderChange(event) {
110
117
  var valueToCheck = event.target.value;
@@ -140,7 +147,8 @@ var DxcSlider = function DxcSlider(_ref) {
140
147
  theme: colorsTheme.slider
141
148
  }, /*#__PURE__*/_react["default"].createElement(Container, {
142
149
  margin: margin,
143
- size: size
150
+ size: size,
151
+ ref: ref
144
152
  }, /*#__PURE__*/_react["default"].createElement(Label, {
145
153
  id: labelId,
146
154
  disabled: disabled,
@@ -158,7 +166,6 @@ var DxcSlider = function DxcSlider(_ref) {
158
166
  min: minValue,
159
167
  max: maxValue,
160
168
  step: step,
161
- marks: marks,
162
169
  disabled: disabled,
163
170
  "aria-labelledby": labelId,
164
171
  "aria-orientation": "horizontal",
@@ -182,7 +189,7 @@ var DxcSlider = function DxcSlider(_ref) {
182
189
  onChange: handlerInputChange,
183
190
  size: "fillParent"
184
191
  })))));
185
- };
192
+ });
186
193
 
187
194
  var sizes = {
188
195
  medium: "360px",
@@ -244,10 +251,10 @@ var HelperText = _styledComponents["default"].span(_templateObject3 || (_templat
244
251
  return props.theme.helperTextLineHeight;
245
252
  });
246
253
 
247
- var SliderInput = _styledComponents["default"].input(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n width: 100%;\n min-width: 240px;\n height: ", ";\n display: inline-block;\n vertical-align: middle;\n -webkit-appearance: none;\n background-color: ", ";\n background-image: ", ";\n background-repeat: no-repeat;\n background-size: ", ";\n border-radius: 5px;\n z-index: 1;\n cursor: ", ";\n &::-webkit-slider-runnable-track {\n -webkit-appearance: none;\n box-shadow: none;\n border: none;\n background: transparent;\n margin: 0px -8px;\n }\n\n &::-webkit-slider-thumb {\n -webkit-appearance: none;\n border: none;\n height: ", ";\n width: ", ";\n border-radius: 25px;\n background: ", ";\n &:active {\n ", "\n }\n &:hover {\n ", "\n }\n }\n &::-moz-range-track {\n -webkit-appearance: none;\n box-shadow: none;\n border: none;\n background: transparent;\n }\n &::-moz-range-thumb {\n -webkit-appearance: none;\n border: none;\n height: ", ";\n width: ", ";\n border-radius: 25px;\n background: ", ";\n &:active {\n background: ", ";\n transform: scale(1.16667);\n }\n &:hover {\n ", "\n }\n }\n &:focus {\n outline: none;\n &::-webkit-slider-thumb {\n outline: ", "\n auto 1px;\n outline-offset: 2px;\n }\n &::-moz-range-thumb {\n outline: ", "\n auto 1px;\n outline-offset: 2px;\n }\n }\n"])), function (props) {
254
+ var SliderInput = _styledComponents["default"].input(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n width: 100%;\n min-width: 240px;\n height: ", ";\n display: inline-block;\n vertical-align: middle;\n -webkit-appearance: none;\n background-color: ", ";\n background-image: ", ";\n background-repeat: no-repeat;\n background-size: ", ";\n border-radius: 5px;\n cursor: ", ";\n &::-webkit-slider-runnable-track {\n -webkit-appearance: none;\n box-shadow: none;\n border: none;\n background: transparent;\n margin: 0px -8px;\n }\n\n &::-webkit-slider-thumb {\n -webkit-appearance: none;\n border: none;\n height: ", ";\n width: ", ";\n border-radius: 25px;\n background: ", ";\n &:active {\n ", "\n }\n &:hover {\n ", "\n }\n }\n &::-moz-range-track {\n -webkit-appearance: none;\n box-shadow: none;\n border: none;\n background: transparent;\n }\n &::-moz-range-thumb {\n -webkit-appearance: none;\n border: none;\n height: ", ";\n width: ", ";\n border-radius: 25px;\n background: ", ";\n &:active {\n background: ", ";\n transform: scale(1.16667);\n }\n &:hover {\n ", "\n }\n }\n &:focus {\n outline: none;\n &::-webkit-slider-thumb {\n outline: ", "\n auto 1px;\n outline-offset: 2px;\n }\n &::-moz-range-thumb {\n outline: ", "\n auto 1px;\n outline-offset: 2px;\n }\n }\n"])), function (props) {
248
255
  return props.theme.trackLineThickness;
249
256
  }, function (props) {
250
- return props.disabled ? props.backgroundType === "dark" ? props.theme.disabledTotalLineColorOnDark + "61" : props.theme.disabledTotalLineColor + "61" : props.backgroundType === "dark" ? props.theme.totalLineColorOnDark + "61" : props.theme.totalLineColor + "61";
257
+ return props.disabled ? props.backgroundType === "dark" ? props.theme.disabledTotalLineColorOnDark + "61" : props.theme.disabledTotalLineColor + "61" : props.backgroundType === "dark" ? props.theme.totalLineColorOnDark + "61" : props.theme.totalLineColor;
251
258
  }, function (props) {
252
259
  return props.disabled ? props.backgroundType === "dark" ? "linear-gradient(".concat(props.theme.disabledTrackLineColorOnDark, ", ").concat(props.theme.disabledTrackLineColorOnDark, ")") : "linear-gradient(".concat(props.theme.disabledTrackLineColor, ", ").concat(props.theme.disabledTrackLineColor, ")") : props.backgroundType === "dark" ? "linear-gradient(".concat(props.theme.trackLineColorOnDark, ", ").concat(props.theme.trackLineColorOnDark, ")") : "linear-gradient(".concat(props.theme.trackLineColor, ", ").concat(props.theme.trackLineColor, ")");
253
260
  }, function (props) {
@@ -309,20 +316,22 @@ var MaxLabelContainer = (0, _styledComponents["default"])(LimitLabelContainer)(_
309
316
  return props.step === 1 ? props.theme.ceilLabelMarginLeft : "1.25rem";
310
317
  });
311
318
 
312
- var SliderInputContainer = _styledComponents["default"].div(_templateObject9 || (_templateObject9 = (0, _taggedTemplateLiteral2["default"])(["\n position: relative;\n width: 100%;\n height: 24px;\n display: flex;\n align-items: center;\n justify-content: center;\n margin-right: -2px;\n padding-top: 1px;\n"])));
319
+ var SliderInputContainer = _styledComponents["default"].div(_templateObject9 || (_templateObject9 = (0, _taggedTemplateLiteral2["default"])(["\n position: relative;\n width: 100%;\n height: 24px;\n display: flex;\n align-items: center;\n justify-content: center;\n margin-right: -2px;\n padding-top: 1px;\n z-index: 0;\n"])));
313
320
 
314
321
  var MarksContainer = _styledComponents["default"].div(_templateObject10 || (_templateObject10 = (0, _taggedTemplateLiteral2["default"])(["\n ", "\n position: absolute;\n pointer-events: none;\n height: 100%;\n display: flex;\n align-items: center;\n"])), function (props) {
315
322
  return props.isFirefox ? getFireFoxStyles() : getChromeStyles();
316
323
  });
317
324
 
318
- var TickMark = _styledComponents["default"].span(_templateObject11 || (_templateObject11 = (0, _taggedTemplateLiteral2["default"])(["\n position: absolute;\n background: ", ";\n height: ", ";\n width: ", ";\n border-radius: 18px;\n left: ", ";\n"])), function (props) {
325
+ var TickMark = _styledComponents["default"].span(_templateObject11 || (_templateObject11 = (0, _taggedTemplateLiteral2["default"])(["\n position: absolute;\n background: ", ";\n height: ", ";\n width: ", ";\n border-radius: 18px;\n left: ", ";\n z-index: ", ";\n"])), function (props) {
319
326
  return props.disabled ? props.backgroundType === "dark" ? props.theme.disabledTickBackgroundColorOnDark : props.theme.disabledTickBackgroundColor : props.backgroundType === "dark" ? props.theme.tickBackgroundColorOnDark : props.theme.tickBackgroundColor;
320
327
  }, function (props) {
321
328
  return props.theme.tickHeight;
322
329
  }, function (props) {
323
330
  return props.theme.tickWidth;
324
331
  }, function (props) {
325
- return "".concat(props.stepPosition, "%");
332
+ return "calc(".concat(props.stepPosition, " * 100%)");
333
+ }, function (props) {
334
+ return "".concat(props.stepPosition <= props.stepValue ? "-1" : "0");
326
335
  });
327
336
 
328
337
  var StyledTextInput = _styledComponents["default"].div(_templateObject12 || (_templateObject12 = (0, _taggedTemplateLiteral2["default"])(["\n margin-left: ", ";\n max-width: 70px;\n"])), function (props) {
@@ -4,6 +4,7 @@ import { BackgroundColorProvider } from "../BackgroundColorContext";
4
4
  import Title from "../../.storybook/components/Title";
5
5
  import ExampleContainer from "../../.storybook/components/ExampleContainer";
6
6
  import DarkContainer from "../../.storybook/components/DarkSection";
7
+ import { HalstackProvider } from "../HalstackContext";
7
8
 
8
9
  export default {
9
10
  title: "Slider",
@@ -12,6 +13,14 @@ export default {
12
13
 
13
14
  const labelFormat = (value) => `${value}E100000000000000000000000`;
14
15
 
16
+ const opinionatedTheme = {
17
+ slider: {
18
+ baseColor: "#0067b3",
19
+ fontColor: "#000000",
20
+ totalLineColor: "#e6e6e6",
21
+ },
22
+ };
23
+
15
24
  export const Chromatic = () => (
16
25
  <>
17
26
  <Title title="States" theme="light" level={2} />
@@ -179,5 +188,53 @@ export const Chromatic = () => (
179
188
  size="large"
180
189
  />
181
190
  </ExampleContainer>
191
+ <Title title="Opinionated theme" theme="light" level={2} />
192
+ <ExampleContainer pseudoState="pseudo-hover">
193
+ <Title title="Hovered" theme="light" level={4} />
194
+ <HalstackProvider theme={opinionatedTheme}>
195
+ <DxcSlider label="Slider" helperText="Help message" showLimitsValues />
196
+ </HalstackProvider>
197
+ </ExampleContainer>
198
+ <ExampleContainer pseudoState="pseudo-active">
199
+ <Title title="Active" theme="light" level={4} />
200
+ <HalstackProvider theme={opinionatedTheme}>
201
+ <DxcSlider label="Slider" helperText="Help message" showLimitsValues />
202
+ </HalstackProvider>
203
+ </ExampleContainer>
204
+ <ExampleContainer pseudoState="pseudo-focus">
205
+ <Title title="Focused" theme="light" level={4} />
206
+ <HalstackProvider theme={opinionatedTheme}>
207
+ <DxcSlider label="Slider" helperText="Help message" showLimitsValues />
208
+ </HalstackProvider>
209
+ </ExampleContainer>
210
+ <ExampleContainer>
211
+ <Title title="Disabled discrete slider with input" theme="light" level={4} />{" "}
212
+ <HalstackProvider theme={opinionatedTheme}>
213
+ <DxcSlider
214
+ label="Slider"
215
+ helperText="Help message"
216
+ disabled
217
+ defaultValue={40}
218
+ minValue={0}
219
+ maxValue={50}
220
+ showLimitsValues
221
+ showInput
222
+ marks
223
+ step={10}
224
+ />
225
+ </HalstackProvider>
226
+ </ExampleContainer>
227
+ <ExampleContainer>
228
+ <Title title="Continuous slider" theme="light" level={4} />
229
+ <HalstackProvider theme={opinionatedTheme}>
230
+ <DxcSlider defaultValue={65} label="Slider" helperText="Help message" showLimitsValues />
231
+ </HalstackProvider>
232
+ </ExampleContainer>
233
+ <ExampleContainer>
234
+ <Title title="Discrete slider" theme="light" level={4} />
235
+ <HalstackProvider theme={opinionatedTheme}>
236
+ <DxcSlider defaultValue={20} label="Slider" helperText="Help message" showLimitsValues marks step={5} />
237
+ </HalstackProvider>
238
+ </ExampleContainer>
182
239
  </>
183
240
  );
@@ -8,7 +8,7 @@ var _react2 = require("@testing-library/react");
8
8
 
9
9
  var _userEvent = _interopRequireDefault(require("@testing-library/user-event"));
10
10
 
11
- var _Slider = _interopRequireDefault(require("./Slider"));
11
+ var _Slider = _interopRequireDefault(require("./Slider.tsx"));
12
12
 
13
13
  describe("Slider component tests", function () {
14
14
  test("Slider renders with correct text and label id", function () {
package/slider/types.d.ts CHANGED
@@ -1,5 +1,5 @@
1
- export declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
2
- export declare type Margin = {
1
+ declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
2
+ declare type Margin = {
3
3
  top?: Space;
4
4
  bottom?: Space;
5
5
  left?: Space;
@@ -79,4 +79,8 @@ declare type Props = {
79
79
  */
80
80
  size?: "medium" | "large" | "fillParent";
81
81
  };
82
+ /**
83
+ * Reference to the component.
84
+ */
85
+ export declare type RefType = HTMLDivElement;
82
86
  export default Props;