@dxc-technology/halstack-react 0.0.0-b50ba80 → 0.0.0-b5ec444
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 +1245 -6
- package/HalstackContext.js +181 -114
- package/README.md +47 -0
- package/accordion/Accordion.d.ts +1 -1
- package/accordion/Accordion.js +116 -160
- package/accordion/Accordion.stories.tsx +102 -126
- package/accordion/Accordion.test.js +25 -41
- package/accordion/types.d.ts +5 -16
- package/accordion-group/AccordionGroup.d.ts +4 -3
- 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/types.d.ts +11 -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 +141 -41
- 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 +2 -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 +63 -117
- 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 +64 -107
- 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 +142 -181
- package/checkbox/Checkbox.stories.tsx +128 -94
- package/checkbox/Checkbox.test.js +160 -39
- package/checkbox/types.d.ts +11 -3
- 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 +1395 -0
- package/common/variables.js +1025 -1134
- 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 +152 -298
- 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.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/dropdown/Dropdown.d.ts +1 -1
- package/dropdown/Dropdown.js +248 -303
- 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 +45 -96
- 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 +72 -117
- 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 +90 -170
- 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 +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 +2 -2
- package/layout/ApplicationLayout.d.ts +16 -6
- package/layout/ApplicationLayout.js +82 -166
- 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 +2 -2
- package/link/Link.js +42 -89
- package/link/Link.stories.tsx +73 -6
- package/link/Link.test.js +24 -44
- package/link/types.d.ts +14 -15
- package/main.d.ts +13 -13
- package/main.js +57 -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 +47 -37
- package/number-input/NumberInput.stories.tsx +42 -26
- package/number-input/NumberInput.test.js +860 -377
- package/number-input/types.d.ts +11 -5
- package/package.json +43 -45
- 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 +160 -143
- package/password-input/types.d.ts +8 -7
- 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.js +71 -44
- 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.js +71 -116
- 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.d.ts +7 -0
- package/resultset-table/ResultsetTable.js +167 -0
- package/{resultsetTable → resultset-table}/ResultsetTable.stories.tsx +152 -30
- package/resultset-table/ResultsetTable.test.js +371 -0
- package/{resultsetTable → resultset-table}/types.d.ts +13 -7
- 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 +45 -51
- package/select/Option.js +27 -50
- package/select/Select.js +181 -246
- package/select/Select.stories.tsx +525 -136
- package/select/Select.test.js +2009 -1696
- package/select/types.d.ts +16 -20
- 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 -181
- package/slider/Slider.test.js +185 -81
- package/slider/types.d.ts +7 -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 +147 -125
- package/switch/Switch.stories.tsx +37 -60
- package/switch/Switch.test.js +138 -56
- package/switch/types.d.ts +7 -3
- package/table/ActionsCell.d.ts +4 -0
- package/table/ActionsCell.js +68 -0
- package/table/DropdownTheme.js +62 -0
- package/table/Table.d.ts +4 -1
- package/table/Table.js +26 -32
- package/table/Table.stories.tsx +658 -0
- package/table/Table.test.js +95 -8
- package/table/types.d.ts +45 -6
- package/tabs/Tab.d.ts +4 -0
- package/tabs/Tab.js +116 -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.js +29 -61
- package/tag/Tag.stories.tsx +14 -1
- 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.js +40 -28
- package/text-input/Suggestions.d.ts +4 -0
- package/text-input/Suggestions.js +84 -0
- package/text-input/TextInput.js +318 -524
- 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.js +79 -131
- 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.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.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 +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.js +51 -91
- package/wizard/Wizard.stories.tsx +40 -1
- package/wizard/Wizard.test.js +54 -81
- package/wizard/types.d.ts +7 -7
- 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 -173
- package/radio/Radio.stories.tsx +0 -192
- package/radio/Radio.test.js +0 -71
- package/radio/types.d.ts +0 -54
- 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/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,4 +1,4 @@
|
|
|
1
|
-
export
|
|
1
|
+
export type Option = {
|
|
2
2
|
/**
|
|
3
3
|
* Label of the option placed next to the radio input.
|
|
4
4
|
*/
|
|
@@ -14,11 +14,11 @@ export declare type Option = {
|
|
|
14
14
|
*/
|
|
15
15
|
disabled?: boolean;
|
|
16
16
|
};
|
|
17
|
-
|
|
17
|
+
type RadioGroupProps = {
|
|
18
18
|
/**
|
|
19
19
|
* Text to be placed above the radio group.
|
|
20
20
|
*/
|
|
21
|
-
label
|
|
21
|
+
label?: string;
|
|
22
22
|
/**
|
|
23
23
|
* Name attribute of the input element. This attribute will allow users
|
|
24
24
|
* to find the component's value during the submit event.
|
|
@@ -49,9 +49,9 @@ declare type RadioGroupProps = {
|
|
|
49
49
|
*/
|
|
50
50
|
optionalItemLabel?: string;
|
|
51
51
|
/**
|
|
52
|
-
* If true, the component will be
|
|
52
|
+
* If true, the component will not be mutable, meaning the user can not edit the control.
|
|
53
53
|
*/
|
|
54
|
-
|
|
54
|
+
readOnly?: boolean;
|
|
55
55
|
/**
|
|
56
56
|
* Sets the orientation of the options within the radio group.
|
|
57
57
|
*/
|
|
@@ -97,18 +97,18 @@ declare type RadioGroupProps = {
|
|
|
97
97
|
/**
|
|
98
98
|
* Reference to the component.
|
|
99
99
|
*/
|
|
100
|
-
export
|
|
100
|
+
export type RefType = HTMLDivElement;
|
|
101
101
|
/**
|
|
102
102
|
* Single radio prop types.
|
|
103
103
|
*/
|
|
104
|
-
export
|
|
105
|
-
|
|
106
|
-
|
|
104
|
+
export type RadioProps = {
|
|
105
|
+
label: string;
|
|
106
|
+
checked: boolean;
|
|
107
107
|
onClick: () => void;
|
|
108
108
|
error?: string;
|
|
109
109
|
disabled: boolean;
|
|
110
110
|
focused: boolean;
|
|
111
|
-
|
|
111
|
+
readOnly: boolean;
|
|
112
112
|
tabIndex: number;
|
|
113
113
|
};
|
|
114
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;
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import ResultsetTablePropsType from "./types";
|
|
3
|
+
declare const DxcResultsetTable: {
|
|
4
|
+
({ columns, rows, showGoToPage, itemsPerPage, itemsPerPageOptions, itemsPerPageFunction, margin, tabIndex, mode, }: ResultsetTablePropsType): JSX.Element;
|
|
5
|
+
ActionsCell: ({ actions }: import("../table/types").ActionCellsPropsType) => JSX.Element;
|
|
6
|
+
};
|
|
7
|
+
export default DxcResultsetTable;
|
|
@@ -0,0 +1,167 @@
|
|
|
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 _ActionsCell = _interopRequireDefault(require("../table/ActionsCell"));
|
|
16
|
+
var _Paginator = _interopRequireDefault(require("../paginator/Paginator"));
|
|
17
|
+
var _Table = _interopRequireDefault(require("../table/Table"));
|
|
18
|
+
var _useTheme = _interopRequireDefault(require("../useTheme"));
|
|
19
|
+
var _Icons = _interopRequireDefault(require("./Icons"));
|
|
20
|
+
var _utils = require("../common/utils");
|
|
21
|
+
var _coreTokens = _interopRequireDefault(require("../common/coreTokens"));
|
|
22
|
+
var _templateObject, _templateObject2, _templateObject3;
|
|
23
|
+
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); }
|
|
24
|
+
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; }
|
|
25
|
+
var normalizeSortValue = function normalizeSortValue(sortValue) {
|
|
26
|
+
return typeof sortValue === "string" ? sortValue.toUpperCase() : sortValue;
|
|
27
|
+
};
|
|
28
|
+
var sortArray = function sortArray(index, order, resultset) {
|
|
29
|
+
return resultset.slice().sort(function (element1, element2) {
|
|
30
|
+
var sortValueA = normalizeSortValue(element1[index].sortValue || element1[index].displayValue);
|
|
31
|
+
var sortValueB = normalizeSortValue(element2[index].sortValue || element2[index].displayValue);
|
|
32
|
+
var comparison = 0;
|
|
33
|
+
if ((0, _typeof2["default"])(sortValueA) === "object") {
|
|
34
|
+
comparison = -1;
|
|
35
|
+
} else if ((0, _typeof2["default"])(sortValueB) === "object") {
|
|
36
|
+
comparison = 1;
|
|
37
|
+
} else if (sortValueA > sortValueB) {
|
|
38
|
+
comparison = 1;
|
|
39
|
+
} else if (sortValueA < sortValueB) {
|
|
40
|
+
comparison = -1;
|
|
41
|
+
}
|
|
42
|
+
return order === "descending" ? comparison * -1 : comparison;
|
|
43
|
+
});
|
|
44
|
+
};
|
|
45
|
+
var getMinItemsPerPageIndex = function getMinItemsPerPageIndex(currentPageInternal, itemsPerPage, page) {
|
|
46
|
+
return currentPageInternal === 1 ? 0 : itemsPerPage * (page - 1);
|
|
47
|
+
};
|
|
48
|
+
var getMaxItemsPerPageIndex = function getMaxItemsPerPageIndex(minItemsPerPageIndex, itemsPerPage, resultset, page) {
|
|
49
|
+
return minItemsPerPageIndex + itemsPerPage > resultset.length ? resultset.length : itemsPerPage * page - 1;
|
|
50
|
+
};
|
|
51
|
+
var DxcResultsetTable = function DxcResultsetTable(_ref) {
|
|
52
|
+
var columns = _ref.columns,
|
|
53
|
+
rows = _ref.rows,
|
|
54
|
+
_ref$showGoToPage = _ref.showGoToPage,
|
|
55
|
+
showGoToPage = _ref$showGoToPage === void 0 ? true : _ref$showGoToPage,
|
|
56
|
+
_ref$itemsPerPage = _ref.itemsPerPage,
|
|
57
|
+
itemsPerPage = _ref$itemsPerPage === void 0 ? 5 : _ref$itemsPerPage,
|
|
58
|
+
itemsPerPageOptions = _ref.itemsPerPageOptions,
|
|
59
|
+
itemsPerPageFunction = _ref.itemsPerPageFunction,
|
|
60
|
+
margin = _ref.margin,
|
|
61
|
+
_ref$tabIndex = _ref.tabIndex,
|
|
62
|
+
tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex,
|
|
63
|
+
_ref$mode = _ref.mode,
|
|
64
|
+
mode = _ref$mode === void 0 ? "default" : _ref$mode;
|
|
65
|
+
var colorsTheme = (0, _useTheme["default"])();
|
|
66
|
+
var _useState = (0, _react.useState)(1),
|
|
67
|
+
_useState2 = (0, _slicedToArray2["default"])(_useState, 2),
|
|
68
|
+
page = _useState2[0],
|
|
69
|
+
changePage = _useState2[1];
|
|
70
|
+
var _useState3 = (0, _react.useState)(-1),
|
|
71
|
+
_useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
|
|
72
|
+
sortColumnIndex = _useState4[0],
|
|
73
|
+
changeSortColumnIndex = _useState4[1];
|
|
74
|
+
var _useState5 = (0, _react.useState)("ascending"),
|
|
75
|
+
_useState6 = (0, _slicedToArray2["default"])(_useState5, 2),
|
|
76
|
+
sortOrder = _useState6[0],
|
|
77
|
+
changeSortOrder = _useState6[1];
|
|
78
|
+
var minItemsPerPageIndex = (0, _react.useMemo)(function () {
|
|
79
|
+
return getMinItemsPerPageIndex(page, itemsPerPage, page);
|
|
80
|
+
}, [itemsPerPage, page]);
|
|
81
|
+
var maxItemsPerPageIndex = (0, _react.useMemo)(function () {
|
|
82
|
+
return getMaxItemsPerPageIndex(minItemsPerPageIndex, itemsPerPage, rows, page);
|
|
83
|
+
}, [itemsPerPage, minItemsPerPageIndex, page, rows]);
|
|
84
|
+
var sortedResultset = (0, _react.useMemo)(function () {
|
|
85
|
+
return sortColumnIndex !== -1 ? sortArray(sortColumnIndex, sortOrder, rows) : rows;
|
|
86
|
+
}, [sortColumnIndex, sortOrder, rows]);
|
|
87
|
+
var filteredResultset = (0, _react.useMemo)(function () {
|
|
88
|
+
return sortedResultset && sortedResultset.slice(minItemsPerPageIndex, maxItemsPerPageIndex + 1);
|
|
89
|
+
}, [sortedResultset, minItemsPerPageIndex, maxItemsPerPageIndex]);
|
|
90
|
+
var goToPage = function goToPage(newPage) {
|
|
91
|
+
changePage(newPage);
|
|
92
|
+
};
|
|
93
|
+
var changeSorting = function changeSorting(columnIndex) {
|
|
94
|
+
changePage(1);
|
|
95
|
+
changeSortColumnIndex(columnIndex);
|
|
96
|
+
changeSortOrder(sortColumnIndex === -1 || sortColumnIndex !== columnIndex ? "ascending" : sortOrder === "ascending" ? "descending" : "ascending");
|
|
97
|
+
};
|
|
98
|
+
(0, _react.useEffect)(function () {
|
|
99
|
+
rows.length > 0 ? changePage(1) : changePage(0);
|
|
100
|
+
}, [rows]);
|
|
101
|
+
return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
|
|
102
|
+
theme: colorsTheme.table
|
|
103
|
+
}, /*#__PURE__*/_react["default"].createElement(DxcResultsetTableContainer, {
|
|
104
|
+
margin: margin
|
|
105
|
+
}, /*#__PURE__*/_react["default"].createElement(_Table["default"], {
|
|
106
|
+
mode: mode
|
|
107
|
+
}, /*#__PURE__*/_react["default"].createElement("thead", null, /*#__PURE__*/_react["default"].createElement("tr", null, columns.map(function (column, index) {
|
|
108
|
+
return /*#__PURE__*/_react["default"].createElement("th", {
|
|
109
|
+
key: "tableHeader_".concat(index),
|
|
110
|
+
"aria-sort": column.isSortable ? sortColumnIndex === index ? sortOrder : "none" : undefined
|
|
111
|
+
}, /*#__PURE__*/_react["default"].createElement(HeaderContainer, {
|
|
112
|
+
role: column.isSortable ? "button" : undefined,
|
|
113
|
+
key: "headerContainer_".concat(index),
|
|
114
|
+
onClick: function onClick() {
|
|
115
|
+
column.isSortable && changeSorting(index);
|
|
116
|
+
},
|
|
117
|
+
tabIndex: column.isSortable ? tabIndex : -1,
|
|
118
|
+
isSortable: column.isSortable,
|
|
119
|
+
mode: mode
|
|
120
|
+
}, /*#__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)));
|
|
121
|
+
}))), /*#__PURE__*/_react["default"].createElement("tbody", null, filteredResultset.map(function (cells, index) {
|
|
122
|
+
return /*#__PURE__*/_react["default"].createElement("tr", {
|
|
123
|
+
key: "resultSetTableCell_".concat(page, "_").concat(index)
|
|
124
|
+
}, cells.map(function (cellContent, index) {
|
|
125
|
+
return /*#__PURE__*/_react["default"].createElement("td", {
|
|
126
|
+
key: "resultSetTableCellContent_".concat(index)
|
|
127
|
+
}, cellContent.displayValue);
|
|
128
|
+
}));
|
|
129
|
+
}))), /*#__PURE__*/_react["default"].createElement(_Paginator["default"], {
|
|
130
|
+
totalItems: rows.length,
|
|
131
|
+
itemsPerPage: itemsPerPage,
|
|
132
|
+
itemsPerPageOptions: itemsPerPageOptions,
|
|
133
|
+
itemsPerPageFunction: itemsPerPageFunction,
|
|
134
|
+
currentPage: page,
|
|
135
|
+
showGoToPage: showGoToPage,
|
|
136
|
+
onPageChange: goToPage,
|
|
137
|
+
tabIndex: tabIndex
|
|
138
|
+
})));
|
|
139
|
+
};
|
|
140
|
+
var calculateWidth = function calculateWidth(margin) {
|
|
141
|
+
return "calc(100% - ".concat((0, _utils.getMargin)(margin, "left"), " - ").concat((0, _utils.getMargin)(margin, "right"), ")");
|
|
142
|
+
};
|
|
143
|
+
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) {
|
|
144
|
+
return calculateWidth(props.margin);
|
|
145
|
+
}, function (props) {
|
|
146
|
+
return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
|
|
147
|
+
}, function (props) {
|
|
148
|
+
return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.top ? _variables.spaces[props.margin.top] : "";
|
|
149
|
+
}, function (props) {
|
|
150
|
+
return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.right ? _variables.spaces[props.margin.right] : "";
|
|
151
|
+
}, function (props) {
|
|
152
|
+
return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.bottom ? _variables.spaces[props.margin.bottom] : "";
|
|
153
|
+
}, function (props) {
|
|
154
|
+
return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.left ? _variables.spaces[props.margin.left] : "";
|
|
155
|
+
});
|
|
156
|
+
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) {
|
|
157
|
+
return props.theme.headerTextAlign === "center" ? "center" : props.theme.headerTextAlign === "right" ? "flex-end" : "flex-start";
|
|
158
|
+
}, _coreTokens["default"].spacing_8, function (props) {
|
|
159
|
+
return props.isSortable ? "pointer" : "default";
|
|
160
|
+
}, function (props) {
|
|
161
|
+
return props.isSortable && "&:focus {\n outline: #0095ff solid 2px;\n }";
|
|
162
|
+
});
|
|
163
|
+
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) {
|
|
164
|
+
return props.theme.sortIconColor;
|
|
165
|
+
});
|
|
166
|
+
DxcResultsetTable.ActionsCell = _ActionsCell["default"];
|
|
167
|
+
var _default = exports["default"] = DxcResultsetTable;
|
|
@@ -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: "https://www.freepnglogos.com/uploads/facebook-logo-design-1.png",
|
|
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,114 @@ 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
|
+
<SmallContainer>
|
|
265
|
+
<Title title="Small container and text overflow" theme="light" level={4} />
|
|
266
|
+
<DxcResultsetTable columns={columnsSortable} rows={longValues} />
|
|
267
|
+
</SmallContainer>
|
|
268
|
+
</ExampleContainer>
|
|
269
|
+
<ExampleContainer>
|
|
270
|
+
<Title title="Reduced sortable table" theme="light" level={4} />
|
|
271
|
+
<DxcResultsetTable columns={columnsSortable} rows={rowsSortable} mode="reduced" />
|
|
272
|
+
</ExampleContainer>
|
|
273
|
+
{/* PENDING SMALL ICON VERSION */}
|
|
274
|
+
<ExampleContainer>
|
|
275
|
+
<Title title="Reduced with items per page option" theme="light" level={4} />
|
|
276
|
+
<DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2} itemsPerPageOptions={[2, 3]} mode="reduced" />
|
|
277
|
+
</ExampleContainer>
|
|
278
|
+
<ExampleContainer>
|
|
279
|
+
<Title title="Reduced scroll resultset table" theme="light" level={4} />
|
|
280
|
+
<DxcResultsetTable columns={longColumns} rows={longRows} mode="reduced" />
|
|
281
|
+
</ExampleContainer>
|
|
282
|
+
<ExampleContainer>
|
|
283
|
+
<SmallContainer>
|
|
284
|
+
<Title title="Reduced small container and text overflow" theme="light" level={4} />
|
|
285
|
+
<DxcResultsetTable columns={columnsSortable} rows={longValues} mode="reduced" />
|
|
286
|
+
</SmallContainer>
|
|
188
287
|
</ExampleContainer>
|
|
189
288
|
<Title title="Margins" theme="light" level={2} />
|
|
190
289
|
<ExampleContainer>
|
|
191
290
|
<Title title="Xxsmall" theme="light" level={4} />
|
|
192
|
-
<DxcResultsetTable columns={columns} rows={rows} margin={"xxsmall"}
|
|
291
|
+
<DxcResultsetTable columns={columns} rows={rows} margin={"xxsmall"} />
|
|
193
292
|
</ExampleContainer>
|
|
194
293
|
<ExampleContainer>
|
|
195
294
|
<Title title="Xsmall" theme="light" level={4} />
|
|
196
|
-
<DxcResultsetTable columns={columns} rows={rows} margin={"xsmall"}
|
|
295
|
+
<DxcResultsetTable columns={columns} rows={rows} margin={"xsmall"} />
|
|
197
296
|
</ExampleContainer>
|
|
198
297
|
<ExampleContainer>
|
|
199
298
|
<Title title="Small" theme="light" level={4} />
|
|
200
|
-
<DxcResultsetTable columns={columns} rows={rows} margin={"small"}
|
|
299
|
+
<DxcResultsetTable columns={columns} rows={rows} margin={"small"} />
|
|
201
300
|
</ExampleContainer>
|
|
202
301
|
<ExampleContainer>
|
|
203
302
|
<Title title="Medium" theme="light" level={4} />
|
|
204
|
-
<DxcResultsetTable columns={columns} rows={rows} margin={"medium"}
|
|
303
|
+
<DxcResultsetTable columns={columns} rows={rows} margin={"medium"} />
|
|
205
304
|
</ExampleContainer>
|
|
206
305
|
<ExampleContainer>
|
|
207
306
|
<Title title="Large" theme="light" level={4} />
|
|
208
|
-
<DxcResultsetTable columns={columns} rows={rows} margin={"large"}
|
|
307
|
+
<DxcResultsetTable columns={columns} rows={rows} margin={"large"} />
|
|
209
308
|
</ExampleContainer>
|
|
210
309
|
<ExampleContainer>
|
|
211
310
|
<Title title="Xlarge" theme="light" level={4} />
|
|
212
|
-
<DxcResultsetTable columns={columns} rows={rows} margin={"xlarge"}
|
|
311
|
+
<DxcResultsetTable columns={columns} rows={rows} margin={"xlarge"} />
|
|
213
312
|
</ExampleContainer>
|
|
214
|
-
<ExampleContainer>
|
|
313
|
+
<ExampleContainer expanded>
|
|
215
314
|
<Title title="Xxlarge" theme="light" level={4} />
|
|
216
|
-
<DxcResultsetTable columns={columns} rows={rows} margin={"xxlarge"}
|
|
217
|
-
<hr />
|
|
315
|
+
<DxcResultsetTable columns={columns} rows={rows} margin={"xxlarge"} />
|
|
218
316
|
</ExampleContainer>
|
|
219
317
|
</>
|
|
220
318
|
);
|
|
221
319
|
|
|
320
|
+
const SmallContainer = styled.div`
|
|
321
|
+
width: 500px;
|
|
322
|
+
`;
|
|
323
|
+
|
|
222
324
|
const ResultsetTableAsc = () => (
|
|
223
325
|
<ExampleContainer>
|
|
224
326
|
<Title title="Ascendant sorting" theme="light" level={4} />
|
|
225
|
-
<DxcResultsetTable columns={columnsSortable} rows={rowsSortable}
|
|
327
|
+
<DxcResultsetTable columns={columnsSortable} rows={rowsSortable} />
|
|
226
328
|
</ExampleContainer>
|
|
227
329
|
);
|
|
228
330
|
|
|
229
331
|
export const AscendentSorting = ResultsetTableAsc.bind({});
|
|
230
332
|
AscendentSorting.play = async ({ canvasElement }) => {
|
|
231
333
|
const canvas = within(canvasElement);
|
|
232
|
-
|
|
334
|
+
const idHeader = canvas.getAllByRole("button")[0];
|
|
335
|
+
await userEvent.click(idHeader);
|
|
233
336
|
};
|
|
234
337
|
|
|
235
338
|
const ResultsetTableDesc = () => (
|
|
236
339
|
<ExampleContainer>
|
|
237
340
|
<Title title="Descendant sorting" theme="light" level={4} />
|
|
238
|
-
<DxcResultsetTable columns={columnsSortable} rows={rowsSortable}
|
|
341
|
+
<DxcResultsetTable columns={columnsSortable} rows={rowsSortable} />
|
|
239
342
|
</ExampleContainer>
|
|
240
343
|
);
|
|
241
344
|
|
|
242
345
|
export const DescendantSorting = ResultsetTableDesc.bind({});
|
|
243
346
|
DescendantSorting.play = async ({ canvasElement }) => {
|
|
244
347
|
const canvas = within(canvasElement);
|
|
245
|
-
|
|
246
|
-
await userEvent.click(
|
|
348
|
+
const nameHeader = canvas.getAllByRole("button")[1];
|
|
349
|
+
await userEvent.click(nameHeader);
|
|
350
|
+
await userEvent.click(nameHeader);
|
|
247
351
|
};
|
|
248
352
|
|
|
249
353
|
const ResultsetTableMiddle = () => (
|
|
250
354
|
<ExampleContainer>
|
|
251
355
|
<Title title="Middle page" theme="light" level={4} />
|
|
252
|
-
<DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2}
|
|
356
|
+
<DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2} />
|
|
253
357
|
</ExampleContainer>
|
|
254
358
|
);
|
|
255
359
|
|
|
@@ -263,7 +367,7 @@ MiddlePage.play = async ({ canvasElement }) => {
|
|
|
263
367
|
const ResultsetTableLast = () => (
|
|
264
368
|
<ExampleContainer>
|
|
265
369
|
<Title title="Last page" theme="light" level={4} />
|
|
266
|
-
<DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2}
|
|
370
|
+
<DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2} />
|
|
267
371
|
</ExampleContainer>
|
|
268
372
|
);
|
|
269
373
|
|
|
@@ -273,3 +377,21 @@ LastPage.play = async ({ canvasElement }) => {
|
|
|
273
377
|
const nextButton = canvas.getAllByRole("button")[3];
|
|
274
378
|
await userEvent.click(nextButton);
|
|
275
379
|
};
|
|
380
|
+
|
|
381
|
+
const ResultsetActionsCellDropdown = () => (
|
|
382
|
+
<ExampleContainer>
|
|
383
|
+
<Title title="Dropdown Action" theme="light" level={4} />
|
|
384
|
+
<DxcResultsetTable columns={columns} rows={rowsIcon} itemsPerPage={2} />
|
|
385
|
+
<Title title="Custom theme actions cell" theme="light" level={4} />
|
|
386
|
+
<HalstackProvider advancedTheme={advancedTheme}>
|
|
387
|
+
<DxcResultsetTable columns={columns} rows={rowsIcon} itemsPerPage={2} />
|
|
388
|
+
</HalstackProvider>
|
|
389
|
+
</ExampleContainer>
|
|
390
|
+
);
|
|
391
|
+
|
|
392
|
+
export const DropdownAction = ResultsetActionsCellDropdown.bind({});
|
|
393
|
+
DropdownAction.play = async ({ canvasElement }) => {
|
|
394
|
+
const canvas = within(canvasElement);
|
|
395
|
+
const dropdown = canvas.getAllByRole("button")[5];
|
|
396
|
+
await userEvent.click(dropdown);
|
|
397
|
+
};
|