@dxc-technology/halstack-react 0.0.0-dcd93c4 → 0.0.0-dcee34a
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.js +98 -50
- package/accordion/Accordion.js +117 -104
- package/accordion/Accordion.stories.tsx +103 -15
- package/accordion/Accordion.test.js +9 -10
- package/accordion/types.d.ts +5 -4
- package/accordion-group/AccordionGroup.js +1 -21
- package/accordion-group/AccordionGroup.stories.tsx +27 -1
- package/accordion-group/AccordionGroup.test.js +20 -45
- package/accordion-group/types.d.ts +10 -3
- package/alert/Alert.js +1 -1
- package/alert/Alert.stories.tsx +28 -0
- package/bleed/Bleed.stories.tsx +63 -63
- package/box/Box.js +1 -1
- package/box/Box.stories.tsx +15 -0
- package/box/types.d.ts +1 -0
- 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/button/Button.js +50 -70
- package/button/Button.stories.tsx +159 -8
- package/button/types.d.ts +7 -7
- package/card/types.d.ts +1 -0
- package/checkbox/Checkbox.d.ts +2 -2
- package/checkbox/Checkbox.js +92 -99
- package/checkbox/Checkbox.stories.tsx +131 -59
- package/checkbox/Checkbox.test.js +93 -16
- package/checkbox/types.d.ts +6 -2
- package/chip/Chip.js +16 -22
- package/chip/Chip.stories.tsx +96 -9
- package/chip/types.d.ts +1 -1
- package/common/variables.js +328 -260
- package/date-input/Calendar.d.ts +4 -0
- package/date-input/Calendar.js +258 -0
- package/date-input/DateInput.js +134 -237
- package/date-input/DateInput.stories.tsx +199 -33
- package/date-input/DateInput.test.js +494 -138
- package/date-input/DatePicker.d.ts +4 -0
- package/date-input/DatePicker.js +146 -0
- package/date-input/Icons.d.ts +6 -0
- package/date-input/Icons.js +75 -0
- package/date-input/YearPicker.d.ts +4 -0
- package/date-input/YearPicker.js +126 -0
- package/date-input/types.d.ts +51 -0
- package/dialog/Dialog.js +50 -28
- package/dialog/Dialog.stories.tsx +99 -22
- package/dialog/Dialog.test.js +34 -4
- package/dialog/types.d.ts +3 -2
- package/dropdown/Dropdown.d.ts +1 -1
- package/dropdown/Dropdown.js +246 -249
- package/dropdown/Dropdown.stories.tsx +245 -56
- package/dropdown/Dropdown.test.js +504 -108
- package/dropdown/DropdownMenu.d.ts +4 -0
- package/dropdown/DropdownMenu.js +70 -0
- package/dropdown/DropdownMenuItem.d.ts +4 -0
- package/dropdown/DropdownMenuItem.js +81 -0
- package/dropdown/types.d.ts +25 -5
- package/file-input/FileInput.d.ts +2 -2
- package/file-input/FileInput.js +177 -219
- package/file-input/FileInput.stories.tsx +122 -11
- package/file-input/FileInput.test.js +53 -12
- package/file-input/FileItem.d.ts +4 -14
- package/file-input/FileItem.js +38 -63
- package/file-input/types.d.ts +17 -0
- package/flex/Flex.d.ts +4 -0
- package/flex/Flex.js +69 -0
- package/flex/Flex.stories.tsx +103 -0
- package/flex/types.d.ts +32 -0
- package/footer/Footer.stories.tsx +99 -1
- package/footer/types.d.ts +2 -1
- package/header/Header.js +87 -87
- package/header/Header.stories.tsx +152 -9
- package/header/Icons.js +2 -2
- package/header/types.d.ts +3 -2
- package/inset/Inset.stories.tsx +4 -4
- package/layout/ApplicationLayout.d.ts +15 -6
- package/layout/ApplicationLayout.js +36 -64
- package/layout/ApplicationLayout.stories.tsx +80 -44
- package/layout/types.d.ts +17 -27
- package/link/Link.js +2 -2
- package/link/Link.stories.tsx +72 -5
- package/link/types.d.ts +1 -1
- package/main.d.ts +6 -10
- package/main.js +28 -60
- package/{tabs-nav → nav-tabs}/NavTabs.js +6 -6
- package/{tabs-nav → nav-tabs}/NavTabs.stories.tsx +96 -6
- package/{tabs-nav → nav-tabs}/Tab.js +37 -20
- package/{tabs-nav → nav-tabs}/types.d.ts +1 -1
- package/number-input/NumberInput.test.js +43 -7
- package/package.json +16 -21
- package/paginator/Icons.d.ts +5 -0
- package/paginator/Icons.js +16 -28
- package/paginator/Paginator.js +6 -12
- package/paginator/Paginator.stories.tsx +24 -0
- package/paginator/Paginator.test.js +18 -11
- package/paragraph/Paragraph.d.ts +6 -0
- package/paragraph/Paragraph.js +38 -0
- package/paragraph/Paragraph.stories.tsx +44 -0
- package/password-input/PasswordInput.test.js +13 -12
- package/progress-bar/ProgressBar.d.ts +2 -2
- package/progress-bar/ProgressBar.js +59 -53
- package/progress-bar/ProgressBar.stories.jsx +38 -3
- package/progress-bar/ProgressBar.test.js +67 -22
- package/progress-bar/types.d.ts +3 -4
- package/quick-nav/QuickNav.js +18 -17
- package/quick-nav/QuickNav.stories.tsx +145 -26
- package/radio-group/Radio.d.ts +1 -1
- package/radio-group/Radio.js +43 -28
- package/radio-group/RadioGroup.js +24 -24
- package/radio-group/RadioGroup.stories.tsx +132 -18
- package/radio-group/RadioGroup.test.js +123 -96
- package/radio-group/types.d.ts +2 -2
- package/resultsetTable/Icons.d.ts +7 -0
- package/resultsetTable/Icons.js +51 -0
- package/resultsetTable/ResultsetTable.js +48 -107
- package/resultsetTable/ResultsetTable.stories.tsx +50 -25
- package/resultsetTable/ResultsetTable.test.js +40 -63
- package/resultsetTable/types.d.ts +2 -2
- package/select/Listbox.js +4 -10
- package/select/Option.js +11 -24
- package/select/Select.js +54 -50
- package/select/Select.stories.tsx +494 -149
- package/select/Select.test.js +338 -272
- package/select/types.d.ts +3 -5
- package/sidenav/Sidenav.d.ts +6 -5
- package/sidenav/Sidenav.js +174 -55
- package/sidenav/Sidenav.stories.tsx +249 -149
- package/sidenav/Sidenav.test.js +25 -37
- package/sidenav/types.d.ts +50 -27
- package/slider/Slider.d.ts +2 -2
- package/slider/Slider.js +120 -95
- package/slider/Slider.stories.tsx +64 -1
- package/slider/Slider.test.js +121 -21
- package/slider/types.d.ts +6 -2
- package/spinner/Spinner.js +2 -2
- package/spinner/Spinner.stories.jsx +27 -1
- package/switch/Switch.d.ts +2 -2
- package/switch/Switch.js +135 -68
- package/switch/Switch.stories.tsx +41 -30
- package/switch/Switch.test.js +144 -17
- package/switch/types.d.ts +6 -2
- package/table/Table.js +1 -1
- package/table/Table.stories.jsx +80 -1
- package/table/Table.test.js +1 -1
- package/tabs/Tab.d.ts +4 -0
- package/tabs/Tab.js +133 -0
- package/tabs/Tabs.js +360 -104
- package/tabs/Tabs.stories.tsx +119 -5
- package/tabs/Tabs.test.js +217 -6
- package/tabs/types.d.ts +15 -5
- package/tag/Tag.js +1 -1
- package/tag/Tag.stories.tsx +14 -1
- package/tag/types.d.ts +1 -1
- package/text-input/Icons.d.ts +8 -0
- package/text-input/Icons.js +60 -0
- package/text-input/Suggestion.js +38 -9
- package/text-input/Suggestions.d.ts +4 -0
- package/text-input/Suggestions.js +134 -0
- package/text-input/TextInput.js +195 -292
- package/text-input/TextInput.stories.tsx +280 -185
- package/text-input/TextInput.test.js +737 -725
- package/text-input/types.d.ts +22 -3
- package/textarea/Textarea.stories.jsx +60 -1
- package/toggle-group/ToggleGroup.stories.tsx +42 -0
- package/toggle-group/types.d.ts +1 -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/wizard/Wizard.js +9 -16
- package/wizard/Wizard.stories.tsx +40 -1
- package/wizard/types.d.ts +5 -4
- package/common/RequiredComponent.js +0 -32
- package/inline/Inline.d.ts +0 -4
- package/inline/Inline.js +0 -60
- package/inline/Inline.stories.tsx +0 -319
- package/inline/types.d.ts +0 -36
- package/list/List.d.ts +0 -4
- package/list/List.js +0 -47
- package/list/List.stories.tsx +0 -89
- package/list/types.d.ts +0 -7
- 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 -4
- package/stack/Stack.js +0 -56
- package/stack/Stack.stories.tsx +0 -263
- package/stack/types.d.ts +0 -32
- package/tabs-nav/types.js +0 -5
- package/text/Text.d.ts +0 -7
- package/text/Text.js +0 -30
- package/text/Text.stories.tsx +0 -19
- /package/{inline → bulleted-list}/types.js +0 -0
- /package/{list → flex}/types.js +0 -0
- /package/{tabs-nav → nav-tabs}/NavTabs.d.ts +0 -0
- /package/{tabs-nav → nav-tabs}/NavTabs.test.js +0 -0
- /package/{tabs-nav → nav-tabs}/Tab.d.ts +0 -0
- /package/{row → nav-tabs}/types.js +0 -0
- /package/{stack → typography}/types.js +0 -0
|
@@ -1,20 +1,31 @@
|
|
|
1
1
|
import React from "react";
|
|
2
|
-
import { userEvent, within } from "@storybook/testing-library";
|
|
3
2
|
import DxcDialog from "./Dialog";
|
|
3
|
+
import DxcTextInput from "../text-input/TextInput";
|
|
4
|
+
import DxcButton from "../button/Button";
|
|
5
|
+
import DxcFlex from "../flex/Flex";
|
|
6
|
+
import DxcInset from "../inset/Inset";
|
|
4
7
|
import Title from "../../.storybook/components/Title";
|
|
5
8
|
import ExampleContainer from "../../.storybook/components/ExampleContainer";
|
|
9
|
+
import { HalstackProvider } from "../HalstackContext";
|
|
6
10
|
|
|
7
11
|
export default {
|
|
8
12
|
title: "Dialog ",
|
|
9
13
|
component: DxcDialog,
|
|
10
14
|
};
|
|
11
15
|
|
|
16
|
+
const opinionatedTheme = {
|
|
17
|
+
dialog: {
|
|
18
|
+
baseColor: "#ffffff",
|
|
19
|
+
closeIconColor: "#000000",
|
|
20
|
+
overlayColor: "#000000b3",
|
|
21
|
+
},
|
|
22
|
+
};
|
|
23
|
+
|
|
12
24
|
export const DefaultDialog = () => (
|
|
13
25
|
<>
|
|
14
26
|
<ExampleContainer expanded={true}>
|
|
15
27
|
<Title title="Default dialog" theme="light" level={4} />
|
|
16
28
|
<DxcDialog>
|
|
17
|
-
{" "}
|
|
18
29
|
<p>
|
|
19
30
|
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi egestas luctus porttitor. Donec massa magna,
|
|
20
31
|
placerat sit amet felis eget, venenatis fringilla ipsum. Lorem ipsum dolor sit amet, consectetur adipiscing
|
|
@@ -25,7 +36,74 @@ export const DefaultDialog = () => (
|
|
|
25
36
|
fringilla mauris. Vivamus bibendum turpis est, id elementum purus euismod sit amet. Etiam sit amet maximus
|
|
26
37
|
augue. Vivamus erat sapien, ultricies fringilla tellus id, condimentum blandit justo. Praesent quis nunc
|
|
27
38
|
dignissim, pharetra neque molestie, molestie lectus.
|
|
28
|
-
</p>
|
|
39
|
+
</p>
|
|
40
|
+
</DxcDialog>
|
|
41
|
+
</ExampleContainer>
|
|
42
|
+
</>
|
|
43
|
+
);
|
|
44
|
+
|
|
45
|
+
export const DefaultDialogOpinionated = () => (
|
|
46
|
+
<>
|
|
47
|
+
<ExampleContainer expanded={true}>
|
|
48
|
+
<Title title="Default dialog" theme="light" level={4} />
|
|
49
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
50
|
+
<DxcDialog>
|
|
51
|
+
<p>
|
|
52
|
+
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi egestas luctus porttitor. Donec massa magna,
|
|
53
|
+
placerat sit amet felis eget, venenatis fringilla ipsum. Lorem ipsum dolor sit amet, consectetur adipiscing
|
|
54
|
+
elit. Donec congue laoreet orci, nec elementum dolor consequat quis. Curabitur rhoncus justo sed dapibus
|
|
55
|
+
tincidunt. Vestibulum cursus ut risus sit amet congue. Nunc luctus, urna ullamcorper facilisis Jia Le, risus
|
|
56
|
+
eros aliquam erat, ut efficitur ante neque id odio. Nam orci leo, dignissim sit amet dolor ut, congue
|
|
57
|
+
gravida enim. Donec rhoncus aliquam nisl, ac cursus enim bibendum vitae. Nunc sit amet elit ornare,
|
|
58
|
+
malesuada urna eu, fringilla mauris. Vivamus bibendum turpis est, id elementum purus euismod sit amet. Etiam
|
|
59
|
+
sit amet maximus augue. Vivamus erat sapien, ultricies fringilla tellus id, condimentum blandit justo.
|
|
60
|
+
Praesent quis nunc dignissim, pharetra neque molestie, molestie lectus.
|
|
61
|
+
</p>
|
|
62
|
+
</DxcDialog>
|
|
63
|
+
</HalstackProvider>
|
|
64
|
+
</ExampleContainer>
|
|
65
|
+
</>
|
|
66
|
+
);
|
|
67
|
+
|
|
68
|
+
export const DialogWithInputs = () => (
|
|
69
|
+
<>
|
|
70
|
+
<ExampleContainer expanded={true}>
|
|
71
|
+
<Title title="Dialog with inputs" theme="light" level={4} />
|
|
72
|
+
<DxcDialog>
|
|
73
|
+
<DxcInset bottom="1rem">
|
|
74
|
+
<DxcFlex gap="2rem" direction="column">
|
|
75
|
+
<DxcFlex gap="1rem" direction="column">
|
|
76
|
+
<DxcTextInput size="fillParent" label="Name"></DxcTextInput>
|
|
77
|
+
<DxcTextInput size="fillParent" label="Surname"></DxcTextInput>
|
|
78
|
+
</DxcFlex>
|
|
79
|
+
<DxcFlex justifyContent="flex-end" gap="1rem">
|
|
80
|
+
<DxcButton label="Save"></DxcButton>
|
|
81
|
+
<DxcButton label="Cancel" mode="secondary"></DxcButton>
|
|
82
|
+
</DxcFlex>
|
|
83
|
+
</DxcFlex>
|
|
84
|
+
</DxcInset>
|
|
85
|
+
</DxcDialog>
|
|
86
|
+
</ExampleContainer>
|
|
87
|
+
</>
|
|
88
|
+
);
|
|
89
|
+
|
|
90
|
+
const RespDialog = () => (
|
|
91
|
+
<>
|
|
92
|
+
<ExampleContainer expanded={true}>
|
|
93
|
+
<Title title="Responsive dialog" theme="light" level={4} />
|
|
94
|
+
<DxcDialog>
|
|
95
|
+
<DxcInset bottom="1rem">
|
|
96
|
+
<DxcFlex gap="2rem" direction="column">
|
|
97
|
+
<DxcFlex gap="1rem" direction="column">
|
|
98
|
+
<DxcTextInput size="fillParent" label="Name"></DxcTextInput>
|
|
99
|
+
<DxcTextInput size="fillParent" label="Surname"></DxcTextInput>
|
|
100
|
+
</DxcFlex>
|
|
101
|
+
<DxcFlex justifyContent="flex-end" gap="1rem">
|
|
102
|
+
<DxcButton label="Save"></DxcButton>
|
|
103
|
+
<DxcButton label="Cancel" mode="secondary"></DxcButton>
|
|
104
|
+
</DxcFlex>
|
|
105
|
+
</DxcFlex>
|
|
106
|
+
</DxcInset>
|
|
29
107
|
</DxcDialog>
|
|
30
108
|
</ExampleContainer>
|
|
31
109
|
</>
|
|
@@ -35,7 +113,6 @@ export const DialogWithoutOverlay = () => (
|
|
|
35
113
|
<ExampleContainer expanded={true}>
|
|
36
114
|
<Title title="Dialog Without Overlay" theme="light" level={4} />
|
|
37
115
|
<DxcDialog overlay={false}>
|
|
38
|
-
{" "}
|
|
39
116
|
<p>
|
|
40
117
|
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi egestas luctus porttitor. Donec massa magna,
|
|
41
118
|
placerat sit amet felis eget, venenatis fringilla ipsum. Lorem ipsum dolor sit amet, consectetur adipiscing
|
|
@@ -46,7 +123,7 @@ export const DialogWithoutOverlay = () => (
|
|
|
46
123
|
fringilla mauris. Vivamus bibendum turpis est, id elementum purus euismod sit amet. Etiam sit amet maximus
|
|
47
124
|
augue. Vivamus erat sapien, ultricies fringilla tellus id, condimentum blandit justo. Praesent quis nunc
|
|
48
125
|
dignissim, pharetra neque molestie, molestie lectus.
|
|
49
|
-
</p>
|
|
126
|
+
</p>
|
|
50
127
|
</DxcDialog>
|
|
51
128
|
</ExampleContainer>
|
|
52
129
|
);
|
|
@@ -55,7 +132,6 @@ export const DialogCloseVisibleFalse = () => (
|
|
|
55
132
|
<ExampleContainer expanded={true}>
|
|
56
133
|
<Title title="Dialog Close Visible" theme="dark" level={4} />
|
|
57
134
|
<DxcDialog isCloseVisible={false}>
|
|
58
|
-
{" "}
|
|
59
135
|
<p>
|
|
60
136
|
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi egestas luctus porttitor. Donec massa magna,
|
|
61
137
|
placerat sit amet felis eget, venenatis fringilla ipsum. Lorem ipsum dolor sit amet, consectetur adipiscing
|
|
@@ -66,7 +142,7 @@ export const DialogCloseVisibleFalse = () => (
|
|
|
66
142
|
fringilla mauris. Vivamus bibendum turpis est, id elementum purus euismod sit amet. Etiam sit amet maximus
|
|
67
143
|
augue. Vivamus erat sapien, ultricies fringilla tellus id, condimentum blandit justo. Praesent quis nunc
|
|
68
144
|
dignissim, pharetra neque molestie, molestie lectus.
|
|
69
|
-
</p>
|
|
145
|
+
</p>
|
|
70
146
|
</DxcDialog>
|
|
71
147
|
</ExampleContainer>
|
|
72
148
|
);
|
|
@@ -75,7 +151,6 @@ export const DialogWithXxsmallPadding = () => (
|
|
|
75
151
|
<ExampleContainer expanded={true}>
|
|
76
152
|
<Title title="Dialog With Xxsmall Padding" theme="light" level={4} />
|
|
77
153
|
<DxcDialog padding={"xxsmall"}>
|
|
78
|
-
{" "}
|
|
79
154
|
<p>
|
|
80
155
|
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi egestas luctus porttitor. Donec massa magna,
|
|
81
156
|
placerat sit amet felis eget, venenatis fringilla ipsum. Lorem ipsum dolor sit amet, consectetur adipiscing
|
|
@@ -86,7 +161,7 @@ export const DialogWithXxsmallPadding = () => (
|
|
|
86
161
|
fringilla mauris. Vivamus bibendum turpis est, id elementum purus euismod sit amet. Etiam sit amet maximus
|
|
87
162
|
augue. Vivamus erat sapien, ultricies fringilla tellus id, condimentum blandit justo. Praesent quis nunc
|
|
88
163
|
dignissim, pharetra neque molestie, molestie lectus.
|
|
89
|
-
</p>
|
|
164
|
+
</p>
|
|
90
165
|
</DxcDialog>
|
|
91
166
|
</ExampleContainer>
|
|
92
167
|
);
|
|
@@ -95,7 +170,6 @@ export const DialogWithXsmallPadding = () => (
|
|
|
95
170
|
<ExampleContainer expanded={true}>
|
|
96
171
|
<Title title="Dialog With Xsmall Padding" theme="light" level={4} />
|
|
97
172
|
<DxcDialog padding={"xsmall"}>
|
|
98
|
-
{" "}
|
|
99
173
|
<p>
|
|
100
174
|
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi egestas luctus porttitor. Donec massa magna,
|
|
101
175
|
placerat sit amet felis eget, venenatis fringilla ipsum. Lorem ipsum dolor sit amet, consectetur adipiscing
|
|
@@ -106,7 +180,7 @@ export const DialogWithXsmallPadding = () => (
|
|
|
106
180
|
fringilla mauris. Vivamus bibendum turpis est, id elementum purus euismod sit amet. Etiam sit amet maximus
|
|
107
181
|
augue. Vivamus erat sapien, ultricies fringilla tellus id, condimentum blandit justo. Praesent quis nunc
|
|
108
182
|
dignissim, pharetra neque molestie, molestie lectus.
|
|
109
|
-
</p>
|
|
183
|
+
</p>
|
|
110
184
|
</DxcDialog>
|
|
111
185
|
</ExampleContainer>
|
|
112
186
|
);
|
|
@@ -115,7 +189,6 @@ export const DialogWithSmallPadding = () => (
|
|
|
115
189
|
<ExampleContainer expanded={true}>
|
|
116
190
|
<Title title="Dialog With Small Padding" theme="light" level={4} />
|
|
117
191
|
<DxcDialog padding={"small"}>
|
|
118
|
-
{" "}
|
|
119
192
|
<p>
|
|
120
193
|
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi egestas luctus porttitor. Donec massa magna,
|
|
121
194
|
placerat sit amet felis eget, venenatis fringilla ipsum. Lorem ipsum dolor sit amet, consectetur adipiscing
|
|
@@ -126,7 +199,7 @@ export const DialogWithSmallPadding = () => (
|
|
|
126
199
|
fringilla mauris. Vivamus bibendum turpis est, id elementum purus euismod sit amet. Etiam sit amet maximus
|
|
127
200
|
augue. Vivamus erat sapien, ultricies fringilla tellus id, condimentum blandit justo. Praesent quis nunc
|
|
128
201
|
dignissim, pharetra neque molestie, molestie lectus.
|
|
129
|
-
</p>
|
|
202
|
+
</p>
|
|
130
203
|
</DxcDialog>
|
|
131
204
|
</ExampleContainer>
|
|
132
205
|
);
|
|
@@ -135,7 +208,6 @@ export const DialogWithMediumPadding = () => (
|
|
|
135
208
|
<ExampleContainer expanded={true}>
|
|
136
209
|
<Title title="Dialog With Medium Padding" theme="light" level={4} />
|
|
137
210
|
<DxcDialog padding={"medium"}>
|
|
138
|
-
{" "}
|
|
139
211
|
<p>
|
|
140
212
|
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi egestas luctus porttitor. Donec massa magna,
|
|
141
213
|
placerat sit amet felis eget, venenatis fringilla ipsum. Lorem ipsum dolor sit amet, consectetur adipiscing
|
|
@@ -146,7 +218,7 @@ export const DialogWithMediumPadding = () => (
|
|
|
146
218
|
fringilla mauris. Vivamus bibendum turpis est, id elementum purus euismod sit amet. Etiam sit amet maximus
|
|
147
219
|
augue. Vivamus erat sapien, ultricies fringilla tellus id, condimentum blandit justo. Praesent quis nunc
|
|
148
220
|
dignissim, pharetra neque molestie, molestie lectus.
|
|
149
|
-
</p>
|
|
221
|
+
</p>
|
|
150
222
|
</DxcDialog>
|
|
151
223
|
</ExampleContainer>
|
|
152
224
|
);
|
|
@@ -155,7 +227,6 @@ export const DialogWithLargePadding = () => (
|
|
|
155
227
|
<ExampleContainer expanded={true}>
|
|
156
228
|
<Title title="Dialog With Large Padding" theme="light" level={4} />
|
|
157
229
|
<DxcDialog padding={"large"}>
|
|
158
|
-
{" "}
|
|
159
230
|
<p>
|
|
160
231
|
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi egestas luctus porttitor. Donec massa magna,
|
|
161
232
|
placerat sit amet felis eget, venenatis fringilla ipsum. Lorem ipsum dolor sit amet, consectetur adipiscing
|
|
@@ -166,7 +237,7 @@ export const DialogWithLargePadding = () => (
|
|
|
166
237
|
fringilla mauris. Vivamus bibendum turpis est, id elementum purus euismod sit amet. Etiam sit amet maximus
|
|
167
238
|
augue. Vivamus erat sapien, ultricies fringilla tellus id, condimentum blandit justo. Praesent quis nunc
|
|
168
239
|
dignissim, pharetra neque molestie, molestie lectus.
|
|
169
|
-
</p>
|
|
240
|
+
</p>
|
|
170
241
|
</DxcDialog>
|
|
171
242
|
</ExampleContainer>
|
|
172
243
|
);
|
|
@@ -175,7 +246,6 @@ export const DialogWithXlargePadding = () => (
|
|
|
175
246
|
<ExampleContainer expanded={true}>
|
|
176
247
|
<Title title="Dialog With Xlarge Padding" theme="light" level={4} />
|
|
177
248
|
<DxcDialog padding={"xlarge"}>
|
|
178
|
-
{" "}
|
|
179
249
|
<p>
|
|
180
250
|
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi egestas luctus porttitor. Donec massa magna,
|
|
181
251
|
placerat sit amet felis eget, venenatis fringilla ipsum. Lorem ipsum dolor sit amet, consectetur adipiscing
|
|
@@ -186,7 +256,7 @@ export const DialogWithXlargePadding = () => (
|
|
|
186
256
|
fringilla mauris. Vivamus bibendum turpis est, id elementum purus euismod sit amet. Etiam sit amet maximus
|
|
187
257
|
augue. Vivamus erat sapien, ultricies fringilla tellus id, condimentum blandit justo. Praesent quis nunc
|
|
188
258
|
dignissim, pharetra neque molestie, molestie lectus.
|
|
189
|
-
</p>
|
|
259
|
+
</p>
|
|
190
260
|
</DxcDialog>
|
|
191
261
|
</ExampleContainer>
|
|
192
262
|
);
|
|
@@ -195,7 +265,6 @@ export const DialogWithXxlargePadding = () => (
|
|
|
195
265
|
<ExampleContainer expanded={true}>
|
|
196
266
|
<Title title="Dialog With Xxlarge Padding" theme="light" level={4} />
|
|
197
267
|
<DxcDialog padding={"xxlarge"}>
|
|
198
|
-
{" "}
|
|
199
268
|
<p>
|
|
200
269
|
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi egestas luctus porttitor. Donec massa magna,
|
|
201
270
|
placerat sit amet felis eget, venenatis fringilla ipsum. Lorem ipsum dolor sit amet, consectetur adipiscing
|
|
@@ -206,7 +275,15 @@ export const DialogWithXxlargePadding = () => (
|
|
|
206
275
|
fringilla mauris. Vivamus bibendum turpis est, id elementum purus euismod sit amet. Etiam sit amet maximus
|
|
207
276
|
augue. Vivamus erat sapien, ultricies fringilla tellus id, condimentum blandit justo. Praesent quis nunc
|
|
208
277
|
dignissim, pharetra neque molestie, molestie lectus.
|
|
209
|
-
</p>
|
|
278
|
+
</p>
|
|
210
279
|
</DxcDialog>
|
|
211
280
|
</ExampleContainer>
|
|
212
|
-
);
|
|
281
|
+
);
|
|
282
|
+
|
|
283
|
+
export const ResponsiveDialog = RespDialog.bind({});
|
|
284
|
+
ResponsiveDialog.parameters = {
|
|
285
|
+
viewport: {
|
|
286
|
+
defaultViewport: "iphonex",
|
|
287
|
+
},
|
|
288
|
+
chromatic: { viewports: [375] },
|
|
289
|
+
};
|
package/dialog/Dialog.test.js
CHANGED
|
@@ -9,10 +9,13 @@ var _react2 = require("@testing-library/react");
|
|
|
9
9
|
var _Dialog = _interopRequireDefault(require("./Dialog"));
|
|
10
10
|
|
|
11
11
|
describe("Dialog component tests", function () {
|
|
12
|
-
test("Dialog renders with correct text", function () {
|
|
12
|
+
test("Dialog renders with correct text and accesibility attributes", function () {
|
|
13
13
|
var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], null, "dialog-text")),
|
|
14
|
-
getByText = _render.getByText
|
|
14
|
+
getByText = _render.getByText,
|
|
15
|
+
getByRole = _render.getByRole;
|
|
15
16
|
|
|
17
|
+
expect(getByRole("dialog")).toBeTruthy();
|
|
18
|
+
expect(getByRole("dialog").getAttribute("aria-modal")).toBe("true");
|
|
16
19
|
expect(getByText("dialog-text")).toBeTruthy();
|
|
17
20
|
});
|
|
18
21
|
test("Dialog renders without close button", function () {
|
|
@@ -23,18 +26,45 @@ describe("Dialog component tests", function () {
|
|
|
23
26
|
|
|
24
27
|
expect(queryByRole("button")).toBeFalsy();
|
|
25
28
|
});
|
|
29
|
+
test("Dialog renders with aria-modal false when overlay is not used", function () {
|
|
30
|
+
var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], {
|
|
31
|
+
isCloseVisible: false,
|
|
32
|
+
overlay: false
|
|
33
|
+
}, "dialog-text")),
|
|
34
|
+
getByRole = _render3.getByRole;
|
|
35
|
+
|
|
36
|
+
expect(getByRole("dialog")).toBeTruthy();
|
|
37
|
+
expect(getByRole("dialog").getAttribute("aria-modal")).toBe("false");
|
|
38
|
+
});
|
|
26
39
|
test("Calls correct function onCloseClick", function () {
|
|
27
40
|
var onCloseClick = jest.fn();
|
|
28
41
|
|
|
29
|
-
var
|
|
42
|
+
var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], {
|
|
30
43
|
onCloseClick: onCloseClick
|
|
31
44
|
}, "dialog-text")),
|
|
32
|
-
getByRole =
|
|
45
|
+
getByRole = _render4.getByRole;
|
|
33
46
|
|
|
34
47
|
var closeButton = getByRole("button");
|
|
35
48
|
|
|
36
49
|
_react2.fireEvent.click(closeButton);
|
|
37
50
|
|
|
51
|
+
expect(onCloseClick).toHaveBeenCalled();
|
|
52
|
+
});
|
|
53
|
+
test("Calls correct function onCloseClick when 'escape' key is pressed", function () {
|
|
54
|
+
var onCloseClick = jest.fn();
|
|
55
|
+
|
|
56
|
+
var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], {
|
|
57
|
+
onCloseClick: onCloseClick
|
|
58
|
+
}, "dialog-text")),
|
|
59
|
+
getByRole = _render5.getByRole;
|
|
60
|
+
|
|
61
|
+
_react2.fireEvent.keyDown(getByRole("button"), {
|
|
62
|
+
key: "Escape",
|
|
63
|
+
code: "Escape",
|
|
64
|
+
keyCode: 27,
|
|
65
|
+
charCode: 27
|
|
66
|
+
});
|
|
67
|
+
|
|
38
68
|
expect(onCloseClick).toHaveBeenCalled();
|
|
39
69
|
});
|
|
40
70
|
});
|
package/dialog/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;
|
|
@@ -26,6 +26,7 @@ declare type Props = {
|
|
|
26
26
|
*/
|
|
27
27
|
onBackgroundClick?: () => void;
|
|
28
28
|
/**
|
|
29
|
+
* @deprecated This prop will be removed shortly, consider using the Inset component for this purpose.
|
|
29
30
|
* Size of the padding to be applied to the component ('xxsmall' | 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge' | 'xxlarge').
|
|
30
31
|
* You can pass an object with 'top', 'bottom', 'left' and 'right' properties in order to specify different padding sizes.
|
|
31
32
|
*/
|
package/dropdown/Dropdown.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
/// <reference types="react" />
|
|
2
2
|
import DropdownPropsType from "./types";
|
|
3
|
-
declare const DxcDropdown: ({ options, optionsIconPosition, icon, iconPosition, label, caretHidden,
|
|
3
|
+
declare const DxcDropdown: ({ options, optionsIconPosition, icon, iconPosition, label, caretHidden, disabled, expandOnHover, onSelectOption, margin, size, tabIndex, }: DropdownPropsType) => JSX.Element;
|
|
4
4
|
export default DxcDropdown;
|