@dxc-technology/halstack-react 10.1.0 → 12.0.0
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 +4 -21
- package/HalstackContext.d.ts +45 -143
- package/HalstackContext.js +10 -35
- package/accordion/Accordion.accessibility.test.js +71 -0
- package/accordion/Accordion.js +33 -84
- package/accordion/Accordion.stories.tsx +8 -64
- package/accordion/Accordion.test.js +18 -33
- package/accordion/types.d.ts +6 -6
- package/accordion-group/AccordionGroup.accessibility.test.js +88 -0
- package/accordion-group/AccordionGroup.d.ts +2 -3
- package/accordion-group/AccordionGroup.js +17 -44
- package/accordion-group/AccordionGroup.stories.tsx +24 -24
- package/accordion-group/AccordionGroup.test.js +42 -60
- package/accordion-group/AccordionGroupAccordion.js +11 -23
- package/accordion-group/AccordionGroupContext.d.ts +3 -0
- package/accordion-group/AccordionGroupContext.js +8 -0
- package/accordion-group/types.d.ts +7 -7
- 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/alert/Alert.accessibility.test.js +95 -0
- package/alert/Alert.js +34 -120
- package/alert/Alert.test.js +28 -45
- package/alert/types.d.ts +5 -5
- package/badge/Badge.accessibility.test.js +129 -0
- package/badge/Badge.d.ts +1 -1
- package/badge/Badge.js +142 -42
- package/badge/Badge.stories.tsx +210 -0
- package/badge/Badge.test.js +30 -0
- package/badge/types.d.ts +52 -3
- package/bleed/Bleed.js +13 -21
- package/bleed/types.d.ts +2 -2
- package/box/Box.accessibility.test.js +33 -0
- package/box/Box.js +11 -33
- package/box/Box.test.js +1 -6
- package/box/types.d.ts +3 -3
- package/breadcrumbs/Breadcrumbs.accessibility.test.d.ts +1 -0
- package/breadcrumbs/Breadcrumbs.accessibility.test.js +96 -0
- package/breadcrumbs/Breadcrumbs.d.ts +4 -0
- package/breadcrumbs/Breadcrumbs.js +79 -0
- package/breadcrumbs/Breadcrumbs.stories.tsx +194 -0
- package/breadcrumbs/Breadcrumbs.test.d.ts +1 -0
- package/breadcrumbs/Breadcrumbs.test.js +169 -0
- package/breadcrumbs/Item.d.ts +4 -0
- package/breadcrumbs/Item.js +52 -0
- package/breadcrumbs/dropdownTheme.d.ts +53 -0
- package/breadcrumbs/dropdownTheme.js +62 -0
- package/breadcrumbs/types.d.ts +16 -0
- package/breadcrumbs/types.js +5 -0
- package/bulleted-list/BulletedList.accessibility.test.js +119 -0
- package/bulleted-list/BulletedList.js +22 -55
- package/bulleted-list/BulletedList.stories.tsx +2 -93
- package/bulleted-list/types.d.ts +5 -5
- package/button/Button.accessibility.test.js +127 -0
- package/button/Button.js +36 -59
- package/button/Button.stories.tsx +35 -135
- package/button/Button.test.js +13 -21
- package/button/types.d.ts +5 -5
- package/card/Card.accessibility.test.js +36 -0
- package/card/Card.js +23 -45
- package/card/Card.test.js +10 -21
- package/card/types.d.ts +5 -5
- package/checkbox/Checkbox.accessibility.test.js +87 -0
- package/checkbox/Checkbox.js +88 -123
- package/checkbox/Checkbox.stories.tsx +16 -54
- package/checkbox/Checkbox.test.js +107 -63
- package/checkbox/types.d.ts +8 -4
- package/chip/Chip.accessibility.test.js +67 -0
- package/chip/Chip.js +22 -36
- package/chip/Chip.stories.tsx +10 -25
- package/chip/Chip.test.js +17 -30
- package/chip/types.d.ts +4 -4
- package/common/coreTokens.d.ts +105 -14
- package/common/coreTokens.js +40 -23
- package/common/utils.js +2 -8
- package/common/variables.d.ts +46 -144
- package/common/variables.js +120 -225
- package/container/Container.d.ts +4 -0
- package/container/Container.js +194 -0
- package/container/Container.stories.tsx +214 -0
- package/container/types.d.ts +74 -0
- package/container/types.js +5 -0
- package/contextual-menu/ContextualMenu.accessibility.test.js +97 -0
- package/contextual-menu/ContextualMenu.d.ts +5 -0
- package/contextual-menu/ContextualMenu.js +88 -0
- package/contextual-menu/ContextualMenu.stories.tsx +232 -0
- package/contextual-menu/ContextualMenu.test.js +205 -0
- package/contextual-menu/GroupItem.d.ts +4 -0
- package/contextual-menu/GroupItem.js +67 -0
- package/contextual-menu/ItemAction.d.ts +4 -0
- package/contextual-menu/ItemAction.js +51 -0
- package/contextual-menu/MenuItem.d.ts +4 -0
- package/contextual-menu/MenuItem.js +29 -0
- package/contextual-menu/SingleItem.d.ts +4 -0
- package/contextual-menu/SingleItem.js +38 -0
- package/contextual-menu/types.d.ts +58 -0
- package/contextual-menu/types.js +5 -0
- package/date-input/Calendar.js +13 -57
- package/date-input/DateInput.accessibility.test.js +228 -0
- package/date-input/DateInput.js +53 -100
- package/date-input/DateInput.stories.tsx +19 -31
- package/date-input/DateInput.test.js +674 -701
- package/date-input/DatePicker.js +23 -48
- package/date-input/YearPicker.js +8 -34
- package/date-input/types.d.ts +28 -22
- package/dialog/Dialog.accessibility.test.js +69 -0
- package/dialog/Dialog.js +21 -59
- package/dialog/Dialog.stories.tsx +176 -0
- package/dialog/Dialog.test.js +126 -188
- package/dialog/types.d.ts +18 -13
- 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 +63 -130
- package/dropdown/Dropdown.stories.tsx +15 -26
- package/dropdown/Dropdown.test.js +402 -389
- package/dropdown/DropdownMenu.js +12 -23
- package/dropdown/DropdownMenuItem.js +13 -21
- package/dropdown/types.d.ts +20 -24
- package/file-input/FileInput.accessibility.test.js +160 -0
- package/file-input/FileInput.js +180 -284
- package/file-input/FileInput.stories.tsx +1 -1
- package/file-input/FileInput.test.js +279 -354
- package/file-input/FileItem.js +29 -66
- package/file-input/types.d.ts +9 -9
- package/flex/Flex.js +25 -39
- package/flex/types.d.ts +6 -6
- package/footer/Footer.accessibility.test.js +125 -0
- package/footer/Footer.d.ts +1 -1
- package/footer/Footer.js +43 -68
- package/footer/Footer.stories.tsx +58 -2
- package/footer/Footer.test.js +18 -32
- package/footer/Icons.d.ts +3 -2
- package/footer/Icons.js +53 -22
- package/footer/types.d.ts +17 -17
- package/grid/Grid.js +1 -16
- package/grid/types.d.ts +10 -10
- package/header/Header.accessibility.test.js +93 -0
- package/header/Header.d.ts +1 -1
- package/header/Header.js +38 -104
- package/header/Header.stories.tsx +16 -0
- package/header/Header.test.js +12 -25
- package/header/Icons.d.ts +2 -2
- package/header/Icons.js +3 -13
- package/header/types.d.ts +7 -8
- package/heading/Heading.accessibility.test.js +33 -0
- package/heading/Heading.js +9 -31
- package/heading/Heading.test.js +70 -87
- package/heading/types.d.ts +7 -7
- 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.d.ts +2 -2
- package/image/Image.js +17 -32
- package/image/Image.stories.tsx +3 -1
- package/image/types.d.ts +2 -2
- package/inset/Inset.js +13 -21
- package/inset/types.d.ts +2 -2
- package/layout/ApplicationLayout.d.ts +2 -2
- package/layout/ApplicationLayout.js +23 -60
- package/layout/Icons.d.ts +4 -5
- package/layout/Icons.js +2 -16
- package/layout/types.d.ts +3 -3
- package/link/Link.accessibility.test.js +108 -0
- package/link/Link.js +28 -47
- package/link/Link.stories.tsx +4 -4
- package/link/Link.test.js +23 -41
- package/link/types.d.ts +14 -14
- package/main.d.ts +8 -4
- package/main.js +39 -60
- package/nav-tabs/NavTabs.accessibility.test.js +44 -0
- package/nav-tabs/NavTabs.d.ts +1 -2
- package/nav-tabs/NavTabs.js +19 -48
- package/nav-tabs/NavTabs.stories.tsx +30 -25
- package/nav-tabs/NavTabs.test.js +45 -50
- package/nav-tabs/NavTabsContext.d.ts +3 -0
- package/nav-tabs/NavTabsContext.js +8 -0
- package/nav-tabs/Tab.js +38 -67
- package/nav-tabs/types.d.ts +10 -10
- package/number-input/NumberInput.accessibility.test.js +228 -0
- package/number-input/NumberInput.d.ts +0 -7
- package/number-input/NumberInput.js +47 -39
- package/number-input/NumberInput.stories.tsx +42 -26
- package/number-input/NumberInput.test.js +839 -575
- package/number-input/NumberInputContext.d.ts +3 -0
- package/number-input/NumberInputContext.js +8 -0
- package/number-input/types.d.ts +17 -5
- package/package.json +41 -37
- package/paginator/Paginator.accessibility.test.js +79 -0
- package/paginator/Paginator.js +27 -52
- package/paginator/Paginator.test.js +224 -207
- package/paginator/types.d.ts +3 -3
- package/paragraph/Paragraph.accessibility.test.js +28 -0
- package/paragraph/Paragraph.js +3 -19
- package/paragraph/Paragraph.stories.tsx +0 -17
- package/password-input/PasswordInput.accessibility.test.js +153 -0
- package/password-input/PasswordInput.js +32 -54
- package/password-input/PasswordInput.stories.tsx +1 -34
- package/password-input/PasswordInput.test.js +153 -129
- package/password-input/types.d.ts +8 -7
- package/progress-bar/ProgressBar.accessibility.test.js +35 -0
- package/progress-bar/ProgressBar.js +26 -56
- package/progress-bar/{ProgressBar.stories.jsx → ProgressBar.stories.tsx} +1 -1
- package/progress-bar/ProgressBar.test.js +35 -52
- package/progress-bar/types.d.ts +3 -3
- package/quick-nav/QuickNav.accessibility.test.js +57 -0
- package/quick-nav/QuickNav.js +4 -27
- package/quick-nav/QuickNav.stories.tsx +1 -1
- package/quick-nav/types.d.ts +10 -10
- package/radio-group/Radio.d.ts +1 -1
- package/radio-group/Radio.js +22 -54
- package/radio-group/RadioGroup.accessibility.test.js +97 -0
- package/radio-group/RadioGroup.js +38 -83
- package/radio-group/RadioGroup.stories.tsx +10 -10
- package/radio-group/RadioGroup.test.js +504 -470
- package/radio-group/types.d.ts +8 -8
- package/resultset-table/Icons.d.ts +7 -0
- package/{resultsetTable → resultset-table}/Icons.js +1 -5
- package/resultset-table/ResultsetTable.accessibility.test.js +285 -0
- package/resultset-table/ResultsetTable.d.ts +7 -0
- package/{resultsetTable → resultset-table}/ResultsetTable.js +45 -69
- package/{resultsetTable → resultset-table}/ResultsetTable.stories.tsx +118 -5
- package/{resultsetTable → resultset-table}/ResultsetTable.test.js +148 -92
- package/{resultsetTable → resultset-table}/types.d.ts +44 -11
- package/resultset-table/types.js +5 -0
- package/select/Listbox.js +40 -54
- package/select/Option.js +28 -36
- package/select/Select.accessibility.test.js +228 -0
- package/select/Select.js +107 -171
- package/select/Select.stories.tsx +59 -111
- package/select/Select.test.js +1895 -1858
- package/select/types.d.ts +15 -16
- package/sidenav/Sidenav.accessibility.test.js +59 -0
- package/sidenav/Sidenav.js +44 -81
- package/sidenav/Sidenav.stories.tsx +4 -9
- package/sidenav/Sidenav.test.js +3 -10
- package/{layout → sidenav}/SidenavContext.d.ts +1 -1
- package/{layout → sidenav}/SidenavContext.js +3 -9
- package/sidenav/types.d.ts +20 -20
- package/slider/Slider.accessibility.test.js +104 -0
- package/slider/Slider.js +70 -126
- package/slider/Slider.test.js +107 -103
- package/slider/types.d.ts +4 -4
- package/spinner/Spinner.accessibility.test.js +96 -0
- package/spinner/Spinner.js +21 -55
- package/spinner/Spinner.test.js +25 -34
- package/spinner/types.d.ts +3 -3
- 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 +98 -0
- package/switch/Switch.js +49 -97
- package/switch/Switch.stories.tsx +12 -34
- package/switch/Switch.test.js +51 -96
- package/switch/types.d.ts +4 -4
- package/table/DropdownTheme.js +62 -0
- package/table/Table.accessibility.test.js +93 -0
- package/table/Table.d.ts +6 -2
- package/table/Table.js +76 -33
- package/table/{Table.stories.jsx → Table.stories.tsx} +309 -2
- package/table/Table.test.js +93 -6
- package/table/types.d.ts +34 -6
- package/tabs/Tab.js +22 -37
- package/tabs/Tabs.accessibility.test.js +56 -0
- package/tabs/Tabs.js +59 -147
- package/tabs/Tabs.stories.tsx +8 -4
- package/tabs/Tabs.test.js +57 -131
- package/tabs/types.d.ts +21 -21
- package/tag/Tag.accessibility.test.js +69 -0
- package/tag/Tag.js +27 -57
- package/tag/Tag.stories.tsx +4 -7
- package/tag/Tag.test.js +17 -36
- package/tag/types.d.ts +9 -9
- package/text-input/Suggestion.js +9 -26
- package/text-input/Suggestions.d.ts +1 -1
- package/text-input/Suggestions.js +30 -70
- package/text-input/TextInput.accessibility.test.js +321 -0
- package/text-input/TextInput.js +203 -289
- package/text-input/TextInput.stories.tsx +65 -160
- package/text-input/TextInput.test.js +1227 -1194
- package/text-input/types.d.ts +25 -17
- package/textarea/Textarea.accessibility.test.js +155 -0
- package/textarea/Textarea.js +68 -109
- package/textarea/{Textarea.stories.jsx → Textarea.stories.tsx} +58 -100
- package/textarea/Textarea.test.js +150 -179
- package/textarea/types.d.ts +9 -5
- package/toggle-group/ToggleGroup.accessibility.test.js +107 -0
- package/toggle-group/ToggleGroup.js +25 -64
- package/toggle-group/ToggleGroup.stories.tsx +4 -4
- package/toggle-group/ToggleGroup.test.js +48 -81
- package/toggle-group/types.d.ts +12 -12
- package/typography/Typography.accessibility.test.js +339 -0
- package/typography/Typography.js +4 -13
- package/typography/types.d.ts +1 -1
- package/useTheme.d.ts +43 -141
- package/useTheme.js +1 -8
- package/useTranslatedLabels.js +1 -7
- package/utils/BaseTypography.d.ts +2 -2
- package/utils/BaseTypography.js +16 -30
- package/utils/FocusLock.js +25 -39
- package/wizard/Wizard.accessibility.test.js +55 -0
- package/wizard/Wizard.js +27 -73
- package/wizard/Wizard.stories.tsx +19 -0
- package/wizard/Wizard.test.js +53 -80
- package/wizard/types.d.ts +8 -8
- 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/date-input/Icons.d.ts +0 -6
- package/date-input/Icons.js +0 -75
- package/paginator/Icons.d.ts +0 -5
- package/paginator/Icons.js +0 -54
- package/password-input/Icons.d.ts +0 -6
- package/password-input/Icons.js +0 -39
- package/resultsetTable/Icons.d.ts +0 -7
- package/resultsetTable/ResultsetTable.d.ts +0 -4
- package/select/Icons.d.ts +0 -10
- package/select/Icons.js +0 -93
- package/sidenav/Icons.d.ts +0 -7
- package/sidenav/Icons.js +0 -51
- package/slider/Slider.stories.tsx +0 -240
- package/text-input/Icons.d.ts +0 -8
- package/text-input/Icons.js +0 -60
- /package/{resultsetTable → action-icon}/types.js +0 -0
- /package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +0 -0
|
@@ -1,19 +1,31 @@
|
|
|
1
1
|
import React from "react";
|
|
2
2
|
import DxcResultsetTable from "./ResultsetTable";
|
|
3
|
-
import DxcButton from "../button/Button";
|
|
4
3
|
import Title from "../../.storybook/components/Title";
|
|
5
4
|
import ExampleContainer from "../../.storybook/components/ExampleContainer";
|
|
6
5
|
import { userEvent, within } from "@storybook/testing-library";
|
|
7
6
|
import styled from "styled-components";
|
|
7
|
+
import { HalstackProvider } from "../HalstackContext";
|
|
8
|
+
import { disabledRules } from "../../test/accessibility/rules/specific/resultset-table/disabledRules";
|
|
9
|
+
import preview from "../../.storybook/preview";
|
|
8
10
|
|
|
9
11
|
export default {
|
|
10
12
|
title: "Resultset Table",
|
|
11
13
|
component: DxcResultsetTable,
|
|
14
|
+
parameters: {
|
|
15
|
+
a11y: {
|
|
16
|
+
config: {
|
|
17
|
+
rules: [
|
|
18
|
+
...disabledRules.map((ruleId) => ({ id: ruleId, reviewOnFail: true })),
|
|
19
|
+
...preview?.parameters?.a11y?.config?.rules,
|
|
20
|
+
],
|
|
21
|
+
},
|
|
22
|
+
},
|
|
23
|
+
},
|
|
12
24
|
};
|
|
13
25
|
|
|
14
26
|
const deleteIcon = (
|
|
15
27
|
<svg xmlns="http://www.w3.org/2000/svg" height="24" viewBox="0 0 24 24" width="24">
|
|
16
|
-
<path d="M6 19c0 1.1.9 2 2 2h8c1.1 0 2-.9 2-2V7H6v12zM19 4h-3.5l-1-1h-5l-1 1H5v2h14V4z" />
|
|
28
|
+
<path fill="currentColor" d="M6 19c0 1.1.9 2 2 2h8c1.1 0 2-.9 2-2V7H6v12zM19 4h-3.5l-1-1h-5l-1 1H5v2h14V4z" />
|
|
17
29
|
<path d="M0 0h24v24H0z" fill="none" />
|
|
18
30
|
</svg>
|
|
19
31
|
);
|
|
@@ -29,17 +41,77 @@ const rows = [
|
|
|
29
41
|
[{ displayValue: "006" }, { displayValue: "Cris" }, { displayValue: "Paris" }],
|
|
30
42
|
];
|
|
31
43
|
|
|
44
|
+
const advancedTheme = {
|
|
45
|
+
table: {
|
|
46
|
+
actionIconColor: "#1B75BB",
|
|
47
|
+
hoverActionIconColor: "#1B75BB",
|
|
48
|
+
activeActionIconColor: "#1B75BB",
|
|
49
|
+
focusActionIconColor: "#1B75BB",
|
|
50
|
+
disabledActionIconColor: "#666666",
|
|
51
|
+
hoverButtonBackgroundColor: "#cccccc",
|
|
52
|
+
},
|
|
53
|
+
};
|
|
54
|
+
|
|
55
|
+
const actions = [
|
|
56
|
+
{
|
|
57
|
+
title: "icon",
|
|
58
|
+
onClick: (value?) => {
|
|
59
|
+
console.log(value);
|
|
60
|
+
},
|
|
61
|
+
options: [
|
|
62
|
+
{
|
|
63
|
+
value: "1",
|
|
64
|
+
label: "Amazon with a very long text",
|
|
65
|
+
},
|
|
66
|
+
{
|
|
67
|
+
value: "2",
|
|
68
|
+
label: "Ebay",
|
|
69
|
+
},
|
|
70
|
+
{
|
|
71
|
+
value: "3",
|
|
72
|
+
label: "Apple",
|
|
73
|
+
},
|
|
74
|
+
],
|
|
75
|
+
},
|
|
76
|
+
{
|
|
77
|
+
icon: "filled_edit",
|
|
78
|
+
title: "icon",
|
|
79
|
+
onClick: () => {},
|
|
80
|
+
},
|
|
81
|
+
{
|
|
82
|
+
icon: deleteIcon,
|
|
83
|
+
title: "icon",
|
|
84
|
+
onClick: () => {},
|
|
85
|
+
disabled: true,
|
|
86
|
+
},
|
|
87
|
+
{
|
|
88
|
+
icon: deleteIcon,
|
|
89
|
+
title: "icon",
|
|
90
|
+
onClick: () => {},
|
|
91
|
+
},
|
|
92
|
+
];
|
|
93
|
+
|
|
32
94
|
const rowsIcon = [
|
|
33
95
|
[
|
|
34
96
|
{ displayValue: "001", sortValue: "001" },
|
|
35
97
|
{ displayValue: "Peter" },
|
|
36
|
-
{
|
|
98
|
+
{
|
|
99
|
+
displayValue: <DxcResultsetTable.ActionsCell actions={actions} />,
|
|
100
|
+
},
|
|
101
|
+
],
|
|
102
|
+
[
|
|
103
|
+
{ displayValue: "002", sortValue: "002" },
|
|
104
|
+
{ displayValue: "Louis" },
|
|
105
|
+
{
|
|
106
|
+
displayValue: <DxcResultsetTable.ActionsCell actions={actions} />,
|
|
107
|
+
},
|
|
37
108
|
],
|
|
38
|
-
[{ displayValue: "002", sortValue: "002" }, { displayValue: "Louis" }, { displayValue: "" }],
|
|
39
109
|
[
|
|
40
110
|
{ displayValue: "003", sortValue: "003" },
|
|
41
111
|
{ displayValue: "Mark" },
|
|
42
|
-
{
|
|
112
|
+
{
|
|
113
|
+
displayValue: <DxcResultsetTable.ActionsCell actions={actions} />,
|
|
114
|
+
},
|
|
43
115
|
],
|
|
44
116
|
];
|
|
45
117
|
|
|
@@ -200,12 +272,35 @@ export const Chromatic = () => (
|
|
|
200
272
|
<Title title="Scroll resultset table" theme="light" level={4} />
|
|
201
273
|
<DxcResultsetTable columns={longColumns} rows={longRows} />
|
|
202
274
|
</ExampleContainer>
|
|
275
|
+
<ExampleContainer>
|
|
276
|
+
<Title title="Without paginator" theme="light" level={4} />
|
|
277
|
+
<DxcResultsetTable columns={columns} rows={rows} hidePaginator />
|
|
278
|
+
</ExampleContainer>
|
|
203
279
|
<ExampleContainer>
|
|
204
280
|
<SmallContainer>
|
|
205
281
|
<Title title="Small container and text overflow" theme="light" level={4} />
|
|
206
282
|
<DxcResultsetTable columns={columnsSortable} rows={longValues} />
|
|
207
283
|
</SmallContainer>
|
|
208
284
|
</ExampleContainer>
|
|
285
|
+
<ExampleContainer>
|
|
286
|
+
<Title title="Reduced sortable table" theme="light" level={4} />
|
|
287
|
+
<DxcResultsetTable columns={columnsSortable} rows={rowsSortable} mode="reduced" />
|
|
288
|
+
</ExampleContainer>
|
|
289
|
+
{/* PENDING SMALL ICON VERSION */}
|
|
290
|
+
<ExampleContainer>
|
|
291
|
+
<Title title="Reduced with items per page option" theme="light" level={4} />
|
|
292
|
+
<DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2} itemsPerPageOptions={[2, 3]} mode="reduced" />
|
|
293
|
+
</ExampleContainer>
|
|
294
|
+
<ExampleContainer>
|
|
295
|
+
<Title title="Reduced scroll resultset table" theme="light" level={4} />
|
|
296
|
+
<DxcResultsetTable columns={longColumns} rows={longRows} mode="reduced" />
|
|
297
|
+
</ExampleContainer>
|
|
298
|
+
<ExampleContainer>
|
|
299
|
+
<SmallContainer>
|
|
300
|
+
<Title title="Reduced small container and text overflow" theme="light" level={4} />
|
|
301
|
+
<DxcResultsetTable columns={columnsSortable} rows={longValues} mode="reduced" />
|
|
302
|
+
</SmallContainer>
|
|
303
|
+
</ExampleContainer>
|
|
209
304
|
<Title title="Margins" theme="light" level={2} />
|
|
210
305
|
<ExampleContainer>
|
|
211
306
|
<Title title="Xxsmall" theme="light" level={4} />
|
|
@@ -298,3 +393,21 @@ LastPage.play = async ({ canvasElement }) => {
|
|
|
298
393
|
const nextButton = canvas.getAllByRole("button")[3];
|
|
299
394
|
await userEvent.click(nextButton);
|
|
300
395
|
};
|
|
396
|
+
|
|
397
|
+
const ResultsetActionsCellDropdown = () => (
|
|
398
|
+
<ExampleContainer>
|
|
399
|
+
<Title title="Dropdown Action" theme="light" level={4} />
|
|
400
|
+
<DxcResultsetTable columns={columns} rows={rowsIcon} itemsPerPage={2} />
|
|
401
|
+
<Title title="Custom theme actions cell" theme="light" level={4} />
|
|
402
|
+
<HalstackProvider advancedTheme={advancedTheme}>
|
|
403
|
+
<DxcResultsetTable columns={columns} rows={rowsIcon} itemsPerPage={2} />
|
|
404
|
+
</HalstackProvider>
|
|
405
|
+
</ExampleContainer>
|
|
406
|
+
);
|
|
407
|
+
|
|
408
|
+
export const DropdownAction = ResultsetActionsCellDropdown.bind({});
|
|
409
|
+
DropdownAction.play = async ({ canvasElement }) => {
|
|
410
|
+
const canvas = within(canvasElement);
|
|
411
|
+
const dropdown = canvas.getAllByRole("button")[5];
|
|
412
|
+
await userEvent.click(dropdown);
|
|
413
|
+
};
|
|
@@ -1,19 +1,14 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
|
|
4
|
+
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
5
|
+
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
5
6
|
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
|
|
6
|
-
|
|
7
7
|
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
|
|
8
|
-
|
|
9
8
|
var _react = _interopRequireDefault(require("react"));
|
|
10
|
-
|
|
11
9
|
var _react2 = require("@testing-library/react");
|
|
12
|
-
|
|
13
10
|
var _userEvent = _interopRequireDefault(require("@testing-library/user-event"));
|
|
14
|
-
|
|
15
11
|
var _ResultsetTable = _interopRequireDefault(require("./ResultsetTable.tsx"));
|
|
16
|
-
|
|
17
12
|
// Mocking DOMRect for Radix Primitive Popover
|
|
18
13
|
global.globalThis = global;
|
|
19
14
|
global.DOMRect = {
|
|
@@ -28,12 +23,10 @@ global.DOMRect = {
|
|
|
28
23
|
};
|
|
29
24
|
}
|
|
30
25
|
};
|
|
31
|
-
|
|
32
26
|
global.ResizeObserver = /*#__PURE__*/function () {
|
|
33
27
|
function ResizeObserver() {
|
|
34
28
|
(0, _classCallCheck2["default"])(this, ResizeObserver);
|
|
35
29
|
}
|
|
36
|
-
|
|
37
30
|
(0, _createClass2["default"])(ResizeObserver, [{
|
|
38
31
|
key: "observe",
|
|
39
32
|
value: function observe() {}
|
|
@@ -46,7 +39,18 @@ global.ResizeObserver = /*#__PURE__*/function () {
|
|
|
46
39
|
}]);
|
|
47
40
|
return ResizeObserver;
|
|
48
41
|
}();
|
|
49
|
-
|
|
42
|
+
var icon = /*#__PURE__*/_react["default"].createElement("svg", {
|
|
43
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
44
|
+
height: "24px",
|
|
45
|
+
viewBox: "0 0 24 24",
|
|
46
|
+
width: "24px",
|
|
47
|
+
fill: "currentColor"
|
|
48
|
+
}, /*#__PURE__*/_react["default"].createElement("path", {
|
|
49
|
+
d: "M0 0h24v24H0V0zm0 0h24v24H0V0z",
|
|
50
|
+
fill: "none"
|
|
51
|
+
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
52
|
+
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"
|
|
53
|
+
}));
|
|
50
54
|
var columns = [{
|
|
51
55
|
displayValue: "Id",
|
|
52
56
|
isSortable: false
|
|
@@ -181,92 +185,88 @@ var rows2 = [[{
|
|
|
181
185
|
describe("Resultset table component tests", function () {
|
|
182
186
|
test("Resultset table rendered correctly", function () {
|
|
183
187
|
var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
188
|
+
columns: columns,
|
|
189
|
+
rows: rows,
|
|
190
|
+
itemsPerPage: 3
|
|
191
|
+
})),
|
|
192
|
+
getByText = _render.getByText;
|
|
190
193
|
expect(getByText("Peter")).toBeTruthy();
|
|
191
194
|
});
|
|
192
195
|
test("Resultset table shows as many rows as itemsPerPage", function () {
|
|
193
196
|
var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
197
|
+
columns: columns,
|
|
198
|
+
rows: rows,
|
|
199
|
+
itemsPerPage: 3
|
|
200
|
+
})),
|
|
201
|
+
getAllByRole = _render2.getAllByRole;
|
|
200
202
|
expect(getAllByRole("row").length - 1).toEqual(3);
|
|
201
203
|
});
|
|
202
204
|
test("Resultset table shows rows on second page", function () {
|
|
203
205
|
var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
206
|
+
columns: columns,
|
|
207
|
+
rows: rows,
|
|
208
|
+
itemsPerPage: 3
|
|
209
|
+
})),
|
|
210
|
+
getByText = _render3.getByText,
|
|
211
|
+
getAllByRole = _render3.getAllByRole;
|
|
211
212
|
expect(getByText("Peter")).toBeTruthy();
|
|
212
213
|
expect(getByText("Louis")).toBeTruthy();
|
|
213
214
|
expect(getByText("Lana")).toBeTruthy();
|
|
214
215
|
expect(getAllByRole("row").length - 1).toEqual(3);
|
|
215
216
|
var nextButton = getAllByRole("button")[3];
|
|
216
|
-
|
|
217
217
|
_react2.fireEvent.click(nextButton);
|
|
218
|
-
|
|
219
|
-
expect(getByText("4 to 6 of 10")).toBeTruthy();
|
|
220
|
-
expect(getByText("Rick")).toBeTruthy();
|
|
221
|
-
expect(getByText("Mark")).toBeTruthy();
|
|
222
|
-
expect(getByText("Cris")).toBeTruthy();
|
|
223
|
-
expect(getAllByRole("row").length - 1).toEqual(3);
|
|
224
|
-
});
|
|
225
|
-
test("Resultset table goToPage works as expected", function () {
|
|
226
|
-
window.HTMLElement.prototype.scrollIntoView = function () {};
|
|
227
|
-
|
|
228
|
-
window.HTMLElement.prototype.scrollTo = function () {};
|
|
229
|
-
|
|
230
|
-
var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
|
|
231
|
-
columns: columns,
|
|
232
|
-
showGoToPage: true,
|
|
233
|
-
rows: rows,
|
|
234
|
-
itemsPerPage: 3
|
|
235
|
-
})),
|
|
236
|
-
getByText = _render4.getByText,
|
|
237
|
-
getAllByRole = _render4.getAllByRole;
|
|
238
|
-
|
|
239
|
-
expect(getByText("Peter")).toBeTruthy();
|
|
240
|
-
expect(getByText("Louis")).toBeTruthy();
|
|
241
|
-
expect(getByText("Lana")).toBeTruthy();
|
|
242
|
-
expect(getAllByRole("row").length - 1).toEqual(3);
|
|
243
|
-
var goToPageSelect = getAllByRole("button")[3];
|
|
244
|
-
|
|
245
|
-
_userEvent["default"].click(goToPageSelect);
|
|
246
|
-
|
|
247
|
-
var goToPageOption = getByText("2");
|
|
248
|
-
|
|
249
|
-
_userEvent["default"].click(goToPageOption);
|
|
250
|
-
|
|
251
218
|
expect(getByText("4 to 6 of 10")).toBeTruthy();
|
|
252
219
|
expect(getByText("Rick")).toBeTruthy();
|
|
253
220
|
expect(getByText("Mark")).toBeTruthy();
|
|
254
221
|
expect(getByText("Cris")).toBeTruthy();
|
|
255
222
|
expect(getAllByRole("row").length - 1).toEqual(3);
|
|
256
223
|
});
|
|
224
|
+
test("Resultset table goToPage works as expected", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
|
|
225
|
+
var _render4, getByText, getAllByRole, goToPageSelect, goToPageOption;
|
|
226
|
+
return _regenerator["default"].wrap(function _callee$(_context) {
|
|
227
|
+
while (1) switch (_context.prev = _context.next) {
|
|
228
|
+
case 0:
|
|
229
|
+
window.HTMLElement.prototype.scrollIntoView = function () {};
|
|
230
|
+
window.HTMLElement.prototype.scrollTo = function () {};
|
|
231
|
+
_render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
|
|
232
|
+
columns: columns,
|
|
233
|
+
showGoToPage: true,
|
|
234
|
+
rows: rows,
|
|
235
|
+
itemsPerPage: 3
|
|
236
|
+
})), getByText = _render4.getByText, getAllByRole = _render4.getAllByRole;
|
|
237
|
+
expect(getByText("Peter")).toBeTruthy();
|
|
238
|
+
expect(getByText("Louis")).toBeTruthy();
|
|
239
|
+
expect(getByText("Lana")).toBeTruthy();
|
|
240
|
+
expect(getAllByRole("row").length - 1).toEqual(3);
|
|
241
|
+
goToPageSelect = getAllByRole("button")[3];
|
|
242
|
+
_context.next = 10;
|
|
243
|
+
return _userEvent["default"].click(goToPageSelect);
|
|
244
|
+
case 10:
|
|
245
|
+
goToPageOption = getByText("2");
|
|
246
|
+
_context.next = 13;
|
|
247
|
+
return _userEvent["default"].click(goToPageOption);
|
|
248
|
+
case 13:
|
|
249
|
+
expect(getByText("4 to 6 of 10")).toBeTruthy();
|
|
250
|
+
expect(getByText("Rick")).toBeTruthy();
|
|
251
|
+
expect(getByText("Mark")).toBeTruthy();
|
|
252
|
+
expect(getByText("Cris")).toBeTruthy();
|
|
253
|
+
expect(getAllByRole("row").length - 1).toEqual(3);
|
|
254
|
+
case 18:
|
|
255
|
+
case "end":
|
|
256
|
+
return _context.stop();
|
|
257
|
+
}
|
|
258
|
+
}, _callee);
|
|
259
|
+
})));
|
|
257
260
|
test("Resultset table going to the last page shows only one row", function () {
|
|
258
261
|
var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
262
|
+
columns: columns,
|
|
263
|
+
rows: rows,
|
|
264
|
+
itemsPerPage: 3
|
|
265
|
+
})),
|
|
266
|
+
getByText = _render5.getByText,
|
|
267
|
+
getAllByRole = _render5.getAllByRole;
|
|
266
268
|
var lastButton = getAllByRole("button")[4];
|
|
267
|
-
|
|
268
269
|
_react2.fireEvent.click(lastButton);
|
|
269
|
-
|
|
270
270
|
expect(getByText("10 to 10 of 10")).toBeTruthy();
|
|
271
271
|
expect(getAllByRole("row")).toHaveLength(2);
|
|
272
272
|
expect(getByText("Cosmin")).toBeTruthy();
|
|
@@ -278,26 +278,21 @@ describe("Resultset table component tests", function () {
|
|
|
278
278
|
itemsPerPage: 3
|
|
279
279
|
}));
|
|
280
280
|
expect(component.queryByText("Peter")).toBeTruthy();
|
|
281
|
-
|
|
282
281
|
_react2.fireEvent.click(component.queryByText("Name"));
|
|
283
|
-
|
|
284
282
|
expect(component.queryByText("Tina")).not.toBeTruthy();
|
|
285
283
|
expect(component.queryByText("Cosmin")).toBeTruthy();
|
|
286
|
-
|
|
287
284
|
_react2.fireEvent.click(component.queryByText("Name"));
|
|
288
|
-
|
|
289
285
|
expect(component.queryByText("Tina")).toBeTruthy();
|
|
290
286
|
expect(component.queryByText("Cosmin")).not.toBeTruthy();
|
|
291
287
|
});
|
|
292
288
|
test("Resultset table change rows should go to first page", function () {
|
|
293
289
|
var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
|
|
290
|
+
columns: columns,
|
|
291
|
+
rows: rows,
|
|
292
|
+
itemsPerPage: 3
|
|
293
|
+
})),
|
|
294
|
+
queryByText = _render6.queryByText,
|
|
295
|
+
rerender = _render6.rerender;
|
|
301
296
|
expect(queryByText("Peter")).toBeTruthy();
|
|
302
297
|
rerender( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
|
|
303
298
|
columns: columns,
|
|
@@ -308,18 +303,79 @@ describe("Resultset table component tests", function () {
|
|
|
308
303
|
});
|
|
309
304
|
test("Resultset table change itemsPerPage should go to first page", function () {
|
|
310
305
|
var _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
306
|
+
columns: columns,
|
|
307
|
+
rows: rows,
|
|
308
|
+
itemsPerPage: 3,
|
|
309
|
+
itemsPerPageOptions: [2, 3]
|
|
310
|
+
})),
|
|
311
|
+
getAllByRole = _render7.getAllByRole;
|
|
318
312
|
var lastButton = getAllByRole("button")[4];
|
|
319
313
|
expect(getAllByRole("row").length - 1).toEqual(3);
|
|
320
|
-
|
|
321
314
|
_react2.fireEvent.click(lastButton);
|
|
322
|
-
|
|
323
315
|
expect(getAllByRole("row").length - 1).toEqual(1);
|
|
324
316
|
});
|
|
317
|
+
test("Resultset table may not use the paginator", function () {
|
|
318
|
+
var _render8 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
|
|
319
|
+
columns: columns,
|
|
320
|
+
rows: rows,
|
|
321
|
+
hidePaginator: true
|
|
322
|
+
})),
|
|
323
|
+
getAllByRole = _render8.getAllByRole;
|
|
324
|
+
var nextButton = getAllByRole("button")[3];
|
|
325
|
+
expect(nextButton).not.toBeTruthy();
|
|
326
|
+
});
|
|
327
|
+
test("Resultset table with ActionsCell", function () {
|
|
328
|
+
var onSelectOption = jest.fn();
|
|
329
|
+
var onClick = jest.fn();
|
|
330
|
+
var actions = [{
|
|
331
|
+
icon: icon,
|
|
332
|
+
title: "icon1",
|
|
333
|
+
onClick: onSelectOption,
|
|
334
|
+
options: [{
|
|
335
|
+
value: "1",
|
|
336
|
+
label: "Amazon"
|
|
337
|
+
}, {
|
|
338
|
+
value: "2",
|
|
339
|
+
label: "Ebay"
|
|
340
|
+
}, {
|
|
341
|
+
value: "3",
|
|
342
|
+
label: "Aliexpress"
|
|
343
|
+
}]
|
|
344
|
+
}, {
|
|
345
|
+
icon: icon,
|
|
346
|
+
title: "icon2",
|
|
347
|
+
onClick: onClick
|
|
348
|
+
}];
|
|
349
|
+
var actionRows = [[{
|
|
350
|
+
displayValue: "001",
|
|
351
|
+
sortValue: "001"
|
|
352
|
+
}, {
|
|
353
|
+
displayValue: "Peter",
|
|
354
|
+
sortValue: "Peter"
|
|
355
|
+
}, {
|
|
356
|
+
displayValue: /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"].ActionsCell, {
|
|
357
|
+
actions: actions
|
|
358
|
+
}),
|
|
359
|
+
sortValue: "Actions"
|
|
360
|
+
}]];
|
|
361
|
+
var _render9 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
|
|
362
|
+
columns: columns,
|
|
363
|
+
rows: actionRows,
|
|
364
|
+
itemsPerPage: 3
|
|
365
|
+
})),
|
|
366
|
+
getAllByRole = _render9.getAllByRole,
|
|
367
|
+
getByRole = _render9.getByRole,
|
|
368
|
+
getByText = _render9.getByText;
|
|
369
|
+
var dropdown = getAllByRole("button")[2];
|
|
370
|
+
(0, _react2.act)(function () {
|
|
371
|
+
_userEvent["default"].click(dropdown);
|
|
372
|
+
});
|
|
373
|
+
expect(getByRole("menu")).toBeTruthy();
|
|
374
|
+
var option = getByText("Aliexpress");
|
|
375
|
+
_userEvent["default"].click(option);
|
|
376
|
+
expect(onSelectOption).toHaveBeenCalledWith("3");
|
|
377
|
+
var action = getAllByRole("button")[1];
|
|
378
|
+
_userEvent["default"].click(action);
|
|
379
|
+
expect(onClick).toHaveBeenCalled();
|
|
380
|
+
});
|
|
325
381
|
});
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
/// <reference types="react" />
|
|
2
|
-
|
|
3
|
-
|
|
2
|
+
type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
|
|
3
|
+
type Margin = {
|
|
4
4
|
top?: Space;
|
|
5
5
|
bottom?: Space;
|
|
6
6
|
left?: Space;
|
|
7
7
|
right?: Space;
|
|
8
8
|
};
|
|
9
|
-
export
|
|
9
|
+
export type Column = {
|
|
10
10
|
/**
|
|
11
11
|
* Column display value.
|
|
12
12
|
*/
|
|
@@ -16,7 +16,7 @@ export declare type Column = {
|
|
|
16
16
|
*/
|
|
17
17
|
isSortable?: boolean;
|
|
18
18
|
};
|
|
19
|
-
|
|
19
|
+
export type Row = {
|
|
20
20
|
/**
|
|
21
21
|
* Value to be displayed in the cell.
|
|
22
22
|
*/
|
|
@@ -27,7 +27,7 @@ declare type Row = {
|
|
|
27
27
|
*/
|
|
28
28
|
sortValue?: string;
|
|
29
29
|
};
|
|
30
|
-
|
|
30
|
+
type CommonProps = {
|
|
31
31
|
/**
|
|
32
32
|
* An array of objects representing the columns of the table.
|
|
33
33
|
*/
|
|
@@ -37,6 +37,24 @@ declare type Props = {
|
|
|
37
37
|
* as many objects as columns in the table.
|
|
38
38
|
*/
|
|
39
39
|
rows: Row[][];
|
|
40
|
+
/**
|
|
41
|
+
* Size of the margin to be applied to the component. You can pass an object with 'top',
|
|
42
|
+
* 'bottom', 'left' and 'right' properties in order to specify different margin sizes.
|
|
43
|
+
*/
|
|
44
|
+
margin?: Space | Margin;
|
|
45
|
+
/**
|
|
46
|
+
* Value of the tabindex attribute applied to the sortable icon.
|
|
47
|
+
*/
|
|
48
|
+
tabIndex?: number;
|
|
49
|
+
/**
|
|
50
|
+
* Determines the visual style and layout
|
|
51
|
+
* - "default": The default mode with big spacing
|
|
52
|
+
* - "reduced": A reduced mode with minimal spacing for dense tables
|
|
53
|
+
*/
|
|
54
|
+
mode?: "default" | "reduced";
|
|
55
|
+
};
|
|
56
|
+
type PaginatedProps = CommonProps & {
|
|
57
|
+
hidePaginator?: false;
|
|
40
58
|
/**
|
|
41
59
|
* If true, a select component for navigation between pages will be displayed.
|
|
42
60
|
*/
|
|
@@ -53,15 +71,30 @@ declare type Props = {
|
|
|
53
71
|
* This function will be called when the user selects an item per page
|
|
54
72
|
* option. The value selected will be passed as a parameter.
|
|
55
73
|
*/
|
|
56
|
-
itemsPerPageFunction?: (
|
|
74
|
+
itemsPerPageFunction?: (value: number) => void;
|
|
75
|
+
};
|
|
76
|
+
type NonPaginatedProps = CommonProps & {
|
|
57
77
|
/**
|
|
58
|
-
*
|
|
59
|
-
* 'bottom', 'left' and 'right' properties in order to specify different margin sizes.
|
|
78
|
+
* If true, paginator will not be displayed.
|
|
60
79
|
*/
|
|
61
|
-
|
|
80
|
+
hidePaginator: true;
|
|
62
81
|
/**
|
|
63
|
-
*
|
|
82
|
+
* If true, a select component for navigation between pages will be displayed.
|
|
64
83
|
*/
|
|
65
|
-
|
|
84
|
+
showGoToPage?: never;
|
|
85
|
+
/**
|
|
86
|
+
* Number of items per page.
|
|
87
|
+
*/
|
|
88
|
+
itemsPerPage?: never;
|
|
89
|
+
/**
|
|
90
|
+
* An array of numbers representing the items per page options.
|
|
91
|
+
*/
|
|
92
|
+
itemsPerPageOptions?: never;
|
|
93
|
+
/**
|
|
94
|
+
* This function will be called when the user selects an item per page
|
|
95
|
+
* option. The value selected will be passed as a parameter.
|
|
96
|
+
*/
|
|
97
|
+
itemsPerPageFunction?: never;
|
|
66
98
|
};
|
|
99
|
+
type Props = PaginatedProps | NonPaginatedProps;
|
|
67
100
|
export default Props;
|