@dxc-technology/halstack-react 0.0.0-c9c1158 → 0.0.0-c9efd3e
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 +1 -10
- package/BackgroundColorContext.js +2 -7
- package/HalstackContext.d.ts +29 -133
- package/HalstackContext.js +1 -1
- package/accordion/Accordion.accessibility.test.js +71 -0
- package/accordion/Accordion.js +10 -26
- package/accordion/Accordion.stories.tsx +4 -36
- package/accordion/types.d.ts +1 -1
- package/accordion-group/AccordionGroup.accessibility.test.js +88 -0
- package/accordion-group/AccordionGroup.d.ts +2 -3
- package/accordion-group/AccordionGroup.js +3 -3
- package/accordion-group/AccordionGroupAccordion.js +2 -2
- package/accordion-group/AccordionGroupContext.d.ts +3 -0
- package/accordion-group/AccordionGroupContext.js +8 -0
- package/accordion-group/types.d.ts +1 -1
- package/action-icon/ActionIcon.accessibility.test.js +63 -0
- package/action-icon/ActionIcon.d.ts +4 -0
- package/action-icon/ActionIcon.js +48 -0
- package/action-icon/ActionIcon.stories.tsx +41 -0
- package/action-icon/ActionIcon.test.js +64 -0
- package/action-icon/types.d.ts +26 -0
- package/action-icon/types.js +5 -0
- package/alert/Alert.accessibility.test.js +95 -0
- package/alert/Alert.js +15 -72
- package/badge/Badge.accessibility.test.js +129 -0
- package/badge/Badge.d.ts +1 -1
- package/badge/Badge.js +141 -28
- package/badge/Badge.stories.tsx +210 -0
- package/badge/Badge.test.js +30 -0
- package/badge/types.d.ts +52 -3
- package/box/Box.accessibility.test.js +33 -0
- package/box/Box.js +1 -4
- package/bulleted-list/BulletedList.accessibility.test.js +107 -0
- package/bulleted-list/BulletedList.js +15 -22
- package/bulleted-list/BulletedList.stories.tsx +1 -2
- package/button/Button.accessibility.test.js +127 -0
- package/button/Button.js +15 -15
- package/button/Button.stories.tsx +32 -51
- package/button/Button.test.js +3 -1
- package/button/types.d.ts +1 -1
- package/card/Card.accessibility.test.js +36 -0
- package/checkbox/Checkbox.accessibility.test.js +87 -0
- package/checkbox/Checkbox.js +26 -31
- package/chip/Chip.accessibility.test.js +67 -0
- package/chip/Chip.js +8 -5
- package/chip/Chip.stories.tsx +5 -24
- package/chip/Chip.test.js +4 -4
- package/common/coreTokens.d.ts +1 -1
- package/common/coreTokens.js +3 -3
- package/common/variables.d.ts +29 -133
- package/common/variables.js +38 -142
- package/container/Container.js +3 -7
- package/container/Container.stories.tsx +10 -25
- package/contextual-menu/ContextualMenu.accessibility.test.js +86 -0
- package/contextual-menu/ContextualMenu.d.ts +7 -0
- package/contextual-menu/ContextualMenu.js +71 -0
- package/contextual-menu/ContextualMenu.stories.tsx +182 -0
- package/contextual-menu/ContextualMenu.test.js +71 -0
- package/contextual-menu/MenuItemAction.d.ts +4 -0
- package/contextual-menu/MenuItemAction.js +46 -0
- package/contextual-menu/types.d.ts +22 -0
- package/contextual-menu/types.js +5 -0
- package/date-input/DateInput.accessibility.test.js +216 -0
- package/date-input/types.d.ts +2 -2
- package/dialog/Dialog.accessibility.test.js +69 -0
- package/dialog/Dialog.js +2 -5
- package/dialog/Dialog.stories.tsx +170 -0
- package/dialog/Dialog.test.js +1 -1
- package/divider/Divider.accessibility.test.js +33 -0
- package/divider/Divider.d.ts +4 -0
- package/divider/Divider.js +36 -0
- package/divider/Divider.stories.tsx +223 -0
- package/divider/Divider.test.js +38 -0
- package/divider/types.d.ts +21 -0
- package/divider/types.js +5 -0
- package/dropdown/Dropdown.accessibility.test.js +180 -0
- package/dropdown/Dropdown.js +21 -36
- package/dropdown/Dropdown.stories.tsx +5 -16
- package/dropdown/DropdownMenuItem.js +6 -3
- package/dropdown/types.d.ts +3 -5
- package/file-input/FileInput.accessibility.test.js +160 -0
- package/file-input/FileInput.js +3 -39
- package/file-input/FileInput.test.js +7 -84
- package/file-input/FileItem.js +13 -27
- package/footer/Footer.accessibility.test.js +117 -0
- package/footer/Footer.d.ts +1 -1
- package/footer/Footer.js +36 -31
- package/footer/Footer.stories.tsx +46 -2
- package/footer/Icons.d.ts +1 -0
- package/footer/Icons.js +65 -1
- package/footer/types.d.ts +8 -8
- package/header/Header.accessibility.test.js +84 -0
- package/header/Header.js +18 -40
- package/header/types.d.ts +4 -3
- package/heading/Heading.accessibility.test.js +33 -0
- package/icon/Icon.accessibility.test.js +30 -0
- package/icon/Icon.d.ts +4 -0
- package/icon/Icon.js +33 -0
- package/icon/Icon.stories.tsx +28 -0
- package/icon/types.d.ts +4 -0
- package/icon/types.js +5 -0
- package/image/Image.accessibility.test.js +56 -0
- package/image/Image.stories.tsx +3 -1
- package/layout/ApplicationLayout.d.ts +1 -1
- package/layout/ApplicationLayout.js +1 -1
- package/layout/Icons.js +0 -2
- package/link/Link.accessibility.test.js +112 -0
- package/link/Link.js +7 -5
- package/link/Link.stories.tsx +2 -2
- package/link/types.d.ts +1 -1
- package/main.d.ts +5 -3
- package/main.js +22 -8
- package/nav-tabs/NavTabs.accessibility.test.js +52 -0
- package/nav-tabs/NavTabs.d.ts +1 -2
- package/nav-tabs/NavTabs.js +9 -6
- package/nav-tabs/NavTabs.stories.tsx +6 -4
- package/nav-tabs/NavTabs.test.js +3 -2
- package/nav-tabs/NavTabsContext.d.ts +3 -0
- package/nav-tabs/NavTabsContext.js +8 -0
- package/nav-tabs/Tab.js +8 -7
- package/number-input/NumberInput.accessibility.test.js +228 -0
- package/number-input/NumberInput.d.ts +0 -7
- package/number-input/NumberInput.js +24 -5
- package/number-input/NumberInput.test.js +165 -6
- package/number-input/NumberInputContext.d.ts +3 -0
- package/number-input/NumberInputContext.js +8 -0
- package/number-input/types.d.ts +6 -0
- package/package.json +12 -12
- package/paginator/Paginator.accessibility.test.js +79 -0
- package/paginator/Paginator.js +1 -4
- package/paragraph/Paragraph.accessibility.test.js +28 -0
- package/paragraph/Paragraph.js +2 -7
- package/password-input/PasswordInput.accessibility.test.js +153 -0
- package/password-input/PasswordInput.stories.tsx +0 -1
- package/progress-bar/ProgressBar.accessibility.test.js +35 -0
- package/progress-bar/ProgressBar.js +5 -11
- package/quick-nav/QuickNav.accessibility.test.js +57 -0
- package/radio-group/RadioGroup.accessibility.test.js +97 -0
- package/radio-group/RadioGroup.js +1 -1
- package/resultset-table/ResultsetTable.accessibility.test.js +274 -0
- package/resultset-table/ResultsetTable.d.ts +4 -1
- package/resultset-table/ResultsetTable.js +23 -12
- package/resultset-table/ResultsetTable.stories.tsx +106 -5
- package/resultset-table/ResultsetTable.test.js +76 -0
- package/resultset-table/types.d.ts +40 -7
- package/select/Option.js +8 -1
- package/select/Select.accessibility.test.js +217 -0
- package/select/Select.js +35 -27
- package/select/Select.stories.tsx +0 -1
- package/select/Select.test.js +498 -462
- package/select/types.d.ts +2 -2
- package/sidenav/Sidenav.accessibility.test.js +59 -0
- package/sidenav/Sidenav.js +20 -18
- package/sidenav/Sidenav.stories.tsx +4 -9
- package/sidenav/types.d.ts +2 -2
- package/slider/Slider.accessibility.test.js +104 -0
- package/slider/Slider.js +37 -46
- package/spinner/Spinner.accessibility.test.js +96 -0
- package/spinner/Spinner.js +6 -14
- package/status-light/StatusLight.accessibility.test.js +157 -0
- package/status-light/StatusLight.d.ts +4 -0
- package/status-light/StatusLight.js +51 -0
- package/status-light/StatusLight.stories.tsx +74 -0
- package/status-light/StatusLight.test.js +25 -0
- package/status-light/types.d.ts +17 -0
- package/status-light/types.js +5 -0
- package/switch/Switch.accessibility.test.js +89 -0
- package/switch/Switch.js +23 -28
- package/table/DropdownTheme.js +62 -0
- package/table/Table.accessibility.test.js +82 -0
- package/table/Table.d.ts +6 -2
- package/table/Table.js +73 -11
- package/table/Table.stories.tsx +297 -2
- package/table/Table.test.js +92 -0
- package/table/types.d.ts +28 -0
- package/tabs/Tab.js +7 -4
- package/tabs/Tabs.accessibility.test.js +56 -0
- package/tabs/Tabs.js +4 -5
- package/tabs/Tabs.stories.tsx +1 -1
- package/tag/Tag.accessibility.test.js +69 -0
- package/tag/Tag.js +6 -6
- package/tag/Tag.stories.tsx +4 -7
- package/tag/Tag.test.js +4 -12
- package/tag/types.d.ts +2 -2
- package/text-input/Suggestions.js +7 -10
- package/text-input/TextInput.accessibility.test.js +321 -0
- package/text-input/TextInput.js +77 -102
- package/text-input/TextInput.stories.tsx +1 -1
- package/text-input/TextInput.test.js +96 -79
- package/textarea/Textarea.accessibility.test.js +155 -0
- package/textarea/Textarea.js +10 -16
- package/textarea/Textarea.stories.tsx +0 -1
- package/toggle-group/ToggleGroup.accessibility.test.js +107 -0
- package/toggle-group/ToggleGroup.js +1 -4
- package/typography/Typography.accessibility.test.js +339 -0
- package/useTheme.d.ts +29 -133
- package/utils/FocusLock.js +15 -5
- package/wizard/Wizard.accessibility.test.js +55 -0
- package/wizard/types.d.ts +1 -1
- package/common/OpenSans.css +0 -69
- package/common/fonts/OpenSans-Bold.ttf +0 -0
- package/common/fonts/OpenSans-BoldItalic.ttf +0 -0
- package/common/fonts/OpenSans-ExtraBold.ttf +0 -0
- package/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
- package/common/fonts/OpenSans-Italic.ttf +0 -0
- package/common/fonts/OpenSans-Light.ttf +0 -0
- package/common/fonts/OpenSans-LightItalic.ttf +0 -0
- package/common/fonts/OpenSans-Regular.ttf +0 -0
- package/common/fonts/OpenSans-SemiBold.ttf +0 -0
- package/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
- package/sidenav/Icons.d.ts +0 -7
- package/sidenav/Icons.js +0 -47
- package/text-input/Icons.d.ts +0 -8
- package/text-input/Icons.js +0 -56
- /package/{layout → sidenav}/SidenavContext.d.ts +0 -0
- /package/{layout → sidenav}/SidenavContext.js +0 -0
package/table/Table.stories.tsx
CHANGED
|
@@ -3,6 +3,7 @@ import DxcTable from "./Table";
|
|
|
3
3
|
import Title from "../../.storybook/components/Title";
|
|
4
4
|
import ExampleContainer from "../../.storybook/components/ExampleContainer";
|
|
5
5
|
import { HalstackProvider } from "../HalstackContext";
|
|
6
|
+
import { userEvent, within } from "@storybook/testing-library";
|
|
6
7
|
|
|
7
8
|
export default {
|
|
8
9
|
title: "Table",
|
|
@@ -17,11 +18,233 @@ const opinionatedTheme = {
|
|
|
17
18
|
},
|
|
18
19
|
};
|
|
19
20
|
|
|
21
|
+
const advancedTheme = {
|
|
22
|
+
table: {
|
|
23
|
+
actionIconColor: "#1B75BB",
|
|
24
|
+
hoverActionIconColor: "#1B75BB",
|
|
25
|
+
activeActionIconColor: "#1B75BB",
|
|
26
|
+
focusActionIconColor: "#1B75BB",
|
|
27
|
+
hoverButtonBackgroundColor: "#cccccc",
|
|
28
|
+
},
|
|
29
|
+
};
|
|
30
|
+
|
|
31
|
+
const actions = [
|
|
32
|
+
{
|
|
33
|
+
title: "icon",
|
|
34
|
+
onClick: (value?) => {
|
|
35
|
+
console.log(value);
|
|
36
|
+
},
|
|
37
|
+
options: [
|
|
38
|
+
{
|
|
39
|
+
value: "1",
|
|
40
|
+
label: "Amazon with a very long text",
|
|
41
|
+
},
|
|
42
|
+
{
|
|
43
|
+
value: "2",
|
|
44
|
+
label: "Ebay",
|
|
45
|
+
},
|
|
46
|
+
{
|
|
47
|
+
value: "3",
|
|
48
|
+
label: "Apple",
|
|
49
|
+
},
|
|
50
|
+
],
|
|
51
|
+
},
|
|
52
|
+
{
|
|
53
|
+
title: "icon",
|
|
54
|
+
onClick: (value?) => {
|
|
55
|
+
console.log(value);
|
|
56
|
+
},
|
|
57
|
+
options: [
|
|
58
|
+
{
|
|
59
|
+
value: "1",
|
|
60
|
+
label: "Amazon with a very long text",
|
|
61
|
+
},
|
|
62
|
+
{
|
|
63
|
+
value: "2",
|
|
64
|
+
label: "Ebay",
|
|
65
|
+
},
|
|
66
|
+
{
|
|
67
|
+
value: "3",
|
|
68
|
+
label: "Apple",
|
|
69
|
+
},
|
|
70
|
+
],
|
|
71
|
+
},
|
|
72
|
+
{
|
|
73
|
+
disabled: true,
|
|
74
|
+
title: "icon",
|
|
75
|
+
onClick: (value?) => {
|
|
76
|
+
console.log(value);
|
|
77
|
+
},
|
|
78
|
+
options: [
|
|
79
|
+
{
|
|
80
|
+
value: "1",
|
|
81
|
+
label: "Amazon with a very long text",
|
|
82
|
+
},
|
|
83
|
+
{
|
|
84
|
+
value: "2",
|
|
85
|
+
label: "Ebay",
|
|
86
|
+
},
|
|
87
|
+
{
|
|
88
|
+
value: "3",
|
|
89
|
+
label: "Apple",
|
|
90
|
+
},
|
|
91
|
+
],
|
|
92
|
+
},
|
|
93
|
+
{
|
|
94
|
+
icon: "filled_edit",
|
|
95
|
+
title: "icon",
|
|
96
|
+
onClick: () => {},
|
|
97
|
+
},
|
|
98
|
+
{
|
|
99
|
+
icon: "filled_delete",
|
|
100
|
+
title: "icon",
|
|
101
|
+
onClick: () => {},
|
|
102
|
+
disabled: true,
|
|
103
|
+
},
|
|
104
|
+
];
|
|
105
|
+
|
|
20
106
|
export const Chromatic = () => (
|
|
21
107
|
<>
|
|
22
108
|
<ExampleContainer>
|
|
23
109
|
<Title title="Default" theme="light" level={4} />
|
|
24
110
|
<DxcTable>
|
|
111
|
+
<tr>
|
|
112
|
+
<th>header 1</th>
|
|
113
|
+
<th>header 2</th>
|
|
114
|
+
<th>actions</th>
|
|
115
|
+
</tr>
|
|
116
|
+
<tr>
|
|
117
|
+
<td>cell 1</td>
|
|
118
|
+
<td>cell 2</td>
|
|
119
|
+
<td>
|
|
120
|
+
<DxcTable.ActionsCell actions={actions} />
|
|
121
|
+
</td>
|
|
122
|
+
</tr>
|
|
123
|
+
<tr>
|
|
124
|
+
<td>cell 4</td>
|
|
125
|
+
<td>cell 5</td>
|
|
126
|
+
<td>
|
|
127
|
+
<DxcTable.ActionsCell actions={actions} />
|
|
128
|
+
</td>
|
|
129
|
+
</tr>
|
|
130
|
+
<tr>
|
|
131
|
+
<td>cell 7</td>
|
|
132
|
+
<td>cell 8</td>
|
|
133
|
+
<td>
|
|
134
|
+
<DxcTable.ActionsCell actions={actions} />
|
|
135
|
+
</td>
|
|
136
|
+
</tr>
|
|
137
|
+
</DxcTable>
|
|
138
|
+
</ExampleContainer>
|
|
139
|
+
<ExampleContainer>
|
|
140
|
+
<Title title="Custom actionsCell theme" theme="light" level={4} />
|
|
141
|
+
<HalstackProvider advancedTheme={advancedTheme}>
|
|
142
|
+
<DxcTable>
|
|
143
|
+
<tr>
|
|
144
|
+
<th>header 1</th>
|
|
145
|
+
<th>header 2</th>
|
|
146
|
+
<th>actions</th>
|
|
147
|
+
</tr>
|
|
148
|
+
<tr>
|
|
149
|
+
<td>cell 1</td>
|
|
150
|
+
<td>cell 2</td>
|
|
151
|
+
<td>
|
|
152
|
+
<DxcTable.ActionsCell actions={actions} />
|
|
153
|
+
</td>
|
|
154
|
+
</tr>
|
|
155
|
+
<tr>
|
|
156
|
+
<td>cell 4</td>
|
|
157
|
+
<td>cell 5</td>
|
|
158
|
+
<td>
|
|
159
|
+
<DxcTable.ActionsCell actions={actions} />
|
|
160
|
+
</td>
|
|
161
|
+
</tr>
|
|
162
|
+
<tr>
|
|
163
|
+
<td>cell 7</td>
|
|
164
|
+
<td>cell 8</td>
|
|
165
|
+
<td>
|
|
166
|
+
<DxcTable.ActionsCell actions={actions} />
|
|
167
|
+
</td>
|
|
168
|
+
</tr>
|
|
169
|
+
</DxcTable>
|
|
170
|
+
</HalstackProvider>
|
|
171
|
+
</ExampleContainer>
|
|
172
|
+
<ExampleContainer>
|
|
173
|
+
<Title title="With scrollbar" theme="light" level={4} />
|
|
174
|
+
<div
|
|
175
|
+
style={{ height: 200 + "px", display: "flex", flexDirection: "row", width: 100 + "%", marginBottom: 50 + "px" }}
|
|
176
|
+
>
|
|
177
|
+
<DxcTable>
|
|
178
|
+
<tr>
|
|
179
|
+
<th>
|
|
180
|
+
header<br></br>subheader
|
|
181
|
+
</th>
|
|
182
|
+
<th>
|
|
183
|
+
header<br></br>subheader
|
|
184
|
+
</th>
|
|
185
|
+
<th>
|
|
186
|
+
header<br></br>subheader
|
|
187
|
+
</th>
|
|
188
|
+
</tr>
|
|
189
|
+
<tr>
|
|
190
|
+
<td>
|
|
191
|
+
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et
|
|
192
|
+
dolore magna aliqua.
|
|
193
|
+
</td>
|
|
194
|
+
<td>
|
|
195
|
+
Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo
|
|
196
|
+
consequat.
|
|
197
|
+
</td>
|
|
198
|
+
<td>
|
|
199
|
+
Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur.
|
|
200
|
+
</td>
|
|
201
|
+
</tr>
|
|
202
|
+
<tr>
|
|
203
|
+
<td>cell data</td>
|
|
204
|
+
<td>cell data</td>
|
|
205
|
+
<td>cell data</td>
|
|
206
|
+
</tr>
|
|
207
|
+
<tr>
|
|
208
|
+
<td>cell data</td>
|
|
209
|
+
<td>cell data</td>
|
|
210
|
+
<td>cell data</td>
|
|
211
|
+
</tr>
|
|
212
|
+
<tr>
|
|
213
|
+
<td>cell data</td>
|
|
214
|
+
<td>cell data</td>
|
|
215
|
+
<td>cell data</td>
|
|
216
|
+
</tr>
|
|
217
|
+
<tr>
|
|
218
|
+
<td>cell data</td>
|
|
219
|
+
<td>cell data</td>
|
|
220
|
+
<td>cell data</td>
|
|
221
|
+
</tr>
|
|
222
|
+
<tr>
|
|
223
|
+
<td>cell data</td>
|
|
224
|
+
<td>cell data</td>
|
|
225
|
+
<td>cell data</td>
|
|
226
|
+
</tr>
|
|
227
|
+
<tr>
|
|
228
|
+
<td>cell data</td>
|
|
229
|
+
<td>cell data</td>
|
|
230
|
+
<td>cell data</td>
|
|
231
|
+
</tr>
|
|
232
|
+
<tr>
|
|
233
|
+
<td>cell data</td>
|
|
234
|
+
<td>cell data</td>
|
|
235
|
+
<td>cell data</td>
|
|
236
|
+
</tr>
|
|
237
|
+
<tr>
|
|
238
|
+
<td>cell data</td>
|
|
239
|
+
<td>cell data</td>
|
|
240
|
+
<td>cell data</td>
|
|
241
|
+
</tr>
|
|
242
|
+
</DxcTable>
|
|
243
|
+
</div>
|
|
244
|
+
</ExampleContainer>
|
|
245
|
+
<ExampleContainer>
|
|
246
|
+
<Title title="Default reduced" theme="light" level={4} />
|
|
247
|
+
<DxcTable mode="reduced">
|
|
25
248
|
<tr>
|
|
26
249
|
<th>header 1</th>
|
|
27
250
|
<th>header 2</th>
|
|
@@ -45,11 +268,11 @@ export const Chromatic = () => (
|
|
|
45
268
|
</DxcTable>
|
|
46
269
|
</ExampleContainer>
|
|
47
270
|
<ExampleContainer>
|
|
48
|
-
<Title title="
|
|
271
|
+
<Title title="Reduced with scrollbar" theme="light" level={4} />
|
|
49
272
|
<div
|
|
50
273
|
style={{ height: 200 + "px", display: "flex", flexDirection: "row", width: 100 + "%", marginBottom: 50 + "px" }}
|
|
51
274
|
>
|
|
52
|
-
<DxcTable>
|
|
275
|
+
<DxcTable mode="reduced">
|
|
53
276
|
<tr>
|
|
54
277
|
<th>
|
|
55
278
|
header<br></br>subheader
|
|
@@ -117,6 +340,37 @@ export const Chromatic = () => (
|
|
|
117
340
|
</DxcTable>
|
|
118
341
|
</div>
|
|
119
342
|
</ExampleContainer>
|
|
343
|
+
<ExampleContainer>
|
|
344
|
+
<Title title="Reduced table with actions" theme="light" level={4} />
|
|
345
|
+
<DxcTable mode="reduced">
|
|
346
|
+
<tr>
|
|
347
|
+
<th>header 1</th>
|
|
348
|
+
<th>header 2</th>
|
|
349
|
+
<th>header 3</th>
|
|
350
|
+
</tr>
|
|
351
|
+
<tr>
|
|
352
|
+
<td>cell 1</td>
|
|
353
|
+
<td>cell 2</td>
|
|
354
|
+
<td>
|
|
355
|
+
<DxcTable.ActionsCell actions={actions} />
|
|
356
|
+
</td>
|
|
357
|
+
</tr>
|
|
358
|
+
<tr>
|
|
359
|
+
<td>cell 4</td>
|
|
360
|
+
<td>cell 5</td>
|
|
361
|
+
<td>
|
|
362
|
+
<DxcTable.ActionsCell actions={actions} />
|
|
363
|
+
</td>
|
|
364
|
+
</tr>
|
|
365
|
+
<tr>
|
|
366
|
+
<td>cell 7</td>
|
|
367
|
+
<td>cell 8</td>
|
|
368
|
+
<td>
|
|
369
|
+
<DxcTable.ActionsCell actions={actions} />
|
|
370
|
+
</td>
|
|
371
|
+
</tr>
|
|
372
|
+
</DxcTable>
|
|
373
|
+
</ExampleContainer>
|
|
120
374
|
<Title title="Margins" theme="light" level={2} />
|
|
121
375
|
<ExampleContainer>
|
|
122
376
|
<Title title="Xxsmall margin" theme="light" level={4} />
|
|
@@ -354,3 +608,44 @@ export const Chromatic = () => (
|
|
|
354
608
|
</ExampleContainer>
|
|
355
609
|
</>
|
|
356
610
|
);
|
|
611
|
+
|
|
612
|
+
const ActionsCellDropdown = () => (
|
|
613
|
+
<ExampleContainer>
|
|
614
|
+
<Title title="Dropdown Action" theme="light" level={4} />
|
|
615
|
+
<DxcTable>
|
|
616
|
+
<tr>
|
|
617
|
+
<th>header 1</th>
|
|
618
|
+
<th>header 2</th>
|
|
619
|
+
<th>actions</th>
|
|
620
|
+
</tr>
|
|
621
|
+
<tr>
|
|
622
|
+
<td>cell 1</td>
|
|
623
|
+
<td>cell 2</td>
|
|
624
|
+
<td>
|
|
625
|
+
<DxcTable.ActionsCell actions={actions} />
|
|
626
|
+
</td>
|
|
627
|
+
</tr>
|
|
628
|
+
<tr>
|
|
629
|
+
<td>cell 4</td>
|
|
630
|
+
<td>cell 5</td>
|
|
631
|
+
<td>
|
|
632
|
+
<DxcTable.ActionsCell actions={actions} />
|
|
633
|
+
</td>
|
|
634
|
+
</tr>
|
|
635
|
+
<tr>
|
|
636
|
+
<td>cell 7</td>
|
|
637
|
+
<td>cell 8</td>
|
|
638
|
+
<td>
|
|
639
|
+
<DxcTable.ActionsCell actions={actions} />
|
|
640
|
+
</td>
|
|
641
|
+
</tr>
|
|
642
|
+
</DxcTable>
|
|
643
|
+
</ExampleContainer>
|
|
644
|
+
);
|
|
645
|
+
|
|
646
|
+
export const DropdownAction = ActionsCellDropdown.bind({});
|
|
647
|
+
DropdownAction.play = async ({ canvasElement }) => {
|
|
648
|
+
const canvas = within(canvasElement);
|
|
649
|
+
const nextButton = canvas.getAllByRole("button")[8];
|
|
650
|
+
await userEvent.click(nextButton);
|
|
651
|
+
};
|
package/table/Table.test.js
CHANGED
|
@@ -1,9 +1,55 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
5
|
+
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
6
|
+
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
|
|
7
|
+
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
|
|
4
8
|
var _react = _interopRequireDefault(require("react"));
|
|
5
9
|
var _react2 = require("@testing-library/react");
|
|
6
10
|
var _Table = _interopRequireDefault(require("./Table.tsx"));
|
|
11
|
+
var _userEvent = _interopRequireDefault(require("@testing-library/user-event"));
|
|
12
|
+
global.globalThis = global;
|
|
13
|
+
global.DOMRect = {
|
|
14
|
+
fromRect: function fromRect() {
|
|
15
|
+
return {
|
|
16
|
+
top: 0,
|
|
17
|
+
left: 0,
|
|
18
|
+
bottom: 0,
|
|
19
|
+
right: 0,
|
|
20
|
+
width: 0,
|
|
21
|
+
height: 0
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
};
|
|
25
|
+
global.ResizeObserver = /*#__PURE__*/function () {
|
|
26
|
+
function ResizeObserver() {
|
|
27
|
+
(0, _classCallCheck2["default"])(this, ResizeObserver);
|
|
28
|
+
}
|
|
29
|
+
(0, _createClass2["default"])(ResizeObserver, [{
|
|
30
|
+
key: "observe",
|
|
31
|
+
value: function observe() {}
|
|
32
|
+
}, {
|
|
33
|
+
key: "unobserve",
|
|
34
|
+
value: function unobserve() {}
|
|
35
|
+
}, {
|
|
36
|
+
key: "disconnect",
|
|
37
|
+
value: function disconnect() {}
|
|
38
|
+
}]);
|
|
39
|
+
return ResizeObserver;
|
|
40
|
+
}();
|
|
41
|
+
var icon = /*#__PURE__*/_react["default"].createElement("svg", {
|
|
42
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
43
|
+
height: "24px",
|
|
44
|
+
viewBox: "0 0 24 24",
|
|
45
|
+
width: "24px",
|
|
46
|
+
fill: "currentColor"
|
|
47
|
+
}, /*#__PURE__*/_react["default"].createElement("path", {
|
|
48
|
+
d: "M0 0h24v24H0V0zm0 0h24v24H0V0z",
|
|
49
|
+
fill: "none"
|
|
50
|
+
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
51
|
+
d: "M1 9l2 2c4.97-4.97 13.03-4.97 18 0l2-2C16.93 2.93 7.08 2.93 1 9zm8 8l3 3 3-3c-1.65-1.66-4.34-1.66-6 0zm-4-4l2 2c2.76-2.76 7.24-2.76 10 0l2-2C15.14 9.14 8.87 9.14 5 13z"
|
|
52
|
+
}));
|
|
7
53
|
describe("Table component tests", function () {
|
|
8
54
|
test("Table renders with correct content", function () {
|
|
9
55
|
var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Table["default"], null, /*#__PURE__*/_react["default"].createElement("thead", null, /*#__PURE__*/_react["default"].createElement("tr", null, /*#__PURE__*/_react["default"].createElement("th", null, "header-1"), /*#__PURE__*/_react["default"].createElement("th", null, "header-2"), /*#__PURE__*/_react["default"].createElement("th", null, "header-3"))), /*#__PURE__*/_react["default"].createElement("tbody", null, /*#__PURE__*/_react["default"].createElement("tr", null, /*#__PURE__*/_react["default"].createElement("td", null, "cell-1"), /*#__PURE__*/_react["default"].createElement("td", null, "cell-2"), /*#__PURE__*/_react["default"].createElement("td", null, "cell-3")), /*#__PURE__*/_react["default"].createElement("tr", null, /*#__PURE__*/_react["default"].createElement("td", null, "cell-4"), /*#__PURE__*/_react["default"].createElement("td", null, "cell-5"), /*#__PURE__*/_react["default"].createElement("td", null, "cell-6"))))),
|
|
@@ -18,4 +64,50 @@ describe("Table component tests", function () {
|
|
|
18
64
|
expect(getByText("cell-5")).toBeTruthy();
|
|
19
65
|
expect(getByText("cell-6")).toBeTruthy();
|
|
20
66
|
});
|
|
67
|
+
test("Table ActionsCell", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
|
|
68
|
+
var onSelectOption, onClick, actions, _render2, getAllByRole, getByRole, getByText, dropdown, option, action;
|
|
69
|
+
return _regenerator["default"].wrap(function _callee$(_context) {
|
|
70
|
+
while (1) switch (_context.prev = _context.next) {
|
|
71
|
+
case 0:
|
|
72
|
+
onSelectOption = jest.fn();
|
|
73
|
+
onClick = jest.fn();
|
|
74
|
+
actions = [{
|
|
75
|
+
icon: icon,
|
|
76
|
+
title: "icon1",
|
|
77
|
+
onClick: onSelectOption,
|
|
78
|
+
options: [{
|
|
79
|
+
value: "1",
|
|
80
|
+
label: "Amazon"
|
|
81
|
+
}, {
|
|
82
|
+
value: "2",
|
|
83
|
+
label: "Ebay"
|
|
84
|
+
}, {
|
|
85
|
+
value: "3",
|
|
86
|
+
label: "Aliexpress"
|
|
87
|
+
}]
|
|
88
|
+
}, {
|
|
89
|
+
icon: icon,
|
|
90
|
+
title: "icon2",
|
|
91
|
+
onClick: onClick
|
|
92
|
+
}];
|
|
93
|
+
_render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Table["default"], null, /*#__PURE__*/_react["default"].createElement("thead", null, /*#__PURE__*/_react["default"].createElement("tr", null, /*#__PURE__*/_react["default"].createElement("th", null, "header-1"), /*#__PURE__*/_react["default"].createElement("th", null, "header-2"), /*#__PURE__*/_react["default"].createElement("th", null, "header-3"))), /*#__PURE__*/_react["default"].createElement("tbody", null, /*#__PURE__*/_react["default"].createElement("tr", null, /*#__PURE__*/_react["default"].createElement("td", null, "cell-1"), /*#__PURE__*/_react["default"].createElement("td", null, "cell-2"), /*#__PURE__*/_react["default"].createElement("td", null, "cell-3")), /*#__PURE__*/_react["default"].createElement("tr", null, /*#__PURE__*/_react["default"].createElement("td", null, "cell-4"), /*#__PURE__*/_react["default"].createElement("td", null, "cell-5"), /*#__PURE__*/_react["default"].createElement("td", null, /*#__PURE__*/_react["default"].createElement(_Table["default"].ActionsCell, {
|
|
94
|
+
actions: actions
|
|
95
|
+
})))))), getAllByRole = _render2.getAllByRole, getByRole = _render2.getByRole, getByText = _render2.getByText;
|
|
96
|
+
dropdown = getAllByRole("button")[1];
|
|
97
|
+
(0, _react2.act)(function () {
|
|
98
|
+
_userEvent["default"].click(dropdown);
|
|
99
|
+
});
|
|
100
|
+
expect(getByRole("menu")).toBeTruthy();
|
|
101
|
+
option = getByText("Aliexpress");
|
|
102
|
+
_userEvent["default"].click(option);
|
|
103
|
+
expect(onSelectOption).toHaveBeenCalledWith("3");
|
|
104
|
+
action = getAllByRole("button")[0];
|
|
105
|
+
_userEvent["default"].click(action);
|
|
106
|
+
expect(onClick).toHaveBeenCalled();
|
|
107
|
+
case 13:
|
|
108
|
+
case "end":
|
|
109
|
+
return _context.stop();
|
|
110
|
+
}
|
|
111
|
+
}, _callee);
|
|
112
|
+
})));
|
|
21
113
|
});
|
package/table/types.d.ts
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
/// <reference types="react" />
|
|
2
|
+
import { Option } from "../dropdown/types";
|
|
2
3
|
type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
|
|
3
4
|
type Margin = {
|
|
4
5
|
top?: Space;
|
|
@@ -6,6 +7,27 @@ type Margin = {
|
|
|
6
7
|
left?: Space;
|
|
7
8
|
right?: Space;
|
|
8
9
|
};
|
|
10
|
+
type SVG = React.ReactNode & React.SVGProps<SVGSVGElement>;
|
|
11
|
+
export type DeepPartial<T> = {
|
|
12
|
+
[P in keyof T]?: Partial<T[P]>;
|
|
13
|
+
};
|
|
14
|
+
export type ActionCellsPropsType = {
|
|
15
|
+
actions: Array<{
|
|
16
|
+
icon: string | SVG;
|
|
17
|
+
title: string;
|
|
18
|
+
onClick: () => void;
|
|
19
|
+
disabled?: boolean;
|
|
20
|
+
tabIndex?: number;
|
|
21
|
+
options?: never;
|
|
22
|
+
} | {
|
|
23
|
+
icon?: never;
|
|
24
|
+
title: string;
|
|
25
|
+
onClick: (value?: string) => void;
|
|
26
|
+
disabled?: boolean;
|
|
27
|
+
tabIndex?: number;
|
|
28
|
+
options: Option[];
|
|
29
|
+
}>;
|
|
30
|
+
};
|
|
9
31
|
type Props = {
|
|
10
32
|
/**
|
|
11
33
|
* The center section of the table. Can be used to render custom
|
|
@@ -17,5 +39,11 @@ type Props = {
|
|
|
17
39
|
* You can pass an object with 'top', 'bottom', 'left' and 'right' properties in order to specify different margin sizes.
|
|
18
40
|
*/
|
|
19
41
|
margin?: Space | Margin;
|
|
42
|
+
/**
|
|
43
|
+
* Determines the visual style and layout
|
|
44
|
+
* - "default": Default table size.
|
|
45
|
+
* - "reduced": More compact table with less spacing for high density information.
|
|
46
|
+
*/
|
|
47
|
+
mode?: "default" | "reduced";
|
|
20
48
|
};
|
|
21
49
|
export default Props;
|
package/tabs/Tab.js
CHANGED
|
@@ -46,7 +46,8 @@ var Tab = /*#__PURE__*/(0, _react.forwardRef)(function (_ref, ref) {
|
|
|
46
46
|
}, /*#__PURE__*/_react["default"].createElement(MainLabelContainer, {
|
|
47
47
|
notificationNumber: tab.notificationNumber,
|
|
48
48
|
hasLabelAndIcon: hasLabelAndIcon,
|
|
49
|
-
iconPosition: iconPosition
|
|
49
|
+
iconPosition: iconPosition,
|
|
50
|
+
disabled: tab.isDisabled
|
|
50
51
|
}, tab.icon && /*#__PURE__*/_react["default"].createElement(TabIconContainer, {
|
|
51
52
|
hasLabelAndIcon: hasLabelAndIcon,
|
|
52
53
|
iconPosition: iconPosition
|
|
@@ -61,11 +62,13 @@ var Tab = /*#__PURE__*/(0, _react.forwardRef)(function (_ref, ref) {
|
|
|
61
62
|
textAlign: "center",
|
|
62
63
|
letterSpacing: "0.025em",
|
|
63
64
|
lineHeight: "1.715em"
|
|
64
|
-
}, tab.label)), tab.notificationNumber && /*#__PURE__*/_react["default"].createElement(BadgeContainer, {
|
|
65
|
+
}, tab.label)), tab.notificationNumber && !tab.isDisabled && /*#__PURE__*/_react["default"].createElement(BadgeContainer, {
|
|
65
66
|
hasLabelAndIcon: hasLabelAndIcon,
|
|
66
67
|
iconPosition: iconPosition
|
|
67
68
|
}, /*#__PURE__*/_react["default"].createElement(_Badge["default"], {
|
|
68
|
-
|
|
69
|
+
mode: "notification",
|
|
70
|
+
size: "small",
|
|
71
|
+
label: typeof tab.notificationNumber === "number" && tab.notificationNumber
|
|
69
72
|
})));
|
|
70
73
|
});
|
|
71
74
|
var TabContainer = _styledComponents["default"].button(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n text-transform: ", ";\n overflow: hidden;\n flex-shrink: 0;\n border: 0;\n cursor: pointer;\n display: inline-flex;\n align-items: center;\n user-select: none;\n vertical-align: middle;\n justify-content: center;\n min-width: 90px;\n max-width: 360px;\n padding: ", ";\n height: ", ";\n min-height: ", ";\n background-color: ", ";\n\n &:hover {\n background-color: ", ";\n }\n &:active {\n background-color: ", ";\n }\n &:focus {\n outline: ", " solid 1px;\n outline-offset: -1px;\n }\n svg {\n color: ", ";\n }\n\n &[aria-selected=\"true\"] {\n background-color: ", ";\n svg {\n color: ", ";\n }\n opacity: 1;\n }\n\n &:disabled {\n background-color: ", " !important;\n cursor: not-allowed !important;\n pointer-events: all;\n font-style: ", ";\n outline: none !important;\n\n svg {\n color: ", ";\n }\n > div {\n opacity: 0.5;\n }\n }\n"])), function (props) {
|
|
@@ -103,7 +106,7 @@ var BadgeContainer = _styledComponents["default"].div(_templateObject2 || (_temp
|
|
|
103
106
|
var MainLabelContainer = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: ", ";\n align-items: center;\n margin-left: ", ";\n"])), function (props) {
|
|
104
107
|
return props.hasLabelAndIcon && props.iconPosition === "top" && "column" || "row";
|
|
105
108
|
}, function (props) {
|
|
106
|
-
return props.notificationNumber ? typeof props.notificationNumber === "number" ? "
|
|
109
|
+
return props.notificationNumber && !props.disabled ? typeof props.notificationNumber === "number" ? "36px" : "18px" : "unset";
|
|
107
110
|
});
|
|
108
111
|
var TabIconContainer = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n margin-bottom: ", ";\n margin-right: ", ";\n\n img,\n svg {\n height: 22px;\n width: 22px;\n }\n"])), function (props) {
|
|
109
112
|
return props.hasLabelAndIcon && props.iconPosition === "top" && "8px" || "";
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
5
|
+
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
6
|
+
var _react = _interopRequireDefault(require("react"));
|
|
7
|
+
var _react2 = require("@testing-library/react");
|
|
8
|
+
var _jestAxe = require("jest-axe");
|
|
9
|
+
var _Tabs = _interopRequireDefault(require("./Tabs.tsx"));
|
|
10
|
+
var iconSVG = /*#__PURE__*/_react["default"].createElement("svg", {
|
|
11
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
12
|
+
viewBox: "0 0 20 20",
|
|
13
|
+
height: "20",
|
|
14
|
+
width: "20",
|
|
15
|
+
fill: "currentColor"
|
|
16
|
+
}, /*#__PURE__*/_react["default"].createElement("path", {
|
|
17
|
+
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"
|
|
18
|
+
}));
|
|
19
|
+
var sampleTabs = [{
|
|
20
|
+
label: "Tab-1",
|
|
21
|
+
icon: iconSVG,
|
|
22
|
+
notificationNumber: 10
|
|
23
|
+
}, {
|
|
24
|
+
label: "Tab-2",
|
|
25
|
+
icon: iconSVG
|
|
26
|
+
}, {
|
|
27
|
+
label: "Tab-3",
|
|
28
|
+
notificationNumber: 20
|
|
29
|
+
}, {
|
|
30
|
+
label: "Tab-4",
|
|
31
|
+
isDisabled: true
|
|
32
|
+
}];
|
|
33
|
+
describe("Tabs component accessibility tests", function () {
|
|
34
|
+
it("Should not have basic accessibility issues", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
|
|
35
|
+
var _render, container, results;
|
|
36
|
+
return _regenerator["default"].wrap(function _callee$(_context) {
|
|
37
|
+
while (1) switch (_context.prev = _context.next) {
|
|
38
|
+
case 0:
|
|
39
|
+
_render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Tabs["default"], {
|
|
40
|
+
tabs: sampleTabs,
|
|
41
|
+
margin: "medium",
|
|
42
|
+
iconPosition: "left",
|
|
43
|
+
defaultActiveTabIndex: 0
|
|
44
|
+
})), container = _render.container;
|
|
45
|
+
_context.next = 3;
|
|
46
|
+
return (0, _jestAxe.axe)(container);
|
|
47
|
+
case 3:
|
|
48
|
+
results = _context.sent;
|
|
49
|
+
expect(results).toHaveNoViolations();
|
|
50
|
+
case 5:
|
|
51
|
+
case "end":
|
|
52
|
+
return _context.stop();
|
|
53
|
+
}
|
|
54
|
+
}, _callee);
|
|
55
|
+
})));
|
|
56
|
+
});
|
package/tabs/Tabs.js
CHANGED
|
@@ -40,14 +40,13 @@ var useResize = function useResize(refTabList) {
|
|
|
40
40
|
viewWidth = _useState2[0],
|
|
41
41
|
setViewWidth = _useState2[1];
|
|
42
42
|
var handleWindowSizeChange = (0, _react.useCallback)(function () {
|
|
43
|
-
var _refTabList$current;
|
|
44
|
-
setViewWidth(refTabList === null || refTabList === void 0 ? void 0 : (_refTabList$current = refTabList.current) === null || _refTabList$current === void 0 ? void 0 : _refTabList$current.offsetWidth);
|
|
43
|
+
var _refTabList$current$o, _refTabList$current;
|
|
44
|
+
setViewWidth((_refTabList$current$o = refTabList === null || refTabList === void 0 ? void 0 : (_refTabList$current = refTabList.current) === null || _refTabList$current === void 0 ? void 0 : _refTabList$current.offsetWidth) !== null && _refTabList$current$o !== void 0 ? _refTabList$current$o : 0);
|
|
45
45
|
}, [refTabList]);
|
|
46
46
|
(0, _react.useEffect)(function () {
|
|
47
|
-
|
|
47
|
+
handleWindowSizeChange();
|
|
48
48
|
window.addEventListener("resize", handleWindowSizeChange);
|
|
49
49
|
return function () {
|
|
50
|
-
window.removeEventListener("load", handleWindowSizeChange);
|
|
51
50
|
window.removeEventListener("resize", handleWindowSizeChange);
|
|
52
51
|
};
|
|
53
52
|
}, [handleWindowSizeChange]);
|
|
@@ -349,7 +348,7 @@ var Tabs = _styledComponents["default"].div(_templateObject3 || (_templateObject
|
|
|
349
348
|
}, function (props) {
|
|
350
349
|
return props.theme.unselectedBackgroundColor;
|
|
351
350
|
});
|
|
352
|
-
var ScrollIndicator = _styledComponents["default"].button(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n box-sizing: border-box;\n display: ", ";\n justify-content: center;\n min-width: ", ";\n height: ", "px;\n padding: 0;\n border: none;\n background-color: #ffffff;\n font-size: 1.25rem;\n cursor: pointer;\n\n &:hover {\n background-color: ", ";\n }\n &:focus {\n outline: ", " solid 1px;\n outline-offset: -1px;\n }\n &:active {\n background-color: ", ";\n }\n &:disabled {\n cursor: default;\n svg {\n visibility: hidden;\n }\n &:focus {\n outline: none;\n }\n &:hover,\n &:active {\n background-color: transparent !important;\n }\n }\n\n svg {\n align-self: center;\n height: 20px;\n width: 20px;\n fill: ", ";\n }\n"])), function (props) {
|
|
351
|
+
var ScrollIndicator = _styledComponents["default"].button(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n box-sizing: border-box;\n display: ", ";\n justify-content: center;\n min-width: ", ";\n height: ", "px;\n padding: 0;\n border: none;\n background-color: #ffffff;\n font-size: 1.25rem;\n cursor: pointer;\n\n &:hover {\n background-color: ", ";\n }\n &:focus {\n outline: ", " solid 1px;\n outline-offset: -1px;\n }\n &:active {\n background-color: ", ";\n }\n &:disabled {\n cursor: default;\n display: none;\n svg {\n visibility: hidden;\n }\n &:focus {\n outline: none;\n }\n &:hover,\n &:active {\n background-color: transparent !important;\n }\n }\n\n svg {\n align-self: center;\n height: 20px;\n width: 20px;\n fill: ", ";\n }\n"])), function (props) {
|
|
353
352
|
return props.enabled ? "flex" : "none";
|
|
354
353
|
}, function (props) {
|
|
355
354
|
return props.theme.scrollButtonsWidth;
|
package/tabs/Tabs.stories.tsx
CHANGED
|
@@ -71,7 +71,7 @@ const firstDisabledTabs: any = [
|
|
|
71
71
|
|
|
72
72
|
const tabsNotification = tabs.map((tab, index) => ({
|
|
73
73
|
...tab,
|
|
74
|
-
notificationNumber: (index === 0 && true) || (index === 1 && 5) || (index === 2 && 200),
|
|
74
|
+
notificationNumber: (index === 0 && true) || (index === 1 && 5) || (index === 2 && 100) || (index === 3 && 200),
|
|
75
75
|
}));
|
|
76
76
|
|
|
77
77
|
const tabsIcon = tabs.map((tab, index) =>
|