@dxc-technology/halstack-react 0.0.0-ecc45e2 → 0.0.0-ede733c
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/BackgroundColorContext.d.ts +2 -2
- package/BackgroundColorContext.js +1 -1
- package/HalstackContext.d.ts +1329 -5
- package/HalstackContext.js +117 -77
- package/accordion/Accordion.js +118 -110
- package/accordion/Accordion.stories.tsx +103 -15
- package/accordion/Accordion.test.js +10 -11
- package/accordion/types.d.ts +1 -0
- package/accordion-group/AccordionGroup.d.ts +4 -3
- package/accordion-group/AccordionGroup.js +24 -65
- package/accordion-group/AccordionGroup.stories.tsx +27 -1
- package/accordion-group/AccordionGroup.test.js +21 -46
- package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
- package/accordion-group/AccordionGroupAccordion.js +43 -0
- package/accordion-group/types.d.ts +7 -0
- package/alert/Alert.js +5 -9
- package/alert/Alert.stories.tsx +28 -0
- package/alert/Alert.test.js +1 -1
- package/bleed/Bleed.stories.tsx +1 -0
- package/box/Box.js +4 -6
- package/box/Box.stories.tsx +15 -0
- package/box/Box.test.js +1 -1
- package/box/types.d.ts +1 -0
- package/bulleted-list/BulletedList.js +4 -2
- package/bulleted-list/BulletedList.stories.tsx +7 -1
- package/bulleted-list/types.d.ts +31 -4
- package/button/Button.js +13 -16
- package/button/Button.stories.tsx +151 -9
- package/button/Button.test.js +1 -1
- package/button/types.d.ts +3 -3
- package/card/Card.js +12 -13
- package/card/Card.stories.tsx +12 -13
- package/card/Card.test.js +1 -1
- package/card/types.d.ts +1 -0
- package/checkbox/Checkbox.d.ts +2 -2
- package/checkbox/Checkbox.js +94 -101
- package/checkbox/Checkbox.stories.tsx +131 -59
- package/checkbox/Checkbox.test.js +94 -17
- package/checkbox/types.d.ts +4 -0
- package/chip/Chip.js +28 -49
- package/chip/Chip.stories.tsx +121 -26
- package/chip/Chip.test.js +3 -5
- package/common/OpenSans.css +68 -80
- package/common/coreTokens.d.ts +146 -0
- package/common/coreTokens.js +167 -0
- package/common/utils.d.ts +1 -0
- package/common/utils.js +4 -4
- package/common/variables.d.ts +1482 -0
- package/common/variables.js +994 -1137
- 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 +60 -73
- package/dialog/Dialog.stories.tsx +229 -121
- package/dialog/Dialog.test.js +302 -3
- package/dialog/types.d.ts +3 -2
- package/dropdown/Dropdown.js +43 -42
- package/dropdown/Dropdown.stories.tsx +210 -84
- package/dropdown/Dropdown.test.js +22 -27
- package/dropdown/DropdownMenu.js +12 -18
- package/dropdown/DropdownMenuItem.js +5 -18
- package/dropdown/types.d.ts +3 -3
- package/file-input/FileInput.d.ts +2 -2
- package/file-input/FileInput.js +174 -220
- package/file-input/FileInput.stories.tsx +122 -11
- package/file-input/FileInput.test.js +14 -14
- package/file-input/FileItem.d.ts +4 -14
- package/file-input/FileItem.js +39 -63
- package/file-input/types.d.ts +17 -0
- package/flex/Flex.d.ts +1 -1
- package/flex/Flex.js +33 -19
- package/flex/Flex.stories.tsx +35 -26
- package/flex/types.d.ts +83 -7
- package/footer/Footer.js +6 -8
- package/footer/Footer.stories.tsx +99 -1
- package/footer/Footer.test.js +14 -26
- package/footer/types.d.ts +1 -0
- package/grid/Grid.d.ts +7 -0
- package/grid/Grid.js +91 -0
- package/grid/Grid.stories.tsx +219 -0
- package/grid/types.d.ts +115 -0
- package/header/Header.d.ts +3 -2
- package/header/Header.js +21 -23
- package/header/Header.stories.tsx +152 -9
- package/header/Header.test.js +2 -2
- package/header/types.d.ts +3 -2
- package/heading/Heading.js +1 -1
- package/heading/Heading.test.js +1 -1
- package/inset/Inset.stories.tsx +2 -1
- package/layout/ApplicationLayout.d.ts +3 -3
- package/layout/ApplicationLayout.js +1 -1
- package/layout/ApplicationLayout.stories.tsx +1 -0
- package/layout/types.d.ts +2 -3
- package/link/Link.js +4 -4
- package/link/Link.stories.tsx +60 -0
- package/link/Link.test.js +2 -4
- package/link/types.d.ts +2 -2
- package/main.d.ts +3 -2
- package/main.js +9 -1
- package/{tabs-nav → nav-tabs}/NavTabs.js +1 -1
- package/{tabs-nav → nav-tabs}/NavTabs.stories.tsx +96 -6
- package/{tabs-nav → nav-tabs}/NavTabs.test.js +1 -1
- package/{tabs-nav → nav-tabs}/Tab.js +38 -18
- package/nav-tabs/types.js +5 -0
- package/number-input/NumberInput.test.js +44 -8
- package/package.json +15 -20
- package/paginator/Icons.d.ts +5 -0
- package/paginator/Icons.js +16 -28
- package/paginator/Paginator.js +7 -15
- package/paginator/Paginator.stories.tsx +24 -0
- package/paginator/Paginator.test.js +45 -48
- package/paragraph/Paragraph.d.ts +3 -4
- package/paragraph/Paragraph.js +5 -5
- package/password-input/PasswordInput.test.js +14 -13
- package/progress-bar/ProgressBar.d.ts +2 -2
- package/progress-bar/ProgressBar.js +5 -5
- package/progress-bar/ProgressBar.stories.jsx +35 -2
- package/progress-bar/ProgressBar.test.js +1 -1
- package/progress-bar/types.d.ts +4 -3
- package/quick-nav/QuickNav.js +11 -12
- package/quick-nav/QuickNav.stories.tsx +111 -19
- package/radio-group/Radio.d.ts +1 -1
- package/radio-group/Radio.js +43 -28
- package/radio-group/RadioGroup.js +15 -13
- package/radio-group/RadioGroup.stories.tsx +132 -18
- package/radio-group/RadioGroup.test.js +124 -97
- 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 +49 -108
- package/resultsetTable/ResultsetTable.stories.tsx +50 -25
- package/resultsetTable/ResultsetTable.test.js +41 -64
- package/resultsetTable/types.d.ts +1 -1
- package/select/Listbox.d.ts +1 -1
- package/select/Listbox.js +5 -35
- package/select/Option.js +11 -24
- package/select/Select.js +59 -36
- package/select/Select.stories.tsx +494 -150
- package/select/Select.test.js +341 -288
- package/select/types.d.ts +2 -2
- package/sidenav/Icons.d.ts +7 -0
- package/sidenav/Icons.js +51 -0
- package/sidenav/Sidenav.d.ts +2 -2
- package/sidenav/Sidenav.js +66 -96
- package/sidenav/Sidenav.stories.tsx +165 -63
- package/sidenav/types.d.ts +21 -18
- package/slider/Slider.d.ts +2 -2
- package/slider/Slider.js +119 -95
- package/slider/Slider.stories.tsx +64 -1
- package/slider/Slider.test.js +88 -25
- package/slider/types.d.ts +4 -0
- package/spinner/Spinner.js +17 -23
- package/spinner/Spinner.stories.jsx +53 -27
- package/spinner/Spinner.test.js +1 -1
- package/switch/Switch.d.ts +3 -3
- package/switch/Switch.js +96 -85
- package/switch/Switch.stories.tsx +33 -0
- package/switch/Switch.test.js +27 -14
- package/switch/types.d.ts +8 -3
- package/table/Table.js +3 -3
- package/table/Table.stories.jsx +80 -1
- package/table/Table.test.js +2 -2
- package/tabs/Tab.d.ts +4 -0
- package/tabs/Tab.js +132 -0
- package/tabs/Tabs.js +358 -108
- package/tabs/Tabs.stories.tsx +119 -5
- package/tabs/Tabs.test.js +220 -10
- package/tabs/types.d.ts +12 -2
- package/tag/Tag.js +8 -10
- package/tag/Tag.stories.tsx +14 -1
- package/tag/Tag.test.js +1 -1
- package/text-input/Icons.d.ts +8 -0
- package/text-input/Icons.js +60 -0
- package/text-input/Suggestion.js +40 -11
- package/text-input/Suggestions.d.ts +4 -0
- package/text-input/Suggestions.js +134 -0
- package/text-input/TextInput.js +189 -277
- package/text-input/TextInput.stories.tsx +280 -184
- package/text-input/TextInput.test.js +736 -725
- package/text-input/types.d.ts +21 -2
- package/textarea/Textarea.js +3 -4
- package/textarea/Textarea.stories.jsx +60 -1
- package/textarea/Textarea.test.js +2 -4
- package/toggle-group/ToggleGroup.d.ts +2 -2
- package/toggle-group/ToggleGroup.js +7 -4
- package/toggle-group/ToggleGroup.stories.tsx +42 -0
- package/toggle-group/ToggleGroup.test.js +1 -1
- package/toggle-group/types.d.ts +1 -1
- package/typography/Typography.d.ts +2 -2
- package/typography/Typography.js +14 -113
- package/typography/Typography.stories.tsx +1 -1
- package/useTheme.d.ts +1234 -1
- package/useTheme.js +1 -1
- package/useTranslatedLabels.d.ts +84 -1
- package/utils/BaseTypography.d.ts +21 -0
- package/utils/BaseTypography.js +108 -0
- package/utils/FocusLock.d.ts +13 -0
- package/utils/FocusLock.js +138 -0
- package/wizard/Wizard.js +2 -2
- package/wizard/Wizard.stories.tsx +20 -0
- package/wizard/Wizard.test.js +1 -1
- package/wizard/types.d.ts +5 -6
- package/common/RequiredComponent.js +0 -32
- /package/{tabs-nav → grid}/types.js +0 -0
- /package/{tabs-nav → nav-tabs}/NavTabs.d.ts +0 -0
- /package/{tabs-nav → nav-tabs}/Tab.d.ts +0 -0
- /package/{tabs-nav → nav-tabs}/types.d.ts +0 -0
package/tabs/Tabs.stories.tsx
CHANGED
|
@@ -2,6 +2,7 @@ import React from "react";
|
|
|
2
2
|
import DxcTabs from "./Tabs";
|
|
3
3
|
import Title from "../../.storybook/components/Title";
|
|
4
4
|
import ExampleContainer from "../../.storybook/components/ExampleContainer";
|
|
5
|
+
import { HalstackProvider } from "../HalstackContext";
|
|
5
6
|
|
|
6
7
|
export default {
|
|
7
8
|
title: "Tabs",
|
|
@@ -9,9 +10,8 @@ export default {
|
|
|
9
10
|
};
|
|
10
11
|
|
|
11
12
|
const iconSVG = (
|
|
12
|
-
<svg viewBox="0 0
|
|
13
|
-
<path d="
|
|
14
|
-
<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" />
|
|
13
|
+
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20" height="20" width="20" fill="currentColor">
|
|
14
|
+
<path d="m10 17-1.042-.938q-2.083-1.854-3.437-3.177-1.354-1.323-2.136-2.354Q2.604 9.5 2.302 8.646 2 7.792 2 6.896q0-1.854 1.271-3.125T6.396 2.5q1.021 0 1.979.438.958.437 1.625 1.229.667-.792 1.625-1.229.958-.438 1.979-.438 1.854 0 3.125 1.271T18 6.896q0 .896-.292 1.729-.291.833-1.073 1.854-.781 1.021-2.145 2.365-1.365 1.344-3.49 3.26Zm0-2.021q1.938-1.729 3.188-2.948 1.25-1.219 1.989-2.125.74-.906 1.031-1.614.292-.709.292-1.396 0-1.229-.833-2.063Q14.833 4 13.604 4q-.729 0-1.364.302-.636.302-1.094.844L10.417 6h-.834l-.729-.854q-.458-.542-1.114-.844Q7.083 4 6.396 4q-1.229 0-2.063.833-.833.834-.833 2.063 0 .687.271 1.364.271.678.989 1.573.719.896 1.98 2.125Q8 13.188 10 14.979Zm0-5.5Z" />
|
|
15
15
|
</svg>
|
|
16
16
|
);
|
|
17
17
|
|
|
@@ -29,6 +29,44 @@ const tabs: any = [
|
|
|
29
29
|
{
|
|
30
30
|
label: "Tab 4",
|
|
31
31
|
},
|
|
32
|
+
{
|
|
33
|
+
label: "Tab 5",
|
|
34
|
+
},
|
|
35
|
+
{
|
|
36
|
+
label: "Tab 6",
|
|
37
|
+
},
|
|
38
|
+
{
|
|
39
|
+
label: "Tab 7",
|
|
40
|
+
},
|
|
41
|
+
];
|
|
42
|
+
|
|
43
|
+
const disabledTabs: any = [
|
|
44
|
+
{
|
|
45
|
+
label: "Tab 1",
|
|
46
|
+
isDisabled: true,
|
|
47
|
+
},
|
|
48
|
+
{
|
|
49
|
+
label: "Tab 2",
|
|
50
|
+
isDisabled: true,
|
|
51
|
+
},
|
|
52
|
+
{
|
|
53
|
+
label: "Tab 3",
|
|
54
|
+
isDisabled: true,
|
|
55
|
+
},
|
|
56
|
+
];
|
|
57
|
+
|
|
58
|
+
const firstDisabledTabs: any = [
|
|
59
|
+
{
|
|
60
|
+
label: "Tab 1",
|
|
61
|
+
isDisabled: true,
|
|
62
|
+
},
|
|
63
|
+
{
|
|
64
|
+
label: "Tab 2",
|
|
65
|
+
isDisabled: true,
|
|
66
|
+
},
|
|
67
|
+
{
|
|
68
|
+
label: "Tab 3",
|
|
69
|
+
},
|
|
32
70
|
];
|
|
33
71
|
|
|
34
72
|
const tabsNotification = tabs.map((tab, index) => ({
|
|
@@ -36,16 +74,34 @@ const tabsNotification = tabs.map((tab, index) => ({
|
|
|
36
74
|
notificationNumber: (index === 0 && true) || (index === 1 && 5) || (index === 2 && 200),
|
|
37
75
|
}));
|
|
38
76
|
|
|
39
|
-
const tabsIcon = tabs.map((tab) =>
|
|
77
|
+
const tabsIcon = tabs.map((tab, index) =>
|
|
78
|
+
index <= tabs.length / 2
|
|
79
|
+
? { ...tab, icon: "https://cdn-icons-png.flaticon.com/512/5039/5039041.png" }
|
|
80
|
+
: { ...tab, icon: iconSVG }
|
|
81
|
+
);
|
|
40
82
|
|
|
41
83
|
const tabsNotificationIcon = tabsNotification.map((tab) => ({ ...tab, icon: iconSVG }));
|
|
42
84
|
|
|
85
|
+
const opinionatedTheme = {
|
|
86
|
+
tabs: {
|
|
87
|
+
baseColor: "#5f249f",
|
|
88
|
+
},
|
|
89
|
+
};
|
|
90
|
+
|
|
43
91
|
export const Chromatic = () => (
|
|
44
92
|
<>
|
|
45
93
|
<ExampleContainer>
|
|
46
94
|
<Title title="Only label" theme="light" level={4} />
|
|
47
95
|
<DxcTabs tabs={tabs} />
|
|
48
96
|
</ExampleContainer>
|
|
97
|
+
<ExampleContainer>
|
|
98
|
+
<Title title="Disabled tabs" theme="light" level={4} />
|
|
99
|
+
<DxcTabs activeTabIndex={0} tabs={disabledTabs} />
|
|
100
|
+
</ExampleContainer>
|
|
101
|
+
<ExampleContainer>
|
|
102
|
+
<Title title="First two tabs disabled" theme="light" level={4} />
|
|
103
|
+
<DxcTabs tabs={firstDisabledTabs} />
|
|
104
|
+
</ExampleContainer>
|
|
49
105
|
<ExampleContainer pseudoState="pseudo-hover">
|
|
50
106
|
<Title title="Hovered tabs" theme="light" level={4} />
|
|
51
107
|
<DxcTabs tabs={tabs} />
|
|
@@ -106,7 +162,65 @@ export const Chromatic = () => (
|
|
|
106
162
|
<ExampleContainer>
|
|
107
163
|
<Title title="Xxlarge margin" theme="light" level={4} />
|
|
108
164
|
<DxcTabs tabs={tabs} margin="xxlarge" />
|
|
109
|
-
|
|
165
|
+
</ExampleContainer>
|
|
166
|
+
<Title title="Opinionated theme" theme="light" level={2} />
|
|
167
|
+
<ExampleContainer>
|
|
168
|
+
<Title title="With icon and notification" theme="light" level={4} />
|
|
169
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
170
|
+
<DxcTabs tabs={tabsNotificationIcon} />
|
|
171
|
+
</HalstackProvider>
|
|
172
|
+
</ExampleContainer>
|
|
173
|
+
<ExampleContainer>
|
|
174
|
+
<Title title="Disabled" theme="light" level={4} />
|
|
175
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
176
|
+
<DxcTabs activeTabIndex={0} tabs={disabledTabs} />
|
|
177
|
+
</HalstackProvider>
|
|
178
|
+
</ExampleContainer>
|
|
179
|
+
<ExampleContainer pseudoState="pseudo-hover">
|
|
180
|
+
<Title title="Hovered" theme="light" level={4} />
|
|
181
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
182
|
+
<DxcTabs tabs={tabs} />
|
|
183
|
+
</HalstackProvider>
|
|
184
|
+
</ExampleContainer>
|
|
185
|
+
<ExampleContainer pseudoState="pseudo-focus">
|
|
186
|
+
<Title title="Focused" theme="light" level={4} />
|
|
187
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
188
|
+
<DxcTabs tabs={tabs} />
|
|
189
|
+
</HalstackProvider>
|
|
190
|
+
</ExampleContainer>
|
|
191
|
+
<ExampleContainer pseudoState="pseudo-active">
|
|
192
|
+
<Title title="Actived" theme="light" level={4} />
|
|
193
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
194
|
+
<DxcTabs tabs={tabs} />
|
|
195
|
+
</HalstackProvider>
|
|
110
196
|
</ExampleContainer>
|
|
111
197
|
</>
|
|
112
198
|
);
|
|
199
|
+
|
|
200
|
+
export const ScrollableTabs = () => (
|
|
201
|
+
<>
|
|
202
|
+
<ExampleContainer>
|
|
203
|
+
<Title title="Only label" theme="light" level={4} />
|
|
204
|
+
<DxcTabs tabs={tabs} />
|
|
205
|
+
</ExampleContainer>
|
|
206
|
+
<ExampleContainer pseudoState="pseudo-hover">
|
|
207
|
+
<Title title="Hovered tabs" theme="light" level={4} />
|
|
208
|
+
<DxcTabs tabs={tabs} />
|
|
209
|
+
</ExampleContainer>
|
|
210
|
+
<ExampleContainer pseudoState="pseudo-focus">
|
|
211
|
+
<Title title="Focused tabs" theme="light" level={4} />
|
|
212
|
+
<DxcTabs tabs={tabs} />
|
|
213
|
+
</ExampleContainer>
|
|
214
|
+
<ExampleContainer pseudoState="pseudo-active">
|
|
215
|
+
<Title title="Actived tabs" theme="light" level={4} />
|
|
216
|
+
<DxcTabs tabs={tabs} />
|
|
217
|
+
</ExampleContainer>
|
|
218
|
+
</>
|
|
219
|
+
);
|
|
220
|
+
|
|
221
|
+
ScrollableTabs.parameters = {
|
|
222
|
+
viewport: {
|
|
223
|
+
defaultViewport: "iphonex",
|
|
224
|
+
},
|
|
225
|
+
chromatic: { viewports: [375], delay: 5000 },
|
|
226
|
+
};
|
package/tabs/Tabs.test.js
CHANGED
|
@@ -6,7 +6,7 @@ var _react = _interopRequireDefault(require("react"));
|
|
|
6
6
|
|
|
7
7
|
var _react2 = require("@testing-library/react");
|
|
8
8
|
|
|
9
|
-
var _Tabs = _interopRequireDefault(require("./Tabs"));
|
|
9
|
+
var _Tabs = _interopRequireDefault(require("./Tabs.tsx"));
|
|
10
10
|
|
|
11
11
|
var sampleTabs = [{
|
|
12
12
|
label: "Tab-1"
|
|
@@ -17,13 +17,30 @@ var sampleTabs = [{
|
|
|
17
17
|
}];
|
|
18
18
|
var sampleTabsWithBadge = [{
|
|
19
19
|
label: "Tab-1",
|
|
20
|
-
notificationNumber:
|
|
20
|
+
notificationNumber: 10
|
|
21
21
|
}, {
|
|
22
22
|
label: "Tab-2",
|
|
23
|
-
notificationNumber:
|
|
23
|
+
notificationNumber: 20
|
|
24
24
|
}, {
|
|
25
25
|
label: "Tab-3",
|
|
26
|
-
notificationNumber:
|
|
26
|
+
notificationNumber: 101
|
|
27
|
+
}];
|
|
28
|
+
var sampleTabsMiddleDisabled = [{
|
|
29
|
+
label: "Tab-1"
|
|
30
|
+
}, {
|
|
31
|
+
label: "Tab-2",
|
|
32
|
+
isDisabled: true
|
|
33
|
+
}, {
|
|
34
|
+
label: "Tab-3"
|
|
35
|
+
}];
|
|
36
|
+
var sampleTabsLastTabNonDisabled = [{
|
|
37
|
+
label: "Tab-1",
|
|
38
|
+
isDisabled: true
|
|
39
|
+
}, {
|
|
40
|
+
label: "Tab-2",
|
|
41
|
+
isDisabled: true
|
|
42
|
+
}, {
|
|
43
|
+
label: "Tab-3"
|
|
27
44
|
}];
|
|
28
45
|
describe("Tabs component tests", function () {
|
|
29
46
|
test("Tabs render with correct labels", function () {
|
|
@@ -103,18 +120,26 @@ describe("Tabs component tests", function () {
|
|
|
103
120
|
tabs: sampleTabs,
|
|
104
121
|
onTabClick: onTabClick
|
|
105
122
|
})),
|
|
106
|
-
getByText = _render6.getByText
|
|
123
|
+
getByText = _render6.getByText,
|
|
124
|
+
getAllByRole = _render6.getAllByRole;
|
|
107
125
|
|
|
126
|
+
var tabs = getAllByRole("tab");
|
|
108
127
|
var tab1 = getByText("Tab-1");
|
|
109
128
|
var tab2 = getByText("Tab-2");
|
|
110
129
|
|
|
111
130
|
_react2.fireEvent.click(tab2);
|
|
112
131
|
|
|
113
132
|
expect(onTabClick).toHaveBeenCalledWith(1);
|
|
133
|
+
expect(tabs[0].getAttribute("aria-selected")).toBe("false");
|
|
134
|
+
expect(tabs[1].getAttribute("aria-selected")).toBe("true");
|
|
135
|
+
expect(tabs[2].getAttribute("aria-selected")).toBe("false");
|
|
114
136
|
|
|
115
137
|
_react2.fireEvent.click(tab1);
|
|
116
138
|
|
|
117
139
|
expect(onTabClick).toHaveBeenCalledWith(0);
|
|
140
|
+
expect(tabs[0].getAttribute("aria-selected")).toBe("true");
|
|
141
|
+
expect(tabs[1].getAttribute("aria-selected")).toBe("false");
|
|
142
|
+
expect(tabs[2].getAttribute("aria-selected")).toBe("false");
|
|
118
143
|
});
|
|
119
144
|
test("Controlled tabs", function () {
|
|
120
145
|
var onTabClick = jest.fn();
|
|
@@ -124,17 +149,202 @@ describe("Tabs component tests", function () {
|
|
|
124
149
|
onTabClick: onTabClick,
|
|
125
150
|
activeTabIndex: 0
|
|
126
151
|
})),
|
|
127
|
-
|
|
152
|
+
getAllByRole = _render7.getAllByRole;
|
|
128
153
|
|
|
129
|
-
var
|
|
130
|
-
var tab3 = getByText("Tab-3");
|
|
154
|
+
var tabs = getAllByRole("tab");
|
|
131
155
|
|
|
132
|
-
_react2.fireEvent.click(
|
|
156
|
+
_react2.fireEvent.click(tabs[1]);
|
|
157
|
+
|
|
158
|
+
expect(onTabClick).toHaveBeenCalledWith(1);
|
|
159
|
+
expect(tabs[0].getAttribute("aria-selected")).toBe("true");
|
|
160
|
+
expect(tabs[1].getAttribute("aria-selected")).toBe("false");
|
|
161
|
+
expect(tabs[2].getAttribute("aria-selected")).toBe("false");
|
|
162
|
+
|
|
163
|
+
_react2.fireEvent.click(tabs[2]);
|
|
164
|
+
|
|
165
|
+
expect(onTabClick).toHaveBeenCalledWith(2);
|
|
166
|
+
expect(tabs[0].getAttribute("aria-selected")).toBe("true");
|
|
167
|
+
expect(tabs[1].getAttribute("aria-selected")).toBe("false");
|
|
168
|
+
expect(tabs[2].getAttribute("aria-selected")).toBe("false");
|
|
169
|
+
});
|
|
170
|
+
test("Uncontrolled tabs should have focus in the first non-disabled tab", function () {
|
|
171
|
+
var onTabClick = jest.fn();
|
|
172
|
+
|
|
173
|
+
var _render8 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Tabs["default"], {
|
|
174
|
+
tabs: sampleTabsLastTabNonDisabled,
|
|
175
|
+
onTabClick: onTabClick
|
|
176
|
+
})),
|
|
177
|
+
getAllByRole = _render8.getAllByRole;
|
|
178
|
+
|
|
179
|
+
var tabs = getAllByRole("tab");
|
|
180
|
+
expect(tabs[0].hasAttribute("disabled")).toBeTruthy();
|
|
181
|
+
expect(tabs[1].hasAttribute("disabled")).toBeTruthy();
|
|
182
|
+
expect(tabs[2].hasAttribute("disabled")).toBeFalsy();
|
|
183
|
+
expect(tabs[0].getAttribute("aria-selected")).toBe("false");
|
|
184
|
+
expect(tabs[1].getAttribute("aria-selected")).toBe("false");
|
|
185
|
+
expect(tabs[2].getAttribute("aria-selected")).toBe("true");
|
|
186
|
+
});
|
|
187
|
+
test("Controlled tabs with active index in disabled tab should not change focus to the first available tab", function () {
|
|
188
|
+
var onTabClick = jest.fn();
|
|
189
|
+
|
|
190
|
+
var _render9 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Tabs["default"], {
|
|
191
|
+
tabs: sampleTabsLastTabNonDisabled,
|
|
192
|
+
onTabClick: onTabClick,
|
|
193
|
+
activeTabIndex: 0
|
|
194
|
+
})),
|
|
195
|
+
getAllByRole = _render9.getAllByRole;
|
|
196
|
+
|
|
197
|
+
var tabs = getAllByRole("tab");
|
|
198
|
+
expect(tabs[0].getAttribute("aria-selected")).toBe("true");
|
|
199
|
+
expect(tabs[1].getAttribute("aria-selected")).toBe("false");
|
|
200
|
+
expect(tabs[2].getAttribute("aria-selected")).toBe("false");
|
|
201
|
+
expect(tabs[0].hasAttribute("disabled")).toBeTruthy();
|
|
202
|
+
expect(tabs[1].hasAttribute("disabled")).toBeTruthy();
|
|
203
|
+
expect(tabs[2].hasAttribute("disabled")).toBeFalsy();
|
|
204
|
+
|
|
205
|
+
_react2.fireEvent.click(tabs[2]);
|
|
206
|
+
|
|
207
|
+
expect(onTabClick).toHaveBeenCalledWith(2);
|
|
208
|
+
expect(tabs[0].getAttribute("aria-selected")).toBe("true");
|
|
209
|
+
expect(tabs[1].getAttribute("aria-selected")).toBe("false");
|
|
210
|
+
expect(tabs[2].getAttribute("aria-selected")).toBe("false");
|
|
211
|
+
expect(tabs[0].hasAttribute("disabled")).toBeTruthy();
|
|
212
|
+
expect(tabs[1].hasAttribute("disabled")).toBeTruthy();
|
|
213
|
+
expect(tabs[2].hasAttribute("disabled")).toBeFalsy();
|
|
214
|
+
});
|
|
215
|
+
test("Select tabs with keyboard event arrows", function () {
|
|
216
|
+
var onTabClick = jest.fn();
|
|
217
|
+
|
|
218
|
+
var _render10 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Tabs["default"], {
|
|
219
|
+
tabs: sampleTabs,
|
|
220
|
+
onTabClick: onTabClick
|
|
221
|
+
})),
|
|
222
|
+
getByText = _render10.getByText,
|
|
223
|
+
getByRole = _render10.getByRole,
|
|
224
|
+
getAllByRole = _render10.getAllByRole;
|
|
225
|
+
|
|
226
|
+
var tabList = getByRole("tablist");
|
|
227
|
+
var tab1 = getByText("Tab-1");
|
|
228
|
+
var tabs = getAllByRole("tab");
|
|
229
|
+
|
|
230
|
+
_react2.fireEvent.click(tab1);
|
|
231
|
+
|
|
232
|
+
expect(tabs[0].getAttribute("aria-selected")).toBe("true");
|
|
233
|
+
expect(tabs[1].getAttribute("aria-selected")).toBe("false");
|
|
234
|
+
expect(tabs[2].getAttribute("aria-selected")).toBe("false");
|
|
235
|
+
expect(onTabClick).toHaveBeenCalledWith(0);
|
|
133
236
|
|
|
237
|
+
_react2.fireEvent.keyDown(tabList, {
|
|
238
|
+
key: "ArrowRight"
|
|
239
|
+
});
|
|
240
|
+
|
|
241
|
+
_react2.fireEvent.keyDown(tabList, {
|
|
242
|
+
key: "Enter"
|
|
243
|
+
});
|
|
244
|
+
|
|
245
|
+
expect(tabs[0].getAttribute("aria-selected")).toBe("false");
|
|
246
|
+
expect(tabs[1].getAttribute("aria-selected")).toBe("true");
|
|
247
|
+
expect(tabs[2].getAttribute("aria-selected")).toBe("false");
|
|
134
248
|
expect(onTabClick).toHaveBeenCalledWith(1);
|
|
135
249
|
|
|
136
|
-
_react2.fireEvent.
|
|
250
|
+
_react2.fireEvent.keyDown(tabList, {
|
|
251
|
+
key: "ArrowRight"
|
|
252
|
+
});
|
|
253
|
+
|
|
254
|
+
_react2.fireEvent.keyDown(tabList, {
|
|
255
|
+
key: "Enter"
|
|
256
|
+
});
|
|
257
|
+
|
|
258
|
+
expect(tabs[0].getAttribute("aria-selected")).toBe("false");
|
|
259
|
+
expect(tabs[1].getAttribute("aria-selected")).toBe("false");
|
|
260
|
+
expect(tabs[2].getAttribute("aria-selected")).toBe("true");
|
|
261
|
+
expect(onTabClick).toHaveBeenCalledWith(2);
|
|
262
|
+
|
|
263
|
+
_react2.fireEvent.keyDown(tabList, {
|
|
264
|
+
key: "ArrowLeft"
|
|
265
|
+
});
|
|
266
|
+
|
|
267
|
+
_react2.fireEvent.keyDown(tabList, {
|
|
268
|
+
key: "Enter"
|
|
269
|
+
});
|
|
270
|
+
|
|
271
|
+
expect(tabs[0].getAttribute("aria-selected")).toBe("false");
|
|
272
|
+
expect(tabs[1].getAttribute("aria-selected")).toBe("true");
|
|
273
|
+
expect(tabs[2].getAttribute("aria-selected")).toBe("false");
|
|
274
|
+
expect(onTabClick).toHaveBeenCalledWith(1);
|
|
275
|
+
|
|
276
|
+
_react2.fireEvent.keyDown(tabList, {
|
|
277
|
+
key: "ArrowLeft"
|
|
278
|
+
});
|
|
279
|
+
|
|
280
|
+
_react2.fireEvent.keyDown(tabList, {
|
|
281
|
+
key: "Enter"
|
|
282
|
+
});
|
|
283
|
+
|
|
284
|
+
expect(tabs[0].getAttribute("aria-selected")).toBe("true");
|
|
285
|
+
expect(tabs[1].getAttribute("aria-selected")).toBe("false");
|
|
286
|
+
expect(tabs[2].getAttribute("aria-selected")).toBe("false");
|
|
287
|
+
expect(onTabClick).toHaveBeenCalledWith(0);
|
|
288
|
+
|
|
289
|
+
_react2.fireEvent.keyDown(tabList, {
|
|
290
|
+
key: "ArrowLeft"
|
|
291
|
+
});
|
|
137
292
|
|
|
293
|
+
_react2.fireEvent.keyDown(tabList, {
|
|
294
|
+
key: "Enter"
|
|
295
|
+
});
|
|
296
|
+
|
|
297
|
+
expect(tabs[0].getAttribute("aria-selected")).toBe("false");
|
|
298
|
+
expect(tabs[1].getAttribute("aria-selected")).toBe("false");
|
|
299
|
+
expect(tabs[2].getAttribute("aria-selected")).toBe("true");
|
|
300
|
+
expect(onTabClick).toHaveBeenCalledWith(2);
|
|
301
|
+
|
|
302
|
+
_react2.fireEvent.keyDown(tabList, {
|
|
303
|
+
key: "ArrowRight"
|
|
304
|
+
});
|
|
305
|
+
|
|
306
|
+
_react2.fireEvent.keyDown(tabList, {
|
|
307
|
+
key: "Enter"
|
|
308
|
+
});
|
|
309
|
+
|
|
310
|
+
expect(tabs[0].getAttribute("aria-selected")).toBe("true");
|
|
311
|
+
expect(tabs[1].getAttribute("aria-selected")).toBe("false");
|
|
312
|
+
expect(tabs[2].getAttribute("aria-selected")).toBe("false");
|
|
313
|
+
expect(onTabClick).toHaveBeenCalledWith(0);
|
|
314
|
+
});
|
|
315
|
+
test("Skip disabled tab with keyboard event arrows", function () {
|
|
316
|
+
var onTabClick = jest.fn();
|
|
317
|
+
|
|
318
|
+
var _render11 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Tabs["default"], {
|
|
319
|
+
tabs: sampleTabsMiddleDisabled,
|
|
320
|
+
onTabClick: onTabClick
|
|
321
|
+
})),
|
|
322
|
+
getByText = _render11.getByText,
|
|
323
|
+
getByRole = _render11.getByRole,
|
|
324
|
+
getAllByRole = _render11.getAllByRole;
|
|
325
|
+
|
|
326
|
+
var tabList = getByRole("tablist");
|
|
327
|
+
var tab1 = getByText("Tab-1");
|
|
328
|
+
var tabs = getAllByRole("tab");
|
|
329
|
+
|
|
330
|
+
_react2.fireEvent.click(tab1);
|
|
331
|
+
|
|
332
|
+
expect(tabs[0].getAttribute("aria-selected")).toBe("true");
|
|
333
|
+
expect(tabs[1].getAttribute("aria-selected")).toBe("false");
|
|
334
|
+
expect(tabs[2].getAttribute("aria-selected")).toBe("false");
|
|
335
|
+
expect(onTabClick).toHaveBeenCalledWith(0);
|
|
336
|
+
|
|
337
|
+
_react2.fireEvent.keyDown(tabList, {
|
|
338
|
+
key: "ArrowRight"
|
|
339
|
+
});
|
|
340
|
+
|
|
341
|
+
_react2.fireEvent.keyDown(tabList, {
|
|
342
|
+
key: " "
|
|
343
|
+
});
|
|
344
|
+
|
|
345
|
+
expect(tabs[0].getAttribute("aria-selected")).toBe("false");
|
|
346
|
+
expect(tabs[1].getAttribute("aria-selected")).toBe("false");
|
|
347
|
+
expect(tabs[2].getAttribute("aria-selected")).toBe("true");
|
|
138
348
|
expect(onTabClick).toHaveBeenCalledWith(2);
|
|
139
349
|
});
|
|
140
350
|
});
|
package/tabs/types.d.ts
CHANGED
|
@@ -21,7 +21,7 @@ declare type TabCommonProps = {
|
|
|
21
21
|
*/
|
|
22
22
|
notificationNumber?: boolean | number;
|
|
23
23
|
};
|
|
24
|
-
declare type TabLabelProps = TabCommonProps & {
|
|
24
|
+
export declare type TabLabelProps = TabCommonProps & {
|
|
25
25
|
/**
|
|
26
26
|
* Tab label.
|
|
27
27
|
*/
|
|
@@ -31,7 +31,7 @@ declare type TabLabelProps = TabCommonProps & {
|
|
|
31
31
|
*/
|
|
32
32
|
icon?: string | SVG;
|
|
33
33
|
};
|
|
34
|
-
declare type TabIconProps = TabCommonProps & {
|
|
34
|
+
export declare type TabIconProps = TabCommonProps & {
|
|
35
35
|
/**
|
|
36
36
|
* Tab label.
|
|
37
37
|
*/
|
|
@@ -41,6 +41,16 @@ declare type TabIconProps = TabCommonProps & {
|
|
|
41
41
|
*/
|
|
42
42
|
icon: string | SVG;
|
|
43
43
|
};
|
|
44
|
+
export declare type TabProps = {
|
|
45
|
+
tab: TabLabelProps | TabIconProps;
|
|
46
|
+
active: boolean;
|
|
47
|
+
tabIndex: number;
|
|
48
|
+
hasLabelAndIcon: boolean;
|
|
49
|
+
iconPosition: "top" | "left";
|
|
50
|
+
onClick: () => void;
|
|
51
|
+
onMouseEnter: () => void;
|
|
52
|
+
onMouseLeave: () => void;
|
|
53
|
+
};
|
|
44
54
|
declare type Props = {
|
|
45
55
|
/**
|
|
46
56
|
* An array of objects representing the tabs.
|
package/tag/Tag.js
CHANGED
|
@@ -19,11 +19,11 @@ var _react = _interopRequireWildcard(require("react"));
|
|
|
19
19
|
|
|
20
20
|
var _styledComponents = _interopRequireWildcard(require("styled-components"));
|
|
21
21
|
|
|
22
|
-
var _variables = require("../common/variables
|
|
22
|
+
var _variables = require("../common/variables");
|
|
23
23
|
|
|
24
24
|
var _useTheme = _interopRequireDefault(require("../useTheme"));
|
|
25
25
|
|
|
26
|
-
var _utils = require("../common/utils
|
|
26
|
+
var _utils = require("../common/utils");
|
|
27
27
|
|
|
28
28
|
var _Box = _interopRequireDefault(require("../box/Box"));
|
|
29
29
|
|
|
@@ -64,9 +64,7 @@ var DxcTag = function DxcTag(_ref) {
|
|
|
64
64
|
var tagContent = /*#__PURE__*/_react["default"].createElement(_Box["default"], {
|
|
65
65
|
size: size,
|
|
66
66
|
shadowDepth: isHovered && (onClick || linkHref) && 2 || 1
|
|
67
|
-
}, /*#__PURE__*/_react["default"].createElement(TagContent, {
|
|
68
|
-
labelPosition: labelPosition
|
|
69
|
-
}, labelPosition === "before" && size !== "small" && label && /*#__PURE__*/_react["default"].createElement(TagLabel, null, label), icon && /*#__PURE__*/_react["default"].createElement(IconContainer, {
|
|
67
|
+
}, /*#__PURE__*/_react["default"].createElement(TagContent, null, labelPosition === "before" && size !== "small" && label && /*#__PURE__*/_react["default"].createElement(TagLabel, null, label), icon && /*#__PURE__*/_react["default"].createElement(IconContainer, {
|
|
70
68
|
iconBgColor: iconBgColor
|
|
71
69
|
}, typeof icon === "string" ? /*#__PURE__*/_react["default"].createElement(TagIcon, {
|
|
72
70
|
src: icon
|
|
@@ -99,7 +97,7 @@ var sizes = {
|
|
|
99
97
|
medium: "240px",
|
|
100
98
|
large: "480px",
|
|
101
99
|
fillParent: "100%",
|
|
102
|
-
fitContent: "
|
|
100
|
+
fitContent: "fit-content"
|
|
103
101
|
};
|
|
104
102
|
|
|
105
103
|
var calculateWidth = function calculateWidth(margin, size) {
|
|
@@ -114,16 +112,16 @@ var StyledDxcTag = _styledComponents["default"].div(_templateObject || (_templat
|
|
|
114
112
|
return margin && (0, _typeof2["default"])(margin) !== "object" ? _variables.spaces[margin] : "0px";
|
|
115
113
|
}, function (_ref4) {
|
|
116
114
|
var margin = _ref4.margin;
|
|
117
|
-
return margin && margin.top ? _variables.spaces[margin.top] : "";
|
|
115
|
+
return margin && (0, _typeof2["default"])(margin) === "object" && margin.top ? _variables.spaces[margin.top] : "";
|
|
118
116
|
}, function (_ref5) {
|
|
119
117
|
var margin = _ref5.margin;
|
|
120
|
-
return margin && margin.right ? _variables.spaces[margin.right] : "";
|
|
118
|
+
return margin && (0, _typeof2["default"])(margin) === "object" && margin.right ? _variables.spaces[margin.right] : "";
|
|
121
119
|
}, function (_ref6) {
|
|
122
120
|
var margin = _ref6.margin;
|
|
123
|
-
return margin && margin.bottom ? _variables.spaces[margin.bottom] : "";
|
|
121
|
+
return margin && (0, _typeof2["default"])(margin) === "object" && margin.bottom ? _variables.spaces[margin.bottom] : "";
|
|
124
122
|
}, function (_ref7) {
|
|
125
123
|
var margin = _ref7.margin;
|
|
126
|
-
return margin && margin.left ? _variables.spaces[margin.left] : "";
|
|
124
|
+
return margin && (0, _typeof2["default"])(margin) === "object" && margin.left ? _variables.spaces[margin.left] : "";
|
|
127
125
|
}, function (props) {
|
|
128
126
|
return calculateWidth(props.margin, props.size);
|
|
129
127
|
}, function (props) {
|
package/tag/Tag.stories.tsx
CHANGED
|
@@ -3,6 +3,7 @@ import { userEvent, within } from "@storybook/testing-library";
|
|
|
3
3
|
import Title from "../../.storybook/components/Title";
|
|
4
4
|
import ExampleContainer from "../../.storybook/components/ExampleContainer";
|
|
5
5
|
import DxcTag from "./Tag";
|
|
6
|
+
import { HalstackProvider } from "../HalstackContext";
|
|
6
7
|
|
|
7
8
|
export default {
|
|
8
9
|
title: "Tag",
|
|
@@ -23,6 +24,13 @@ const largeIcon = (
|
|
|
23
24
|
</svg>
|
|
24
25
|
);
|
|
25
26
|
|
|
27
|
+
const opinionatedTheme = {
|
|
28
|
+
tag: {
|
|
29
|
+
fontColor: "#000000",
|
|
30
|
+
iconColor: "#ffffff",
|
|
31
|
+
},
|
|
32
|
+
};
|
|
33
|
+
|
|
26
34
|
export const Chromatic = () => (
|
|
27
35
|
<>
|
|
28
36
|
<ExampleContainer>
|
|
@@ -124,7 +132,12 @@ export const Chromatic = () => (
|
|
|
124
132
|
<Title title="FitContent size" theme="light" level={4} />
|
|
125
133
|
<DxcTag label="FitContent" size="fitContent" icon={icon} />
|
|
126
134
|
</ExampleContainer>
|
|
127
|
-
<
|
|
135
|
+
<Title title="Opinionated theme" theme="light" level={2} />
|
|
136
|
+
<ExampleContainer>
|
|
137
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
138
|
+
<DxcTag label="Tag" icon={icon} />
|
|
139
|
+
</HalstackProvider>
|
|
140
|
+
</ExampleContainer>
|
|
128
141
|
</>
|
|
129
142
|
);
|
|
130
143
|
|
package/tag/Tag.test.js
CHANGED
|
@@ -6,7 +6,7 @@ var _react = _interopRequireDefault(require("react"));
|
|
|
6
6
|
|
|
7
7
|
var _react2 = require("@testing-library/react");
|
|
8
8
|
|
|
9
|
-
var _Tag = _interopRequireDefault(require("./Tag"));
|
|
9
|
+
var _Tag = _interopRequireDefault(require("./Tag.tsx"));
|
|
10
10
|
|
|
11
11
|
describe("Tag component tests", function () {
|
|
12
12
|
test("Tag renders with correct label", function () {
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports["default"] = void 0;
|
|
9
|
+
|
|
10
|
+
var _react = _interopRequireDefault(require("react"));
|
|
11
|
+
|
|
12
|
+
var icons = {
|
|
13
|
+
error: /*#__PURE__*/_react["default"].createElement("svg", {
|
|
14
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
15
|
+
height: "24px",
|
|
16
|
+
viewBox: "0 0 24 24",
|
|
17
|
+
width: "24px",
|
|
18
|
+
fill: "currentColor"
|
|
19
|
+
}, /*#__PURE__*/_react["default"].createElement("path", {
|
|
20
|
+
d: "M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm1 15h-2v-2h2v2zm0-4h-2V7h2v6z"
|
|
21
|
+
})),
|
|
22
|
+
clear: /*#__PURE__*/_react["default"].createElement("svg", {
|
|
23
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
24
|
+
width: "24",
|
|
25
|
+
height: "24",
|
|
26
|
+
viewBox: "0 0 24 24",
|
|
27
|
+
fill: "currentColor"
|
|
28
|
+
}, /*#__PURE__*/_react["default"].createElement("path", {
|
|
29
|
+
d: "M0 0h24v24H0V0z",
|
|
30
|
+
fill: "none"
|
|
31
|
+
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
32
|
+
d: "M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12 19 6.41z"
|
|
33
|
+
})),
|
|
34
|
+
increment: /*#__PURE__*/_react["default"].createElement("svg", {
|
|
35
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
36
|
+
height: "24px",
|
|
37
|
+
viewBox: "0 0 24 24",
|
|
38
|
+
width: "24px",
|
|
39
|
+
fill: "currentColor"
|
|
40
|
+
}, /*#__PURE__*/_react["default"].createElement("path", {
|
|
41
|
+
d: "M0 0h24v24H0z",
|
|
42
|
+
fill: "none"
|
|
43
|
+
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
44
|
+
d: "M19 13h-6v6h-2v-6H5v-2h6V5h2v6h6v2z"
|
|
45
|
+
})),
|
|
46
|
+
decrement: /*#__PURE__*/_react["default"].createElement("svg", {
|
|
47
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
48
|
+
height: "24px",
|
|
49
|
+
viewBox: "0 0 24 24",
|
|
50
|
+
width: "24px",
|
|
51
|
+
fill: "currentColor"
|
|
52
|
+
}, /*#__PURE__*/_react["default"].createElement("path", {
|
|
53
|
+
d: "M0 0h24v24H0z",
|
|
54
|
+
fill: "none"
|
|
55
|
+
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
56
|
+
d: "M19 13H5v-2h14v2z"
|
|
57
|
+
}))
|
|
58
|
+
};
|
|
59
|
+
var _default = icons;
|
|
60
|
+
exports["default"] = _default;
|