@dxc-technology/halstack-react 0.0.0-c9b5c13 → 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 +5 -22
- package/HalstackContext.d.ts +1243 -6
- package/HalstackContext.js +126 -111
- package/README.md +47 -0
- package/accordion/Accordion.accessibility.test.js +71 -0
- package/accordion/Accordion.d.ts +1 -1
- package/accordion/Accordion.js +104 -161
- package/accordion/Accordion.stories.tsx +84 -140
- package/accordion/Accordion.test.js +25 -41
- package/accordion/types.d.ts +6 -17
- package/accordion-group/AccordionGroup.accessibility.test.js +88 -0
- package/accordion-group/AccordionGroup.d.ts +2 -2
- package/accordion-group/AccordionGroup.js +31 -98
- package/accordion-group/AccordionGroup.stories.tsx +94 -67
- package/accordion-group/AccordionGroup.test.js +52 -105
- package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
- package/accordion-group/AccordionGroupAccordion.js +31 -0
- package/accordion-group/AccordionGroupContext.d.ts +3 -0
- package/accordion-group/AccordionGroupContext.js +8 -0
- package/accordion-group/types.d.ts +12 -17
- 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 +32 -125
- package/alert/Alert.stories.tsx +28 -0
- package/alert/Alert.test.js +29 -46
- 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 +14 -55
- package/bleed/Bleed.stories.tsx +95 -95
- package/bleed/types.d.ts +2 -2
- package/box/Box.accessibility.test.js +33 -0
- package/box/Box.d.ts +1 -1
- package/box/Box.js +19 -60
- package/box/Box.stories.tsx +38 -51
- package/box/Box.test.js +2 -7
- package/box/types.d.ts +3 -14
- package/bulleted-list/BulletedList.accessibility.test.js +107 -0
- package/bulleted-list/BulletedList.d.ts +7 -0
- package/bulleted-list/BulletedList.js +92 -0
- package/bulleted-list/BulletedList.stories.tsx +115 -0
- package/bulleted-list/types.d.ts +38 -0
- package/button/Button.accessibility.test.js +127 -0
- package/button/Button.d.ts +1 -1
- package/button/Button.js +64 -117
- package/button/Button.stories.tsx +151 -100
- package/button/Button.test.js +20 -17
- package/button/types.d.ts +12 -8
- package/card/Card.accessibility.test.js +36 -0
- package/card/Card.d.ts +1 -1
- package/card/Card.js +48 -89
- package/card/Card.stories.tsx +12 -42
- package/card/Card.test.js +11 -22
- package/card/types.d.ts +6 -11
- package/checkbox/Checkbox.accessibility.test.js +87 -0
- package/checkbox/Checkbox.d.ts +2 -2
- package/checkbox/Checkbox.js +140 -182
- package/checkbox/Checkbox.stories.tsx +128 -94
- package/checkbox/Checkbox.test.js +160 -39
- package/checkbox/types.d.ts +11 -3
- package/chip/Chip.accessibility.test.js +67 -0
- package/chip/Chip.js +43 -80
- package/chip/Chip.stories.tsx +102 -26
- package/chip/Chip.test.js +18 -33
- package/chip/types.d.ts +4 -4
- package/common/coreTokens.d.ts +237 -0
- package/common/coreTokens.js +184 -0
- package/common/utils.d.ts +1 -0
- package/common/utils.js +6 -12
- package/common/variables.d.ts +1395 -0
- package/common/variables.js +942 -1145
- 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/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/date-input/Calendar.d.ts +4 -0
- package/date-input/Calendar.js +214 -0
- package/date-input/DateInput.accessibility.test.js +216 -0
- package/date-input/DateInput.js +150 -299
- package/date-input/DateInput.stories.tsx +203 -56
- package/date-input/DateInput.test.js +700 -371
- package/date-input/DatePicker.d.ts +4 -0
- package/date-input/DatePicker.js +115 -0
- package/date-input/Icons.d.ts +6 -0
- package/date-input/Icons.js +58 -0
- package/date-input/YearPicker.d.ts +4 -0
- package/date-input/YearPicker.js +100 -0
- package/date-input/types.d.ts +72 -15
- package/dialog/Dialog.accessibility.test.js +69 -0
- package/dialog/Dialog.d.ts +1 -1
- package/dialog/Dialog.js +73 -107
- package/dialog/Dialog.stories.tsx +320 -167
- package/dialog/Dialog.test.js +287 -20
- package/dialog/types.d.ts +18 -25
- 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/dropdown/Dropdown.accessibility.test.js +180 -0
- package/dropdown/Dropdown.d.ts +1 -1
- package/dropdown/Dropdown.js +231 -303
- package/dropdown/Dropdown.stories.tsx +235 -57
- package/dropdown/Dropdown.test.js +575 -165
- package/dropdown/DropdownMenu.d.ts +4 -0
- package/dropdown/DropdownMenu.js +63 -0
- package/dropdown/DropdownMenuItem.d.ts +4 -0
- package/dropdown/DropdownMenuItem.js +70 -0
- package/dropdown/types.d.ts +35 -19
- package/file-input/FileInput.accessibility.test.js +160 -0
- package/file-input/FileInput.d.ts +2 -2
- package/file-input/FileInput.js +241 -391
- package/file-input/FileInput.stories.tsx +123 -12
- package/file-input/FileInput.test.js +292 -367
- package/file-input/FileItem.d.ts +4 -14
- package/file-input/FileItem.js +52 -117
- package/file-input/types.d.ts +25 -8
- package/flex/Flex.d.ts +4 -0
- package/flex/Flex.js +57 -0
- package/flex/Flex.stories.tsx +112 -0
- package/flex/types.d.ts +97 -0
- package/footer/Footer.accessibility.test.js +117 -0
- package/footer/Footer.d.ts +1 -1
- package/footer/Footer.js +73 -118
- package/footer/Footer.stories.tsx +87 -21
- package/footer/Footer.test.js +33 -57
- package/footer/Icons.d.ts +3 -2
- package/footer/Icons.js +67 -8
- package/footer/types.d.ts +26 -27
- package/grid/Grid.d.ts +7 -0
- package/grid/Grid.js +76 -0
- package/grid/Grid.stories.tsx +219 -0
- package/grid/types.d.ts +115 -0
- package/grid/types.js +5 -0
- package/header/Header.accessibility.test.js +84 -0
- package/header/Header.d.ts +4 -3
- package/header/Header.js +88 -182
- package/header/Header.stories.tsx +118 -39
- package/header/Header.test.js +13 -26
- package/header/Icons.d.ts +2 -2
- package/header/Icons.js +4 -9
- package/header/types.d.ts +7 -21
- package/heading/Heading.accessibility.test.js +33 -0
- package/heading/Heading.js +10 -32
- package/heading/Heading.test.js +71 -88
- 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 +4 -0
- package/image/Image.js +70 -0
- package/image/Image.stories.tsx +129 -0
- package/image/types.d.ts +72 -0
- package/image/types.js +5 -0
- package/inset/Inset.js +14 -55
- package/inset/Inset.stories.tsx +37 -36
- package/inset/types.d.ts +2 -2
- package/layout/ApplicationLayout.d.ts +15 -6
- package/layout/ApplicationLayout.js +52 -117
- package/layout/ApplicationLayout.stories.tsx +81 -45
- package/layout/Icons.d.ts +8 -5
- package/layout/Icons.js +49 -59
- package/layout/types.d.ts +21 -32
- package/link/Link.accessibility.test.js +112 -0
- package/link/Link.js +32 -51
- package/link/Link.stories.tsx +74 -7
- package/link/Link.test.js +24 -44
- package/link/types.d.ts +14 -14
- package/main.d.ts +14 -12
- package/main.js +63 -99
- package/nav-tabs/NavTabs.accessibility.test.js +52 -0
- package/nav-tabs/NavTabs.d.ts +7 -0
- package/{tabs-nav → nav-tabs}/NavTabs.js +30 -62
- package/{tabs-nav → nav-tabs}/NavTabs.stories.tsx +115 -9
- package/{tabs-nav → nav-tabs}/NavTabs.test.js +39 -45
- package/nav-tabs/NavTabsContext.d.ts +3 -0
- package/nav-tabs/NavTabsContext.js +8 -0
- package/nav-tabs/Tab.js +118 -0
- package/{tabs-nav → nav-tabs}/types.d.ts +14 -15
- package/nav-tabs/types.js +5 -0
- package/number-input/NumberInput.accessibility.test.js +228 -0
- package/number-input/NumberInput.js +46 -36
- package/number-input/NumberInput.stories.tsx +42 -26
- package/number-input/NumberInput.test.js +860 -377
- package/number-input/NumberInputContext.d.ts +3 -4
- package/number-input/NumberInputContext.js +3 -14
- package/number-input/types.d.ts +17 -5
- package/package.json +49 -51
- package/paginator/Icons.d.ts +5 -0
- package/paginator/Icons.js +21 -47
- package/paginator/Paginator.accessibility.test.js +79 -0
- package/paginator/Paginator.js +23 -59
- package/paginator/Paginator.stories.tsx +24 -0
- package/paginator/Paginator.test.js +280 -211
- package/paginator/types.d.ts +3 -3
- package/paragraph/Paragraph.accessibility.test.js +28 -0
- package/paragraph/Paragraph.d.ts +5 -0
- package/paragraph/Paragraph.js +22 -0
- package/paragraph/Paragraph.stories.tsx +27 -0
- package/password-input/Icons.d.ts +6 -0
- package/password-input/Icons.js +35 -0
- package/password-input/PasswordInput.accessibility.test.js +153 -0
- package/password-input/PasswordInput.js +57 -126
- package/password-input/PasswordInput.stories.tsx +1 -33
- package/password-input/PasswordInput.test.js +160 -142
- package/password-input/types.d.ts +8 -7
- package/progress-bar/ProgressBar.accessibility.test.js +35 -0
- package/progress-bar/ProgressBar.js +65 -91
- package/progress-bar/{ProgressBar.stories.jsx → ProgressBar.stories.tsx} +39 -4
- package/progress-bar/ProgressBar.test.js +72 -44
- package/progress-bar/types.d.ts +3 -3
- package/quick-nav/QuickNav.accessibility.test.js +57 -0
- package/quick-nav/QuickNav.js +29 -47
- package/quick-nav/QuickNav.stories.tsx +146 -27
- package/quick-nav/types.d.ts +10 -10
- package/radio-group/Radio.d.ts +1 -1
- package/radio-group/Radio.js +59 -76
- package/radio-group/RadioGroup.accessibility.test.js +97 -0
- package/radio-group/RadioGroup.js +67 -114
- package/radio-group/RadioGroup.stories.tsx +132 -18
- package/radio-group/RadioGroup.test.js +518 -457
- package/radio-group/types.d.ts +10 -10
- package/resultset-table/Icons.d.ts +7 -0
- package/resultset-table/Icons.js +47 -0
- package/resultset-table/ResultsetTable.accessibility.test.js +274 -0
- package/resultset-table/ResultsetTable.d.ts +7 -0
- package/resultset-table/ResultsetTable.js +170 -0
- package/{resultsetTable → resultset-table}/ResultsetTable.stories.tsx +156 -30
- package/resultset-table/ResultsetTable.test.js +381 -0
- package/{resultsetTable → resultset-table}/types.d.ts +44 -11
- package/resultset-table/types.js +5 -0
- package/select/Icons.d.ts +7 -7
- package/select/Icons.js +1 -5
- package/select/Listbox.d.ts +1 -1
- package/select/Listbox.js +42 -51
- package/select/Option.js +27 -50
- package/select/Select.accessibility.test.js +217 -0
- package/select/Select.js +152 -207
- package/select/Select.stories.tsx +515 -139
- package/select/Select.test.js +2001 -1751
- package/select/types.d.ts +16 -20
- package/sidenav/Sidenav.accessibility.test.js +59 -0
- package/sidenav/Sidenav.d.ts +6 -5
- package/sidenav/Sidenav.js +132 -78
- package/sidenav/Sidenav.stories.tsx +246 -151
- package/sidenav/Sidenav.test.js +26 -45
- package/{layout → sidenav}/SidenavContext.d.ts +1 -1
- package/{layout → sidenav}/SidenavContext.js +3 -9
- package/sidenav/types.d.ts +52 -26
- package/slider/Slider.accessibility.test.js +104 -0
- package/slider/Slider.d.ts +2 -2
- package/slider/Slider.js +148 -181
- package/slider/Slider.test.js +185 -81
- package/slider/types.d.ts +7 -3
- package/spinner/Spinner.accessibility.test.js +96 -0
- package/spinner/Spinner.js +31 -75
- package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +53 -27
- package/spinner/Spinner.test.js +26 -35
- 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 +89 -0
- package/switch/Switch.d.ts +2 -2
- package/switch/Switch.js +145 -126
- package/switch/Switch.stories.tsx +37 -60
- package/switch/Switch.test.js +138 -56
- package/switch/types.d.ts +7 -3
- 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 +78 -35
- package/table/Table.stories.tsx +651 -0
- package/table/Table.test.js +95 -8
- package/table/types.d.ts +34 -6
- package/tabs/Tab.d.ts +4 -0
- package/tabs/Tab.js +116 -0
- package/tabs/Tabs.accessibility.test.js +56 -0
- package/tabs/Tabs.js +314 -141
- package/tabs/Tabs.stories.tsx +120 -6
- package/tabs/Tabs.test.js +223 -69
- package/tabs/types.d.ts +28 -18
- package/tag/Tag.accessibility.test.js +69 -0
- package/tag/Tag.js +35 -67
- package/tag/Tag.stories.tsx +18 -8
- package/tag/Tag.test.js +18 -37
- package/tag/types.d.ts +9 -9
- package/text-input/Suggestion.js +40 -28
- package/text-input/Suggestions.d.ts +4 -0
- package/text-input/Suggestions.js +86 -0
- package/text-input/TextInput.accessibility.test.js +321 -0
- package/text-input/TextInput.js +311 -514
- package/text-input/TextInput.stories.tsx +266 -275
- package/text-input/TextInput.test.js +1419 -1375
- package/text-input/types.d.ts +43 -16
- package/textarea/Textarea.accessibility.test.js +155 -0
- package/textarea/Textarea.js +70 -113
- package/textarea/Textarea.stories.tsx +174 -0
- package/textarea/Textarea.test.js +152 -183
- package/textarea/types.d.ts +9 -5
- package/toggle-group/ToggleGroup.accessibility.test.js +107 -0
- package/toggle-group/ToggleGroup.d.ts +2 -2
- package/toggle-group/ToggleGroup.js +92 -106
- package/toggle-group/ToggleGroup.stories.tsx +49 -4
- package/toggle-group/ToggleGroup.test.js +69 -88
- package/toggle-group/types.d.ts +26 -17
- package/typography/Typography.accessibility.test.js +339 -0
- package/typography/Typography.d.ts +4 -0
- package/typography/Typography.js +23 -0
- package/typography/Typography.stories.tsx +198 -0
- package/typography/types.d.ts +18 -0
- package/typography/types.js +5 -0
- package/useTheme.d.ts +1147 -1
- package/useTheme.js +2 -9
- package/useTranslatedLabels.d.ts +84 -1
- package/useTranslatedLabels.js +1 -7
- package/utils/BaseTypography.d.ts +21 -0
- package/utils/BaseTypography.js +94 -0
- package/utils/FocusLock.d.ts +13 -0
- package/utils/FocusLock.js +124 -0
- package/wizard/Wizard.accessibility.test.js +55 -0
- package/wizard/Wizard.js +24 -66
- package/wizard/Wizard.stories.tsx +40 -1
- package/wizard/Wizard.test.js +54 -81
- package/wizard/types.d.ts +8 -8
- package/card/ice-cream.jpg +0 -0
- package/common/OpenSans.css +0 -81
- package/common/RequiredComponent.js +0 -32
- 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/list/List.d.ts +0 -4
- package/list/List.js +0 -47
- package/list/List.stories.tsx +0 -95
- package/list/types.d.ts +0 -7
- package/number-input/numberInputContextTypes.d.ts +0 -19
- package/resultsetTable/ResultsetTable.d.ts +0 -4
- package/resultsetTable/ResultsetTable.js +0 -254
- package/resultsetTable/ResultsetTable.test.js +0 -306
- package/row/Row.d.ts +0 -3
- package/row/Row.js +0 -127
- package/row/Row.stories.tsx +0 -237
- package/row/types.d.ts +0 -28
- package/slider/Slider.stories.tsx +0 -177
- package/stack/Stack.d.ts +0 -3
- package/stack/Stack.js +0 -97
- package/stack/Stack.stories.tsx +0 -164
- package/stack/types.d.ts +0 -24
- package/table/Table.stories.jsx +0 -277
- package/tabs-nav/NavTabs.d.ts +0 -8
- package/tabs-nav/Tab.js +0 -132
- package/text/Text.d.ts +0 -7
- package/text/Text.js +0 -30
- package/text/Text.stories.tsx +0 -19
- package/textarea/Textarea.stories.jsx +0 -157
- /package/{list → action-icon}/types.js +0 -0
- /package/{resultsetTable → bulleted-list}/types.js +0 -0
- /package/{row → container}/types.js +0 -0
- /package/{stack → contextual-menu}/types.js +0 -0
- /package/{tabs-nav → divider}/types.js +0 -0
- /package/{number-input/numberInputContextTypes.js → flex/types.js} +0 -0
- /package/{tabs-nav → nav-tabs}/Tab.d.ts +0 -0
|
@@ -1,9 +1,10 @@
|
|
|
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";
|
|
6
|
+
import styled from "styled-components";
|
|
7
|
+
import { HalstackProvider } from "../HalstackContext";
|
|
7
8
|
|
|
8
9
|
export default {
|
|
9
10
|
title: "Resultset Table",
|
|
@@ -12,7 +13,7 @@ export default {
|
|
|
12
13
|
|
|
13
14
|
const deleteIcon = (
|
|
14
15
|
<svg xmlns="http://www.w3.org/2000/svg" height="24" viewBox="0 0 24 24" width="24">
|
|
15
|
-
<path d="M6 19c0 1.1.9 2 2 2h8c1.1 0 2-.9 2-2V7H6v12zM19 4h-3.5l-1-1h-5l-1 1H5v2h14V4z" />
|
|
16
|
+
<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" />
|
|
16
17
|
<path d="M0 0h24v24H0z" fill="none" />
|
|
17
18
|
</svg>
|
|
18
19
|
);
|
|
@@ -28,17 +29,77 @@ const rows = [
|
|
|
28
29
|
[{ displayValue: "006" }, { displayValue: "Cris" }, { displayValue: "Paris" }],
|
|
29
30
|
];
|
|
30
31
|
|
|
32
|
+
const advancedTheme = {
|
|
33
|
+
table: {
|
|
34
|
+
actionIconColor: "#1B75BB",
|
|
35
|
+
hoverActionIconColor: "#1B75BB",
|
|
36
|
+
activeActionIconColor: "#1B75BB",
|
|
37
|
+
focusActionIconColor: "#1B75BB",
|
|
38
|
+
disabledActionIconColor: "#666666",
|
|
39
|
+
hoverButtonBackgroundColor: "#cccccc",
|
|
40
|
+
},
|
|
41
|
+
};
|
|
42
|
+
|
|
43
|
+
const actions = [
|
|
44
|
+
{
|
|
45
|
+
title: "icon",
|
|
46
|
+
onClick: (value?) => {
|
|
47
|
+
console.log(value);
|
|
48
|
+
},
|
|
49
|
+
options: [
|
|
50
|
+
{
|
|
51
|
+
value: "1",
|
|
52
|
+
label: "Amazon with a very long text",
|
|
53
|
+
},
|
|
54
|
+
{
|
|
55
|
+
value: "2",
|
|
56
|
+
label: "Ebay",
|
|
57
|
+
},
|
|
58
|
+
{
|
|
59
|
+
value: "3",
|
|
60
|
+
label: "Apple",
|
|
61
|
+
},
|
|
62
|
+
],
|
|
63
|
+
},
|
|
64
|
+
{
|
|
65
|
+
icon: "filled_edit",
|
|
66
|
+
title: "icon",
|
|
67
|
+
onClick: () => {},
|
|
68
|
+
},
|
|
69
|
+
{
|
|
70
|
+
icon: deleteIcon,
|
|
71
|
+
title: "icon",
|
|
72
|
+
onClick: () => {},
|
|
73
|
+
disabled: true,
|
|
74
|
+
},
|
|
75
|
+
{
|
|
76
|
+
icon: deleteIcon,
|
|
77
|
+
title: "icon",
|
|
78
|
+
onClick: () => {},
|
|
79
|
+
},
|
|
80
|
+
];
|
|
81
|
+
|
|
31
82
|
const rowsIcon = [
|
|
32
83
|
[
|
|
33
84
|
{ displayValue: "001", sortValue: "001" },
|
|
34
85
|
{ displayValue: "Peter" },
|
|
35
|
-
{
|
|
86
|
+
{
|
|
87
|
+
displayValue: <DxcResultsetTable.ActionsCell actions={actions} />,
|
|
88
|
+
},
|
|
89
|
+
],
|
|
90
|
+
[
|
|
91
|
+
{ displayValue: "002", sortValue: "002" },
|
|
92
|
+
{ displayValue: "Louis" },
|
|
93
|
+
{
|
|
94
|
+
displayValue: <DxcResultsetTable.ActionsCell actions={actions} />,
|
|
95
|
+
},
|
|
36
96
|
],
|
|
37
|
-
[{ displayValue: "002", sortValue: "002" }, { displayValue: "Louis" }, { displayValue: "" }],
|
|
38
97
|
[
|
|
39
98
|
{ displayValue: "003", sortValue: "003" },
|
|
40
99
|
{ displayValue: "Mark" },
|
|
41
|
-
{
|
|
100
|
+
{
|
|
101
|
+
displayValue: <DxcResultsetTable.ActionsCell actions={actions} />,
|
|
102
|
+
},
|
|
42
103
|
],
|
|
43
104
|
];
|
|
44
105
|
|
|
@@ -48,6 +109,24 @@ const columnsSortable = [
|
|
|
48
109
|
{ displayValue: "City", isSortable: false },
|
|
49
110
|
];
|
|
50
111
|
|
|
112
|
+
const longValues = [
|
|
113
|
+
[
|
|
114
|
+
{ displayValue: "000000000000000001", sortValue: "000000000000000001" },
|
|
115
|
+
{ displayValue: "Peter Larsson González", sortValue: "Peter" },
|
|
116
|
+
{ displayValue: "Miami: The city that never sleeps", sortValue: "Miami" },
|
|
117
|
+
],
|
|
118
|
+
[
|
|
119
|
+
{ displayValue: "002", sortValue: "002" },
|
|
120
|
+
{ displayValue: "Louis", sortValue: "Louis" },
|
|
121
|
+
{ displayValue: "London", sortValue: "London" },
|
|
122
|
+
],
|
|
123
|
+
[
|
|
124
|
+
{ displayValue: "003", sortValue: "003" },
|
|
125
|
+
{ displayValue: "Aida", sortValue: "Aida" },
|
|
126
|
+
{ displayValue: "Wroclaw", sortValue: "Wroclaw" },
|
|
127
|
+
],
|
|
128
|
+
];
|
|
129
|
+
|
|
51
130
|
const rowsSortable = [
|
|
52
131
|
[
|
|
53
132
|
{ displayValue: "001", sortValue: "001" },
|
|
@@ -167,89 +246,118 @@ export const Chromatic = () => (
|
|
|
167
246
|
<>
|
|
168
247
|
<ExampleContainer>
|
|
169
248
|
<Title title="Sortable table" theme="light" level={4} />
|
|
170
|
-
<DxcResultsetTable columns={columnsSortable} rows={rowsSortable}
|
|
249
|
+
<DxcResultsetTable columns={columnsSortable} rows={rowsSortable} />
|
|
171
250
|
</ExampleContainer>
|
|
172
251
|
<ExampleContainer>
|
|
173
252
|
<Title title="With action" theme="light" level={4} />
|
|
174
|
-
<DxcResultsetTable columns={columns} rows={rowsIcon}
|
|
253
|
+
<DxcResultsetTable columns={columns} rows={rowsIcon} />
|
|
175
254
|
</ExampleContainer>
|
|
176
255
|
<ExampleContainer>
|
|
177
256
|
<Title title="With items per page option" theme="light" level={4} />
|
|
178
|
-
<DxcResultsetTable
|
|
179
|
-
columns={columns}
|
|
180
|
-
rows={rows}
|
|
181
|
-
itemsPerPage={2}
|
|
182
|
-
itemsPerPageOptions={[2, 3]}
|
|
183
|
-
></DxcResultsetTable>
|
|
257
|
+
<DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2} itemsPerPageOptions={[2, 3]} />
|
|
184
258
|
</ExampleContainer>
|
|
185
259
|
<ExampleContainer>
|
|
186
260
|
<Title title="Scroll resultset table" theme="light" level={4} />
|
|
187
|
-
<DxcResultsetTable columns={longColumns} rows={longRows}
|
|
261
|
+
<DxcResultsetTable columns={longColumns} rows={longRows} />
|
|
262
|
+
</ExampleContainer>
|
|
263
|
+
<ExampleContainer>
|
|
264
|
+
<Title title="Without paginator" theme="light" level={4} />
|
|
265
|
+
<DxcResultsetTable columns={columns} rows={rows} hidePaginator />
|
|
266
|
+
</ExampleContainer>
|
|
267
|
+
<ExampleContainer>
|
|
268
|
+
<SmallContainer>
|
|
269
|
+
<Title title="Small container and text overflow" theme="light" level={4} />
|
|
270
|
+
<DxcResultsetTable columns={columnsSortable} rows={longValues} />
|
|
271
|
+
</SmallContainer>
|
|
272
|
+
</ExampleContainer>
|
|
273
|
+
<ExampleContainer>
|
|
274
|
+
<Title title="Reduced sortable table" theme="light" level={4} />
|
|
275
|
+
<DxcResultsetTable columns={columnsSortable} rows={rowsSortable} mode="reduced" />
|
|
276
|
+
</ExampleContainer>
|
|
277
|
+
{/* PENDING SMALL ICON VERSION */}
|
|
278
|
+
<ExampleContainer>
|
|
279
|
+
<Title title="Reduced with items per page option" theme="light" level={4} />
|
|
280
|
+
<DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2} itemsPerPageOptions={[2, 3]} mode="reduced" />
|
|
281
|
+
</ExampleContainer>
|
|
282
|
+
<ExampleContainer>
|
|
283
|
+
<Title title="Reduced scroll resultset table" theme="light" level={4} />
|
|
284
|
+
<DxcResultsetTable columns={longColumns} rows={longRows} mode="reduced" />
|
|
285
|
+
</ExampleContainer>
|
|
286
|
+
<ExampleContainer>
|
|
287
|
+
<SmallContainer>
|
|
288
|
+
<Title title="Reduced small container and text overflow" theme="light" level={4} />
|
|
289
|
+
<DxcResultsetTable columns={columnsSortable} rows={longValues} mode="reduced" />
|
|
290
|
+
</SmallContainer>
|
|
188
291
|
</ExampleContainer>
|
|
189
292
|
<Title title="Margins" theme="light" level={2} />
|
|
190
293
|
<ExampleContainer>
|
|
191
294
|
<Title title="Xxsmall" theme="light" level={4} />
|
|
192
|
-
<DxcResultsetTable columns={columns} rows={rows} margin={"xxsmall"}
|
|
295
|
+
<DxcResultsetTable columns={columns} rows={rows} margin={"xxsmall"} />
|
|
193
296
|
</ExampleContainer>
|
|
194
297
|
<ExampleContainer>
|
|
195
298
|
<Title title="Xsmall" theme="light" level={4} />
|
|
196
|
-
<DxcResultsetTable columns={columns} rows={rows} margin={"xsmall"}
|
|
299
|
+
<DxcResultsetTable columns={columns} rows={rows} margin={"xsmall"} />
|
|
197
300
|
</ExampleContainer>
|
|
198
301
|
<ExampleContainer>
|
|
199
302
|
<Title title="Small" theme="light" level={4} />
|
|
200
|
-
<DxcResultsetTable columns={columns} rows={rows} margin={"small"}
|
|
303
|
+
<DxcResultsetTable columns={columns} rows={rows} margin={"small"} />
|
|
201
304
|
</ExampleContainer>
|
|
202
305
|
<ExampleContainer>
|
|
203
306
|
<Title title="Medium" theme="light" level={4} />
|
|
204
|
-
<DxcResultsetTable columns={columns} rows={rows} margin={"medium"}
|
|
307
|
+
<DxcResultsetTable columns={columns} rows={rows} margin={"medium"} />
|
|
205
308
|
</ExampleContainer>
|
|
206
309
|
<ExampleContainer>
|
|
207
310
|
<Title title="Large" theme="light" level={4} />
|
|
208
|
-
<DxcResultsetTable columns={columns} rows={rows} margin={"large"}
|
|
311
|
+
<DxcResultsetTable columns={columns} rows={rows} margin={"large"} />
|
|
209
312
|
</ExampleContainer>
|
|
210
313
|
<ExampleContainer>
|
|
211
314
|
<Title title="Xlarge" theme="light" level={4} />
|
|
212
|
-
<DxcResultsetTable columns={columns} rows={rows} margin={"xlarge"}
|
|
315
|
+
<DxcResultsetTable columns={columns} rows={rows} margin={"xlarge"} />
|
|
213
316
|
</ExampleContainer>
|
|
214
|
-
<ExampleContainer>
|
|
317
|
+
<ExampleContainer expanded>
|
|
215
318
|
<Title title="Xxlarge" theme="light" level={4} />
|
|
216
|
-
<DxcResultsetTable columns={columns} rows={rows} margin={"xxlarge"}
|
|
217
|
-
<hr />
|
|
319
|
+
<DxcResultsetTable columns={columns} rows={rows} margin={"xxlarge"} />
|
|
218
320
|
</ExampleContainer>
|
|
219
321
|
</>
|
|
220
322
|
);
|
|
221
323
|
|
|
324
|
+
const SmallContainer = styled.div`
|
|
325
|
+
width: 500px;
|
|
326
|
+
`;
|
|
327
|
+
|
|
222
328
|
const ResultsetTableAsc = () => (
|
|
223
329
|
<ExampleContainer>
|
|
224
330
|
<Title title="Ascendant sorting" theme="light" level={4} />
|
|
225
|
-
<DxcResultsetTable columns={columnsSortable} rows={rowsSortable}
|
|
331
|
+
<DxcResultsetTable columns={columnsSortable} rows={rowsSortable} />
|
|
226
332
|
</ExampleContainer>
|
|
227
333
|
);
|
|
228
334
|
|
|
229
335
|
export const AscendentSorting = ResultsetTableAsc.bind({});
|
|
230
336
|
AscendentSorting.play = async ({ canvasElement }) => {
|
|
231
337
|
const canvas = within(canvasElement);
|
|
232
|
-
|
|
338
|
+
const idHeader = canvas.getAllByRole("button")[0];
|
|
339
|
+
await userEvent.click(idHeader);
|
|
233
340
|
};
|
|
234
341
|
|
|
235
342
|
const ResultsetTableDesc = () => (
|
|
236
343
|
<ExampleContainer>
|
|
237
344
|
<Title title="Descendant sorting" theme="light" level={4} />
|
|
238
|
-
<DxcResultsetTable columns={columnsSortable} rows={rowsSortable}
|
|
345
|
+
<DxcResultsetTable columns={columnsSortable} rows={rowsSortable} />
|
|
239
346
|
</ExampleContainer>
|
|
240
347
|
);
|
|
241
348
|
|
|
242
349
|
export const DescendantSorting = ResultsetTableDesc.bind({});
|
|
243
350
|
DescendantSorting.play = async ({ canvasElement }) => {
|
|
244
351
|
const canvas = within(canvasElement);
|
|
245
|
-
|
|
246
|
-
await userEvent.click(
|
|
352
|
+
const nameHeader = canvas.getAllByRole("button")[1];
|
|
353
|
+
await userEvent.click(nameHeader);
|
|
354
|
+
await userEvent.click(nameHeader);
|
|
247
355
|
};
|
|
248
356
|
|
|
249
357
|
const ResultsetTableMiddle = () => (
|
|
250
358
|
<ExampleContainer>
|
|
251
359
|
<Title title="Middle page" theme="light" level={4} />
|
|
252
|
-
<DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2}
|
|
360
|
+
<DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2} />
|
|
253
361
|
</ExampleContainer>
|
|
254
362
|
);
|
|
255
363
|
|
|
@@ -263,7 +371,7 @@ MiddlePage.play = async ({ canvasElement }) => {
|
|
|
263
371
|
const ResultsetTableLast = () => (
|
|
264
372
|
<ExampleContainer>
|
|
265
373
|
<Title title="Last page" theme="light" level={4} />
|
|
266
|
-
<DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2}
|
|
374
|
+
<DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2} />
|
|
267
375
|
</ExampleContainer>
|
|
268
376
|
);
|
|
269
377
|
|
|
@@ -273,3 +381,21 @@ LastPage.play = async ({ canvasElement }) => {
|
|
|
273
381
|
const nextButton = canvas.getAllByRole("button")[3];
|
|
274
382
|
await userEvent.click(nextButton);
|
|
275
383
|
};
|
|
384
|
+
|
|
385
|
+
const ResultsetActionsCellDropdown = () => (
|
|
386
|
+
<ExampleContainer>
|
|
387
|
+
<Title title="Dropdown Action" theme="light" level={4} />
|
|
388
|
+
<DxcResultsetTable columns={columns} rows={rowsIcon} itemsPerPage={2} />
|
|
389
|
+
<Title title="Custom theme actions cell" theme="light" level={4} />
|
|
390
|
+
<HalstackProvider advancedTheme={advancedTheme}>
|
|
391
|
+
<DxcResultsetTable columns={columns} rows={rowsIcon} itemsPerPage={2} />
|
|
392
|
+
</HalstackProvider>
|
|
393
|
+
</ExampleContainer>
|
|
394
|
+
);
|
|
395
|
+
|
|
396
|
+
export const DropdownAction = ResultsetActionsCellDropdown.bind({});
|
|
397
|
+
DropdownAction.play = async ({ canvasElement }) => {
|
|
398
|
+
const canvas = within(canvasElement);
|
|
399
|
+
const dropdown = canvas.getAllByRole("button")[5];
|
|
400
|
+
await userEvent.click(dropdown);
|
|
401
|
+
};
|
|
@@ -0,0 +1,381 @@
|
|
|
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 _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
|
|
7
|
+
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
|
|
8
|
+
var _react = _interopRequireDefault(require("react"));
|
|
9
|
+
var _react2 = require("@testing-library/react");
|
|
10
|
+
var _userEvent = _interopRequireDefault(require("@testing-library/user-event"));
|
|
11
|
+
var _ResultsetTable = _interopRequireDefault(require("./ResultsetTable.tsx"));
|
|
12
|
+
// Mocking DOMRect for Radix Primitive Popover
|
|
13
|
+
global.globalThis = global;
|
|
14
|
+
global.DOMRect = {
|
|
15
|
+
fromRect: function fromRect() {
|
|
16
|
+
return {
|
|
17
|
+
top: 0,
|
|
18
|
+
left: 0,
|
|
19
|
+
bottom: 0,
|
|
20
|
+
right: 0,
|
|
21
|
+
width: 0,
|
|
22
|
+
height: 0
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
};
|
|
26
|
+
global.ResizeObserver = /*#__PURE__*/function () {
|
|
27
|
+
function ResizeObserver() {
|
|
28
|
+
(0, _classCallCheck2["default"])(this, ResizeObserver);
|
|
29
|
+
}
|
|
30
|
+
(0, _createClass2["default"])(ResizeObserver, [{
|
|
31
|
+
key: "observe",
|
|
32
|
+
value: function observe() {}
|
|
33
|
+
}, {
|
|
34
|
+
key: "unobserve",
|
|
35
|
+
value: function unobserve() {}
|
|
36
|
+
}, {
|
|
37
|
+
key: "disconnect",
|
|
38
|
+
value: function disconnect() {}
|
|
39
|
+
}]);
|
|
40
|
+
return ResizeObserver;
|
|
41
|
+
}();
|
|
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
|
+
}));
|
|
54
|
+
var columns = [{
|
|
55
|
+
displayValue: "Id",
|
|
56
|
+
isSortable: false
|
|
57
|
+
}, {
|
|
58
|
+
displayValue: "Name",
|
|
59
|
+
isSortable: true
|
|
60
|
+
}, {
|
|
61
|
+
displayValue: "City",
|
|
62
|
+
isSortable: false
|
|
63
|
+
}];
|
|
64
|
+
var rows = [[{
|
|
65
|
+
displayValue: "001",
|
|
66
|
+
sortValue: "001"
|
|
67
|
+
}, {
|
|
68
|
+
displayValue: "Peter",
|
|
69
|
+
sortValue: "Peter"
|
|
70
|
+
}, {
|
|
71
|
+
displayValue: "Oviedo",
|
|
72
|
+
sortValue: "Oviedo"
|
|
73
|
+
}], [{
|
|
74
|
+
displayValue: "002",
|
|
75
|
+
sortValue: "002"
|
|
76
|
+
}, {
|
|
77
|
+
displayValue: "Louis",
|
|
78
|
+
sortValue: "Louis"
|
|
79
|
+
}, {
|
|
80
|
+
displayValue: "Oviedo",
|
|
81
|
+
sortValue: "Oviedo"
|
|
82
|
+
}], [{
|
|
83
|
+
displayValue: "003",
|
|
84
|
+
sortValue: "003"
|
|
85
|
+
}, {
|
|
86
|
+
displayValue: "Lana",
|
|
87
|
+
sortValue: "Lana"
|
|
88
|
+
}, {
|
|
89
|
+
displayValue: "Albacete",
|
|
90
|
+
sortValue: "Albacete"
|
|
91
|
+
}], [{
|
|
92
|
+
displayValue: "004",
|
|
93
|
+
sortValue: "004"
|
|
94
|
+
}, {
|
|
95
|
+
displayValue: "Rick",
|
|
96
|
+
sortValue: "Rick"
|
|
97
|
+
}, {
|
|
98
|
+
displayValue: "Albacete",
|
|
99
|
+
sortValue: "Albacete"
|
|
100
|
+
}], [{
|
|
101
|
+
displayValue: "005",
|
|
102
|
+
sortValue: "005"
|
|
103
|
+
}, {
|
|
104
|
+
displayValue: "Mark",
|
|
105
|
+
sortValue: "Mark"
|
|
106
|
+
}, {
|
|
107
|
+
displayValue: "Madrid",
|
|
108
|
+
sortValue: "Madrid"
|
|
109
|
+
}], [{
|
|
110
|
+
displayValue: "006",
|
|
111
|
+
sortValue: "006"
|
|
112
|
+
}, {
|
|
113
|
+
displayValue: "Cris",
|
|
114
|
+
sortValue: "Cris"
|
|
115
|
+
}, {
|
|
116
|
+
displayValue: "Barcelona",
|
|
117
|
+
sortValue: "Barcelona"
|
|
118
|
+
}], [{
|
|
119
|
+
displayValue: "007",
|
|
120
|
+
sortValue: "007"
|
|
121
|
+
}, {
|
|
122
|
+
displayValue: "Susan",
|
|
123
|
+
sortValue: "Susan"
|
|
124
|
+
}, {
|
|
125
|
+
displayValue: "Madrid",
|
|
126
|
+
sortValue: "Madrid"
|
|
127
|
+
}], [{
|
|
128
|
+
displayValue: "008",
|
|
129
|
+
sortValue: "008"
|
|
130
|
+
}, {
|
|
131
|
+
displayValue: "Tina",
|
|
132
|
+
sortValue: "Tina"
|
|
133
|
+
}, {
|
|
134
|
+
displayValue: "Barcelona",
|
|
135
|
+
sortValue: "Barcelona"
|
|
136
|
+
}], [{
|
|
137
|
+
displayValue: "009",
|
|
138
|
+
sortValue: "009"
|
|
139
|
+
}, {
|
|
140
|
+
displayValue: "Kevin",
|
|
141
|
+
sortValue: "Kevin"
|
|
142
|
+
}, {
|
|
143
|
+
displayValue: "Oviedo",
|
|
144
|
+
sortValue: "Oviedo"
|
|
145
|
+
}], [{
|
|
146
|
+
displayValue: "010",
|
|
147
|
+
sortValue: "010"
|
|
148
|
+
}, {
|
|
149
|
+
displayValue: "Cosmin",
|
|
150
|
+
sortValue: "Cosmin"
|
|
151
|
+
}, {
|
|
152
|
+
displayValue: "Barcelona",
|
|
153
|
+
sortValue: "Barcelona"
|
|
154
|
+
}]];
|
|
155
|
+
var rows2 = [[{
|
|
156
|
+
displayValue: "546",
|
|
157
|
+
sortValue: "465"
|
|
158
|
+
}, {
|
|
159
|
+
displayValue: "OtherValue",
|
|
160
|
+
sortValue: "OtherValue"
|
|
161
|
+
}, {
|
|
162
|
+
displayValue: "OtherValue",
|
|
163
|
+
sortValue: "OtherValue"
|
|
164
|
+
}], [{
|
|
165
|
+
displayValue: "978",
|
|
166
|
+
sortValue: "465"
|
|
167
|
+
}, {
|
|
168
|
+
displayValue: "OtherValue",
|
|
169
|
+
sortValue: "OtherValue"
|
|
170
|
+
}, {
|
|
171
|
+
displayValue: "OtherValue",
|
|
172
|
+
sortValue: "OtherValue"
|
|
173
|
+
}, {
|
|
174
|
+
displayValue: ""
|
|
175
|
+
}], [{
|
|
176
|
+
displayValue: "678",
|
|
177
|
+
sortValue: "344"
|
|
178
|
+
}, {
|
|
179
|
+
displayValue: "OtherValue",
|
|
180
|
+
sortValue: "OtherValue"
|
|
181
|
+
}, {
|
|
182
|
+
displayValue: "OtherValue",
|
|
183
|
+
sortValue: "OtherValue"
|
|
184
|
+
}]];
|
|
185
|
+
describe("Resultset table component tests", function () {
|
|
186
|
+
test("Resultset table rendered correctly", function () {
|
|
187
|
+
var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
|
|
188
|
+
columns: columns,
|
|
189
|
+
rows: rows,
|
|
190
|
+
itemsPerPage: 3
|
|
191
|
+
})),
|
|
192
|
+
getByText = _render.getByText;
|
|
193
|
+
expect(getByText("Peter")).toBeTruthy();
|
|
194
|
+
});
|
|
195
|
+
test("Resultset table shows as many rows as itemsPerPage", function () {
|
|
196
|
+
var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
|
|
197
|
+
columns: columns,
|
|
198
|
+
rows: rows,
|
|
199
|
+
itemsPerPage: 3
|
|
200
|
+
})),
|
|
201
|
+
getAllByRole = _render2.getAllByRole;
|
|
202
|
+
expect(getAllByRole("row").length - 1).toEqual(3);
|
|
203
|
+
});
|
|
204
|
+
test("Resultset table shows rows on second page", function () {
|
|
205
|
+
var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
|
|
206
|
+
columns: columns,
|
|
207
|
+
rows: rows,
|
|
208
|
+
itemsPerPage: 3
|
|
209
|
+
})),
|
|
210
|
+
getByText = _render3.getByText,
|
|
211
|
+
getAllByRole = _render3.getAllByRole;
|
|
212
|
+
expect(getByText("Peter")).toBeTruthy();
|
|
213
|
+
expect(getByText("Louis")).toBeTruthy();
|
|
214
|
+
expect(getByText("Lana")).toBeTruthy();
|
|
215
|
+
expect(getAllByRole("row").length - 1).toEqual(3);
|
|
216
|
+
var nextButton = getAllByRole("button")[3];
|
|
217
|
+
_react2.fireEvent.click(nextButton);
|
|
218
|
+
expect(getByText("4 to 6 of 10")).toBeTruthy();
|
|
219
|
+
expect(getByText("Rick")).toBeTruthy();
|
|
220
|
+
expect(getByText("Mark")).toBeTruthy();
|
|
221
|
+
expect(getByText("Cris")).toBeTruthy();
|
|
222
|
+
expect(getAllByRole("row").length - 1).toEqual(3);
|
|
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
|
+
})));
|
|
260
|
+
test("Resultset table going to the last page shows only one row", function () {
|
|
261
|
+
var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
|
|
262
|
+
columns: columns,
|
|
263
|
+
rows: rows,
|
|
264
|
+
itemsPerPage: 3
|
|
265
|
+
})),
|
|
266
|
+
getByText = _render5.getByText,
|
|
267
|
+
getAllByRole = _render5.getAllByRole;
|
|
268
|
+
var lastButton = getAllByRole("button")[4];
|
|
269
|
+
_react2.fireEvent.click(lastButton);
|
|
270
|
+
expect(getByText("10 to 10 of 10")).toBeTruthy();
|
|
271
|
+
expect(getAllByRole("row")).toHaveLength(2);
|
|
272
|
+
expect(getByText("Cosmin")).toBeTruthy();
|
|
273
|
+
});
|
|
274
|
+
test("Resultset table sort rows by column", function () {
|
|
275
|
+
var component = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
|
|
276
|
+
columns: columns,
|
|
277
|
+
rows: rows,
|
|
278
|
+
itemsPerPage: 3
|
|
279
|
+
}));
|
|
280
|
+
expect(component.queryByText("Peter")).toBeTruthy();
|
|
281
|
+
_react2.fireEvent.click(component.queryByText("Name"));
|
|
282
|
+
expect(component.queryByText("Tina")).not.toBeTruthy();
|
|
283
|
+
expect(component.queryByText("Cosmin")).toBeTruthy();
|
|
284
|
+
_react2.fireEvent.click(component.queryByText("Name"));
|
|
285
|
+
expect(component.queryByText("Tina")).toBeTruthy();
|
|
286
|
+
expect(component.queryByText("Cosmin")).not.toBeTruthy();
|
|
287
|
+
});
|
|
288
|
+
test("Resultset table change rows should go to first page", function () {
|
|
289
|
+
var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
|
|
290
|
+
columns: columns,
|
|
291
|
+
rows: rows,
|
|
292
|
+
itemsPerPage: 3
|
|
293
|
+
})),
|
|
294
|
+
queryByText = _render6.queryByText,
|
|
295
|
+
rerender = _render6.rerender;
|
|
296
|
+
expect(queryByText("Peter")).toBeTruthy();
|
|
297
|
+
rerender( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
|
|
298
|
+
columns: columns,
|
|
299
|
+
rows: rows2,
|
|
300
|
+
itemsPerPage: 3
|
|
301
|
+
}));
|
|
302
|
+
expect(queryByText("1 to 3 of 3")).toBeTruthy();
|
|
303
|
+
});
|
|
304
|
+
test("Resultset table change itemsPerPage should go to first page", function () {
|
|
305
|
+
var _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
|
|
306
|
+
columns: columns,
|
|
307
|
+
rows: rows,
|
|
308
|
+
itemsPerPage: 3,
|
|
309
|
+
itemsPerPageOptions: [2, 3]
|
|
310
|
+
})),
|
|
311
|
+
getAllByRole = _render7.getAllByRole;
|
|
312
|
+
var lastButton = getAllByRole("button")[4];
|
|
313
|
+
expect(getAllByRole("row").length - 1).toEqual(3);
|
|
314
|
+
_react2.fireEvent.click(lastButton);
|
|
315
|
+
expect(getAllByRole("row").length - 1).toEqual(1);
|
|
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
|
+
});
|
|
381
|
+
});
|