@dxc-technology/halstack-react 0.0.0-fdc49d2 → 0.0.0-feed711
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.
- package/HalstackContext.d.ts +12 -0
- package/HalstackContext.js +295 -0
- package/accordion/Accordion.js +5 -27
- package/accordion/Accordion.stories.tsx +4 -4
- package/accordion/types.d.ts +1 -1
- package/accordion-group/AccordionGroup.d.ts +1 -1
- package/accordion-group/AccordionGroup.js +14 -15
- package/accordion-group/AccordionGroup.stories.tsx +1 -1
- package/accordion-group/AccordionGroup.test.js +24 -6
- package/accordion-group/types.d.ts +5 -1
- package/alert/Alert.js +4 -1
- package/badge/Badge.d.ts +1 -1
- package/badge/Badge.js +5 -3
- package/badge/types.d.ts +1 -0
- package/bleed/Bleed.js +1 -34
- package/bleed/Bleed.stories.tsx +94 -95
- package/bleed/types.d.ts +1 -1
- package/box/Box.js +22 -32
- package/bulleted-list/BulletedList.d.ts +7 -0
- package/bulleted-list/BulletedList.js +123 -0
- package/bulleted-list/BulletedList.stories.tsx +200 -0
- package/bulleted-list/types.d.ts +11 -0
- package/{list → bulleted-list}/types.js +0 -0
- package/button/Button.js +53 -68
- package/button/Button.stories.tsx +9 -0
- package/button/types.d.ts +7 -7
- package/card/Card.js +24 -27
- package/checkbox/Checkbox.d.ts +1 -1
- package/checkbox/Checkbox.js +38 -28
- package/checkbox/Checkbox.stories.tsx +124 -128
- package/checkbox/types.d.ts +3 -3
- package/chip/types.d.ts +1 -1
- package/common/variables.js +229 -98
- package/date-input/DateInput.js +41 -23
- package/date-input/DateInput.test.js +9 -22
- package/date-input/types.d.ts +12 -9
- package/dialog/Dialog.js +46 -50
- package/dialog/Dialog.stories.tsx +1 -2
- package/dialog/Dialog.test.js +34 -4
- package/dialog/types.d.ts +2 -2
- package/dropdown/Dropdown.d.ts +1 -1
- package/dropdown/Dropdown.js +242 -250
- package/dropdown/Dropdown.stories.tsx +126 -63
- package/dropdown/Dropdown.test.js +510 -108
- package/dropdown/DropdownMenu.d.ts +4 -0
- package/dropdown/DropdownMenu.js +80 -0
- package/dropdown/DropdownMenuItem.d.ts +4 -0
- package/dropdown/DropdownMenuItem.js +92 -0
- package/dropdown/types.d.ts +25 -5
- package/file-input/FileInput.js +9 -6
- package/file-input/FileItem.js +7 -5
- package/flex/Flex.d.ts +4 -0
- package/flex/Flex.js +57 -0
- package/flex/Flex.stories.tsx +103 -0
- package/flex/types.d.ts +21 -0
- package/{radio → flex}/types.js +0 -0
- package/footer/Footer.js +15 -88
- package/footer/Icons.js +1 -1
- package/footer/types.d.ts +1 -1
- package/header/Header.js +95 -114
- package/header/Header.stories.tsx +46 -36
- package/header/Header.test.js +18 -2
- package/header/Icons.js +2 -2
- package/header/types.d.ts +2 -2
- package/inset/Inset.js +1 -34
- package/inset/Inset.stories.tsx +36 -36
- package/inset/types.d.ts +25 -1
- package/layout/ApplicationLayout.d.ts +16 -6
- package/layout/ApplicationLayout.js +71 -131
- package/layout/ApplicationLayout.stories.tsx +83 -93
- package/layout/Icons.d.ts +5 -0
- package/layout/Icons.js +13 -2
- package/layout/SidenavContext.d.ts +5 -0
- package/layout/SidenavContext.js +19 -0
- package/layout/types.d.ts +18 -33
- package/link/Link.d.ts +3 -2
- package/link/Link.js +57 -74
- package/link/Link.stories.tsx +95 -53
- package/link/Link.test.js +7 -15
- package/link/types.d.ts +7 -23
- package/main.d.ts +7 -10
- package/main.js +43 -61
- package/number-input/NumberInput.test.js +2 -4
- package/number-input/types.d.ts +13 -10
- package/package.json +14 -12
- package/paginator/Paginator.js +17 -38
- package/paginator/Paginator.test.js +42 -0
- package/paragraph/Paragraph.d.ts +6 -0
- package/paragraph/Paragraph.js +38 -0
- package/paragraph/Paragraph.stories.tsx +44 -0
- package/password-input/PasswordInput.js +7 -4
- package/password-input/PasswordInput.test.js +3 -6
- package/password-input/types.d.ts +14 -11
- package/progress-bar/ProgressBar.d.ts +2 -2
- package/progress-bar/ProgressBar.js +57 -51
- package/progress-bar/ProgressBar.stories.jsx +13 -11
- package/progress-bar/ProgressBar.test.js +67 -22
- package/progress-bar/types.d.ts +3 -4
- package/quick-nav/QuickNav.js +83 -25
- package/quick-nav/QuickNav.stories.tsx +43 -16
- package/quick-nav/types.d.ts +4 -8
- package/radio-group/Radio.js +1 -1
- package/radio-group/RadioGroup.js +21 -20
- package/resultsetTable/ResultsetTable.test.js +42 -0
- package/select/Listbox.d.ts +4 -0
- package/select/Listbox.js +199 -0
- package/select/Option.js +1 -1
- package/select/Select.js +102 -199
- package/select/Select.stories.tsx +145 -100
- package/select/Select.test.js +440 -281
- package/select/types.d.ts +31 -12
- package/sidenav/Sidenav.d.ts +6 -5
- package/sidenav/Sidenav.js +184 -52
- package/sidenav/Sidenav.stories.tsx +154 -156
- package/sidenav/Sidenav.test.js +25 -37
- package/sidenav/types.d.ts +50 -27
- package/slider/Slider.d.ts +1 -1
- package/slider/Slider.js +5 -4
- package/slider/Slider.stories.tsx +8 -8
- package/slider/Slider.test.js +68 -10
- package/slider/types.d.ts +4 -0
- package/spinner/Spinner.js +1 -1
- package/switch/Switch.d.ts +2 -2
- package/switch/Switch.js +113 -54
- package/switch/Switch.stories.tsx +16 -38
- package/switch/Switch.test.js +122 -8
- package/switch/types.d.ts +5 -6
- package/tabs/Tabs.d.ts +1 -1
- package/tabs/Tabs.js +9 -11
- package/tabs/Tabs.stories.tsx +0 -8
- package/tabs/Tabs.test.js +26 -9
- package/tabs/types.d.ts +5 -1
- package/tabs-nav/NavTabs.d.ts +8 -0
- package/tabs-nav/NavTabs.js +125 -0
- package/tabs-nav/NavTabs.stories.tsx +170 -0
- package/tabs-nav/NavTabs.test.js +82 -0
- package/tabs-nav/Tab.d.ts +4 -0
- package/tabs-nav/Tab.js +130 -0
- package/tabs-nav/types.d.ts +53 -0
- package/{row → tabs-nav}/types.js +0 -0
- package/tag/Tag.js +5 -8
- package/tag/types.d.ts +1 -1
- package/text-input/Suggestion.d.ts +4 -0
- package/text-input/Suggestion.js +55 -0
- package/text-input/TextInput.js +60 -97
- package/text-input/TextInput.stories.tsx +1 -2
- package/text-input/TextInput.test.js +22 -35
- package/text-input/types.d.ts +27 -12
- package/textarea/Textarea.js +10 -19
- package/textarea/types.d.ts +10 -7
- package/toggle-group/ToggleGroup.d.ts +1 -1
- package/toggle-group/ToggleGroup.js +5 -4
- package/toggle-group/ToggleGroup.stories.tsx +4 -4
- package/toggle-group/ToggleGroup.test.js +35 -4
- package/toggle-group/types.d.ts +9 -1
- package/typography/Typography.d.ts +4 -0
- package/typography/Typography.js +131 -0
- package/typography/Typography.stories.tsx +198 -0
- package/typography/types.d.ts +18 -0
- package/{stack → typography}/types.js +0 -0
- package/useTheme.js +2 -2
- package/useTranslatedLabels.d.ts +2 -0
- package/useTranslatedLabels.js +20 -0
- package/wizard/Wizard.js +43 -44
- package/wizard/Wizard.stories.tsx +20 -1
- package/wizard/types.d.ts +5 -4
- package/ThemeContext.d.ts +0 -10
- package/ThemeContext.js +0 -243
- package/list/List.d.ts +0 -4
- package/list/List.js +0 -47
- package/list/List.stories.tsx +0 -95
- package/list/types.d.ts +0 -7
- package/radio/Radio.d.ts +0 -4
- package/radio/Radio.js +0 -174
- package/radio/Radio.stories.tsx +0 -192
- package/radio/Radio.test.js +0 -71
- package/radio/types.d.ts +0 -54
- package/row/Row.d.ts +0 -3
- package/row/Row.js +0 -127
- package/row/Row.stories.tsx +0 -237
- package/row/types.d.ts +0 -28
- package/stack/Stack.d.ts +0 -3
- package/stack/Stack.js +0 -97
- package/stack/Stack.stories.tsx +0 -164
- package/stack/types.d.ts +0 -24
- package/text/Text.d.ts +0 -7
- package/text/Text.js +0 -30
- package/text/Text.stories.tsx +0 -19
|
@@ -1,182 +1,180 @@
|
|
|
1
1
|
import React from "react";
|
|
2
|
-
import styled from "styled-components";
|
|
3
2
|
import DxcSidenav from "./Sidenav";
|
|
4
3
|
import Title from "../../.storybook/components/Title";
|
|
5
4
|
import ExampleContainer from "../../.storybook/components/ExampleContainer";
|
|
5
|
+
import { userEvent, within } from "@storybook/testing-library";
|
|
6
6
|
|
|
7
7
|
export default {
|
|
8
8
|
title: "Sidenav",
|
|
9
9
|
component: DxcSidenav,
|
|
10
10
|
};
|
|
11
11
|
|
|
12
|
-
const
|
|
13
|
-
|
|
14
|
-
|
|
12
|
+
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
|
+
);
|
|
15
18
|
|
|
16
|
-
const
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
height: 500px;
|
|
20
|
-
`;
|
|
19
|
+
const TitleComponent = () => {
|
|
20
|
+
return <DxcSidenav.Title>Dxc technology</DxcSidenav.Title>;
|
|
21
|
+
};
|
|
21
22
|
|
|
22
23
|
export const Chromatic = () => (
|
|
23
24
|
<>
|
|
24
25
|
<ExampleContainer>
|
|
25
|
-
<Title title="
|
|
26
|
-
<DxcSidenav>
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
<
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
<p>Lorem ipsum</p>
|
|
56
|
-
<p>Lorem ipsum</p>{" "}
|
|
57
|
-
</DxcSidenav>
|
|
58
|
-
</ExampleContainer>
|
|
59
|
-
|
|
60
|
-
<ExampleContainer>
|
|
61
|
-
<Title title="Sidenav with small padding" theme="light" level={4} />
|
|
62
|
-
<DxcSidenav padding="small">
|
|
63
|
-
{" "}
|
|
64
|
-
<p>Lorem ipsum</p>
|
|
65
|
-
<p>Lorem ipsum</p>
|
|
66
|
-
<p>Lorem ipsum</p>
|
|
67
|
-
<p>Lorem ipsum</p>
|
|
68
|
-
<p>Lorem ipsum</p>{" "}
|
|
69
|
-
</DxcSidenav>
|
|
70
|
-
</ExampleContainer>
|
|
71
|
-
|
|
72
|
-
<ExampleContainer>
|
|
73
|
-
<Title title="Sidenav with medium padding" theme="light" level={4} />
|
|
74
|
-
<DxcSidenav padding="medium">
|
|
75
|
-
{" "}
|
|
76
|
-
<p>Lorem ipsum</p>
|
|
77
|
-
<p>Lorem ipsum</p>
|
|
78
|
-
<p>Lorem ipsum</p>
|
|
79
|
-
<p>Lorem ipsum</p>
|
|
80
|
-
<p>Lorem ipsum</p>{" "}
|
|
26
|
+
<Title title="Default sidenav" theme="light" level={4} />
|
|
27
|
+
<DxcSidenav title={<TitleComponent />}>
|
|
28
|
+
<DxcSidenav.Section>
|
|
29
|
+
<p>
|
|
30
|
+
Lorem ipsum dolor sit amet, consectetur adipiscing elit. In ullamcorper consectetur mollis. Suspendisse
|
|
31
|
+
vitae lacinia libero.
|
|
32
|
+
</p>
|
|
33
|
+
</DxcSidenav.Section>
|
|
34
|
+
<DxcSidenav.Section>
|
|
35
|
+
<DxcSidenav.Link>Single Link</DxcSidenav.Link>
|
|
36
|
+
<DxcSidenav.Group collapsable={false} title="Single Group" icon={iconSVG}>
|
|
37
|
+
<DxcSidenav.Link>Group Link</DxcSidenav.Link>
|
|
38
|
+
<DxcSidenav.Link>Group Link</DxcSidenav.Link>
|
|
39
|
+
<DxcSidenav.Link>Group Link</DxcSidenav.Link>
|
|
40
|
+
<DxcSidenav.Link>Group Link</DxcSidenav.Link>
|
|
41
|
+
</DxcSidenav.Group>
|
|
42
|
+
</DxcSidenav.Section>
|
|
43
|
+
<DxcSidenav.Section>
|
|
44
|
+
<DxcSidenav.Group collapsable={true} title="Section Group" icon={iconSVG}>
|
|
45
|
+
<DxcSidenav.Link selected>Group Link</DxcSidenav.Link>
|
|
46
|
+
<DxcSidenav.Link icon={iconSVG}>Group Link</DxcSidenav.Link>
|
|
47
|
+
</DxcSidenav.Group>
|
|
48
|
+
<DxcSidenav.Link icon={iconSVG}>Single Link</DxcSidenav.Link>
|
|
49
|
+
<DxcSidenav.Link>Single Link</DxcSidenav.Link>
|
|
50
|
+
<DxcSidenav.Group collapsable={false} title="Section Group">
|
|
51
|
+
<DxcSidenav.Link>Group Link</DxcSidenav.Link>
|
|
52
|
+
<DxcSidenav.Link>Group Link</DxcSidenav.Link>
|
|
53
|
+
<DxcSidenav.Link>Group Link</DxcSidenav.Link>
|
|
54
|
+
</DxcSidenav.Group>
|
|
55
|
+
</DxcSidenav.Section>
|
|
81
56
|
</DxcSidenav>
|
|
82
57
|
</ExampleContainer>
|
|
58
|
+
</>
|
|
59
|
+
);
|
|
83
60
|
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
<p>
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
</DxcSidenav>
|
|
94
|
-
|
|
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
|
+
);
|
|
95
97
|
|
|
98
|
+
const CollapsedGroup = () => (
|
|
99
|
+
<>
|
|
96
100
|
<ExampleContainer>
|
|
97
|
-
<Title title="
|
|
98
|
-
<DxcSidenav
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
101
|
+
<Title title="Default sidenav" theme="light" level={4} />
|
|
102
|
+
<DxcSidenav title={<TitleComponent />}>
|
|
103
|
+
<DxcSidenav.Section>
|
|
104
|
+
<DxcSidenav.Group collapsable={true} title="Collapsable Group" icon={iconSVG}>
|
|
105
|
+
<DxcSidenav.Link>Group Link</DxcSidenav.Link>
|
|
106
|
+
<DxcSidenav.Link>Group Link</DxcSidenav.Link>
|
|
107
|
+
<DxcSidenav.Link>Group Link</DxcSidenav.Link>
|
|
108
|
+
<DxcSidenav.Link>Group Link</DxcSidenav.Link>
|
|
109
|
+
</DxcSidenav.Group>
|
|
110
|
+
</DxcSidenav.Section>
|
|
111
|
+
<DxcSidenav.Section>
|
|
112
|
+
<DxcSidenav.Group collapsable={true} title="Collapsable Group">
|
|
113
|
+
<DxcSidenav.Link selected>Group Link</DxcSidenav.Link>
|
|
114
|
+
<DxcSidenav.Link>Group Link</DxcSidenav.Link>
|
|
115
|
+
</DxcSidenav.Group>
|
|
116
|
+
<DxcSidenav.Group collapsable={false} title="Section Group">
|
|
117
|
+
<DxcSidenav.Link>Group Link</DxcSidenav.Link>
|
|
118
|
+
<DxcSidenav.Link>Group Link</DxcSidenav.Link>
|
|
119
|
+
<DxcSidenav.Link>Group Link</DxcSidenav.Link>
|
|
120
|
+
</DxcSidenav.Group>
|
|
121
|
+
</DxcSidenav.Section>
|
|
105
122
|
</DxcSidenav>
|
|
106
123
|
</ExampleContainer>
|
|
124
|
+
</>
|
|
125
|
+
);
|
|
107
126
|
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
<
|
|
114
|
-
<
|
|
115
|
-
<
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
127
|
+
const HoverSidenav = () => (
|
|
128
|
+
<ExampleContainer pseudoState="pseudo-hover">
|
|
129
|
+
<Title title="Default sidenav" theme="light" level={4} />
|
|
130
|
+
<DxcSidenav title={<TitleComponent />}>
|
|
131
|
+
<DxcSidenav.Section>
|
|
132
|
+
<DxcSidenav.Link>Single Link</DxcSidenav.Link>
|
|
133
|
+
<DxcSidenav.Link>Single Link</DxcSidenav.Link>
|
|
134
|
+
<DxcSidenav.Group collapsable={true} title="Collapsable Group">
|
|
135
|
+
<DxcSidenav.Link selected>Group Link</DxcSidenav.Link>
|
|
136
|
+
<DxcSidenav.Link>Group Link</DxcSidenav.Link>
|
|
137
|
+
<DxcSidenav.Link>Group Link</DxcSidenav.Link>
|
|
138
|
+
<DxcSidenav.Link>Group Link</DxcSidenav.Link>
|
|
139
|
+
</DxcSidenav.Group>
|
|
140
|
+
</DxcSidenav.Section>
|
|
141
|
+
<DxcSidenav.Section>
|
|
142
|
+
<DxcSidenav.Group collapsable={true} title="Not Collapsed Group">
|
|
143
|
+
<DxcSidenav.Link selected>Group Link</DxcSidenav.Link>
|
|
144
|
+
<DxcSidenav.Link>Group Link</DxcSidenav.Link>
|
|
145
|
+
</DxcSidenav.Group>
|
|
146
|
+
<DxcSidenav.Link>Single Link</DxcSidenav.Link>
|
|
147
|
+
<DxcSidenav.Link>Single Link</DxcSidenav.Link>
|
|
148
|
+
<DxcSidenav.Group collapsable={true} title="Collapsable Group">
|
|
149
|
+
<DxcSidenav.Link>Group Link</DxcSidenav.Link>
|
|
150
|
+
<DxcSidenav.Link>Group Link</DxcSidenav.Link>
|
|
151
|
+
<DxcSidenav.Link>Group Link</DxcSidenav.Link>
|
|
152
|
+
</DxcSidenav.Group>
|
|
119
153
|
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
<DxcSidenav.Link onClick={linkClick}>Footer</DxcSidenav.Link>
|
|
130
|
-
</DxcSidenav>
|
|
131
|
-
</ExampleContainer>
|
|
154
|
+
<DxcSidenav.Group collapsable={true} title="Collapsable Group">
|
|
155
|
+
<DxcSidenav.Link>Group Link</DxcSidenav.Link>
|
|
156
|
+
<DxcSidenav.Link>Group Link</DxcSidenav.Link>
|
|
157
|
+
<DxcSidenav.Link>Group Link</DxcSidenav.Link>
|
|
158
|
+
</DxcSidenav.Group>
|
|
159
|
+
</DxcSidenav.Section>
|
|
160
|
+
</DxcSidenav>
|
|
161
|
+
</ExampleContainer>
|
|
162
|
+
);
|
|
132
163
|
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
tincidunt. Vestibulum cursus ut risus sit amet congue. Nunc luctus, urna ullamcorper facilisis Jia Le, risus
|
|
142
|
-
eros aliquam erat, ut efficitur ante neque id odio. Nam orci leo, dignissim sit amet dolor ut, congue
|
|
143
|
-
gravida enim. Donec rhoncus aliquam nisl, ac cursus enim bibendum vitae. Nunc sit amet elit ornare,
|
|
144
|
-
malesuada urna eu, fringilla mauris. Vivamus bibendum turpis est, id elementum purus euismod sit amet. Etiam
|
|
145
|
-
sit amet maximus augue. Vivamus erat sapien, ultricies fringilla tellus id, condimentum blandit justo.
|
|
146
|
-
Praesent quis nunc dignissim, pharetra neque molestie, molestie lectus. Lorem ipsum dolor sit amet,
|
|
147
|
-
consectetur adipiscing elit. Morbi egestas luctus porttitor. Donec massa magna, placerat sit amet felis
|
|
148
|
-
eget, venenatis fringilla ipsum. Lorem ipsum dolor sit amet, consectetur adipiscing elit. Donec congue
|
|
149
|
-
laoreet orci, nec elementum dolor consequat quis. Curabitur rhoncus justo sed dapibus tincidunt. Vestibulum
|
|
150
|
-
cursus ut risus sit amet congue. Nunc luctus, urna ullamcorper facilisis Jia Le, risus eros aliquam erat, ut
|
|
151
|
-
efficitur ante neque id odio. Nam orci leo, dignissim sit amet dolor ut, congue gravida enim. Donec rhoncus
|
|
152
|
-
aliquam nisl, ac cursus enim bibendum vitae. Nunc sit amet elit ornare, malesuada urna eu, fringilla mauris.
|
|
153
|
-
Vivamus bibendum turpis est, id elementum purus euismod sit amet. Etiam sit amet maximus augue. Vivamus erat
|
|
154
|
-
sapien, ultricies fringilla tellus id, condimentum blandit justo. Praesent quis nunc dignissim, pharetra
|
|
155
|
-
neque molestie, molestie lectus.Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi egestas
|
|
156
|
-
luctus porttitor. Donec massa magna, placerat sit amet felis eget, venenatis fringilla ipsum. Lorem ipsum
|
|
157
|
-
dolor sit amet, consectetur adipiscing elit. Donec congue laoreet orci, nec elementum dolor consequat quis.
|
|
158
|
-
Curabitur rhoncus justo sed dapibus tincidunt. Vestibulum cursus ut risus sit amet congue. Nunc luctus, urna
|
|
159
|
-
ullamcorper facilisis Jia Le, risus eros aliquam erat, ut efficitur ante neque id odio. Nam orci leo,
|
|
160
|
-
dignissim sit amet dolor ut, congue gravida enim. Donec rhoncus aliquam nisl, ac cursus enim bibendum vitae.
|
|
161
|
-
Nunc sit amet elit ornare, malesuada urna eu, fringilla mauris. Vivamus bibendum turpis est, id elementum
|
|
162
|
-
purus euismod sit amet. Etiam sit amet maximus augue. Vivamus erat sapien, ultricies fringilla tellus id,
|
|
163
|
-
condimentum blandit justo. Praesent quis nunc dignissim, pharetra neque molestie, molestie lectus.
|
|
164
|
-
</p>
|
|
165
|
-
</DxcSidenav>
|
|
166
|
-
</StyledContainer>
|
|
167
|
-
</ExampleContainer>
|
|
164
|
+
export const CollapseGroup = CollapsedGroup.bind({});
|
|
165
|
+
CollapseGroup.play = async ({ canvasElement }) => {
|
|
166
|
+
const canvas = within(canvasElement);
|
|
167
|
+
const collapsableGroups = canvas.getAllByText("Collapsable Group");
|
|
168
|
+
collapsableGroups.forEach((group) => {
|
|
169
|
+
userEvent.click(group);
|
|
170
|
+
});
|
|
171
|
+
};
|
|
168
172
|
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
<DxcSidenav.Link onClick={linkClick}>Layout</DxcSidenav.Link>
|
|
178
|
-
<DxcSidenav.Link onClick={linkClick}>Footer</DxcSidenav.Link>
|
|
179
|
-
</DxcSidenav>
|
|
180
|
-
</ExampleContainer>
|
|
181
|
-
</>
|
|
182
|
-
);
|
|
173
|
+
export const CollapseHoverGroup = HoverSidenav.bind({});
|
|
174
|
+
CollapseHoverGroup.play = async ({ canvasElement }) => {
|
|
175
|
+
const canvas = within(canvasElement);
|
|
176
|
+
const collapsableGroups = canvas.getAllByText("Collapsable Group");
|
|
177
|
+
collapsableGroups.forEach((group) => {
|
|
178
|
+
userEvent.click(group);
|
|
179
|
+
});
|
|
180
|
+
};
|
package/sidenav/Sidenav.test.js
CHANGED
|
@@ -6,51 +6,39 @@ var _react = _interopRequireDefault(require("react"));
|
|
|
6
6
|
|
|
7
7
|
var _react2 = require("@testing-library/react");
|
|
8
8
|
|
|
9
|
-
var _Sidenav = _interopRequireDefault(require("./Sidenav"));
|
|
10
|
-
|
|
11
|
-
var navContent = /*#__PURE__*/_react["default"].createElement("p", null, "nav-content-test");
|
|
9
|
+
var _Sidenav = _interopRequireDefault(require("./Sidenav.tsx"));
|
|
12
10
|
|
|
13
11
|
describe("Sidenav component tests", function () {
|
|
14
|
-
test("Sidenav
|
|
15
|
-
var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Sidenav["default"], null,
|
|
12
|
+
test("Sidenav renders anchors and Section correctly", function () {
|
|
13
|
+
var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Sidenav["default"], null, /*#__PURE__*/_react["default"].createElement(_Sidenav["default"].Section, null, /*#__PURE__*/_react["default"].createElement("p", null, "nav-content-test"), /*#__PURE__*/_react["default"].createElement(_Sidenav["default"].Link, {
|
|
14
|
+
href: "#"
|
|
15
|
+
}, "Link")))),
|
|
16
16
|
getByText = _render.getByText;
|
|
17
17
|
|
|
18
18
|
expect(getByText("nav-content-test")).toBeTruthy();
|
|
19
|
+
var link = getByText("Link");
|
|
20
|
+
expect(link.closest("a").getAttribute("href")).toBe("#");
|
|
19
21
|
});
|
|
20
|
-
test("Sidenav renders
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
});
|
|
26
|
-
|
|
27
|
-
var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Sidenav["default"], null, navContent)),
|
|
28
|
-
getByText = _render2.getByText;
|
|
29
|
-
|
|
30
|
-
expect(getByText("nav-content-test")).toBeTruthy();
|
|
31
|
-
});
|
|
32
|
-
test("Sidenav renders compound components", function () {
|
|
33
|
-
var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Sidenav["default"], null, /*#__PURE__*/_react["default"].createElement(_Sidenav["default"].Title, null, "test-title"), /*#__PURE__*/_react["default"].createElement(_Sidenav["default"].Subtitle, null, "test-subtitle"), /*#__PURE__*/_react["default"].createElement(_Sidenav["default"].Link, {
|
|
22
|
+
test("Sidenav renders groups correctly", function () {
|
|
23
|
+
var sidenav = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Sidenav["default"], null, /*#__PURE__*/_react["default"].createElement(_Sidenav["default"].Section, null, /*#__PURE__*/_react["default"].createElement(_Sidenav["default"].Group, {
|
|
24
|
+
title: "Collapsable",
|
|
25
|
+
collapsable: true
|
|
26
|
+
}, /*#__PURE__*/_react["default"].createElement(_Sidenav["default"].Link, {
|
|
34
27
|
href: "#"
|
|
35
|
-
}, "
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
onClick: onClick
|
|
47
|
-
}, "test-link"))),
|
|
48
|
-
getByText = _render4.getByText;
|
|
49
|
-
|
|
50
|
-
var link = getByText("test-link");
|
|
28
|
+
}, "Lorem ipsum"), /*#__PURE__*/_react["default"].createElement(_Sidenav["default"].Link, {
|
|
29
|
+
href: "#"
|
|
30
|
+
}, "Lorem ipsum"), /*#__PURE__*/_react["default"].createElement(_Sidenav["default"].Link, {
|
|
31
|
+
href: "#"
|
|
32
|
+
}, "Lorem ipsum"), /*#__PURE__*/_react["default"].createElement(_Sidenav["default"].Link, {
|
|
33
|
+
href: "#"
|
|
34
|
+
}, "Lorem ipsum"), /*#__PURE__*/_react["default"].createElement(_Sidenav["default"].Link, {
|
|
35
|
+
href: "#"
|
|
36
|
+
}, "Lorem ipsum")))));
|
|
37
|
+
expect(sidenav.getByText("Collapsable")).toBeTruthy();
|
|
38
|
+
expect(sidenav.getAllByRole("button")[0].getAttribute("aria-expanded")).toBe("true");
|
|
51
39
|
|
|
52
|
-
_react2.fireEvent.click(
|
|
40
|
+
_react2.fireEvent.click(sidenav.getByText("Collapsable"));
|
|
53
41
|
|
|
54
|
-
expect(
|
|
42
|
+
expect(sidenav.getAllByRole("button")[0].getAttribute("aria-expanded")).toBe("false");
|
|
55
43
|
});
|
|
56
44
|
});
|
package/sidenav/types.d.ts
CHANGED
|
@@ -1,50 +1,73 @@
|
|
|
1
1
|
/// <reference types="react" />
|
|
2
|
-
declare type
|
|
3
|
-
declare type
|
|
4
|
-
top?: Space;
|
|
5
|
-
bottom?: Space;
|
|
6
|
-
left?: Space;
|
|
7
|
-
right?: Space;
|
|
8
|
-
};
|
|
9
|
-
export declare type SidenavLinkPropsType = {
|
|
10
|
-
/**
|
|
11
|
-
* Value of the tabindex.
|
|
12
|
-
*/
|
|
13
|
-
tabIndex?: number;
|
|
2
|
+
declare type SVG = React.ReactNode & React.SVGProps<SVGSVGElement>;
|
|
3
|
+
declare type SidenavPropsType = {
|
|
14
4
|
/**
|
|
15
|
-
*
|
|
5
|
+
* The area inside the sidenav. This area can be used to render the content inside the sidenav.
|
|
16
6
|
*/
|
|
17
|
-
|
|
7
|
+
children: React.ReactNode;
|
|
18
8
|
/**
|
|
19
|
-
*
|
|
9
|
+
* The area assigned to render the sidenav title. It is highly recommended to use the sidenav title.
|
|
20
10
|
*/
|
|
21
|
-
|
|
11
|
+
title?: React.ReactNode;
|
|
12
|
+
};
|
|
13
|
+
export declare type SidenavTitlePropsType = {
|
|
22
14
|
/**
|
|
23
|
-
* The area inside the sidenav
|
|
15
|
+
* The area inside the sidenav title. This area can be used to render custom content.
|
|
24
16
|
*/
|
|
25
17
|
children: React.ReactNode;
|
|
26
18
|
};
|
|
27
|
-
export declare type
|
|
19
|
+
export declare type SidenavSectionPropsType = {
|
|
28
20
|
/**
|
|
29
|
-
* The area inside the sidenav
|
|
21
|
+
* The area inside the sidenav section. This area can be used to render sidenav groups, links and custom content.
|
|
30
22
|
*/
|
|
31
23
|
children: React.ReactNode;
|
|
32
24
|
};
|
|
33
|
-
export declare type
|
|
25
|
+
export declare type SidenavGroupPropsType = {
|
|
34
26
|
/**
|
|
35
|
-
* The area inside the sidenav
|
|
27
|
+
* The area inside the sidenav group. This area can be used to render sidenav links.
|
|
36
28
|
*/
|
|
37
29
|
children: React.ReactNode;
|
|
30
|
+
/**
|
|
31
|
+
* The title of the sidenav group.
|
|
32
|
+
*/
|
|
33
|
+
title?: string;
|
|
34
|
+
/**
|
|
35
|
+
* If true the sidenav group title will be considered a button and the group will be collapsable.
|
|
36
|
+
*/
|
|
37
|
+
collapsable?: boolean;
|
|
38
|
+
/**
|
|
39
|
+
* The icon to be displayed next to the title of the group.
|
|
40
|
+
*/
|
|
41
|
+
icon?: string | SVG;
|
|
38
42
|
};
|
|
39
|
-
declare type
|
|
43
|
+
export declare type SidenavLinkPropsType = {
|
|
40
44
|
/**
|
|
41
|
-
*
|
|
42
|
-
* You can pass an object with 'top', 'bottom', 'left' and 'right' properties in order to specify different padding sizes.
|
|
45
|
+
* Value of the tabindex.
|
|
43
46
|
*/
|
|
44
|
-
|
|
47
|
+
tabIndex?: number;
|
|
45
48
|
/**
|
|
46
|
-
*
|
|
49
|
+
* Page to be opened when the user clicks on the link.
|
|
47
50
|
*/
|
|
48
|
-
|
|
51
|
+
href?: string;
|
|
52
|
+
/**
|
|
53
|
+
* If true, the page is opened in a new browser tab.
|
|
54
|
+
*/
|
|
55
|
+
newWindow?: boolean;
|
|
56
|
+
/**
|
|
57
|
+
* Element or path used as the icon that will be placed to the left of the link text.
|
|
58
|
+
*/
|
|
59
|
+
icon?: string | SVG;
|
|
60
|
+
/**
|
|
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.
|
|
62
|
+
*/
|
|
63
|
+
selected?: boolean;
|
|
64
|
+
/**
|
|
65
|
+
* The area inside the sidenav link.
|
|
66
|
+
*/
|
|
67
|
+
children: string;
|
|
68
|
+
/**
|
|
69
|
+
* This function will be called when the user clicks the link.
|
|
70
|
+
*/
|
|
71
|
+
onClick?: ($event: any) => void;
|
|
49
72
|
};
|
|
50
73
|
export default SidenavPropsType;
|
package/slider/Slider.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
/// <reference types="react" />
|
|
2
2
|
import SliderPropsType from "./types";
|
|
3
|
-
declare const DxcSlider: ({ label, name, value, helperText, minValue, maxValue, step, showLimitsValues, showInput, disabled, marks, onChange, onDragEnd, labelFormatCallback, margin, size, }: SliderPropsType) => JSX.Element;
|
|
3
|
+
declare const DxcSlider: ({ label, name, defaultValue, value, helperText, minValue, maxValue, step, showLimitsValues, showInput, disabled, marks, onChange, onDragEnd, labelFormatCallback, margin, size, }: SliderPropsType) => JSX.Element;
|
|
4
4
|
export default DxcSlider;
|
package/slider/Slider.js
CHANGED
|
@@ -44,6 +44,7 @@ var DxcSlider = function DxcSlider(_ref) {
|
|
|
44
44
|
label = _ref$label === void 0 ? "" : _ref$label,
|
|
45
45
|
_ref$name = _ref.name,
|
|
46
46
|
name = _ref$name === void 0 ? "" : _ref$name,
|
|
47
|
+
defaultValue = _ref.defaultValue,
|
|
47
48
|
value = _ref.value,
|
|
48
49
|
_ref$helperText = _ref.helperText,
|
|
49
50
|
helperText = _ref$helperText === void 0 ? "" : _ref$helperText,
|
|
@@ -68,7 +69,7 @@ var DxcSlider = function DxcSlider(_ref) {
|
|
|
68
69
|
_ref$size = _ref.size,
|
|
69
70
|
size = _ref$size === void 0 ? "fillParent" : _ref$size;
|
|
70
71
|
|
|
71
|
-
var _useState = (0, _react.useState)(0),
|
|
72
|
+
var _useState = (0, _react.useState)(defaultValue !== null && defaultValue !== void 0 ? defaultValue : 0),
|
|
72
73
|
_useState2 = (0, _slicedToArray2["default"])(_useState, 2),
|
|
73
74
|
innerValue = _useState2[0],
|
|
74
75
|
setInnerValue = _useState2[1];
|
|
@@ -88,7 +89,7 @@ var DxcSlider = function DxcSlider(_ref) {
|
|
|
88
89
|
}, [labelFormatCallback, maxValue]);
|
|
89
90
|
|
|
90
91
|
var handlerSliderChange = function handlerSliderChange(event, newValue) {
|
|
91
|
-
var valueToCheck = value
|
|
92
|
+
var valueToCheck = value != null && value >= 0 ? value : innerValue;
|
|
92
93
|
valueToCheck !== newValue && setInnerValue(newValue);
|
|
93
94
|
onChange === null || onChange === void 0 ? void 0 : onChange(newValue);
|
|
94
95
|
};
|
|
@@ -127,7 +128,7 @@ var DxcSlider = function DxcSlider(_ref) {
|
|
|
127
128
|
backgroundType: backgroundType,
|
|
128
129
|
disabled: disabled
|
|
129
130
|
}, minLabel), /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
|
|
130
|
-
value: value != null && value >= 0
|
|
131
|
+
value: value != null && value >= 0 ? value : innerValue,
|
|
131
132
|
min: minValue,
|
|
132
133
|
max: maxValue,
|
|
133
134
|
onChange: handlerSliderChange,
|
|
@@ -142,7 +143,7 @@ var DxcSlider = function DxcSlider(_ref) {
|
|
|
142
143
|
step: step
|
|
143
144
|
}, maxLabel), showInput && /*#__PURE__*/_react["default"].createElement(StyledTextInput, null, /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
|
|
144
145
|
name: name,
|
|
145
|
-
value: value != null && value >= 0
|
|
146
|
+
value: value != null && value >= 0 ? value.toString() : innerValue.toString(),
|
|
146
147
|
disabled: disabled,
|
|
147
148
|
onChange: handlerInputChange,
|
|
148
149
|
size: "fillParent"
|
|
@@ -37,7 +37,7 @@ export const Chromatic = () => (
|
|
|
37
37
|
label="Slider"
|
|
38
38
|
helperText="Help message"
|
|
39
39
|
disabled
|
|
40
|
-
|
|
40
|
+
defaultValue={40}
|
|
41
41
|
minValue={0}
|
|
42
42
|
maxValue={50}
|
|
43
43
|
showLimitsValues
|
|
@@ -49,16 +49,16 @@ export const Chromatic = () => (
|
|
|
49
49
|
<Title title="Variants" theme="light" level={2} />
|
|
50
50
|
<ExampleContainer>
|
|
51
51
|
<Title title="Continuous slider" theme="light" level={4} />
|
|
52
|
-
<DxcSlider
|
|
52
|
+
<DxcSlider defaultValue={65} label="Slider" helperText="Help message" showLimitsValues />
|
|
53
53
|
</ExampleContainer>
|
|
54
54
|
<ExampleContainer>
|
|
55
55
|
<Title title="Discrete slider" theme="light" level={4} />
|
|
56
|
-
<DxcSlider
|
|
56
|
+
<DxcSlider defaultValue={20} label="Slider" helperText="Help message" showLimitsValues marks step={5} />
|
|
57
57
|
</ExampleContainer>
|
|
58
58
|
<ExampleContainer>
|
|
59
59
|
<Title title="Discrete slider with input" theme="light" level={4} />
|
|
60
60
|
<DxcSlider
|
|
61
|
-
|
|
61
|
+
defaultValue={20}
|
|
62
62
|
minValue={0}
|
|
63
63
|
maxValue={50}
|
|
64
64
|
label="Slider"
|
|
@@ -94,7 +94,7 @@ export const Chromatic = () => (
|
|
|
94
94
|
label="Slider"
|
|
95
95
|
helperText="Help message"
|
|
96
96
|
disabled
|
|
97
|
-
|
|
97
|
+
defaultValue={40}
|
|
98
98
|
minValue={0}
|
|
99
99
|
maxValue={50}
|
|
100
100
|
showLimitsValues
|
|
@@ -105,16 +105,16 @@ export const Chromatic = () => (
|
|
|
105
105
|
</ExampleContainer>
|
|
106
106
|
<ExampleContainer>
|
|
107
107
|
<Title title="Continuous slider" theme="dark" level={4} />
|
|
108
|
-
<DxcSlider
|
|
108
|
+
<DxcSlider defaultValue={65} label="Slider" helperText="Help message" showLimitsValues />
|
|
109
109
|
</ExampleContainer>
|
|
110
110
|
<ExampleContainer>
|
|
111
111
|
<Title title="Discrete slider" theme="dark" level={4} />
|
|
112
|
-
<DxcSlider
|
|
112
|
+
<DxcSlider defaultValue={20} label="Slider" helperText="Help message" showLimitsValues marks step={5} />
|
|
113
113
|
</ExampleContainer>
|
|
114
114
|
<ExampleContainer>
|
|
115
115
|
<Title title="Discrete slider with input" theme="dark" level={4} />
|
|
116
116
|
<DxcSlider
|
|
117
|
-
|
|
117
|
+
defaultValue={20}
|
|
118
118
|
minValue={0}
|
|
119
119
|
maxValue={50}
|
|
120
120
|
label="Slider"
|