@dxc-technology/halstack-react 3.2.0 → 4.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/BackgroundColorContext.js +46 -0
- package/ThemeContext.js +250 -0
- package/V3Select/V3Select.js +549 -0
- package/V3Select/index.d.ts +27 -0
- package/V3Textarea/V3Textarea.js +264 -0
- package/V3Textarea/index.d.ts +27 -0
- package/{dist/accordion → accordion}/Accordion.js +119 -50
- package/accordion/index.d.ts +28 -0
- package/{dist/accordion-group → accordion-group}/AccordionGroup.js +33 -1
- package/accordion-group/index.d.ts +16 -0
- package/alert/Alert.js +403 -0
- package/alert/index.d.ts +51 -0
- package/badge/Badge.js +63 -0
- package/{dist/box → box}/Box.js +27 -18
- package/box/index.d.ts +25 -0
- package/button/Button.js +238 -0
- package/button/Button.stories.js +27 -0
- package/button/index.d.ts +24 -0
- package/{dist/card → card}/Card.js +16 -9
- package/card/index.d.ts +22 -0
- package/{dist/checkbox → checkbox}/Checkbox.js +89 -23
- package/checkbox/index.d.ts +24 -0
- package/{dist/chip → chip}/Chip.js +63 -21
- package/chip/index.d.ts +22 -0
- package/{dist/common → common}/OpenSans.css +0 -0
- package/{dist/common → common}/RequiredComponent.js +0 -0
- package/{dist/common → common}/fonts/OpenSans-Bold.ttf +0 -0
- package/{dist/common → common}/fonts/OpenSans-BoldItalic.ttf +0 -0
- package/{dist/common → common}/fonts/OpenSans-ExtraBold.ttf +0 -0
- package/{dist/common → common}/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
- package/{dist/common → common}/fonts/OpenSans-Italic.ttf +0 -0
- package/{dist/common → common}/fonts/OpenSans-Light.ttf +0 -0
- package/{dist/common → common}/fonts/OpenSans-LightItalic.ttf +0 -0
- package/{dist/common → common}/fonts/OpenSans-Regular.ttf +0 -0
- package/{dist/common → common}/fonts/OpenSans-SemiBold.ttf +0 -0
- package/{dist/common → common}/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
- package/common/utils.js +22 -0
- package/common/variables.js +1567 -0
- package/{dist/date → date}/Date.js +60 -38
- package/date/index.d.ts +27 -0
- package/date-input/DateInput.js +400 -0
- package/date-input/index.d.ts +95 -0
- package/{dist/dialog → dialog}/Dialog.js +44 -29
- package/dialog/index.d.ts +18 -0
- package/{dist/dropdown → dropdown}/Dropdown.js +162 -74
- package/dropdown/index.d.ts +26 -0
- package/file-input/FileInput.js +644 -0
- package/file-input/FileItem.js +287 -0
- package/file-input/index.d.ts +81 -0
- package/{dist/footer → footer}/Footer.js +79 -37
- package/footer/Icons.js +77 -0
- package/footer/index.d.ts +25 -0
- package/{dist/header → header}/Header.js +157 -72
- package/header/Icons.js +59 -0
- package/header/index.d.ts +25 -0
- package/heading/Heading.js +230 -0
- package/heading/index.d.ts +17 -0
- package/input-text/Icons.js +22 -0
- package/{dist/input-text → input-text}/InputText.js +162 -66
- package/input-text/index.d.ts +36 -0
- package/{dist/layout → layout}/ApplicationLayout.js +7 -11
- package/layout/Icons.js +55 -0
- package/{dist/link → link}/Link.js +76 -39
- package/link/index.d.ts +23 -0
- package/main.d.ts +40 -0
- package/{dist/main.js → main.js} +71 -15
- package/number-input/NumberInput.js +136 -0
- package/number-input/NumberInputContext.js +16 -0
- package/number-input/index.d.ts +113 -0
- package/package.json +25 -19
- package/paginator/Icons.js +66 -0
- package/{dist/paginator → paginator}/Paginator.js +86 -42
- package/paginator/index.d.ts +20 -0
- package/password-input/PasswordInput.js +203 -0
- package/password-input/index.d.ts +94 -0
- package/{dist/progress-bar → progress-bar}/ProgressBar.js +88 -38
- package/progress-bar/index.d.ts +18 -0
- package/{dist/radio → radio}/Radio.js +28 -9
- package/radio/index.d.ts +23 -0
- package/{dist/resultsetTable → resultsetTable}/ResultsetTable.js +65 -40
- package/resultsetTable/index.d.ts +19 -0
- package/select/Select.js +1138 -0
- package/select/index.d.ts +131 -0
- package/{dist/sidenav → sidenav}/Sidenav.js +47 -23
- package/sidenav/index.d.ts +13 -0
- package/slider/Slider.js +404 -0
- package/slider/index.d.ts +29 -0
- package/spinner/Spinner.js +381 -0
- package/spinner/index.d.ts +17 -0
- package/{dist/switch → switch}/Switch.js +42 -14
- package/switch/index.d.ts +24 -0
- package/{dist/table → table}/Table.js +45 -11
- package/table/index.d.ts +13 -0
- package/{dist/tabs → tabs}/Tabs.js +37 -19
- package/tabs/index.d.ts +19 -0
- package/{dist/tag → tag}/Tag.js +50 -36
- package/tag/index.d.ts +24 -0
- package/text-input/TextInput.js +992 -0
- package/text-input/index.d.ts +135 -0
- package/textarea/Textarea.js +369 -0
- package/textarea/index.d.ts +117 -0
- package/{dist/toggle → toggle}/Toggle.js +0 -0
- package/toggle/index.d.ts +21 -0
- package/toggle-group/ToggleGroup.js +327 -0
- package/toggle-group/index.d.ts +21 -0
- package/{dist/upload → upload}/Upload.js +1 -5
- package/{dist/upload → upload}/buttons-upload/ButtonsUpload.js +28 -16
- package/upload/buttons-upload/Icons.js +40 -0
- package/{dist/upload → upload}/dragAndDropArea/DragAndDropArea.js +61 -25
- package/upload/dragAndDropArea/Icons.js +39 -0
- package/{dist/upload → upload}/file-upload/FileToUpload.js +52 -25
- package/upload/file-upload/Icons.js +66 -0
- package/{dist/upload → upload}/files-upload/FilesToUpload.js +3 -3
- package/upload/index.d.ts +15 -0
- package/upload/transaction/Icons.js +160 -0
- package/{dist/upload → upload}/transaction/Transaction.js +37 -41
- package/{dist/upload → upload}/transactions/Transactions.js +24 -8
- package/{dist/useTheme.js → useTheme.js} +0 -0
- package/wizard/Icons.js +65 -0
- package/{dist/wizard → wizard}/Wizard.js +106 -56
- package/wizard/index.d.ts +18 -0
- package/README.md +0 -66
- package/babel.config.js +0 -8
- package/dist/ThemeContext.js +0 -201
- package/dist/accordion/Accordion.stories.js +0 -207
- package/dist/accordion/readme.md +0 -96
- package/dist/accordion-group/AccordionGroup.stories.js +0 -207
- package/dist/accordion-group/readme.md +0 -70
- package/dist/alert/Alert.js +0 -318
- package/dist/alert/Alert.stories.js +0 -158
- package/dist/alert/close.svg +0 -4
- package/dist/alert/error.svg +0 -4
- package/dist/alert/info.svg +0 -4
- package/dist/alert/readme.md +0 -43
- package/dist/alert/success.svg +0 -4
- package/dist/alert/warning.svg +0 -4
- package/dist/badge/Badge.js +0 -40
- package/dist/button/Button.js +0 -219
- package/dist/button/Button.stories.js +0 -224
- package/dist/button/readme.md +0 -93
- package/dist/checkbox/Checkbox.stories.js +0 -144
- package/dist/checkbox/readme.md +0 -116
- package/dist/common/utils.js +0 -42
- package/dist/common/variables.js +0 -523
- package/dist/date/Date.stories.js +0 -205
- package/dist/date/calendar.svg +0 -1
- package/dist/date/calendar_dark.svg +0 -1
- package/dist/date/readme.md +0 -73
- package/dist/dialog/Dialog.stories.js +0 -217
- package/dist/dialog/readme.md +0 -32
- package/dist/dropdown/Dropdown.stories.js +0 -249
- package/dist/dropdown/baseline-arrow_drop_down.svg +0 -1
- package/dist/dropdown/baseline-arrow_drop_down_wh.svg +0 -4
- package/dist/dropdown/baseline-arrow_drop_up.svg +0 -1
- package/dist/dropdown/baseline-arrow_drop_up_wh.svg +0 -4
- package/dist/dropdown/readme.md +0 -69
- package/dist/footer/Footer.stories.js +0 -94
- package/dist/footer/dxc_logo_wht.png +0 -0
- package/dist/footer/readme.md +0 -41
- package/dist/header/Header.stories.js +0 -176
- package/dist/header/close_icon.svg +0 -1
- package/dist/header/dxc_logo_black.png +0 -0
- package/dist/header/dxc_logo_blk_rgb.svg +0 -6
- package/dist/header/dxc_logo_white.png +0 -0
- package/dist/header/hamb_menu_black.svg +0 -1
- package/dist/header/hamb_menu_white.svg +0 -1
- package/dist/header/readme.md +0 -33
- package/dist/heading/Heading.js +0 -163
- package/dist/input-text/InputText.stories.js +0 -209
- package/dist/input-text/error.svg +0 -1
- package/dist/input-text/readme.md +0 -91
- package/dist/layout/facebook.svg +0 -45
- package/dist/layout/linkedin.svg +0 -50
- package/dist/layout/twitter.svg +0 -53
- package/dist/link/readme.md +0 -51
- package/dist/paginator/images/next.svg +0 -3
- package/dist/paginator/images/nextPage.svg +0 -3
- package/dist/paginator/images/previous.svg +0 -3
- package/dist/paginator/images/previousPage.svg +0 -3
- package/dist/paginator/readme.md +0 -50
- package/dist/progress-bar/ProgressBar.stories.js +0 -280
- package/dist/progress-bar/readme.md +0 -63
- package/dist/radio/Radio.stories.js +0 -166
- package/dist/radio/readme.md +0 -70
- package/dist/resultsetTable/arrow_downward-24px_wht.svg +0 -1
- package/dist/resultsetTable/arrow_upward-24px_wht.svg +0 -1
- package/dist/resultsetTable/unfold_more-24px_wht.svg +0 -1
- package/dist/select/Select.js +0 -490
- package/dist/select/Select.stories.js +0 -235
- package/dist/select/readme.md +0 -72
- package/dist/slider/Slider.js +0 -267
- package/dist/slider/Slider.stories.js +0 -241
- package/dist/slider/readme.md +0 -64
- package/dist/spinner/Spinner.js +0 -198
- package/dist/spinner/Spinner.stories.js +0 -183
- package/dist/spinner/readme.md +0 -65
- package/dist/switch/Switch.stories.js +0 -134
- package/dist/switch/readme.md +0 -133
- package/dist/tabs/Tabs.stories.js +0 -130
- package/dist/tabs/readme.md +0 -78
- package/dist/tabs-for-sections/TabsForSections.js +0 -92
- package/dist/tabs-for-sections/readme.md +0 -78
- package/dist/textarea/Textarea.js +0 -238
- package/dist/toggle/Toggle.stories.js +0 -297
- package/dist/toggle/readme.md +0 -80
- package/dist/toggle-group/ToggleGroup.js +0 -223
- package/dist/toggle-group/readme.md +0 -82
- package/dist/upload/Upload.stories.js +0 -72
- package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
- package/dist/upload/buttons-upload/upload-button.svg +0 -1
- package/dist/upload/dragAndDropArea/upload_drop.svg +0 -4
- package/dist/upload/dragAndDropArea/upload_file.svg +0 -4
- package/dist/upload/file-upload/audio-icon.svg +0 -4
- package/dist/upload/file-upload/close.svg +0 -4
- package/dist/upload/file-upload/file-icon.svg +0 -4
- package/dist/upload/file-upload/video-icon.svg +0 -4
- package/dist/upload/readme.md +0 -37
- package/dist/upload/transaction/audio-icon-err.svg +0 -4
- package/dist/upload/transaction/audio-icon.svg +0 -4
- package/dist/upload/transaction/error-icon.svg +0 -4
- package/dist/upload/transaction/file-icon-err.svg +0 -4
- package/dist/upload/transaction/file-icon.svg +0 -4
- package/dist/upload/transaction/image-icon-err.svg +0 -4
- package/dist/upload/transaction/image-icon.svg +0 -4
- package/dist/upload/transaction/success-icon.svg +0 -4
- package/dist/upload/transaction/video-icon-err.svg +0 -4
- package/dist/upload/transaction/video-icon.svg +0 -4
- package/dist/wizard/invalid_icon.svg +0 -6
- package/dist/wizard/valid_icon.svg +0 -6
- package/dist/wizard/validation-wrong.svg +0 -6
- package/test/Accordion.test.js +0 -33
- package/test/AccordionGroup.test.js +0 -125
- package/test/Alert.test.js +0 -53
- package/test/Box.test.js +0 -10
- package/test/Button.test.js +0 -18
- package/test/Card.test.js +0 -30
- package/test/Checkbox.test.js +0 -45
- package/test/Chip.test.js +0 -25
- package/test/Date.test.js +0 -393
- package/test/Dialog.test.js +0 -23
- package/test/Dropdown.test.js +0 -130
- package/test/Footer.test.js +0 -99
- package/test/Header.test.js +0 -39
- package/test/Heading.test.js +0 -35
- package/test/InputText.test.js +0 -240
- package/test/Link.test.js +0 -42
- package/test/Paginator.test.js +0 -177
- package/test/ProgressBar.test.js +0 -35
- package/test/Radio.test.js +0 -37
- package/test/ResultsetTable.test.js +0 -330
- package/test/Select.test.js +0 -192
- package/test/Sidenav.test.js +0 -45
- package/test/Slider.test.js +0 -82
- package/test/Spinner.test.js +0 -27
- package/test/Switch.test.js +0 -45
- package/test/Table.test.js +0 -36
- package/test/Tabs.test.js +0 -109
- package/test/TabsForSections.test.js +0 -34
- package/test/Tag.test.js +0 -32
- package/test/TextArea.test.js +0 -52
- package/test/ToggleGroup.test.js +0 -81
- package/test/Upload.test.js +0 -60
- package/test/Wizard.test.js +0 -130
- package/test/mocks/pngMock.js +0 -1
- package/test/mocks/svgMock.js +0 -1
package/button/Button.js
ADDED
|
@@ -0,0 +1,238 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
|
|
4
|
+
|
|
5
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
6
|
+
|
|
7
|
+
Object.defineProperty(exports, "__esModule", {
|
|
8
|
+
value: true
|
|
9
|
+
});
|
|
10
|
+
exports["default"] = void 0;
|
|
11
|
+
|
|
12
|
+
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
|
|
13
|
+
|
|
14
|
+
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
|
|
15
|
+
|
|
16
|
+
var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
|
|
17
|
+
|
|
18
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
19
|
+
|
|
20
|
+
var _Button = _interopRequireDefault(require("@material-ui/core/Button"));
|
|
21
|
+
|
|
22
|
+
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
23
|
+
|
|
24
|
+
var _styledComponents = _interopRequireWildcard(require("styled-components"));
|
|
25
|
+
|
|
26
|
+
var _variables = require("../common/variables.js");
|
|
27
|
+
|
|
28
|
+
var _utils = require("../common/utils.js");
|
|
29
|
+
|
|
30
|
+
var _useTheme = _interopRequireDefault(require("../useTheme.js"));
|
|
31
|
+
|
|
32
|
+
var _BackgroundColorContext = _interopRequireDefault(require("../BackgroundColorContext.js"));
|
|
33
|
+
|
|
34
|
+
function _templateObject4() {
|
|
35
|
+
var data = (0, _taggedTemplateLiteral2["default"])(["\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n\n display: inline-block;\n width: ", ";\n cursor: ", ";\n\n .MuiButtonBase-root {\n padding-left: ", ";\n padding-right: ", ";\n padding-top: ", ";\n padding-bottom: ", ";\n\n .MuiButton-label {\n display: flex;\n flex-direction: ", ";\n align-items: center;\n }\n\n box-shadow: 0 0 0 2px transparent;\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n letter-spacing: ", ";\n min-width: ", ";\n width: 100%;\n height: 40px;\n transition: none !important;\n\n &:focus {\n border-color: transparent;\n box-shadow: 0 0 0 2px\n ", ";\n }\n\n ", "\n }\n"]);
|
|
36
|
+
|
|
37
|
+
_templateObject4 = function _templateObject4() {
|
|
38
|
+
return data;
|
|
39
|
+
};
|
|
40
|
+
|
|
41
|
+
return data;
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
function _templateObject3() {
|
|
45
|
+
var data = (0, _taggedTemplateLiteral2["default"])(["\n max-height: 24px;\n max-width: 24px;\n margin-left: ", ";\n margin-right: ", ";\n"]);
|
|
46
|
+
|
|
47
|
+
_templateObject3 = function _templateObject3() {
|
|
48
|
+
return data;
|
|
49
|
+
};
|
|
50
|
+
|
|
51
|
+
return data;
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
function _templateObject2() {
|
|
55
|
+
var data = (0, _taggedTemplateLiteral2["default"])(["\n max-height: 24px;\n max-width: 24px;\n margin-left: ", ";\n margin-right: ", ";\n overflow: hidden;\n display: flex;\n img,\n svg {\n height: 100%;\n width: 100%;\n }\n"]);
|
|
56
|
+
|
|
57
|
+
_templateObject2 = function _templateObject2() {
|
|
58
|
+
return data;
|
|
59
|
+
};
|
|
60
|
+
|
|
61
|
+
return data;
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
function _templateObject() {
|
|
65
|
+
var data = (0, _taggedTemplateLiteral2["default"])(["\n line-height: ", ";\n font-size: ", ";\n text-overflow: ellipsis;\n overflow: hidden;\n text-transform: none;\n margin-right: ", ";\n margin-left: ", ";\n"]);
|
|
66
|
+
|
|
67
|
+
_templateObject = function _templateObject() {
|
|
68
|
+
return data;
|
|
69
|
+
};
|
|
70
|
+
|
|
71
|
+
return data;
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
var DxcButton = function DxcButton(_ref) {
|
|
75
|
+
var _ref$label = _ref.label,
|
|
76
|
+
label = _ref$label === void 0 ? "" : _ref$label,
|
|
77
|
+
_ref$mode = _ref.mode,
|
|
78
|
+
mode = _ref$mode === void 0 ? "primary" : _ref$mode,
|
|
79
|
+
_ref$disabled = _ref.disabled,
|
|
80
|
+
disabled = _ref$disabled === void 0 ? false : _ref$disabled,
|
|
81
|
+
_ref$iconPosition = _ref.iconPosition,
|
|
82
|
+
iconPosition = _ref$iconPosition === void 0 ? "before" : _ref$iconPosition,
|
|
83
|
+
_ref$type = _ref.type,
|
|
84
|
+
type = _ref$type === void 0 ? "button" : _ref$type,
|
|
85
|
+
_ref$iconSrc = _ref.iconSrc,
|
|
86
|
+
iconSrc = _ref$iconSrc === void 0 ? "" : _ref$iconSrc,
|
|
87
|
+
icon = _ref.icon,
|
|
88
|
+
_ref$onClick = _ref.onClick,
|
|
89
|
+
_onClick = _ref$onClick === void 0 ? "" : _ref$onClick,
|
|
90
|
+
margin = _ref.margin,
|
|
91
|
+
size = _ref.size,
|
|
92
|
+
_ref$tabIndex = _ref.tabIndex,
|
|
93
|
+
tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
|
|
94
|
+
|
|
95
|
+
var colorsTheme = (0, _useTheme["default"])();
|
|
96
|
+
var backgroundType = (0, _react.useContext)(_BackgroundColorContext["default"]);
|
|
97
|
+
return _react["default"].createElement(_styledComponents.ThemeProvider, {
|
|
98
|
+
theme: colorsTheme.button
|
|
99
|
+
}, _react["default"].createElement(DxCButton, {
|
|
100
|
+
type: type,
|
|
101
|
+
margin: margin,
|
|
102
|
+
mode: mode !== "primary" && mode !== "secondary" && mode !== "text" ? "primary" : mode,
|
|
103
|
+
disabled: disabled,
|
|
104
|
+
iconPosition: iconPosition,
|
|
105
|
+
size: size,
|
|
106
|
+
backgroundType: backgroundType,
|
|
107
|
+
icon: icon
|
|
108
|
+
}, _react["default"].createElement(_Button["default"], {
|
|
109
|
+
disabled: disabled,
|
|
110
|
+
type: type,
|
|
111
|
+
disableRipple: true,
|
|
112
|
+
"aria-disabled": disabled ? true : false,
|
|
113
|
+
tabIndex: disabled ? -1 : tabIndex,
|
|
114
|
+
onClick: function onClick() {
|
|
115
|
+
if (_onClick) {
|
|
116
|
+
_onClick();
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
}, label && _react["default"].createElement(LabelContainer, {
|
|
120
|
+
icon: icon,
|
|
121
|
+
iconPosition: iconPosition
|
|
122
|
+
}, label), icon ? _react["default"].createElement(IconContainer, {
|
|
123
|
+
label: label,
|
|
124
|
+
iconPosition: iconPosition
|
|
125
|
+
}, (0, _typeof2["default"])(icon) === "object" ? icon : _react["default"].createElement(icon)) : iconSrc && _react["default"].createElement(ButtonIcon, {
|
|
126
|
+
label: label,
|
|
127
|
+
iconPosition: iconPosition,
|
|
128
|
+
src: iconSrc
|
|
129
|
+
}))));
|
|
130
|
+
};
|
|
131
|
+
|
|
132
|
+
var sizes = {
|
|
133
|
+
small: "42px",
|
|
134
|
+
medium: "120px",
|
|
135
|
+
large: "240px",
|
|
136
|
+
fillParent: "100%",
|
|
137
|
+
fitContent: "unset"
|
|
138
|
+
};
|
|
139
|
+
|
|
140
|
+
var calculateWidth = function calculateWidth(margin, size) {
|
|
141
|
+
if (size === "fillParent") {
|
|
142
|
+
return "calc(".concat(sizes[size], " - ").concat((0, _utils.getMargin)(margin, "left"), " - ").concat((0, _utils.getMargin)(margin, "right"), ")");
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
return sizes[size];
|
|
146
|
+
};
|
|
147
|
+
|
|
148
|
+
var LabelContainer = _styledComponents["default"].span(_templateObject(), function (props) {
|
|
149
|
+
return props.theme.labelFontLineHeight;
|
|
150
|
+
}, function (props) {
|
|
151
|
+
return props.theme.fontSize;
|
|
152
|
+
}, function (props) {
|
|
153
|
+
return !props.icon || props.iconPosition === "before" ? "8px" : "0px";
|
|
154
|
+
}, function (props) {
|
|
155
|
+
return !props.icon || props.iconPosition === "after" ? "8px" : "0px";
|
|
156
|
+
});
|
|
157
|
+
|
|
158
|
+
var IconContainer = _styledComponents["default"].div(_templateObject2(), function (props) {
|
|
159
|
+
return !props.label ? "0px" : props.iconPosition === "after" && props.label !== "" && "8px" || "8px";
|
|
160
|
+
}, function (props) {
|
|
161
|
+
return !props.label ? "0px" : props.iconPosition === "before" && props.label !== "" && "8px" || "8px";
|
|
162
|
+
});
|
|
163
|
+
|
|
164
|
+
var ButtonIcon = _styledComponents["default"].img(_templateObject3(), function (props) {
|
|
165
|
+
return props.iconPosition === "after" && props.label !== "" && "10px" || "0px";
|
|
166
|
+
}, function (props) {
|
|
167
|
+
return props.iconPosition === "before" && props.label !== "" && "10px" || "0px";
|
|
168
|
+
});
|
|
169
|
+
|
|
170
|
+
var DxCButton = _styledComponents["default"].div(_templateObject4(), function (props) {
|
|
171
|
+
return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
|
|
172
|
+
}, function (props) {
|
|
173
|
+
return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.top ? _variables.spaces[props.margin.top] : "";
|
|
174
|
+
}, function (props) {
|
|
175
|
+
return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.right ? _variables.spaces[props.margin.right] : "";
|
|
176
|
+
}, function (props) {
|
|
177
|
+
return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.bottom ? _variables.spaces[props.margin.bottom] : "";
|
|
178
|
+
}, function (props) {
|
|
179
|
+
return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.left ? _variables.spaces[props.margin.left] : "";
|
|
180
|
+
}, function (props) {
|
|
181
|
+
return calculateWidth(props.margin, props.size);
|
|
182
|
+
}, function (props) {
|
|
183
|
+
return props.disabled && "not-allowed" || "pointer";
|
|
184
|
+
}, function (props) {
|
|
185
|
+
return props.theme.paddingLeft;
|
|
186
|
+
}, function (props) {
|
|
187
|
+
return props.theme.paddingRight;
|
|
188
|
+
}, function (props) {
|
|
189
|
+
return props.theme.paddingTop;
|
|
190
|
+
}, function (props) {
|
|
191
|
+
return props.theme.paddingBottom;
|
|
192
|
+
}, function (props) {
|
|
193
|
+
return props.iconPosition === "after" && "row" || "row-reverse";
|
|
194
|
+
}, function (props) {
|
|
195
|
+
return props.theme.fontFamily;
|
|
196
|
+
}, function (props) {
|
|
197
|
+
return props.theme.fontSize;
|
|
198
|
+
}, function (props) {
|
|
199
|
+
return props.theme.fontWeight;
|
|
200
|
+
}, function (props) {
|
|
201
|
+
return props.theme.labelLetterSpacing;
|
|
202
|
+
}, function (props) {
|
|
203
|
+
return props.size === "small" && "calc(100% - 22px)" || "unset";
|
|
204
|
+
}, function (props) {
|
|
205
|
+
return props.backgroundType === "dark" ? props.theme.focusBorderColorOnDark : props.theme.focusBorderColor;
|
|
206
|
+
}, function (props) {
|
|
207
|
+
var mode = props.mode,
|
|
208
|
+
backgroundType = props.backgroundType;
|
|
209
|
+
|
|
210
|
+
if (mode === "primary") {
|
|
211
|
+
return "\n border-radius: ".concat(props.theme.primaryBorderRadius, ";\n border-width: ").concat(props.theme.primaryBorderThickness, ";\n border-style: ").concat(props.theme.primaryBorderStyle, ";\n font-family: ").concat(props.theme.primaryFontFamily, ";\n font-size: ").concat(props.theme.primaryFontSize, ";\n font-weight: ").concat(props.theme.primaryFontWeight, ";\n background-color: ").concat(backgroundType === "dark" ? props.theme.primaryBackgroundColorOnDark : props.theme.primaryBackgroundColor, ";\n color: ").concat(backgroundType && backgroundType === "dark" ? props.theme.primaryFontColorOnDark : props.theme.primaryFontColor, " !important;\n\n &:hover {\n background-color: ").concat(backgroundType === "dark" ? props.theme.primaryHoverBackgroundColorOnDark : props.theme.primaryHoverBackgroundColor, ";\n }\n &:active {\n background-color: ").concat(backgroundType === "dark" ? props.theme.primaryActiveBackgroundColorOnDark : props.theme.primaryActiveBackgroundColor, " !important;\n border-color: transparent;\n box-shadow: 0 0 0 2px ").concat(backgroundType === "dark" ? props.theme.focusBorderColorOnDark : props.theme.focusBorderColor, ";\n }\n &:disabled { \n cursor: not-allowed;\n background-color: ").concat(backgroundType === "dark" ? props.theme.primaryDisabledBackgroundColorOnDark : props.theme.primaryDisabledBackgroundColor, ";\n color: ").concat(backgroundType === "dark" ? props.theme.primaryDisabledFontColorOnDark : props.theme.primaryDisabledFontColor, "!important; \n }\n .MuiButton-label {\n z-index: 5;\n }\n ");
|
|
212
|
+
} else if (mode === "secondary") {
|
|
213
|
+
return "\n border-radius: ".concat(props.theme.secondaryBorderRadius, ";\n border-width: ").concat(props.theme.secondaryBorderThickness, ";\n border-style: ").concat(props.theme.secondaryBorderStyle, ";\n font-family: ").concat(props.theme.secondaryFontFamily, ";\n font-size: ").concat(props.theme.secondaryFontSize, ";\n font-weight: ").concat(props.theme.secondaryFontWeight, ";\n background-color: ").concat(backgroundType === "dark" ? props.theme.secondaryBackgroundColorOnDark : props.theme.secondaryBackgroundColor, ";\n color: ").concat(backgroundType === "dark" ? props.theme.secondaryFontColorOnDark : props.theme.secondaryFontColor, " !important;\n border-color: ").concat(backgroundType === "dark" ? props.theme.secondaryBorderColorOnDark : props.theme.secondaryBorderColor, ";\n\n &:hover {\n background-color: ").concat(backgroundType === "dark" ? props.theme.secondaryHoverBackgroundColorOnDark : props.theme.secondaryHoverBackgroundColor, ";\n color: ").concat(backgroundType === "dark" ? props.theme.secondaryHoverFontColorOnDark : props.theme.secondaryHoverFontColor, " !important;\n }\n &:active {\n background-color: ").concat(backgroundType === "dark" ? props.theme.secondaryActiveBackgroundColorOnDark : props.theme.secondaryActiveBackgroundColor, " !important;\n color: ").concat(backgroundType === "dark" ? props.theme.secondaryHoverFontColorOnDark : props.theme.secondaryHoverFontColor, " !important;\n border-color: transparent;\n box-shadow: 0 0 0 2px ").concat(backgroundType === "dark" ? props.theme.focusBorderColorOnDark : props.theme.focusBorderColor, ";\n }\n &:disabled {\n cursor: not-allowed;\n background-color: ").concat(backgroundType === "dark" ? props.theme.secondaryDisabledBackgroundColorOnDark : props.theme.secondaryDisabledBackgroundColor, " !important;\n color: ").concat(backgroundType === "dark" ? props.theme.secondaryDisabledFontColorOnDark : props.theme.secondaryDisabledFontColor, " !important;\n border-color: ").concat(backgroundType === "dark" ? props.theme.secondaryDisabledBorderColorOnDark : props.theme.secondaryDisabledBorderColor, ";\n }\n .MuiButton-label {\n z-index: 5;\n }\n ");
|
|
214
|
+
} else if (mode === "text") {
|
|
215
|
+
return "\n border-radius: ".concat(props.theme.textBorderRadius, ";\n border-width: ").concat(props.theme.textBorderThickness, ";\n border-style: ").concat(props.theme.textBorderStyle, ";\n font-family: ").concat(props.theme.textFontFamily, ";\n font-size: ").concat(props.theme.textFontSize, ";\n font-weight: ").concat(props.theme.textFontWeight, ";\n background-color: ").concat(backgroundType === "dark" ? props.theme.textBackgroundColorOnDark : props.theme.textBackgroundColor, ";\n color: ").concat(backgroundType === "dark" ? props.theme.textFontColorOnDark : props.theme.textFontColor, " !important;\n\n &:hover {\n background-color: ").concat(backgroundType === "dark" ? props.theme.textHoverBackgroundColorOnDark : props.theme.textHoverBackgroundColor, ";\n }\n &:active {\n background-color: ").concat(backgroundType === "dark" ? props.theme.textActiveBackgroundColorOnDark : props.theme.textActiveBackgroundColor, " !important;\n border-color: transparent;\n box-shadow: 0 0 0 2px ").concat(backgroundType === "dark" ? props.theme.focusBorderColorOnDark : props.theme.focusBorderColor, ";\n }\n &:disabled {\n cursor:not-allowed;\n color: ").concat(backgroundType === "dark" ? props.theme.textDisabledFontColorOnDark : props.theme.textDisabledFontColor, " !important;\n background-color: ").concat(backgroundType === "dark" ? props.theme.textDisabledBackgroundColorOnDark : props.theme.textDisabledBackgroundColor, ";\n }\n ");
|
|
216
|
+
}
|
|
217
|
+
});
|
|
218
|
+
|
|
219
|
+
DxcButton.propTypes = {
|
|
220
|
+
size: _propTypes["default"].oneOf((0, _toConsumableArray2["default"])(Object.keys(sizes))),
|
|
221
|
+
margin: _propTypes["default"].oneOfType([_propTypes["default"].shape({
|
|
222
|
+
top: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
|
|
223
|
+
bottom: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
|
|
224
|
+
left: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
|
|
225
|
+
right: _propTypes["default"].oneOf(Object.keys(_variables.spaces))
|
|
226
|
+
}), _propTypes["default"].oneOf((0, _toConsumableArray2["default"])(Object.keys(_variables.spaces)))]),
|
|
227
|
+
label: _propTypes["default"].string,
|
|
228
|
+
mode: _propTypes["default"].oneOf(["primary", "secondary", "text"]),
|
|
229
|
+
disabled: _propTypes["default"].bool,
|
|
230
|
+
iconPosition: _propTypes["default"].oneOf(["after", "before"]),
|
|
231
|
+
onClick: _propTypes["default"].func,
|
|
232
|
+
iconSrc: _propTypes["default"].string,
|
|
233
|
+
icon: _propTypes["default"].oneOfType([_propTypes["default"].element, _propTypes["default"].func]),
|
|
234
|
+
type: _propTypes["default"].oneOf(["button", "reset", "submit"]),
|
|
235
|
+
tabIndex: _propTypes["default"].number
|
|
236
|
+
};
|
|
237
|
+
var _default = DxcButton;
|
|
238
|
+
exports["default"] = _default;
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports.Primary = exports["default"] = void 0;
|
|
9
|
+
|
|
10
|
+
var _react = _interopRequireDefault(require("react"));
|
|
11
|
+
|
|
12
|
+
var _Button = _interopRequireDefault(require("./Button"));
|
|
13
|
+
|
|
14
|
+
var _default = {
|
|
15
|
+
title: "Button",
|
|
16
|
+
component: _Button["default"]
|
|
17
|
+
};
|
|
18
|
+
exports["default"] = _default;
|
|
19
|
+
|
|
20
|
+
var Primary = function Primary() {
|
|
21
|
+
return _react["default"].createElement(_Button["default"], {
|
|
22
|
+
mode: "primary",
|
|
23
|
+
label: "Primary Button"
|
|
24
|
+
});
|
|
25
|
+
};
|
|
26
|
+
|
|
27
|
+
exports.Primary = Primary;
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
type Size = "small" | "medium" | "large" | "fillParent" | "fitContent";
|
|
2
|
+
type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
|
|
3
|
+
type Margin = {
|
|
4
|
+
top?: Space;
|
|
5
|
+
bottom?: Space;
|
|
6
|
+
left?: Space;
|
|
7
|
+
right?: Space;
|
|
8
|
+
};
|
|
9
|
+
|
|
10
|
+
type Props = {
|
|
11
|
+
label?: string;
|
|
12
|
+
mode?: "primary" | "secondary" | "text";
|
|
13
|
+
disabled?: boolean;
|
|
14
|
+
iconPosition?: "before" | "after";
|
|
15
|
+
type?: "button" | "reset" | "submit";
|
|
16
|
+
iconSrc?: string;
|
|
17
|
+
icon?: any;
|
|
18
|
+
onClick?: void;
|
|
19
|
+
margin?: Space | Margin;
|
|
20
|
+
size?: Size;
|
|
21
|
+
tabIndex?: number;
|
|
22
|
+
};
|
|
23
|
+
|
|
24
|
+
export default function DxcButton(props: Props): JSX.Element;
|
|
@@ -19,12 +19,14 @@ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/sli
|
|
|
19
19
|
|
|
20
20
|
var _react = _interopRequireWildcard(require("react"));
|
|
21
21
|
|
|
22
|
-
var _styledComponents =
|
|
22
|
+
var _styledComponents = _interopRequireWildcard(require("styled-components"));
|
|
23
23
|
|
|
24
24
|
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
25
25
|
|
|
26
26
|
var _variables = require("../common/variables.js");
|
|
27
27
|
|
|
28
|
+
var _useTheme = _interopRequireDefault(require("../useTheme.js"));
|
|
29
|
+
|
|
28
30
|
var _Box = _interopRequireDefault(require("../box/Box"));
|
|
29
31
|
|
|
30
32
|
function _templateObject6() {
|
|
@@ -38,7 +40,7 @@ function _templateObject6() {
|
|
|
38
40
|
}
|
|
39
41
|
|
|
40
42
|
function _templateObject5() {
|
|
41
|
-
var data = (0, _taggedTemplateLiteral2["default"])(["\n width:
|
|
43
|
+
var data = (0, _taggedTemplateLiteral2["default"])(["\n width: 35%;\n height: 100%;\n flex-shrink: 0;\n background: ", ";\n justify-content: center;\n align-items: center;\n display: inline-flex;\n"]);
|
|
42
44
|
|
|
43
45
|
_templateObject5 = function _templateObject5() {
|
|
44
46
|
return data;
|
|
@@ -58,7 +60,7 @@ function _templateObject4() {
|
|
|
58
60
|
}
|
|
59
61
|
|
|
60
62
|
function _templateObject3() {
|
|
61
|
-
var data = (0, _taggedTemplateLiteral2["default"])(["\n cursor: pointer;\n text-decoration:
|
|
63
|
+
var data = (0, _taggedTemplateLiteral2["default"])(["\n cursor: pointer;\n text-decoration: none;\n"]);
|
|
62
64
|
|
|
63
65
|
_templateObject3 = function _templateObject3() {
|
|
64
66
|
return data;
|
|
@@ -68,7 +70,7 @@ function _templateObject3() {
|
|
|
68
70
|
}
|
|
69
71
|
|
|
70
72
|
function _templateObject2() {
|
|
71
|
-
var data = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n flex-direction: ", ";\n height:
|
|
73
|
+
var data = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n flex-direction: ", ";\n height: ", ";\n width: ", ";\n &:hover {\n border-color: ", ";\n }\n"]);
|
|
72
74
|
|
|
73
75
|
_templateObject2 = function _templateObject2() {
|
|
74
76
|
return data;
|
|
@@ -101,6 +103,7 @@ var DxcCard = function DxcCard(_ref) {
|
|
|
101
103
|
imageCover = _ref.imageCover,
|
|
102
104
|
_ref$tabIndex = _ref.tabIndex,
|
|
103
105
|
tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
|
|
106
|
+
var colorsTheme = (0, _useTheme["default"])();
|
|
104
107
|
|
|
105
108
|
var _useState = (0, _react.useState)(false),
|
|
106
109
|
_useState2 = (0, _slicedToArray2["default"])(_useState, 2),
|
|
@@ -109,6 +112,8 @@ var DxcCard = function DxcCard(_ref) {
|
|
|
109
112
|
|
|
110
113
|
var tagContent = _react["default"].createElement(_Box["default"], {
|
|
111
114
|
shadowDepth: outlined ? 0 : isHovered && (onClick || linkHref) ? 2 : 1
|
|
115
|
+
}, _react["default"].createElement(_styledComponents.ThemeProvider, {
|
|
116
|
+
theme: colorsTheme.card
|
|
112
117
|
}, _react["default"].createElement(CardContainer, {
|
|
113
118
|
hasAction: onClick || linkHref,
|
|
114
119
|
outlined: outlined,
|
|
@@ -121,7 +126,7 @@ var DxcCard = function DxcCard(_ref) {
|
|
|
121
126
|
src: imageSrc
|
|
122
127
|
})), _react["default"].createElement(CardContent, {
|
|
123
128
|
contentPadding: contentPadding
|
|
124
|
-
}, children)));
|
|
129
|
+
}, children))));
|
|
125
130
|
|
|
126
131
|
return _react["default"].createElement(StyledDxcCard, {
|
|
127
132
|
margin: margin,
|
|
@@ -166,14 +171,16 @@ var StyledDxcCard = _styledComponents["default"].div(_templateObject(), function
|
|
|
166
171
|
var CardContainer = _styledComponents["default"].div(_templateObject2(), function (_ref9) {
|
|
167
172
|
var imagePosition = _ref9.imagePosition;
|
|
168
173
|
return imagePosition === "before" && "row" || "row-reverse";
|
|
174
|
+
}, function (props) {
|
|
175
|
+
return props.theme.height;
|
|
176
|
+
}, function (props) {
|
|
177
|
+
return props.theme.width;
|
|
169
178
|
}, function (_ref10) {
|
|
170
179
|
var hasAction = _ref10.hasAction;
|
|
171
|
-
return hasAction ? "
|
|
180
|
+
return hasAction ? "" : "unset";
|
|
172
181
|
});
|
|
173
182
|
|
|
174
|
-
var StyledLink = _styledComponents["default"].a(_templateObject3()
|
|
175
|
-
return props.theme.textDecoration;
|
|
176
|
-
});
|
|
183
|
+
var StyledLink = _styledComponents["default"].a(_templateObject3());
|
|
177
184
|
|
|
178
185
|
var TagImage = _styledComponents["default"].img(_templateObject4(), function (_ref11) {
|
|
179
186
|
var imagePadding = _ref11.imagePadding;
|
package/card/index.d.ts
ADDED
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
|
|
2
|
+
type Margin = {
|
|
3
|
+
top?: Space;
|
|
4
|
+
bottom?: Space;
|
|
5
|
+
left?: Space;
|
|
6
|
+
right?: Space;
|
|
7
|
+
};
|
|
8
|
+
|
|
9
|
+
type Props = {
|
|
10
|
+
imageSrc?: string;
|
|
11
|
+
margin?: Space | Margin;
|
|
12
|
+
contentPadding?: any;
|
|
13
|
+
linkHref?: string;
|
|
14
|
+
onClick?: void;
|
|
15
|
+
imageBgColor?: string;
|
|
16
|
+
imagePadding?: any;
|
|
17
|
+
imagePosition?: "before" | "after";
|
|
18
|
+
outlined?: boolean;
|
|
19
|
+
imageCover?: boolean;
|
|
20
|
+
};
|
|
21
|
+
|
|
22
|
+
export default function DxcCard(props: Props): JSX.Element;
|
|
@@ -33,8 +33,10 @@ var _utils = require("../common/utils.js");
|
|
|
33
33
|
|
|
34
34
|
var _useTheme = _interopRequireDefault(require("../useTheme.js"));
|
|
35
35
|
|
|
36
|
+
var _BackgroundColorContext = _interopRequireDefault(require("../BackgroundColorContext.js"));
|
|
37
|
+
|
|
36
38
|
function _templateObject3() {
|
|
37
|
-
var data = (0, _taggedTemplateLiteral2["default"])(["\n background-color: ", ";\n width:
|
|
39
|
+
var data = (0, _taggedTemplateLiteral2["default"])(["\n background-color: ", ";\n width: 16px;\n height: 16px;\n position: absolute;\n left: ", ";\n right: ", ";\n z-index: 0;\n margin-left: ", ";\n margin-right: ", ";\n"]);
|
|
38
40
|
|
|
39
41
|
_templateObject3 = function _templateObject3() {
|
|
40
42
|
return data;
|
|
@@ -44,7 +46,7 @@ function _templateObject3() {
|
|
|
44
46
|
}
|
|
45
47
|
|
|
46
48
|
function _templateObject2() {
|
|
47
|
-
var data = (0, _taggedTemplateLiteral2["default"])(["\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n width: ", ";\n display: inline-flex;\n align-items: center;\n cursor: ", ";\n position: relative;\n flex-direction: ", ";\n .MuiCheckbox-colorSecondary {\n &.Mui-checked {\n color: ", ";\n &:hover {\n background-color: transparent;\n }\n }\n }\n .MuiIconButton-colorSecondary {\n &:hover {\n background-color: transparent;\n }\n }\n .MuiButtonBase-root {\n
|
|
49
|
+
var data = (0, _taggedTemplateLiteral2["default"])(["\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n width: ", ";\n display: inline-flex;\n align-items: center;\n cursor: ", ";\n position: relative;\n flex-direction: ", ";\n .MuiCheckbox-colorSecondary {\n .MuiIconButton-label {\n & > .MuiSvgIcon-root {\n color: ", ";\n }\n }\n &.Mui-disabled {\n .MuiIconButton-label {\n & > .MuiSvgIcon-root {\n color: ", ";\n opacity: 0.34;\n }\n }\n }\n &.Mui-checked {\n .MuiIconButton-label {\n & > .MuiSvgIcon-root {\n color: ", ";\n }\n }\n\n &:hover {\n background-color: transparent;\n .MuiIconButton-label {\n & > .MuiSvgIcon-root {\n background-color: transparent;\n color: ", ";\n }\n }\n }\n }\n .MuiIconButton-label {\n & > .MuiSvgIcon-root {\n width: 24px;\n height: 24px;\n }\n }\n }\n\n .MuiIconButton-colorSecondary {\n &:hover {\n background-color: transparent;\n }\n }\n .MuiButtonBase-root {\n &:hover {\n .MuiIconButton-label {\n & > .MuiSvgIcon-root {\n color: ", ";\n }\n }\n }\n\n &.Mui-focusVisible {\n .MuiIconButton-label {\n box-shadow: 0 0 0 2px\n ", ";\n }\n }\n z-index: 1;\n margin-left: ", ";\n margin-right: ", ";\n padding: 0px;\n left: ", ";\n right: ", ";\n }\n"]);
|
|
48
50
|
|
|
49
51
|
_templateObject2 = function _templateObject2() {
|
|
50
52
|
return data;
|
|
@@ -54,7 +56,7 @@ function _templateObject2() {
|
|
|
54
56
|
}
|
|
55
57
|
|
|
56
58
|
function _templateObject() {
|
|
57
|
-
var data = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n
|
|
59
|
+
var data = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n cursor: ", ";\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n"]);
|
|
58
60
|
|
|
59
61
|
_templateObject = function _templateObject() {
|
|
60
62
|
return data;
|
|
@@ -88,7 +90,13 @@ var DxcCheckbox = function DxcCheckbox(_ref) {
|
|
|
88
90
|
innerChecked = _useState2[0],
|
|
89
91
|
setInnerChecked = _useState2[1];
|
|
90
92
|
|
|
93
|
+
var _useState3 = (0, _react.useState)(false),
|
|
94
|
+
_useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
|
|
95
|
+
isLabelHovered = _useState4[0],
|
|
96
|
+
setIsLabelHovered = _useState4[1];
|
|
97
|
+
|
|
91
98
|
var colorsTheme = (0, _useTheme["default"])();
|
|
99
|
+
var backgroundType = (0, _react.useContext)(_BackgroundColorContext["default"]);
|
|
92
100
|
|
|
93
101
|
var handlerCheckboxChange = function handlerCheckboxChange(checkboxValue) {
|
|
94
102
|
if (checked === undefined) {
|
|
@@ -105,19 +113,29 @@ var DxcCheckbox = function DxcCheckbox(_ref) {
|
|
|
105
113
|
}
|
|
106
114
|
};
|
|
107
115
|
|
|
116
|
+
var handleLabelHover = function handleLabelHover() {
|
|
117
|
+
setIsLabelHovered(!isLabelHovered);
|
|
118
|
+
};
|
|
119
|
+
|
|
108
120
|
return _react["default"].createElement(_styledComponents.ThemeProvider, {
|
|
109
121
|
theme: colorsTheme.checkbox
|
|
110
122
|
}, _react["default"].createElement(CheckboxContainer, {
|
|
111
123
|
id: name,
|
|
112
124
|
brightness: _variables.componentTokens,
|
|
125
|
+
label: label,
|
|
113
126
|
labelPosition: labelPosition,
|
|
114
127
|
disabled: disabled,
|
|
115
128
|
margin: margin,
|
|
116
|
-
size: size
|
|
129
|
+
size: size,
|
|
130
|
+
backgroundType: backgroundType,
|
|
131
|
+
isLabelHovered: isLabelHovered
|
|
117
132
|
}, _react["default"].createElement(_Checkbox["default"], {
|
|
118
133
|
checked: checked != undefined ? checked : innerChecked,
|
|
119
|
-
inputProps:
|
|
120
|
-
name: name
|
|
134
|
+
inputProps: {
|
|
135
|
+
name: name,
|
|
136
|
+
"aria-label": label,
|
|
137
|
+
role: "checkbox",
|
|
138
|
+
"aria-checked": checked != undefined ? checked : innerChecked
|
|
121
139
|
},
|
|
122
140
|
onChange: handlerCheckboxChange,
|
|
123
141
|
value: value,
|
|
@@ -128,12 +146,16 @@ var DxcCheckbox = function DxcCheckbox(_ref) {
|
|
|
128
146
|
}), _react["default"].createElement(CheckboxBlackBack, {
|
|
129
147
|
labelPosition: labelPosition,
|
|
130
148
|
disabled: disabled,
|
|
131
|
-
checked: checked != undefined ? checked : innerChecked
|
|
149
|
+
checked: checked != undefined ? checked : innerChecked,
|
|
150
|
+
backgroundType: backgroundType
|
|
132
151
|
}), required && _react["default"].createElement(_RequiredComponent["default"], null), label && _react["default"].createElement(LabelContainer, {
|
|
133
152
|
labelPosition: labelPosition,
|
|
134
153
|
onClick: disabled === true ? function (e) {} : handlerCheckboxChange,
|
|
135
154
|
disabled: disabled,
|
|
136
|
-
className: "labelContainer"
|
|
155
|
+
className: "labelContainer",
|
|
156
|
+
backgroundType: backgroundType,
|
|
157
|
+
onMouseOver: handleLabelHover,
|
|
158
|
+
onMouseOut: handleLabelHover
|
|
137
159
|
}, label)));
|
|
138
160
|
};
|
|
139
161
|
|
|
@@ -153,14 +175,56 @@ var calculateWidth = function calculateWidth(margin, size) {
|
|
|
153
175
|
return sizes[size];
|
|
154
176
|
};
|
|
155
177
|
|
|
178
|
+
var getDisabledColor = function getDisabledColor(props, element) {
|
|
179
|
+
switch (element) {
|
|
180
|
+
case "check":
|
|
181
|
+
return props.backgroundType && props.backgroundType === "dark" ? props.theme.disabledCheckColorOnDark : props.theme.disabledCheckColor;
|
|
182
|
+
break;
|
|
183
|
+
|
|
184
|
+
case "background":
|
|
185
|
+
return props.backgroundType && props.backgroundType === "dark" ? props.theme.disabledBackgroundColorCheckedOnDark : props.theme.disabledBackgroundColorChecked;
|
|
186
|
+
break;
|
|
187
|
+
|
|
188
|
+
case "border":
|
|
189
|
+
return props.backgroundType && props.backgroundType === "dark" ? props.theme.disabledBorderColorOnDark : props.theme.disabledBorderColor;
|
|
190
|
+
break;
|
|
191
|
+
|
|
192
|
+
case "label":
|
|
193
|
+
return props.backgroundType && props.backgroundType === "dark" ? props.theme.disabledFontColorOnDark : props.theme.disabledFontColor;
|
|
194
|
+
break;
|
|
195
|
+
}
|
|
196
|
+
};
|
|
197
|
+
|
|
198
|
+
var getNotDisabledColor = function getNotDisabledColor(props, element) {
|
|
199
|
+
switch (element) {
|
|
200
|
+
case "check":
|
|
201
|
+
return props.backgroundType && props.backgroundType === "dark" ? props.theme.checkColorOnDark : props.theme.checkColor;
|
|
202
|
+
break;
|
|
203
|
+
|
|
204
|
+
case "background":
|
|
205
|
+
return props.backgroundType && props.backgroundType === "dark" ? props.theme.backgroundColorCheckedOnDark : props.theme.backgroundColorChecked;
|
|
206
|
+
break;
|
|
207
|
+
|
|
208
|
+
case "border":
|
|
209
|
+
return props.backgroundType && props.backgroundType === "dark" ? props.theme.borderColorOnDark : props.theme.borderColor;
|
|
210
|
+
break;
|
|
211
|
+
|
|
212
|
+
case "label":
|
|
213
|
+
return props.backgroundType && props.backgroundType === "dark" ? props.theme.fontColorOnDark : props.theme.fontColor;
|
|
214
|
+
break;
|
|
215
|
+
}
|
|
216
|
+
};
|
|
217
|
+
|
|
156
218
|
var LabelContainer = _styledComponents["default"].span(_templateObject(), function (props) {
|
|
157
|
-
return props.
|
|
158
|
-
}, function (props) {
|
|
159
|
-
return props.disabled && "0.34";
|
|
219
|
+
return props.disabled ? getDisabledColor(props, "label") : getNotDisabledColor(props, "label");
|
|
160
220
|
}, function (props) {
|
|
161
221
|
return props.disabled ? "not-allowed" : "pointer";
|
|
162
222
|
}, function (props) {
|
|
163
223
|
return props.theme.fontFamily;
|
|
224
|
+
}, function (props) {
|
|
225
|
+
return props.theme.fontSize;
|
|
226
|
+
}, function (props) {
|
|
227
|
+
return props.theme.fontWeight;
|
|
164
228
|
});
|
|
165
229
|
|
|
166
230
|
var CheckboxContainer = _styledComponents["default"].span(_templateObject2(), function (props) {
|
|
@@ -180,23 +244,29 @@ var CheckboxContainer = _styledComponents["default"].span(_templateObject2(), fu
|
|
|
180
244
|
}, function (props) {
|
|
181
245
|
return props.labelPosition === "before" ? "row-reverse" : "row";
|
|
182
246
|
}, function (props) {
|
|
183
|
-
return props.
|
|
247
|
+
return props.isLabelHovered ? props.backgroundType === "dark" ? props.theme.hoverBorderColorOnDark : props.theme.hoverBorderColor : getNotDisabledColor(props, "border");
|
|
184
248
|
}, function (props) {
|
|
185
|
-
return props
|
|
249
|
+
return getDisabledColor(props, "border");
|
|
186
250
|
}, function (props) {
|
|
187
|
-
return props.
|
|
251
|
+
return props.disabled ? getDisabledColor(props, "background") : getNotDisabledColor(props, "background");
|
|
188
252
|
}, function (props) {
|
|
189
|
-
return props.
|
|
253
|
+
return props.backgroundType === "dark" ? props.theme.hoverBackgroundColorCheckedOnDark : props.theme.hoverBackgroundColorChecked;
|
|
190
254
|
}, function (props) {
|
|
191
|
-
return props.
|
|
255
|
+
return props.backgroundType === "dark" ? props.theme.hoverBorderColorOnDark : props.theme.hoverBorderColor;
|
|
192
256
|
}, function (props) {
|
|
193
|
-
return props.
|
|
257
|
+
return props.backgroundType === "dark" ? props.theme.focusColorOnDark : props.theme.focusColor;
|
|
194
258
|
}, function (props) {
|
|
195
|
-
return props.
|
|
259
|
+
return props.labelPosition === "before" && props.label ? props.theme.checkLabelSpacing : "0";
|
|
260
|
+
}, function (props) {
|
|
261
|
+
return props.labelPosition === "after" && props.label ? props.theme.checkLabelSpacing : "0";
|
|
262
|
+
}, function (props) {
|
|
263
|
+
return props.labelPosition === "before" ? "unset" : "1px";
|
|
264
|
+
}, function (props) {
|
|
265
|
+
return props.labelPosition === "before" ? "1px" : "unset";
|
|
196
266
|
});
|
|
197
267
|
|
|
198
268
|
var CheckboxBlackBack = _styledComponents["default"].span(_templateObject3(), function (props) {
|
|
199
|
-
return props.checked
|
|
269
|
+
return !props.checked ? "transparent" : props.disabled ? getDisabledColor(props, "check") : getNotDisabledColor(props, "check");
|
|
200
270
|
}, function (props) {
|
|
201
271
|
return props.labelPosition === "before" ? "unset" : "5px";
|
|
202
272
|
}, function (props) {
|
|
@@ -205,10 +275,6 @@ var CheckboxBlackBack = _styledComponents["default"].span(_templateObject3(), fu
|
|
|
205
275
|
return props.labelPosition === "after" ? "0px" : "";
|
|
206
276
|
}, function (props) {
|
|
207
277
|
return props.labelPosition === "before" ? "0px" : "";
|
|
208
|
-
}, function (props) {
|
|
209
|
-
return props.labelPosition === "after" ? "0px" : "";
|
|
210
|
-
}, function (props) {
|
|
211
|
-
return props.labelPosition === "before" ? "0px" : "";
|
|
212
278
|
});
|
|
213
279
|
|
|
214
280
|
DxcCheckbox.propTypes = {
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
type Size = "small" | "medium" | "large" | "fillParent" | "fitContent";
|
|
2
|
+
type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
|
|
3
|
+
type Margin = {
|
|
4
|
+
top?: Space;
|
|
5
|
+
bottom?: Space;
|
|
6
|
+
left?: Space;
|
|
7
|
+
right?: Space;
|
|
8
|
+
};
|
|
9
|
+
|
|
10
|
+
type Props = {
|
|
11
|
+
checked?: boolean;
|
|
12
|
+
value?: any;
|
|
13
|
+
label?: string;
|
|
14
|
+
labelPosition?: "before" | "after";
|
|
15
|
+
name?: string,
|
|
16
|
+
disabled?: boolean;
|
|
17
|
+
onChange?: void;
|
|
18
|
+
required?: boolean;
|
|
19
|
+
margin?: Space | Margin;
|
|
20
|
+
size?: Size;
|
|
21
|
+
tabIndex?: number;
|
|
22
|
+
};
|
|
23
|
+
|
|
24
|
+
export default function DxcCheckbox(props: Props): JSX.Element;
|