@dxc-technology/halstack-react 0.0.0-ba408d4 → 0.0.0-bb8df10
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 +10 -0
- package/BackgroundColorContext.js +1 -4
- package/HalstackContext.d.ts +12 -0
- package/HalstackContext.js +295 -0
- package/accordion/Accordion.d.ts +4 -0
- package/accordion/Accordion.js +18 -81
- package/accordion/Accordion.stories.tsx +307 -0
- package/accordion/Accordion.test.js +72 -0
- package/accordion/types.d.ts +68 -0
- package/accordion/types.js +5 -0
- package/accordion-group/AccordionGroup.d.ts +7 -0
- package/accordion-group/AccordionGroup.js +61 -76
- package/accordion-group/AccordionGroup.stories.tsx +225 -0
- package/accordion-group/AccordionGroup.test.js +151 -0
- package/accordion-group/types.d.ts +72 -0
- package/accordion-group/types.js +5 -0
- package/alert/Alert.d.ts +4 -0
- package/alert/Alert.js +7 -23
- package/alert/Alert.stories.tsx +170 -0
- package/alert/Alert.test.js +92 -0
- package/alert/types.d.ts +49 -0
- package/alert/types.js +5 -0
- package/badge/Badge.d.ts +4 -0
- package/badge/Badge.js +6 -4
- package/badge/types.d.ts +5 -0
- package/badge/types.js +5 -0
- package/bleed/Bleed.d.ts +3 -0
- package/bleed/Bleed.js +51 -0
- package/bleed/Bleed.stories.tsx +341 -0
- package/bleed/types.d.ts +37 -0
- package/bleed/types.js +5 -0
- package/box/Box.d.ts +4 -0
- package/box/Box.js +28 -64
- package/box/Box.stories.tsx +132 -0
- package/box/Box.test.js +18 -0
- package/box/types.d.ts +43 -0
- package/box/types.js +5 -0
- package/bulleted-list/BulletedList.d.ts +7 -0
- package/bulleted-list/BulletedList.js +123 -0
- package/bulleted-list/BulletedList.stories.tsx +200 -0
- package/bulleted-list/types.d.ts +11 -0
- package/bulleted-list/types.js +5 -0
- package/button/Button.d.ts +1 -1
- package/button/Button.js +61 -87
- package/button/Button.stories.tsx +259 -282
- package/button/Button.test.js +35 -0
- package/button/types.d.ts +14 -18
- package/card/Card.d.ts +4 -0
- package/card/Card.js +38 -77
- package/card/Card.stories.tsx +201 -0
- package/card/Card.test.js +50 -0
- package/card/ice-cream.jpg +0 -0
- package/card/types.d.ts +67 -0
- package/card/types.js +5 -0
- package/checkbox/Checkbox.d.ts +4 -0
- package/checkbox/Checkbox.js +45 -63
- package/checkbox/Checkbox.stories.tsx +188 -0
- package/checkbox/Checkbox.test.js +78 -0
- package/checkbox/types.d.ts +64 -0
- package/checkbox/types.js +5 -0
- package/chip/Chip.d.ts +4 -0
- package/chip/Chip.js +16 -76
- package/chip/Chip.stories.tsx +119 -0
- package/chip/Chip.test.js +56 -0
- package/chip/types.d.ts +45 -0
- package/chip/types.js +5 -0
- package/common/variables.js +316 -377
- package/date-input/DateInput.d.ts +4 -0
- package/date-input/DateInput.js +65 -89
- package/date-input/DateInput.stories.tsx +138 -0
- package/date-input/DateInput.test.js +479 -0
- package/date-input/types.d.ts +107 -0
- package/date-input/types.js +5 -0
- package/dialog/Dialog.d.ts +4 -0
- package/dialog/Dialog.js +52 -74
- package/dialog/Dialog.stories.tsx +211 -0
- package/dialog/Dialog.test.js +70 -0
- package/dialog/types.d.ts +43 -0
- package/dialog/types.js +5 -0
- package/dropdown/Dropdown.d.ts +4 -0
- package/dropdown/Dropdown.js +239 -302
- package/dropdown/Dropdown.stories.tsx +312 -0
- package/dropdown/Dropdown.test.js +591 -0
- package/dropdown/DropdownMenu.d.ts +4 -0
- package/dropdown/DropdownMenu.js +80 -0
- package/dropdown/DropdownMenuItem.d.ts +4 -0
- package/dropdown/DropdownMenuItem.js +92 -0
- package/dropdown/types.d.ts +100 -0
- package/dropdown/types.js +5 -0
- package/file-input/FileInput.d.ts +4 -0
- package/file-input/FileInput.js +172 -111
- package/file-input/FileInput.stories.tsx +507 -0
- package/file-input/FileInput.test.js +457 -0
- package/file-input/FileItem.d.ts +14 -0
- package/file-input/FileItem.js +16 -23
- package/file-input/types.d.ts +112 -0
- package/file-input/types.js +5 -0
- package/flex/Flex.d.ts +4 -0
- package/flex/Flex.js +57 -0
- package/flex/Flex.stories.tsx +103 -0
- package/flex/types.d.ts +21 -0
- package/flex/types.js +5 -0
- package/footer/Footer.d.ts +4 -0
- package/footer/Footer.js +36 -148
- package/footer/Footer.stories.tsx +130 -0
- package/footer/Footer.test.js +109 -0
- package/footer/Icons.d.ts +2 -0
- package/footer/Icons.js +4 -4
- package/footer/types.d.ts +65 -0
- package/footer/types.js +5 -0
- package/header/Header.d.ts +7 -0
- package/header/Header.js +119 -140
- package/header/Header.stories.tsx +172 -0
- package/header/Header.test.js +79 -0
- package/header/Icons.d.ts +2 -0
- package/header/Icons.js +4 -29
- package/header/types.d.ts +47 -0
- package/header/types.js +5 -0
- package/heading/Heading.d.ts +4 -0
- package/heading/Heading.js +7 -24
- package/heading/Heading.stories.tsx +54 -0
- package/heading/Heading.test.js +186 -0
- package/heading/types.d.ts +33 -0
- package/heading/types.js +5 -0
- package/inset/Inset.d.ts +3 -0
- package/inset/Inset.js +51 -0
- package/inset/Inset.stories.tsx +229 -0
- package/inset/types.d.ts +37 -0
- package/inset/types.js +5 -0
- package/layout/ApplicationLayout.d.ts +20 -0
- package/layout/ApplicationLayout.js +71 -135
- package/layout/ApplicationLayout.stories.tsx +161 -0
- package/layout/Icons.d.ts +5 -0
- package/layout/Icons.js +13 -2
- package/layout/SidenavContext.d.ts +5 -0
- package/layout/SidenavContext.js +19 -0
- package/layout/types.d.ts +42 -0
- package/layout/types.js +5 -0
- package/link/Link.d.ts +4 -0
- package/link/Link.js +60 -107
- package/link/Link.stories.tsx +193 -0
- package/link/Link.test.js +83 -0
- package/link/types.d.ts +54 -0
- package/link/types.js +5 -0
- package/main.d.ts +12 -12
- package/main.js +64 -58
- package/number-input/NumberInput.d.ts +4 -0
- package/number-input/NumberInput.js +16 -68
- package/number-input/NumberInput.stories.tsx +115 -0
- package/number-input/NumberInput.test.js +506 -0
- package/number-input/NumberInputContext.d.ts +4 -0
- package/number-input/NumberInputContext.js +5 -2
- package/number-input/numberInputContextTypes.d.ts +19 -0
- package/number-input/numberInputContextTypes.js +5 -0
- package/number-input/types.d.ts +124 -0
- package/number-input/types.js +5 -0
- package/package.json +17 -13
- package/paginator/Paginator.js +19 -46
- package/paginator/Paginator.stories.tsx +63 -0
- package/paginator/Paginator.test.js +308 -0
- package/paragraph/Paragraph.d.ts +6 -0
- package/paragraph/Paragraph.js +38 -0
- package/paragraph/Paragraph.stories.tsx +44 -0
- package/password-input/PasswordInput.d.ts +4 -0
- package/password-input/PasswordInput.js +24 -57
- package/password-input/PasswordInput.stories.tsx +131 -0
- package/password-input/PasswordInput.test.js +180 -0
- package/password-input/types.d.ts +110 -0
- package/password-input/types.js +5 -0
- package/progress-bar/ProgressBar.d.ts +4 -0
- package/progress-bar/ProgressBar.js +60 -72
- package/progress-bar/ProgressBar.stories.jsx +60 -0
- package/progress-bar/ProgressBar.test.js +110 -0
- package/progress-bar/types.d.ts +36 -0
- package/progress-bar/types.js +5 -0
- package/quick-nav/QuickNav.d.ts +4 -0
- package/quick-nav/QuickNav.js +118 -0
- package/quick-nav/QuickNav.stories.tsx +264 -0
- package/quick-nav/types.d.ts +21 -0
- package/quick-nav/types.js +5 -0
- package/radio-group/Radio.d.ts +4 -0
- package/radio-group/Radio.js +141 -0
- package/radio-group/RadioGroup.d.ts +4 -0
- package/radio-group/RadioGroup.js +281 -0
- package/radio-group/RadioGroup.stories.tsx +100 -0
- package/radio-group/RadioGroup.test.js +695 -0
- package/radio-group/types.d.ts +114 -0
- package/radio-group/types.js +5 -0
- package/resultsetTable/ResultsetTable.d.ts +4 -0
- package/resultsetTable/ResultsetTable.js +9 -29
- package/resultsetTable/ResultsetTable.stories.tsx +275 -0
- package/resultsetTable/ResultsetTable.test.js +348 -0
- package/resultsetTable/types.d.ts +67 -0
- package/resultsetTable/types.js +5 -0
- package/select/Icons.d.ts +10 -0
- package/select/Icons.js +93 -0
- package/select/Listbox.d.ts +4 -0
- package/select/Listbox.js +199 -0
- package/select/Option.d.ts +4 -0
- package/select/Option.js +110 -0
- package/select/Select.d.ts +4 -0
- package/select/Select.js +158 -380
- package/select/Select.stories.tsx +627 -0
- package/select/Select.test.js +2175 -0
- package/select/types.d.ts +210 -0
- package/select/types.js +5 -0
- package/sidenav/Sidenav.d.ts +10 -0
- package/sidenav/Sidenav.js +186 -63
- package/sidenav/Sidenav.stories.tsx +180 -0
- package/sidenav/Sidenav.test.js +44 -0
- package/sidenav/types.d.ts +73 -0
- package/sidenav/types.js +5 -0
- package/slider/Slider.d.ts +4 -0
- package/slider/Slider.js +147 -154
- package/slider/Slider.stories.tsx +183 -0
- package/slider/Slider.test.js +250 -0
- package/slider/types.d.ts +82 -0
- package/slider/types.js +5 -0
- package/spinner/Spinner.d.ts +4 -0
- package/spinner/Spinner.js +9 -26
- package/spinner/Spinner.stories.jsx +103 -0
- package/spinner/Spinner.test.js +64 -0
- package/spinner/types.d.ts +32 -0
- package/spinner/types.js +5 -0
- package/switch/Switch.d.ts +4 -0
- package/switch/Switch.js +129 -86
- package/switch/Switch.stories.tsx +138 -0
- package/switch/Switch.test.js +212 -0
- package/switch/types.d.ts +61 -0
- package/switch/types.js +5 -0
- package/table/Table.d.ts +4 -0
- package/table/Table.js +3 -3
- package/table/Table.stories.jsx +277 -0
- package/table/Table.test.js +26 -0
- package/table/types.d.ts +21 -0
- package/table/types.js +5 -0
- package/tabs/Tab.d.ts +4 -0
- package/tabs/Tab.js +135 -0
- package/tabs/Tabs.d.ts +4 -0
- package/tabs/Tabs.js +364 -156
- package/tabs/Tabs.stories.tsx +186 -0
- package/tabs/Tabs.test.js +351 -0
- package/tabs/types.d.ts +92 -0
- package/tabs/types.js +5 -0
- package/tabs-nav/NavTabs.d.ts +8 -0
- package/tabs-nav/NavTabs.js +125 -0
- package/tabs-nav/NavTabs.stories.tsx +170 -0
- package/tabs-nav/NavTabs.test.js +82 -0
- package/tabs-nav/Tab.d.ts +4 -0
- package/tabs-nav/Tab.js +130 -0
- package/tabs-nav/types.d.ts +53 -0
- package/tabs-nav/types.js +5 -0
- package/tag/Tag.d.ts +4 -0
- package/tag/Tag.js +34 -59
- package/tag/Tag.stories.tsx +142 -0
- package/tag/Tag.test.js +60 -0
- package/tag/types.d.ts +69 -0
- package/tag/types.js +5 -0
- package/text-input/Suggestion.d.ts +4 -0
- package/text-input/Suggestion.js +55 -0
- package/text-input/TextInput.d.ts +4 -0
- package/text-input/TextInput.js +103 -167
- package/text-input/TextInput.stories.tsx +473 -0
- package/text-input/TextInput.test.js +1712 -0
- package/text-input/types.d.ts +178 -0
- package/text-input/types.js +5 -0
- package/textarea/Textarea.d.ts +4 -0
- package/textarea/Textarea.js +39 -79
- package/textarea/Textarea.stories.jsx +157 -0
- package/textarea/Textarea.test.js +437 -0
- package/textarea/types.d.ts +137 -0
- package/textarea/types.js +5 -0
- package/toggle-group/ToggleGroup.d.ts +4 -0
- package/toggle-group/ToggleGroup.js +18 -46
- package/toggle-group/ToggleGroup.stories.tsx +173 -0
- package/toggle-group/ToggleGroup.test.js +156 -0
- package/toggle-group/types.d.ts +105 -0
- package/toggle-group/types.js +5 -0
- package/typography/Typography.d.ts +4 -0
- package/typography/Typography.js +131 -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 +2 -0
- package/useTheme.js +2 -2
- package/useTranslatedLabels.d.ts +2 -0
- package/useTranslatedLabels.js +20 -0
- package/wizard/Wizard.d.ts +4 -0
- package/wizard/Wizard.js +118 -104
- package/wizard/Wizard.stories.tsx +233 -0
- package/wizard/Wizard.test.js +141 -0
- package/wizard/types.d.ts +65 -0
- package/wizard/types.js +5 -0
- package/ThemeContext.js +0 -246
- package/V3Select/V3Select.js +0 -455
- package/V3Select/index.d.ts +0 -27
- package/V3Textarea/V3Textarea.js +0 -260
- package/V3Textarea/index.d.ts +0 -27
- package/accordion/index.d.ts +0 -28
- package/accordion-group/index.d.ts +0 -16
- package/alert/index.d.ts +0 -51
- package/box/index.d.ts +0 -25
- package/card/index.d.ts +0 -22
- package/checkbox/index.d.ts +0 -24
- package/chip/index.d.ts +0 -22
- package/date/Date.js +0 -373
- package/date/index.d.ts +0 -27
- package/date-input/index.d.ts +0 -95
- package/dialog/index.d.ts +0 -18
- package/dropdown/index.d.ts +0 -26
- package/file-input/index.d.ts +0 -81
- package/footer/index.d.ts +0 -25
- package/header/index.d.ts +0 -25
- package/heading/index.d.ts +0 -17
- package/input-text/Icons.js +0 -22
- package/input-text/InputText.js +0 -611
- package/input-text/index.d.ts +0 -36
- package/link/index.d.ts +0 -23
- package/number-input/index.d.ts +0 -113
- package/password-input/index.d.ts +0 -94
- package/progress-bar/index.d.ts +0 -18
- package/radio/Radio.js +0 -195
- package/radio/index.d.ts +0 -23
- package/resultsetTable/index.d.ts +0 -19
- package/select/index.d.ts +0 -131
- package/sidenav/index.d.ts +0 -13
- package/slider/index.d.ts +0 -29
- package/spinner/index.d.ts +0 -17
- package/switch/index.d.ts +0 -24
- package/table/index.d.ts +0 -13
- package/tabs/index.d.ts +0 -19
- package/tag/index.d.ts +0 -24
- package/text-input/index.d.ts +0 -135
- package/textarea/index.d.ts +0 -117
- package/toggle/Toggle.js +0 -186
- package/toggle/index.d.ts +0 -21
- package/toggle-group/index.d.ts +0 -21
- package/upload/Upload.js +0 -201
- package/upload/buttons-upload/ButtonsUpload.js +0 -111
- package/upload/buttons-upload/Icons.js +0 -40
- package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
- package/upload/dragAndDropArea/Icons.js +0 -39
- package/upload/file-upload/FileToUpload.js +0 -115
- package/upload/file-upload/Icons.js +0 -66
- package/upload/files-upload/FilesToUpload.js +0 -109
- package/upload/index.d.ts +0 -15
- package/upload/transaction/Icons.js +0 -160
- package/upload/transaction/Transaction.js +0 -104
- package/upload/transactions/Transactions.js +0 -94
- package/wizard/Icons.js +0 -65
- package/wizard/index.d.ts +0 -18
package/checkbox/Checkbox.js
CHANGED
|
@@ -9,8 +9,6 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
9
9
|
});
|
|
10
10
|
exports["default"] = void 0;
|
|
11
11
|
|
|
12
|
-
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
|
|
13
|
-
|
|
14
12
|
var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
|
|
15
13
|
|
|
16
14
|
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
|
|
@@ -23,17 +21,17 @@ var _styledComponents = _interopRequireWildcard(require("styled-components"));
|
|
|
23
21
|
|
|
24
22
|
var _Checkbox = _interopRequireDefault(require("@material-ui/core/Checkbox"));
|
|
25
23
|
|
|
26
|
-
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
27
|
-
|
|
28
|
-
var _RequiredComponent = _interopRequireDefault(require("../common/RequiredComponent"));
|
|
29
|
-
|
|
30
24
|
var _variables = require("../common/variables.js");
|
|
31
25
|
|
|
32
26
|
var _utils = require("../common/utils.js");
|
|
33
27
|
|
|
34
|
-
var
|
|
28
|
+
var _uuid = require("uuid");
|
|
29
|
+
|
|
30
|
+
var _useTheme = _interopRequireDefault(require("../useTheme"));
|
|
35
31
|
|
|
36
|
-
var
|
|
32
|
+
var _useTranslatedLabels = _interopRequireDefault(require("../useTranslatedLabels"));
|
|
33
|
+
|
|
34
|
+
var _BackgroundColorContext = _interopRequireDefault(require("../BackgroundColorContext"));
|
|
37
35
|
|
|
38
36
|
var _templateObject, _templateObject2, _templateObject3;
|
|
39
37
|
|
|
@@ -43,6 +41,8 @@ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj &&
|
|
|
43
41
|
|
|
44
42
|
var DxcCheckbox = function DxcCheckbox(_ref) {
|
|
45
43
|
var checked = _ref.checked,
|
|
44
|
+
_ref$defaultChecked = _ref.defaultChecked,
|
|
45
|
+
defaultChecked = _ref$defaultChecked === void 0 ? false : _ref$defaultChecked,
|
|
46
46
|
value = _ref.value,
|
|
47
47
|
_ref$label = _ref.label,
|
|
48
48
|
label = _ref$label === void 0 ? "" : _ref$label,
|
|
@@ -52,27 +52,34 @@ var DxcCheckbox = function DxcCheckbox(_ref) {
|
|
|
52
52
|
name = _ref$name === void 0 ? "" : _ref$name,
|
|
53
53
|
_ref$disabled = _ref.disabled,
|
|
54
54
|
disabled = _ref$disabled === void 0 ? false : _ref$disabled,
|
|
55
|
+
_ref$optional = _ref.optional,
|
|
56
|
+
optional = _ref$optional === void 0 ? false : _ref$optional,
|
|
55
57
|
onChange = _ref.onChange,
|
|
56
|
-
_ref$required = _ref.required,
|
|
57
|
-
required = _ref$required === void 0 ? false : _ref$required,
|
|
58
58
|
margin = _ref.margin,
|
|
59
59
|
_ref$size = _ref.size,
|
|
60
60
|
size = _ref$size === void 0 ? "fitContent" : _ref$size,
|
|
61
61
|
_ref$tabIndex = _ref.tabIndex,
|
|
62
62
|
tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
|
|
63
63
|
|
|
64
|
-
var _useState = (0, _react.useState)(
|
|
65
|
-
_useState2 = (0, _slicedToArray2["default"])(_useState,
|
|
66
|
-
|
|
67
|
-
|
|
64
|
+
var _useState = (0, _react.useState)("checkbox-".concat((0, _uuid.v4)())),
|
|
65
|
+
_useState2 = (0, _slicedToArray2["default"])(_useState, 1),
|
|
66
|
+
switchId = _useState2[0];
|
|
67
|
+
|
|
68
|
+
var labelId = "label-".concat(switchId);
|
|
68
69
|
|
|
69
|
-
var _useState3 = (0, _react.useState)(
|
|
70
|
+
var _useState3 = (0, _react.useState)(defaultChecked),
|
|
70
71
|
_useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
|
|
71
|
-
|
|
72
|
-
|
|
72
|
+
innerChecked = _useState4[0],
|
|
73
|
+
setInnerChecked = _useState4[1];
|
|
74
|
+
|
|
75
|
+
var _useState5 = (0, _react.useState)(false),
|
|
76
|
+
_useState6 = (0, _slicedToArray2["default"])(_useState5, 2),
|
|
77
|
+
isLabelHovered = _useState6[0],
|
|
78
|
+
setIsLabelHovered = _useState6[1];
|
|
73
79
|
|
|
74
80
|
var colorsTheme = (0, _useTheme["default"])();
|
|
75
81
|
var backgroundType = (0, _react.useContext)(_BackgroundColorContext["default"]);
|
|
82
|
+
var translatedLabels = (0, _useTranslatedLabels["default"])();
|
|
76
83
|
|
|
77
84
|
var handlerCheckboxChange = function handlerCheckboxChange(checkboxValue) {
|
|
78
85
|
if (checked === undefined) {
|
|
@@ -93,6 +100,17 @@ var DxcCheckbox = function DxcCheckbox(_ref) {
|
|
|
93
100
|
setIsLabelHovered(!isLabelHovered);
|
|
94
101
|
};
|
|
95
102
|
|
|
103
|
+
var labelComponent = /*#__PURE__*/_react["default"].createElement(LabelContainer, {
|
|
104
|
+
id: labelId,
|
|
105
|
+
labelPosition: labelPosition,
|
|
106
|
+
onClick: disabled === true ? function () {} : handlerCheckboxChange,
|
|
107
|
+
disabled: disabled,
|
|
108
|
+
className: "labelContainer",
|
|
109
|
+
backgroundType: backgroundType,
|
|
110
|
+
onMouseOver: handleLabelHover,
|
|
111
|
+
onMouseOut: handleLabelHover
|
|
112
|
+
}, labelPosition === "before" ? /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, label, " ", optional && /*#__PURE__*/_react["default"].createElement("span", null, translatedLabels.formFields.optionalLabel)) : /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, optional && /*#__PURE__*/_react["default"].createElement("span", null, "(Optional)"), " ", label));
|
|
113
|
+
|
|
96
114
|
return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
|
|
97
115
|
theme: colorsTheme.checkbox
|
|
98
116
|
}, /*#__PURE__*/_react["default"].createElement(CheckboxContainer, {
|
|
@@ -105,13 +123,13 @@ var DxcCheckbox = function DxcCheckbox(_ref) {
|
|
|
105
123
|
size: size,
|
|
106
124
|
backgroundType: backgroundType,
|
|
107
125
|
isLabelHovered: isLabelHovered
|
|
108
|
-
}, /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
|
|
109
|
-
checked: checked
|
|
126
|
+
}, label && labelPosition === "before" && labelComponent, /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
|
|
127
|
+
checked: checked !== null && checked !== void 0 ? checked : innerChecked,
|
|
110
128
|
inputProps: {
|
|
111
129
|
name: name,
|
|
112
|
-
"aria-
|
|
130
|
+
"aria-labelledby": labelId,
|
|
113
131
|
role: "checkbox",
|
|
114
|
-
"aria-checked": checked
|
|
132
|
+
"aria-checked": checked !== null && checked !== void 0 ? checked : innerChecked
|
|
115
133
|
},
|
|
116
134
|
onChange: handlerCheckboxChange,
|
|
117
135
|
value: value,
|
|
@@ -122,17 +140,9 @@ var DxcCheckbox = function DxcCheckbox(_ref) {
|
|
|
122
140
|
}), /*#__PURE__*/_react["default"].createElement(CheckboxBlackBack, {
|
|
123
141
|
labelPosition: labelPosition,
|
|
124
142
|
disabled: disabled,
|
|
125
|
-
checked: checked
|
|
143
|
+
checked: checked !== null && checked !== void 0 ? checked : innerChecked,
|
|
126
144
|
backgroundType: backgroundType
|
|
127
|
-
}),
|
|
128
|
-
labelPosition: labelPosition,
|
|
129
|
-
onClick: disabled === true ? function (e) {} : handlerCheckboxChange,
|
|
130
|
-
disabled: disabled,
|
|
131
|
-
className: "labelContainer",
|
|
132
|
-
backgroundType: backgroundType,
|
|
133
|
-
onMouseOver: handleLabelHover,
|
|
134
|
-
onMouseOut: handleLabelHover
|
|
135
|
-
}, label)));
|
|
145
|
+
}), label && labelPosition === "after" && labelComponent));
|
|
136
146
|
};
|
|
137
147
|
|
|
138
148
|
var sizes = {
|
|
@@ -155,19 +165,15 @@ var getDisabledColor = function getDisabledColor(props, element) {
|
|
|
155
165
|
switch (element) {
|
|
156
166
|
case "check":
|
|
157
167
|
return props.backgroundType && props.backgroundType === "dark" ? props.theme.disabledCheckColorOnDark : props.theme.disabledCheckColor;
|
|
158
|
-
break;
|
|
159
168
|
|
|
160
169
|
case "background":
|
|
161
170
|
return props.backgroundType && props.backgroundType === "dark" ? props.theme.disabledBackgroundColorCheckedOnDark : props.theme.disabledBackgroundColorChecked;
|
|
162
|
-
break;
|
|
163
171
|
|
|
164
172
|
case "border":
|
|
165
173
|
return props.backgroundType && props.backgroundType === "dark" ? props.theme.disabledBorderColorOnDark : props.theme.disabledBorderColor;
|
|
166
|
-
break;
|
|
167
174
|
|
|
168
175
|
case "label":
|
|
169
176
|
return props.backgroundType && props.backgroundType === "dark" ? props.theme.disabledFontColorOnDark : props.theme.disabledFontColor;
|
|
170
|
-
break;
|
|
171
177
|
}
|
|
172
178
|
};
|
|
173
179
|
|
|
@@ -175,35 +181,31 @@ var getNotDisabledColor = function getNotDisabledColor(props, element) {
|
|
|
175
181
|
switch (element) {
|
|
176
182
|
case "check":
|
|
177
183
|
return props.backgroundType && props.backgroundType === "dark" ? props.theme.checkColorOnDark : props.theme.checkColor;
|
|
178
|
-
break;
|
|
179
184
|
|
|
180
185
|
case "background":
|
|
181
186
|
return props.backgroundType && props.backgroundType === "dark" ? props.theme.backgroundColorCheckedOnDark : props.theme.backgroundColorChecked;
|
|
182
|
-
break;
|
|
183
187
|
|
|
184
188
|
case "border":
|
|
185
189
|
return props.backgroundType && props.backgroundType === "dark" ? props.theme.borderColorOnDark : props.theme.borderColor;
|
|
186
|
-
break;
|
|
187
190
|
|
|
188
191
|
case "label":
|
|
189
192
|
return props.backgroundType && props.backgroundType === "dark" ? props.theme.fontColorOnDark : props.theme.fontColor;
|
|
190
|
-
break;
|
|
191
193
|
}
|
|
192
194
|
};
|
|
193
195
|
|
|
194
|
-
var LabelContainer = _styledComponents["default"].span(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n
|
|
196
|
+
var LabelContainer = _styledComponents["default"].span(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n cursor: ", ";\n"])), function (props) {
|
|
195
197
|
return props.disabled ? getDisabledColor(props, "label") : getNotDisabledColor(props, "label");
|
|
196
|
-
}, function (props) {
|
|
197
|
-
return props.disabled ? "not-allowed" : "pointer";
|
|
198
198
|
}, function (props) {
|
|
199
199
|
return props.theme.fontFamily;
|
|
200
200
|
}, function (props) {
|
|
201
201
|
return props.theme.fontSize;
|
|
202
202
|
}, function (props) {
|
|
203
203
|
return props.theme.fontWeight;
|
|
204
|
+
}, function (props) {
|
|
205
|
+
return props.disabled ? "not-allowed" : "pointer";
|
|
204
206
|
});
|
|
205
207
|
|
|
206
|
-
var CheckboxContainer = _styledComponents["default"].span(_templateObject2 || (_templateObject2 = (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
|
|
208
|
+
var CheckboxContainer = _styledComponents["default"].span(_templateObject2 || (_templateObject2 = (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 .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 border-radius: 2px;\n outline: 2px solid\n ", ";\n outline-offset: -1px;\n }\n }\n z-index: 1;\n margin-left: ", ";\n margin-right: ", ";\n padding: 0px;\n left: ", ";\n right: ", ";\n }\n"])), function (props) {
|
|
207
209
|
return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
|
|
208
210
|
}, function (props) {
|
|
209
211
|
return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.top ? _variables.spaces[props.margin.top] : "";
|
|
@@ -217,8 +219,6 @@ var CheckboxContainer = _styledComponents["default"].span(_templateObject2 || (_
|
|
|
217
219
|
return calculateWidth(props.margin, props.size);
|
|
218
220
|
}, function (props) {
|
|
219
221
|
return props.disabled ? "not-allowed" : "pointer";
|
|
220
|
-
}, function (props) {
|
|
221
|
-
return props.labelPosition === "before" ? "row-reverse" : "row";
|
|
222
222
|
}, function (props) {
|
|
223
223
|
return props.isLabelHovered ? props.backgroundType === "dark" ? props.theme.hoverBorderColorOnDark : props.theme.hoverBorderColor : getNotDisabledColor(props, "border");
|
|
224
224
|
}, function (props) {
|
|
@@ -253,23 +253,5 @@ var CheckboxBlackBack = _styledComponents["default"].span(_templateObject3 || (_
|
|
|
253
253
|
return props.labelPosition === "before" ? "0px" : "";
|
|
254
254
|
});
|
|
255
255
|
|
|
256
|
-
DxcCheckbox.propTypes = {
|
|
257
|
-
checked: _propTypes["default"].bool,
|
|
258
|
-
value: _propTypes["default"].any,
|
|
259
|
-
label: _propTypes["default"].string,
|
|
260
|
-
labelPosition: _propTypes["default"].oneOf(["after", "before", ""]),
|
|
261
|
-
name: _propTypes["default"].string,
|
|
262
|
-
disabled: _propTypes["default"].bool,
|
|
263
|
-
onChange: _propTypes["default"].func,
|
|
264
|
-
required: _propTypes["default"].bool,
|
|
265
|
-
size: _propTypes["default"].oneOf((0, _toConsumableArray2["default"])(Object.keys(sizes))),
|
|
266
|
-
margin: _propTypes["default"].oneOfType([_propTypes["default"].shape({
|
|
267
|
-
top: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
|
|
268
|
-
bottom: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
|
|
269
|
-
left: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
|
|
270
|
-
right: _propTypes["default"].oneOf(Object.keys(_variables.spaces))
|
|
271
|
-
}), _propTypes["default"].oneOf((0, _toConsumableArray2["default"])(Object.keys(_variables.spaces)))]),
|
|
272
|
-
tabIndex: _propTypes["default"].number
|
|
273
|
-
};
|
|
274
256
|
var _default = DxcCheckbox;
|
|
275
257
|
exports["default"] = _default;
|
|
@@ -0,0 +1,188 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import DxcCheckbox from "./Checkbox";
|
|
3
|
+
import { BackgroundColorProvider } from "../BackgroundColorContext";
|
|
4
|
+
import Title from "../../.storybook/components/Title";
|
|
5
|
+
import ExampleContainer from "../../.storybook/components/ExampleContainer";
|
|
6
|
+
import DarkContainer from "../../.storybook/components/DarkSection";
|
|
7
|
+
import { userEvent } from "@storybook/testing-library";
|
|
8
|
+
|
|
9
|
+
export default {
|
|
10
|
+
title: "Checkbox",
|
|
11
|
+
component: DxcCheckbox,
|
|
12
|
+
};
|
|
13
|
+
|
|
14
|
+
const Checkbox = () => (
|
|
15
|
+
<>
|
|
16
|
+
<ExampleContainer>
|
|
17
|
+
<Title title="Default" theme="light" level={4} />
|
|
18
|
+
<DxcCheckbox label="Checkbox" />
|
|
19
|
+
</ExampleContainer>
|
|
20
|
+
<ExampleContainer>
|
|
21
|
+
<Title title="Focused" theme="light" level={4} />
|
|
22
|
+
<DxcCheckbox label="Focused" />
|
|
23
|
+
</ExampleContainer>
|
|
24
|
+
<ExampleContainer>
|
|
25
|
+
<Title title="Checked" theme="light" level={4} />
|
|
26
|
+
<DxcCheckbox label="Checkbox" defaultChecked />
|
|
27
|
+
</ExampleContainer>
|
|
28
|
+
<ExampleContainer>
|
|
29
|
+
<Title title="Optional" theme="light" level={4} />
|
|
30
|
+
<DxcCheckbox label="Checkbox" optional />
|
|
31
|
+
</ExampleContainer>
|
|
32
|
+
<ExampleContainer>
|
|
33
|
+
<Title title="Disabled and checked" theme="light" level={4} />
|
|
34
|
+
<DxcCheckbox label="Checkbox" disabled defaultChecked />
|
|
35
|
+
</ExampleContainer>
|
|
36
|
+
<ExampleContainer>
|
|
37
|
+
<Title title="Disabled and optional" theme="light" level={4} />
|
|
38
|
+
<DxcCheckbox label="Checkbox" disabled optional />
|
|
39
|
+
</ExampleContainer>
|
|
40
|
+
<ExampleContainer>
|
|
41
|
+
<Title title="Disabled, optional and checked" theme="light" level={4} />
|
|
42
|
+
<DxcCheckbox label="Checkbox" disabled optional defaultChecked />
|
|
43
|
+
</ExampleContainer>
|
|
44
|
+
<ExampleContainer>
|
|
45
|
+
<Title title="Label after" theme="light" level={4} />
|
|
46
|
+
<DxcCheckbox label="Checkbox" labelPosition="after" />
|
|
47
|
+
</ExampleContainer>
|
|
48
|
+
<ExampleContainer>
|
|
49
|
+
<Title title="Checked with label after" theme="light" level={4} />
|
|
50
|
+
<DxcCheckbox label="Checkbox" defaultChecked labelPosition="after" />
|
|
51
|
+
</ExampleContainer>
|
|
52
|
+
<ExampleContainer>
|
|
53
|
+
<Title title="Optional with label after" theme="light" level={4} />
|
|
54
|
+
<DxcCheckbox label="Checkbox" optional labelPosition="after" />
|
|
55
|
+
</ExampleContainer>
|
|
56
|
+
<ExampleContainer>
|
|
57
|
+
<Title title="Disabled and checked with label after" theme="light" level={4} />
|
|
58
|
+
<DxcCheckbox label="Checkbox" disabled defaultChecked labelPosition="after" />
|
|
59
|
+
</ExampleContainer>
|
|
60
|
+
<ExampleContainer>
|
|
61
|
+
<Title title="Disabled and optional with label after" theme="light" level={4} />
|
|
62
|
+
<DxcCheckbox label="Checkbox" disabled optional labelPosition="after" />
|
|
63
|
+
</ExampleContainer>
|
|
64
|
+
<ExampleContainer>
|
|
65
|
+
<Title title="Disabled, optional and checked with label after" theme="light" level={4} />
|
|
66
|
+
<DxcCheckbox label="Checkbox" disabled optional defaultChecked labelPosition="after" />
|
|
67
|
+
</ExampleContainer>
|
|
68
|
+
<ExampleContainer pseudoState="pseudo-hover">
|
|
69
|
+
<Title title="Hovered" theme="light" level={4} />
|
|
70
|
+
<DxcCheckbox label="Hovered" />
|
|
71
|
+
</ExampleContainer>
|
|
72
|
+
<ExampleContainer pseudoState="pseudo-hover">
|
|
73
|
+
<Title title="Hovered and checked" theme="light" level={4} />
|
|
74
|
+
<DxcCheckbox label="Hovered" defaultChecked />
|
|
75
|
+
</ExampleContainer>
|
|
76
|
+
<BackgroundColorProvider color="#333333">
|
|
77
|
+
<DarkContainer>
|
|
78
|
+
<ExampleContainer>
|
|
79
|
+
<Title title="Default" theme="dark" level={4} />
|
|
80
|
+
<DxcCheckbox label="Checkbox" />
|
|
81
|
+
</ExampleContainer>
|
|
82
|
+
<ExampleContainer>
|
|
83
|
+
<Title title="Checked" theme="dark" level={4} />
|
|
84
|
+
<DxcCheckbox label="Checkbox" defaultChecked />
|
|
85
|
+
</ExampleContainer>
|
|
86
|
+
<ExampleContainer>
|
|
87
|
+
<Title title="Optional" theme="dark" level={4} />
|
|
88
|
+
<DxcCheckbox label="Checkbox" optional />
|
|
89
|
+
</ExampleContainer>
|
|
90
|
+
<ExampleContainer>
|
|
91
|
+
<Title title="Disabled and checked" theme="dark" level={4} />
|
|
92
|
+
<DxcCheckbox label="Checkbox" disabled defaultChecked />
|
|
93
|
+
</ExampleContainer>
|
|
94
|
+
<ExampleContainer>
|
|
95
|
+
<Title title="Disabled and optional" theme="dark" level={4} />
|
|
96
|
+
<DxcCheckbox label="Checkbox" disabled optional />
|
|
97
|
+
</ExampleContainer>
|
|
98
|
+
<ExampleContainer>
|
|
99
|
+
<Title title="Disabled, optional and checked" theme="dark" level={4} />
|
|
100
|
+
<DxcCheckbox label="Checkbox" disabled optional defaultChecked />
|
|
101
|
+
</ExampleContainer>
|
|
102
|
+
<ExampleContainer>
|
|
103
|
+
<Title title="Label after" theme="dark" level={4} />
|
|
104
|
+
<DxcCheckbox label="Checkbox" labelPosition="after" />
|
|
105
|
+
</ExampleContainer>
|
|
106
|
+
<ExampleContainer>
|
|
107
|
+
<Title title="Checked with label after" theme="dark" level={4} />
|
|
108
|
+
<DxcCheckbox label="Checkbox" defaultChecked labelPosition="after" />
|
|
109
|
+
</ExampleContainer>
|
|
110
|
+
<ExampleContainer>
|
|
111
|
+
<Title title="Optional with label after" theme="dark" level={4} />
|
|
112
|
+
<DxcCheckbox label="Checkbox" optional labelPosition="after" />
|
|
113
|
+
</ExampleContainer>
|
|
114
|
+
<ExampleContainer>
|
|
115
|
+
<Title title="Disabled and checked with label after" theme="dark" level={4} />
|
|
116
|
+
<DxcCheckbox label="Checkbox" disabled defaultChecked labelPosition="after" />
|
|
117
|
+
</ExampleContainer>
|
|
118
|
+
<ExampleContainer>
|
|
119
|
+
<Title title="Disabled and optional with label after" theme="dark" level={4} />
|
|
120
|
+
<DxcCheckbox label="Checkbox" disabled optional labelPosition="after" />
|
|
121
|
+
</ExampleContainer>
|
|
122
|
+
<ExampleContainer>
|
|
123
|
+
<Title title="Disabled, optional and checked with label after" theme="dark" level={4} />
|
|
124
|
+
<DxcCheckbox label="Checkbox" disabled optional defaultChecked labelPosition="after" />
|
|
125
|
+
</ExampleContainer>
|
|
126
|
+
<ExampleContainer pseudoState="pseudo-hover">
|
|
127
|
+
<Title title="Hovered" theme="dark" level={4} />
|
|
128
|
+
<DxcCheckbox label="Hovered" />
|
|
129
|
+
</ExampleContainer>
|
|
130
|
+
<ExampleContainer pseudoState="pseudo-hover">
|
|
131
|
+
<Title title="Hovered and checked" theme="dark" level={4} />
|
|
132
|
+
<DxcCheckbox label="Hovered" defaultChecked />
|
|
133
|
+
</ExampleContainer>
|
|
134
|
+
</DarkContainer>
|
|
135
|
+
</BackgroundColorProvider>
|
|
136
|
+
<Title title="Sizes" theme="light" level={2} />
|
|
137
|
+
<ExampleContainer>
|
|
138
|
+
<DxcCheckbox label="Small" size="small" />
|
|
139
|
+
</ExampleContainer>
|
|
140
|
+
<ExampleContainer>
|
|
141
|
+
<DxcCheckbox label="Medium" size="medium" />
|
|
142
|
+
</ExampleContainer>
|
|
143
|
+
<ExampleContainer>
|
|
144
|
+
<DxcCheckbox label="Large" size="large" />
|
|
145
|
+
</ExampleContainer>
|
|
146
|
+
<ExampleContainer>
|
|
147
|
+
<DxcCheckbox label="FitContent" size="fitContent" />
|
|
148
|
+
</ExampleContainer>
|
|
149
|
+
<ExampleContainer>
|
|
150
|
+
<DxcCheckbox label="FillParent" size="fillParent" />
|
|
151
|
+
</ExampleContainer>
|
|
152
|
+
<Title title="Margins" theme="light" level={2} />
|
|
153
|
+
<ExampleContainer>
|
|
154
|
+
<Title title="Xxsmall" theme="light" level={4} />
|
|
155
|
+
<DxcCheckbox label="Xxsmall" margin="xxsmall" />
|
|
156
|
+
</ExampleContainer>
|
|
157
|
+
<ExampleContainer>
|
|
158
|
+
<Title title="Xsmall" theme="light" level={4} />
|
|
159
|
+
<DxcCheckbox label="Xsmall" margin="xsmall" />
|
|
160
|
+
</ExampleContainer>
|
|
161
|
+
<ExampleContainer>
|
|
162
|
+
<Title title="Small" theme="light" level={4} />
|
|
163
|
+
<DxcCheckbox label="Small" margin="small" />
|
|
164
|
+
</ExampleContainer>
|
|
165
|
+
<ExampleContainer>
|
|
166
|
+
<Title title="Medium" theme="light" level={4} />
|
|
167
|
+
<DxcCheckbox label="Medium" margin="medium" />
|
|
168
|
+
</ExampleContainer>
|
|
169
|
+
<ExampleContainer>
|
|
170
|
+
<Title title="Large" theme="light" level={4} />
|
|
171
|
+
<DxcCheckbox label="Large" margin="large" />
|
|
172
|
+
</ExampleContainer>
|
|
173
|
+
<ExampleContainer>
|
|
174
|
+
<Title title="Xlarge" theme="light" level={4} />
|
|
175
|
+
<DxcCheckbox label="Xlarge" margin="xlarge" />
|
|
176
|
+
</ExampleContainer>
|
|
177
|
+
<ExampleContainer>
|
|
178
|
+
<Title title="Xxlarge" theme="light" level={4} />
|
|
179
|
+
<DxcCheckbox label="Xxlarge" margin="xxlarge" />
|
|
180
|
+
</ExampleContainer>
|
|
181
|
+
</>
|
|
182
|
+
);
|
|
183
|
+
|
|
184
|
+
export const Chromatic = Checkbox.bind({});
|
|
185
|
+
Chromatic.play = async () => {
|
|
186
|
+
await userEvent.tab();
|
|
187
|
+
await userEvent.tab();
|
|
188
|
+
};
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
var _react = _interopRequireDefault(require("react"));
|
|
6
|
+
|
|
7
|
+
var _react2 = require("@testing-library/react");
|
|
8
|
+
|
|
9
|
+
var _Checkbox = _interopRequireDefault(require("./Checkbox"));
|
|
10
|
+
|
|
11
|
+
describe("Checkbox component tests", function () {
|
|
12
|
+
test("Checkbox renders with correct text", function () {
|
|
13
|
+
var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
|
|
14
|
+
label: "Checkbox"
|
|
15
|
+
})),
|
|
16
|
+
getByText = _render.getByText;
|
|
17
|
+
|
|
18
|
+
expect(getByText("Checkbox")).toBeTruthy();
|
|
19
|
+
});
|
|
20
|
+
test("Calls correct function on click", function () {
|
|
21
|
+
var onChange = jest.fn();
|
|
22
|
+
|
|
23
|
+
var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
|
|
24
|
+
label: "Checkbox",
|
|
25
|
+
onChange: onChange
|
|
26
|
+
})),
|
|
27
|
+
getByText = _render2.getByText;
|
|
28
|
+
|
|
29
|
+
_react2.fireEvent.click(getByText("Checkbox"));
|
|
30
|
+
|
|
31
|
+
expect(onChange).toHaveBeenCalled();
|
|
32
|
+
});
|
|
33
|
+
test("Uncontrolled checkbox", function () {
|
|
34
|
+
var onChange = jest.fn();
|
|
35
|
+
var component = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
|
|
36
|
+
label: "Checkbox",
|
|
37
|
+
onChange: onChange
|
|
38
|
+
}));
|
|
39
|
+
var visibleCheckbox = component.getByText("Checkbox");
|
|
40
|
+
var input = component.getByRole("checkbox");
|
|
41
|
+
expect(input.checked).toBe(false);
|
|
42
|
+
|
|
43
|
+
_react2.fireEvent.click(visibleCheckbox);
|
|
44
|
+
|
|
45
|
+
expect(onChange).toHaveBeenCalled();
|
|
46
|
+
expect(onChange).toHaveBeenCalledWith(true);
|
|
47
|
+
expect(input.checked).toBe(true);
|
|
48
|
+
});
|
|
49
|
+
test("Controlled checkbox", function () {
|
|
50
|
+
var onChange = jest.fn();
|
|
51
|
+
var component = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
|
|
52
|
+
label: "Checkbox",
|
|
53
|
+
checked: false,
|
|
54
|
+
onChange: onChange
|
|
55
|
+
}));
|
|
56
|
+
var input = component.getByRole("checkbox");
|
|
57
|
+
var visibleCheckbox = component.getByText("Checkbox");
|
|
58
|
+
|
|
59
|
+
_react2.fireEvent.click(visibleCheckbox);
|
|
60
|
+
|
|
61
|
+
expect(onChange).toHaveBeenCalled();
|
|
62
|
+
expect(onChange).toHaveBeenCalledWith(true);
|
|
63
|
+
expect(input.checked).toBe(false);
|
|
64
|
+
});
|
|
65
|
+
test("Renders with correct initial value and initial state when it is uncontrolled", function () {
|
|
66
|
+
var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
|
|
67
|
+
label: "Default label",
|
|
68
|
+
defaultChecked: true,
|
|
69
|
+
value: "test-defaultChecked"
|
|
70
|
+
})),
|
|
71
|
+
getByRole = _render3.getByRole;
|
|
72
|
+
|
|
73
|
+
var input = getByRole("checkbox");
|
|
74
|
+
expect(input.checked).toBe(true);
|
|
75
|
+
expect(input.value).toBe("test-defaultChecked");
|
|
76
|
+
expect(input.getAttribute("aria-checked")).toBe("true");
|
|
77
|
+
});
|
|
78
|
+
});
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
|
|
2
|
+
declare type Margin = {
|
|
3
|
+
top?: Space;
|
|
4
|
+
bottom?: Space;
|
|
5
|
+
left?: Space;
|
|
6
|
+
right?: Space;
|
|
7
|
+
};
|
|
8
|
+
declare type Props = {
|
|
9
|
+
/**
|
|
10
|
+
* Initial state of the checkbox, only when it is uncontrolled.
|
|
11
|
+
*/
|
|
12
|
+
defaultChecked?: boolean;
|
|
13
|
+
/**
|
|
14
|
+
* If true, the component is checked. If undefined the component will be
|
|
15
|
+
* uncontrolled and the value will be managed internally by the component.
|
|
16
|
+
*/
|
|
17
|
+
checked?: boolean;
|
|
18
|
+
/**
|
|
19
|
+
* Will be passed to the value attribute of the html input element.
|
|
20
|
+
* When inside a form, this value will be only submitted if the checkbox is checked.
|
|
21
|
+
*/
|
|
22
|
+
value?: string;
|
|
23
|
+
/**
|
|
24
|
+
* Text to be placed next to the checkbox.
|
|
25
|
+
*/
|
|
26
|
+
label?: string;
|
|
27
|
+
/**
|
|
28
|
+
* Whether the label should appear after or before the checkbox.
|
|
29
|
+
*/
|
|
30
|
+
labelPosition?: "before" | "after";
|
|
31
|
+
/**
|
|
32
|
+
* Name attribute of the input element.
|
|
33
|
+
*/
|
|
34
|
+
name?: string;
|
|
35
|
+
/**
|
|
36
|
+
* If true, the component will be disabled.
|
|
37
|
+
*/
|
|
38
|
+
disabled?: boolean;
|
|
39
|
+
/**
|
|
40
|
+
* If true, the component will display '(Optional)' next to the label.
|
|
41
|
+
*/
|
|
42
|
+
optional?: boolean;
|
|
43
|
+
/**
|
|
44
|
+
* This function will be called when the user clicks the checkbox.
|
|
45
|
+
* The new value will be passed as a parameter.
|
|
46
|
+
*/
|
|
47
|
+
onChange?: (value: boolean) => void;
|
|
48
|
+
/**
|
|
49
|
+
* Size of the margin to be applied to the component
|
|
50
|
+
* ('xxsmall' | 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge' | 'xxlarge').
|
|
51
|
+
* You can pass an object with 'top', 'bottom', 'left' and 'right' properties
|
|
52
|
+
* in order to specify different margin sizes.
|
|
53
|
+
*/
|
|
54
|
+
margin?: Space | Margin;
|
|
55
|
+
/**
|
|
56
|
+
* Size of the component.
|
|
57
|
+
*/
|
|
58
|
+
size?: "small" | "medium" | "large" | "fillParent" | "fitContent";
|
|
59
|
+
/**
|
|
60
|
+
* Value of the tabindex.
|
|
61
|
+
*/
|
|
62
|
+
tabIndex?: number;
|
|
63
|
+
};
|
|
64
|
+
export default Props;
|
package/chip/Chip.d.ts
ADDED