@dxc-technology/halstack-react 0.0.0-d3554d7 → 0.0.0-d3df47e
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 +1221 -0
- package/HalstackContext.js +310 -0
- package/README.md +47 -0
- package/accordion/Accordion.d.ts +1 -1
- package/accordion/Accordion.js +116 -181
- package/accordion/Accordion.stories.tsx +103 -127
- package/accordion/Accordion.test.js +32 -33
- package/accordion/types.d.ts +9 -16
- package/accordion-group/AccordionGroup.d.ts +5 -4
- package/accordion-group/AccordionGroup.js +38 -107
- package/accordion-group/AccordionGroup.stories.tsx +95 -68
- package/accordion-group/AccordionGroup.test.js +55 -90
- package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
- package/accordion-group/AccordionGroupAccordion.js +31 -0
- package/accordion-group/types.d.ts +15 -16
- package/action-icon/ActionIcon.d.ts +4 -0
- package/action-icon/ActionIcon.js +47 -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.js +23 -59
- package/alert/Alert.stories.tsx +28 -0
- package/alert/Alert.test.js +29 -46
- package/alert/types.d.ts +5 -5
- package/badge/Badge.d.ts +1 -1
- package/badge/Badge.js +142 -40
- package/badge/Badge.stories.tsx +210 -0
- package/badge/Badge.test.js +30 -0
- package/badge/types.d.ts +52 -2
- package/bleed/Bleed.js +14 -55
- package/bleed/Bleed.stories.tsx +95 -95
- package/bleed/types.d.ts +26 -2
- package/box/Box.d.ts +1 -1
- package/box/Box.js +30 -81
- 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.d.ts +7 -0
- package/bulleted-list/BulletedList.js +89 -0
- package/bulleted-list/BulletedList.stories.tsx +115 -0
- package/bulleted-list/types.d.ts +38 -0
- package/button/Button.d.ts +1 -1
- package/button/Button.js +62 -113
- package/button/Button.stories.tsx +160 -90
- package/button/Button.test.js +20 -17
- package/button/types.d.ts +12 -8
- package/card/Card.d.ts +1 -1
- package/card/Card.js +58 -102
- package/card/Card.stories.tsx +12 -42
- package/card/Card.test.js +11 -22
- package/card/types.d.ts +6 -11
- package/checkbox/Checkbox.d.ts +2 -2
- package/checkbox/Checkbox.js +144 -182
- package/checkbox/Checkbox.stories.tsx +166 -136
- package/checkbox/Checkbox.test.js +163 -29
- package/checkbox/types.d.ts +18 -6
- package/chip/Chip.js +39 -79
- package/chip/Chip.stories.tsx +121 -26
- package/chip/Chip.test.js +16 -31
- package/chip/types.d.ts +4 -4
- package/common/OpenSans.css +68 -80
- 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 +1367 -0
- package/common/variables.js +1002 -1136
- 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/date-input/Calendar.d.ts +4 -0
- package/date-input/Calendar.js +214 -0
- package/date-input/DateInput.js +171 -306
- package/date-input/DateInput.stories.tsx +203 -56
- package/date-input/DateInput.test.js +708 -369
- 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 +86 -22
- package/dialog/Dialog.d.ts +1 -1
- package/dialog/Dialog.js +68 -130
- package/dialog/Dialog.stories.tsx +320 -167
- package/dialog/Dialog.test.js +287 -20
- package/dialog/types.d.ts +18 -25
- package/dropdown/Dropdown.d.ts +1 -1
- package/dropdown/Dropdown.js +243 -304
- package/dropdown/Dropdown.stories.tsx +245 -56
- 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 +67 -0
- package/dropdown/types.d.ts +32 -14
- package/file-input/FileInput.d.ts +2 -2
- package/file-input/FileInput.js +246 -357
- package/file-input/FileInput.stories.tsx +123 -12
- package/file-input/FileInput.test.js +369 -367
- package/file-input/FileItem.d.ts +4 -14
- package/file-input/FileItem.js +50 -99
- 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.d.ts +1 -1
- package/footer/Footer.js +70 -190
- package/footer/Footer.stories.tsx +60 -19
- 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 +25 -26
- 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/header/Header.d.ts +4 -3
- package/header/Header.js +99 -203
- package/header/Header.stories.tsx +152 -63
- package/header/Header.test.js +31 -28
- package/header/Icons.d.ts +2 -2
- package/header/Icons.js +4 -9
- package/header/types.d.ts +5 -19
- package/heading/Heading.js +10 -32
- package/heading/Heading.test.js +71 -88
- package/heading/types.d.ts +7 -7
- package/image/Image.d.ts +4 -0
- package/image/Image.js +70 -0
- package/image/Image.stories.tsx +127 -0
- package/image/types.d.ts +72 -0
- package/inset/Inset.js +14 -55
- package/inset/Inset.stories.tsx +37 -36
- package/inset/types.d.ts +26 -2
- package/layout/ApplicationLayout.d.ts +16 -6
- package/layout/ApplicationLayout.js +84 -181
- package/layout/ApplicationLayout.stories.tsx +85 -94
- package/layout/Icons.d.ts +8 -0
- package/layout/Icons.js +51 -48
- package/layout/SidenavContext.d.ts +5 -0
- package/layout/SidenavContext.js +13 -0
- package/layout/types.d.ts +19 -35
- package/link/Link.d.ts +3 -2
- package/link/Link.js +61 -99
- package/link/Link.stories.tsx +155 -53
- package/link/Link.test.js +25 -53
- package/link/types.d.ts +15 -31
- package/main.d.ts +14 -13
- package/main.js +65 -101
- package/nav-tabs/NavTabs.d.ts +8 -0
- package/nav-tabs/NavTabs.js +93 -0
- package/nav-tabs/NavTabs.stories.tsx +276 -0
- package/nav-tabs/NavTabs.test.js +76 -0
- package/nav-tabs/Tab.d.ts +4 -0
- package/nav-tabs/Tab.js +118 -0
- package/nav-tabs/types.d.ts +52 -0
- package/nav-tabs/types.js +5 -0
- package/number-input/NumberInput.d.ts +7 -0
- package/number-input/NumberInput.js +27 -43
- package/number-input/NumberInput.stories.tsx +44 -28
- package/number-input/NumberInput.test.js +703 -381
- package/number-input/types.d.ts +28 -15
- package/package.json +46 -47
- package/paginator/Icons.d.ts +5 -0
- package/paginator/Icons.js +21 -47
- package/paginator/Paginator.js +34 -91
- package/paginator/Paginator.stories.tsx +24 -0
- package/paginator/Paginator.test.js +280 -211
- package/paginator/types.d.ts +3 -3
- 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.js +57 -123
- package/password-input/PasswordInput.stories.tsx +1 -33
- package/password-input/PasswordInput.test.js +162 -147
- package/password-input/types.d.ts +21 -17
- package/progress-bar/ProgressBar.js +65 -91
- package/progress-bar/ProgressBar.stories.tsx +93 -0
- package/progress-bar/ProgressBar.test.js +72 -44
- package/progress-bar/types.d.ts +3 -3
- package/quick-nav/QuickNav.d.ts +4 -0
- package/quick-nav/QuickNav.js +94 -0
- package/quick-nav/QuickNav.stories.tsx +356 -0
- package/quick-nav/types.d.ts +21 -0
- package/quick-nav/types.js +5 -0
- package/radio-group/Radio.d.ts +1 -1
- package/radio-group/Radio.js +59 -76
- package/radio-group/RadioGroup.js +72 -116
- package/radio-group/RadioGroup.stories.tsx +135 -17
- package/radio-group/RadioGroup.test.js +529 -467
- package/radio-group/types.d.ts +86 -9
- package/resultset-table/Icons.d.ts +7 -0
- package/resultset-table/Icons.js +47 -0
- package/{resultsetTable → resultset-table}/ResultsetTable.d.ts +1 -1
- package/resultset-table/ResultsetTable.js +165 -0
- package/{resultsetTable → resultset-table}/ResultsetTable.stories.tsx +69 -25
- package/{resultsetTable → resultset-table}/ResultsetTable.test.js +117 -118
- package/{resultsetTable → resultset-table}/types.d.ts +13 -7
- package/resultset-table/types.js +5 -0
- package/select/Icons.d.ts +10 -0
- package/select/Icons.js +89 -0
- package/select/Listbox.d.ts +4 -0
- package/select/Listbox.js +143 -0
- package/select/Option.d.ts +4 -0
- package/select/Option.js +87 -0
- package/select/Select.js +223 -502
- package/select/Select.stories.tsx +534 -145
- package/select/Select.test.js +2009 -1539
- package/select/types.d.ts +64 -25
- package/sidenav/Icons.d.ts +7 -0
- package/sidenav/Icons.js +47 -0
- package/sidenav/Sidenav.d.ts +6 -5
- package/sidenav/Sidenav.js +131 -71
- package/sidenav/Sidenav.stories.tsx +251 -151
- package/sidenav/Sidenav.test.js +26 -45
- package/sidenav/types.d.ts +52 -26
- package/slider/Slider.d.ts +2 -2
- package/slider/Slider.js +148 -180
- package/slider/Slider.test.js +198 -73
- package/slider/types.d.ts +11 -3
- 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.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.d.ts +2 -2
- package/switch/Switch.js +149 -114
- package/switch/Switch.stories.tsx +44 -67
- package/switch/Switch.test.js +146 -39
- package/switch/types.d.ts +13 -5
- package/table/Table.d.ts +1 -1
- package/table/Table.js +25 -32
- package/table/{Table.stories.jsx → Table.stories.tsx} +178 -1
- package/table/Table.test.js +3 -8
- package/table/types.d.ts +12 -6
- package/tabs/Tab.d.ts +4 -0
- package/tabs/Tab.js +116 -0
- package/tabs/Tabs.d.ts +1 -1
- package/tabs/Tabs.js +316 -145
- package/tabs/Tabs.stories.tsx +120 -14
- package/tabs/Tabs.test.js +238 -67
- package/tabs/types.d.ts +29 -15
- package/tag/Tag.js +41 -78
- package/tag/Tag.stories.tsx +25 -8
- package/tag/Tag.test.js +20 -31
- package/tag/types.d.ts +7 -7
- package/text-input/Icons.d.ts +8 -0
- package/text-input/Icons.js +56 -0
- package/text-input/Suggestion.d.ts +4 -0
- package/text-input/Suggestion.js +67 -0
- package/text-input/Suggestions.d.ts +4 -0
- package/text-input/Suggestions.js +84 -0
- package/text-input/TextInput.js +324 -548
- package/text-input/TextInput.stories.tsx +272 -281
- package/text-input/TextInput.test.js +1425 -1377
- package/text-input/types.d.ts +70 -24
- package/textarea/Textarea.js +82 -134
- package/textarea/Textarea.stories.tsx +174 -0
- package/textarea/Textarea.test.js +168 -198
- package/textarea/types.d.ts +27 -16
- package/toggle-group/ToggleGroup.d.ts +2 -2
- package/toggle-group/ToggleGroup.js +92 -105
- package/toggle-group/ToggleGroup.stories.tsx +53 -8
- package/toggle-group/ToggleGroup.test.js +78 -66
- package/toggle-group/types.d.ts +34 -17
- 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 +1119 -1
- package/useTheme.js +4 -11
- package/useTranslatedLabels.d.ts +85 -0
- package/useTranslatedLabels.js +14 -0
- 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.d.ts +1 -1
- package/wizard/Wizard.js +70 -101
- package/wizard/Wizard.stories.tsx +48 -19
- package/wizard/Wizard.test.js +73 -87
- package/wizard/types.d.ts +12 -8
- package/ThemeContext.d.ts +0 -10
- package/ThemeContext.js +0 -243
- package/card/ice-cream.jpg +0 -0
- package/common/RequiredComponent.js +0 -32
- 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/NumberInputContext.d.ts +0 -4
- package/number-input/NumberInputContext.js +0 -19
- package/number-input/numberInputContextTypes.d.ts +0 -19
- package/progress-bar/ProgressBar.stories.jsx +0 -58
- package/radio/Radio.d.ts +0 -4
- package/radio/Radio.js +0 -174
- package/radio/Radio.stories.tsx +0 -192
- package/radio/Radio.test.js +0 -71
- package/radio/types.d.ts +0 -54
- package/resultsetTable/ResultsetTable.js +0 -254
- 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 -10
- 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 -9
- 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/{radio → bulleted-list}/types.js +0 -0
- /package/{resultsetTable → container}/types.js +0 -0
- /package/{row → flex}/types.js +0 -0
- /package/{stack → grid}/types.js +0 -0
- /package/{number-input/numberInputContextTypes.js → image/types.js} +0 -0
package/radio-group/types.d.ts
CHANGED
|
@@ -1,37 +1,114 @@
|
|
|
1
|
-
export
|
|
1
|
+
export type Option = {
|
|
2
|
+
/**
|
|
3
|
+
* Label of the option placed next to the radio input.
|
|
4
|
+
*/
|
|
2
5
|
value: string;
|
|
6
|
+
/**
|
|
7
|
+
* Value of the option. It should be unique and
|
|
8
|
+
* not an empty string, which is reserved to the optional item added
|
|
9
|
+
* by 'optional' prop.
|
|
10
|
+
*/
|
|
3
11
|
label: string;
|
|
12
|
+
/**
|
|
13
|
+
* If true, disables the option.
|
|
14
|
+
*/
|
|
4
15
|
disabled?: boolean;
|
|
5
16
|
};
|
|
6
|
-
|
|
7
|
-
|
|
17
|
+
type RadioGroupProps = {
|
|
18
|
+
/**
|
|
19
|
+
* Text to be placed above the radio group.
|
|
20
|
+
*/
|
|
21
|
+
label?: string;
|
|
22
|
+
/**
|
|
23
|
+
* Name attribute of the input element. This attribute will allow users
|
|
24
|
+
* to find the component's value during the submit event.
|
|
25
|
+
*/
|
|
8
26
|
name?: string;
|
|
27
|
+
/**
|
|
28
|
+
* Helper text to be placed above the radio group.
|
|
29
|
+
*/
|
|
9
30
|
helperText?: string;
|
|
31
|
+
/**
|
|
32
|
+
* An array of objects representing the selectable options.
|
|
33
|
+
*/
|
|
10
34
|
options: Option[];
|
|
35
|
+
/**
|
|
36
|
+
* If true, the component will be disabled.
|
|
37
|
+
*/
|
|
11
38
|
disabled?: boolean;
|
|
39
|
+
/**
|
|
40
|
+
* If true, the radio group will be optional, showing
|
|
41
|
+
* (Optional) next to the label and adding a default last
|
|
42
|
+
* option with an empty string as value. Otherwise, the field will be
|
|
43
|
+
* considered required and an error will be passed as a parameter to the
|
|
44
|
+
* OnBlur functions if an option wasn't selected.
|
|
45
|
+
*/
|
|
12
46
|
optional?: boolean;
|
|
47
|
+
/**
|
|
48
|
+
* Label of the optional radio input.
|
|
49
|
+
*/
|
|
13
50
|
optionalItemLabel?: string;
|
|
14
|
-
|
|
51
|
+
/**
|
|
52
|
+
* If true, the component will not be mutable, meaning the user can not edit the control.
|
|
53
|
+
*/
|
|
54
|
+
readOnly?: boolean;
|
|
55
|
+
/**
|
|
56
|
+
* Sets the orientation of the options within the radio group.
|
|
57
|
+
*/
|
|
15
58
|
stacking?: "row" | "column";
|
|
59
|
+
/**
|
|
60
|
+
* Initial value of the radio group, only when it is uncontrolled.
|
|
61
|
+
*/
|
|
16
62
|
defaultValue?: string;
|
|
63
|
+
/**
|
|
64
|
+
* Value of the radio group. If undefined, the component will be
|
|
65
|
+
* uncontrolled and the value will be managed internally by the
|
|
66
|
+
* component.
|
|
67
|
+
*/
|
|
17
68
|
value?: string;
|
|
69
|
+
/**
|
|
70
|
+
* This function will be called when the user chooses an option. The new
|
|
71
|
+
* value will be passed to this function.
|
|
72
|
+
*/
|
|
18
73
|
onChange?: (value: string) => void;
|
|
74
|
+
/**
|
|
75
|
+
* This function will be called when the radio group loses the focus. An
|
|
76
|
+
* object including the value and the error will be passed to this
|
|
77
|
+
* function. If there is no error, error will not be defined.
|
|
78
|
+
*/
|
|
19
79
|
onBlur?: (val: {
|
|
20
80
|
value?: string;
|
|
21
81
|
error?: string;
|
|
22
82
|
}) => void;
|
|
83
|
+
/**
|
|
84
|
+
* If it is a defined value and also a truthy string, the component will
|
|
85
|
+
* change its appearance, showing the error below the radio group. If the
|
|
86
|
+
* defined value is an empty string, it will reserve a space below the
|
|
87
|
+
* component for a future error, but it would not change its look. In
|
|
88
|
+
* case of being undefined or null, both the appearance and the space for
|
|
89
|
+
* the error message would not be modified.
|
|
90
|
+
*/
|
|
23
91
|
error?: string;
|
|
92
|
+
/**
|
|
93
|
+
* Value of the tabindex attribute.
|
|
94
|
+
*/
|
|
24
95
|
tabIndex?: number;
|
|
25
96
|
};
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
97
|
+
/**
|
|
98
|
+
* Reference to the component.
|
|
99
|
+
*/
|
|
100
|
+
export type RefType = HTMLDivElement;
|
|
101
|
+
/**
|
|
102
|
+
* Single radio prop types.
|
|
103
|
+
*/
|
|
104
|
+
export type RadioProps = {
|
|
105
|
+
label: string;
|
|
106
|
+
checked: boolean;
|
|
30
107
|
onClick: () => void;
|
|
31
108
|
error?: string;
|
|
32
109
|
disabled: boolean;
|
|
33
110
|
focused: boolean;
|
|
34
|
-
|
|
111
|
+
readOnly: boolean;
|
|
35
112
|
tabIndex: number;
|
|
36
113
|
};
|
|
37
114
|
export default RadioGroupProps;
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports["default"] = void 0;
|
|
8
|
+
var _react = _interopRequireDefault(require("react"));
|
|
9
|
+
var icons = {
|
|
10
|
+
arrowUp: /*#__PURE__*/_react["default"].createElement("svg", {
|
|
11
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
12
|
+
height: "24",
|
|
13
|
+
viewBox: "0 0 24 24",
|
|
14
|
+
width: "24",
|
|
15
|
+
fill: "currentColor"
|
|
16
|
+
}, /*#__PURE__*/_react["default"].createElement("path", {
|
|
17
|
+
d: "M0 0h24v24H0V0z",
|
|
18
|
+
fill: "none"
|
|
19
|
+
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
20
|
+
d: "M4 12l1.41 1.41L11 7.83V20h2V7.83l5.58 5.59L20 12l-8-8-8 8z"
|
|
21
|
+
})),
|
|
22
|
+
arrowDown: /*#__PURE__*/_react["default"].createElement("svg", {
|
|
23
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
24
|
+
height: "24",
|
|
25
|
+
viewBox: "0 0 24 24",
|
|
26
|
+
width: "24",
|
|
27
|
+
fill: "currentColor"
|
|
28
|
+
}, /*#__PURE__*/_react["default"].createElement("path", {
|
|
29
|
+
d: "M0 0h24v24H0V0z",
|
|
30
|
+
fill: "none"
|
|
31
|
+
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
32
|
+
d: "M20 12l-1.41-1.41L13 16.17V4h-2v12.17l-5.58-5.59L4 12l8 8 8-8z"
|
|
33
|
+
})),
|
|
34
|
+
bothArrows: /*#__PURE__*/_react["default"].createElement("svg", {
|
|
35
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
36
|
+
height: "24",
|
|
37
|
+
viewBox: "0 0 24 24",
|
|
38
|
+
width: "24",
|
|
39
|
+
fill: "currentColor"
|
|
40
|
+
}, /*#__PURE__*/_react["default"].createElement("path", {
|
|
41
|
+
d: "M0 0h24v24H0z",
|
|
42
|
+
fill: "none"
|
|
43
|
+
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
44
|
+
d: "M12 5.83L15.17 9l1.41-1.41L12 3 7.41 7.59 8.83 9 12 5.83zm0 12.34L8.83 15l-1.41 1.41L12 21l4.59-4.59L15.17 15 12 18.17z"
|
|
45
|
+
}))
|
|
46
|
+
};
|
|
47
|
+
var _default = exports["default"] = icons;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
/// <reference types="react" />
|
|
2
2
|
import ResultsetTablePropsType from "./types";
|
|
3
|
-
declare const DxcResultsetTable: ({ columns, rows, showGoToPage, itemsPerPage, itemsPerPageOptions, itemsPerPageFunction, margin, tabIndex, }: ResultsetTablePropsType) => JSX.Element;
|
|
3
|
+
declare const DxcResultsetTable: ({ columns, rows, showGoToPage, itemsPerPage, itemsPerPageOptions, itemsPerPageFunction, margin, tabIndex, mode, }: ResultsetTablePropsType) => JSX.Element;
|
|
4
4
|
export default DxcResultsetTable;
|
|
@@ -0,0 +1,165 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _typeof3 = require("@babel/runtime/helpers/typeof");
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports["default"] = void 0;
|
|
9
|
+
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
|
|
10
|
+
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
11
|
+
var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
|
|
12
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
13
|
+
var _styledComponents = _interopRequireWildcard(require("styled-components"));
|
|
14
|
+
var _variables = require("../common/variables");
|
|
15
|
+
var _Table = _interopRequireDefault(require("../table/Table"));
|
|
16
|
+
var _Paginator = _interopRequireDefault(require("../paginator/Paginator"));
|
|
17
|
+
var _useTheme = _interopRequireDefault(require("../useTheme"));
|
|
18
|
+
var _Icons = _interopRequireDefault(require("./Icons"));
|
|
19
|
+
var _utils = require("../common/utils");
|
|
20
|
+
var _coreTokens = _interopRequireDefault(require("../common/coreTokens"));
|
|
21
|
+
var _templateObject, _templateObject2, _templateObject3;
|
|
22
|
+
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
|
|
23
|
+
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof3(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
|
|
24
|
+
var normalizeSortValue = function normalizeSortValue(sortValue) {
|
|
25
|
+
return typeof sortValue === "string" ? sortValue.toUpperCase() : sortValue;
|
|
26
|
+
};
|
|
27
|
+
var sortArray = function sortArray(index, order, resultset) {
|
|
28
|
+
return resultset.slice().sort(function (element1, element2) {
|
|
29
|
+
var sortValueA = normalizeSortValue(element1[index].sortValue || element1[index].displayValue);
|
|
30
|
+
var sortValueB = normalizeSortValue(element2[index].sortValue || element2[index].displayValue);
|
|
31
|
+
var comparison = 0;
|
|
32
|
+
if ((0, _typeof2["default"])(sortValueA) === "object") {
|
|
33
|
+
comparison = -1;
|
|
34
|
+
} else if ((0, _typeof2["default"])(sortValueB) === "object") {
|
|
35
|
+
comparison = 1;
|
|
36
|
+
} else if (sortValueA > sortValueB) {
|
|
37
|
+
comparison = 1;
|
|
38
|
+
} else if (sortValueA < sortValueB) {
|
|
39
|
+
comparison = -1;
|
|
40
|
+
}
|
|
41
|
+
return order === "descending" ? comparison * -1 : comparison;
|
|
42
|
+
});
|
|
43
|
+
};
|
|
44
|
+
var getMinItemsPerPageIndex = function getMinItemsPerPageIndex(currentPageInternal, itemsPerPage, page) {
|
|
45
|
+
return currentPageInternal === 1 ? 0 : itemsPerPage * (page - 1);
|
|
46
|
+
};
|
|
47
|
+
var getMaxItemsPerPageIndex = function getMaxItemsPerPageIndex(minItemsPerPageIndex, itemsPerPage, resultset, page) {
|
|
48
|
+
return minItemsPerPageIndex + itemsPerPage > resultset.length ? resultset.length : itemsPerPage * page - 1;
|
|
49
|
+
};
|
|
50
|
+
var DxcResultsetTable = function DxcResultsetTable(_ref) {
|
|
51
|
+
var columns = _ref.columns,
|
|
52
|
+
rows = _ref.rows,
|
|
53
|
+
_ref$showGoToPage = _ref.showGoToPage,
|
|
54
|
+
showGoToPage = _ref$showGoToPage === void 0 ? true : _ref$showGoToPage,
|
|
55
|
+
_ref$itemsPerPage = _ref.itemsPerPage,
|
|
56
|
+
itemsPerPage = _ref$itemsPerPage === void 0 ? 5 : _ref$itemsPerPage,
|
|
57
|
+
itemsPerPageOptions = _ref.itemsPerPageOptions,
|
|
58
|
+
itemsPerPageFunction = _ref.itemsPerPageFunction,
|
|
59
|
+
margin = _ref.margin,
|
|
60
|
+
_ref$tabIndex = _ref.tabIndex,
|
|
61
|
+
tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex,
|
|
62
|
+
_ref$mode = _ref.mode,
|
|
63
|
+
mode = _ref$mode === void 0 ? "default" : _ref$mode;
|
|
64
|
+
var colorsTheme = (0, _useTheme["default"])();
|
|
65
|
+
var _useState = (0, _react.useState)(1),
|
|
66
|
+
_useState2 = (0, _slicedToArray2["default"])(_useState, 2),
|
|
67
|
+
page = _useState2[0],
|
|
68
|
+
changePage = _useState2[1];
|
|
69
|
+
var _useState3 = (0, _react.useState)(-1),
|
|
70
|
+
_useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
|
|
71
|
+
sortColumnIndex = _useState4[0],
|
|
72
|
+
changeSortColumnIndex = _useState4[1];
|
|
73
|
+
var _useState5 = (0, _react.useState)("ascending"),
|
|
74
|
+
_useState6 = (0, _slicedToArray2["default"])(_useState5, 2),
|
|
75
|
+
sortOrder = _useState6[0],
|
|
76
|
+
changeSortOrder = _useState6[1];
|
|
77
|
+
var minItemsPerPageIndex = (0, _react.useMemo)(function () {
|
|
78
|
+
return getMinItemsPerPageIndex(page, itemsPerPage, page);
|
|
79
|
+
}, [itemsPerPage, page]);
|
|
80
|
+
var maxItemsPerPageIndex = (0, _react.useMemo)(function () {
|
|
81
|
+
return getMaxItemsPerPageIndex(minItemsPerPageIndex, itemsPerPage, rows, page);
|
|
82
|
+
}, [itemsPerPage, minItemsPerPageIndex, page, rows]);
|
|
83
|
+
var sortedResultset = (0, _react.useMemo)(function () {
|
|
84
|
+
return sortColumnIndex !== -1 ? sortArray(sortColumnIndex, sortOrder, rows) : rows;
|
|
85
|
+
}, [sortColumnIndex, sortOrder, rows]);
|
|
86
|
+
var filteredResultset = (0, _react.useMemo)(function () {
|
|
87
|
+
return sortedResultset && sortedResultset.slice(minItemsPerPageIndex, maxItemsPerPageIndex + 1);
|
|
88
|
+
}, [sortedResultset, minItemsPerPageIndex, maxItemsPerPageIndex]);
|
|
89
|
+
var goToPage = function goToPage(newPage) {
|
|
90
|
+
changePage(newPage);
|
|
91
|
+
};
|
|
92
|
+
var changeSorting = function changeSorting(columnIndex) {
|
|
93
|
+
changePage(1);
|
|
94
|
+
changeSortColumnIndex(columnIndex);
|
|
95
|
+
changeSortOrder(sortColumnIndex === -1 || sortColumnIndex !== columnIndex ? "ascending" : sortOrder === "ascending" ? "descending" : "ascending");
|
|
96
|
+
};
|
|
97
|
+
(0, _react.useEffect)(function () {
|
|
98
|
+
rows.length > 0 ? changePage(1) : changePage(0);
|
|
99
|
+
}, [rows]);
|
|
100
|
+
return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
|
|
101
|
+
theme: colorsTheme.table
|
|
102
|
+
}, /*#__PURE__*/_react["default"].createElement(DxcResultsetTableContainer, {
|
|
103
|
+
margin: margin
|
|
104
|
+
}, /*#__PURE__*/_react["default"].createElement(_Table["default"], {
|
|
105
|
+
mode: mode
|
|
106
|
+
}, /*#__PURE__*/_react["default"].createElement("thead", null, /*#__PURE__*/_react["default"].createElement("tr", null, columns.map(function (column, index) {
|
|
107
|
+
return /*#__PURE__*/_react["default"].createElement("th", {
|
|
108
|
+
key: "tableHeader_".concat(index),
|
|
109
|
+
"aria-sort": column.isSortable ? sortColumnIndex === index ? sortOrder : "none" : undefined
|
|
110
|
+
}, /*#__PURE__*/_react["default"].createElement(HeaderContainer, {
|
|
111
|
+
role: column.isSortable ? "button" : undefined,
|
|
112
|
+
key: "headerContainer_".concat(index),
|
|
113
|
+
onClick: function onClick() {
|
|
114
|
+
column.isSortable && changeSorting(index);
|
|
115
|
+
},
|
|
116
|
+
tabIndex: column.isSortable ? tabIndex : -1,
|
|
117
|
+
isSortable: column.isSortable,
|
|
118
|
+
mode: mode
|
|
119
|
+
}, /*#__PURE__*/_react["default"].createElement("span", null, column.displayValue), column.isSortable && /*#__PURE__*/_react["default"].createElement(SortIcon, null, sortColumnIndex === index ? sortOrder === "ascending" ? _Icons["default"].arrowUp : _Icons["default"].arrowDown : _Icons["default"].bothArrows)));
|
|
120
|
+
}))), /*#__PURE__*/_react["default"].createElement("tbody", null, filteredResultset.map(function (cells, index) {
|
|
121
|
+
return /*#__PURE__*/_react["default"].createElement("tr", {
|
|
122
|
+
key: "resultSetTableCell_".concat(page, "_").concat(index)
|
|
123
|
+
}, cells.map(function (cellContent, index) {
|
|
124
|
+
return /*#__PURE__*/_react["default"].createElement("td", {
|
|
125
|
+
key: "resultSetTableCellContent_".concat(index)
|
|
126
|
+
}, cellContent.displayValue);
|
|
127
|
+
}));
|
|
128
|
+
}))), /*#__PURE__*/_react["default"].createElement(_Paginator["default"], {
|
|
129
|
+
totalItems: rows.length,
|
|
130
|
+
itemsPerPage: itemsPerPage,
|
|
131
|
+
itemsPerPageOptions: itemsPerPageOptions,
|
|
132
|
+
itemsPerPageFunction: itemsPerPageFunction,
|
|
133
|
+
currentPage: page,
|
|
134
|
+
showGoToPage: showGoToPage,
|
|
135
|
+
onPageChange: goToPage,
|
|
136
|
+
tabIndex: tabIndex
|
|
137
|
+
})));
|
|
138
|
+
};
|
|
139
|
+
var calculateWidth = function calculateWidth(margin) {
|
|
140
|
+
return "calc(100% - ".concat((0, _utils.getMargin)(margin, "left"), " - ").concat((0, _utils.getMargin)(margin, "right"), ")");
|
|
141
|
+
};
|
|
142
|
+
var DxcResultsetTableContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n width: ", ";\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n"])), function (props) {
|
|
143
|
+
return calculateWidth(props.margin);
|
|
144
|
+
}, function (props) {
|
|
145
|
+
return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
|
|
146
|
+
}, function (props) {
|
|
147
|
+
return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.top ? _variables.spaces[props.margin.top] : "";
|
|
148
|
+
}, function (props) {
|
|
149
|
+
return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.right ? _variables.spaces[props.margin.right] : "";
|
|
150
|
+
}, function (props) {
|
|
151
|
+
return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.bottom ? _variables.spaces[props.margin.bottom] : "";
|
|
152
|
+
}, function (props) {
|
|
153
|
+
return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.left ? _variables.spaces[props.margin.left] : "";
|
|
154
|
+
});
|
|
155
|
+
var HeaderContainer = _styledComponents["default"].span(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n justify-content: ", ";\n gap: ", ";\n width: fit-content;\n border: 1px solid transparent;\n border-radius: 2px;\n cursor: ", ";\n\n ", "\n"])), function (props) {
|
|
156
|
+
return props.theme.headerTextAlign === "center" ? "center" : props.theme.headerTextAlign === "right" ? "flex-end" : "flex-start";
|
|
157
|
+
}, _coreTokens["default"].spacing_8, function (props) {
|
|
158
|
+
return props.isSortable ? "pointer" : "default";
|
|
159
|
+
}, function (props) {
|
|
160
|
+
return props.isSortable && "&:focus {\n outline: #0095ff solid 2px;\n }";
|
|
161
|
+
});
|
|
162
|
+
var SortIcon = _styledComponents["default"].span(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n height: 14px;\n width: 14px;\n color: ", ";\n\n svg {\n height: 100%;\n width: 100%;\n }\n"])), function (props) {
|
|
163
|
+
return props.theme.sortIconColor;
|
|
164
|
+
});
|
|
165
|
+
var _default = exports["default"] = DxcResultsetTable;
|
|
@@ -4,6 +4,7 @@ import DxcButton from "../button/Button";
|
|
|
4
4
|
import Title from "../../.storybook/components/Title";
|
|
5
5
|
import ExampleContainer from "../../.storybook/components/ExampleContainer";
|
|
6
6
|
import { userEvent, within } from "@storybook/testing-library";
|
|
7
|
+
import styled from "styled-components";
|
|
7
8
|
|
|
8
9
|
export default {
|
|
9
10
|
title: "Resultset Table",
|
|
@@ -48,6 +49,24 @@ const columnsSortable = [
|
|
|
48
49
|
{ displayValue: "City", isSortable: false },
|
|
49
50
|
];
|
|
50
51
|
|
|
52
|
+
const longValues = [
|
|
53
|
+
[
|
|
54
|
+
{ displayValue: "000000000000000001", sortValue: "000000000000000001" },
|
|
55
|
+
{ displayValue: "Peter Larsson González", sortValue: "Peter" },
|
|
56
|
+
{ displayValue: "Miami: The city that never sleeps", sortValue: "Miami" },
|
|
57
|
+
],
|
|
58
|
+
[
|
|
59
|
+
{ displayValue: "002", sortValue: "002" },
|
|
60
|
+
{ displayValue: "Louis", sortValue: "Louis" },
|
|
61
|
+
{ displayValue: "London", sortValue: "London" },
|
|
62
|
+
],
|
|
63
|
+
[
|
|
64
|
+
{ displayValue: "003", sortValue: "003" },
|
|
65
|
+
{ displayValue: "Aida", sortValue: "Aida" },
|
|
66
|
+
{ displayValue: "Wroclaw", sortValue: "Wroclaw" },
|
|
67
|
+
],
|
|
68
|
+
];
|
|
69
|
+
|
|
51
70
|
const rowsSortable = [
|
|
52
71
|
[
|
|
53
72
|
{ displayValue: "001", sortValue: "001" },
|
|
@@ -167,89 +186,114 @@ export const Chromatic = () => (
|
|
|
167
186
|
<>
|
|
168
187
|
<ExampleContainer>
|
|
169
188
|
<Title title="Sortable table" theme="light" level={4} />
|
|
170
|
-
<DxcResultsetTable columns={columnsSortable} rows={rowsSortable}
|
|
189
|
+
<DxcResultsetTable columns={columnsSortable} rows={rowsSortable} />
|
|
171
190
|
</ExampleContainer>
|
|
172
191
|
<ExampleContainer>
|
|
173
192
|
<Title title="With action" theme="light" level={4} />
|
|
174
|
-
<DxcResultsetTable columns={columns} rows={rowsIcon}
|
|
193
|
+
<DxcResultsetTable columns={columns} rows={rowsIcon} />
|
|
175
194
|
</ExampleContainer>
|
|
176
195
|
<ExampleContainer>
|
|
177
196
|
<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>
|
|
197
|
+
<DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2} itemsPerPageOptions={[2, 3]} />
|
|
184
198
|
</ExampleContainer>
|
|
185
199
|
<ExampleContainer>
|
|
186
200
|
<Title title="Scroll resultset table" theme="light" level={4} />
|
|
187
|
-
<DxcResultsetTable columns={longColumns} rows={longRows}
|
|
201
|
+
<DxcResultsetTable columns={longColumns} rows={longRows} />
|
|
202
|
+
</ExampleContainer>
|
|
203
|
+
<ExampleContainer>
|
|
204
|
+
<SmallContainer>
|
|
205
|
+
<Title title="Small container and text overflow" theme="light" level={4} />
|
|
206
|
+
<DxcResultsetTable columns={columnsSortable} rows={longValues} />
|
|
207
|
+
</SmallContainer>
|
|
208
|
+
</ExampleContainer>
|
|
209
|
+
<ExampleContainer>
|
|
210
|
+
<Title title="Reduced sortable table" theme="light" level={4} />
|
|
211
|
+
<DxcResultsetTable columns={columnsSortable} rows={rowsSortable} mode="reduced" />
|
|
212
|
+
</ExampleContainer>
|
|
213
|
+
{/* PENDING SMALL ICON VERSION */}
|
|
214
|
+
<ExampleContainer>
|
|
215
|
+
<Title title="Reduced with items per page option" theme="light" level={4} />
|
|
216
|
+
<DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2} itemsPerPageOptions={[2, 3]} mode="reduced" />
|
|
217
|
+
</ExampleContainer>
|
|
218
|
+
<ExampleContainer>
|
|
219
|
+
<Title title="Reduced scroll resultset table" theme="light" level={4} />
|
|
220
|
+
<DxcResultsetTable columns={longColumns} rows={longRows} mode="reduced" />
|
|
221
|
+
</ExampleContainer>
|
|
222
|
+
<ExampleContainer>
|
|
223
|
+
<SmallContainer>
|
|
224
|
+
<Title title="Reduced small container and text overflow" theme="light" level={4} />
|
|
225
|
+
<DxcResultsetTable columns={columnsSortable} rows={longValues} mode="reduced" />
|
|
226
|
+
</SmallContainer>
|
|
188
227
|
</ExampleContainer>
|
|
189
228
|
<Title title="Margins" theme="light" level={2} />
|
|
190
229
|
<ExampleContainer>
|
|
191
230
|
<Title title="Xxsmall" theme="light" level={4} />
|
|
192
|
-
<DxcResultsetTable columns={columns} rows={rows} margin={"xxsmall"}
|
|
231
|
+
<DxcResultsetTable columns={columns} rows={rows} margin={"xxsmall"} />
|
|
193
232
|
</ExampleContainer>
|
|
194
233
|
<ExampleContainer>
|
|
195
234
|
<Title title="Xsmall" theme="light" level={4} />
|
|
196
|
-
<DxcResultsetTable columns={columns} rows={rows} margin={"xsmall"}
|
|
235
|
+
<DxcResultsetTable columns={columns} rows={rows} margin={"xsmall"} />
|
|
197
236
|
</ExampleContainer>
|
|
198
237
|
<ExampleContainer>
|
|
199
238
|
<Title title="Small" theme="light" level={4} />
|
|
200
|
-
<DxcResultsetTable columns={columns} rows={rows} margin={"small"}
|
|
239
|
+
<DxcResultsetTable columns={columns} rows={rows} margin={"small"} />
|
|
201
240
|
</ExampleContainer>
|
|
202
241
|
<ExampleContainer>
|
|
203
242
|
<Title title="Medium" theme="light" level={4} />
|
|
204
|
-
<DxcResultsetTable columns={columns} rows={rows} margin={"medium"}
|
|
243
|
+
<DxcResultsetTable columns={columns} rows={rows} margin={"medium"} />
|
|
205
244
|
</ExampleContainer>
|
|
206
245
|
<ExampleContainer>
|
|
207
246
|
<Title title="Large" theme="light" level={4} />
|
|
208
|
-
<DxcResultsetTable columns={columns} rows={rows} margin={"large"}
|
|
247
|
+
<DxcResultsetTable columns={columns} rows={rows} margin={"large"} />
|
|
209
248
|
</ExampleContainer>
|
|
210
249
|
<ExampleContainer>
|
|
211
250
|
<Title title="Xlarge" theme="light" level={4} />
|
|
212
|
-
<DxcResultsetTable columns={columns} rows={rows} margin={"xlarge"}
|
|
251
|
+
<DxcResultsetTable columns={columns} rows={rows} margin={"xlarge"} />
|
|
213
252
|
</ExampleContainer>
|
|
214
|
-
<ExampleContainer>
|
|
253
|
+
<ExampleContainer expanded>
|
|
215
254
|
<Title title="Xxlarge" theme="light" level={4} />
|
|
216
|
-
<DxcResultsetTable columns={columns} rows={rows} margin={"xxlarge"}
|
|
217
|
-
<hr />
|
|
255
|
+
<DxcResultsetTable columns={columns} rows={rows} margin={"xxlarge"} />
|
|
218
256
|
</ExampleContainer>
|
|
219
257
|
</>
|
|
220
258
|
);
|
|
221
259
|
|
|
260
|
+
const SmallContainer = styled.div`
|
|
261
|
+
width: 500px;
|
|
262
|
+
`;
|
|
263
|
+
|
|
222
264
|
const ResultsetTableAsc = () => (
|
|
223
265
|
<ExampleContainer>
|
|
224
266
|
<Title title="Ascendant sorting" theme="light" level={4} />
|
|
225
|
-
<DxcResultsetTable columns={columnsSortable} rows={rowsSortable}
|
|
267
|
+
<DxcResultsetTable columns={columnsSortable} rows={rowsSortable} />
|
|
226
268
|
</ExampleContainer>
|
|
227
269
|
);
|
|
228
270
|
|
|
229
271
|
export const AscendentSorting = ResultsetTableAsc.bind({});
|
|
230
272
|
AscendentSorting.play = async ({ canvasElement }) => {
|
|
231
273
|
const canvas = within(canvasElement);
|
|
232
|
-
|
|
274
|
+
const idHeader = canvas.getAllByRole("button")[0];
|
|
275
|
+
await userEvent.click(idHeader);
|
|
233
276
|
};
|
|
234
277
|
|
|
235
278
|
const ResultsetTableDesc = () => (
|
|
236
279
|
<ExampleContainer>
|
|
237
280
|
<Title title="Descendant sorting" theme="light" level={4} />
|
|
238
|
-
<DxcResultsetTable columns={columnsSortable} rows={rowsSortable}
|
|
281
|
+
<DxcResultsetTable columns={columnsSortable} rows={rowsSortable} />
|
|
239
282
|
</ExampleContainer>
|
|
240
283
|
);
|
|
241
284
|
|
|
242
285
|
export const DescendantSorting = ResultsetTableDesc.bind({});
|
|
243
286
|
DescendantSorting.play = async ({ canvasElement }) => {
|
|
244
287
|
const canvas = within(canvasElement);
|
|
245
|
-
|
|
246
|
-
await userEvent.click(
|
|
288
|
+
const nameHeader = canvas.getAllByRole("button")[1];
|
|
289
|
+
await userEvent.click(nameHeader);
|
|
290
|
+
await userEvent.click(nameHeader);
|
|
247
291
|
};
|
|
248
292
|
|
|
249
293
|
const ResultsetTableMiddle = () => (
|
|
250
294
|
<ExampleContainer>
|
|
251
295
|
<Title title="Middle page" theme="light" level={4} />
|
|
252
|
-
<DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2}
|
|
296
|
+
<DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2} />
|
|
253
297
|
</ExampleContainer>
|
|
254
298
|
);
|
|
255
299
|
|
|
@@ -263,7 +307,7 @@ MiddlePage.play = async ({ canvasElement }) => {
|
|
|
263
307
|
const ResultsetTableLast = () => (
|
|
264
308
|
<ExampleContainer>
|
|
265
309
|
<Title title="Last page" theme="light" level={4} />
|
|
266
|
-
<DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2}
|
|
310
|
+
<DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2} />
|
|
267
311
|
</ExampleContainer>
|
|
268
312
|
);
|
|
269
313
|
|