@dxc-technology/halstack-react 0.0.0-b22e2a8 → 0.0.0-b230d97
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 +300 -0
- package/accordion/Accordion.d.ts +1 -1
- package/accordion/Accordion.js +119 -138
- package/accordion/Accordion.stories.tsx +395 -0
- package/accordion/Accordion.test.js +71 -0
- package/accordion/types.d.ts +12 -11
- package/accordion-group/AccordionGroup.d.ts +1 -1
- package/accordion-group/AccordionGroup.js +16 -37
- package/accordion-group/AccordionGroup.stories.tsx +251 -0
- package/accordion-group/AccordionGroup.test.js +126 -0
- package/accordion-group/types.d.ts +17 -10
- package/alert/Alert.js +7 -4
- package/alert/Alert.test.js +92 -0
- package/badge/Badge.d.ts +4 -0
- package/badge/Badge.js +6 -4
- package/badge/types.d.ts +5 -0
- package/{radio → badge}/types.js +0 -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.js +25 -35
- package/box/Box.test.js +18 -0
- package/box/types.d.ts +1 -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 +59 -82
- package/button/Button.stories.tsx +163 -14
- package/button/Button.test.js +35 -0
- package/button/types.d.ts +10 -14
- package/card/Card.js +25 -28
- package/card/Card.stories.tsx +1 -1
- package/card/Card.test.js +50 -0
- package/card/types.d.ts +1 -0
- package/checkbox/Checkbox.d.ts +2 -2
- package/checkbox/Checkbox.js +108 -111
- package/checkbox/Checkbox.stories.tsx +198 -130
- package/checkbox/Checkbox.test.js +155 -0
- package/checkbox/types.d.ts +14 -6
- package/chip/Chip.d.ts +4 -0
- package/chip/Chip.js +22 -88
- package/chip/Chip.stories.tsx +98 -13
- package/chip/Chip.test.js +56 -0
- package/chip/types.d.ts +45 -0
- package/chip/types.js +5 -0
- package/common/variables.js +511 -569
- package/date-input/Calendar.d.ts +4 -0
- package/date-input/Calendar.js +258 -0
- package/date-input/DateInput.js +174 -266
- package/date-input/DateInput.stories.tsx +137 -38
- package/date-input/DateInput.test.js +835 -0
- package/date-input/DatePicker.d.ts +4 -0
- package/date-input/DatePicker.js +146 -0
- package/date-input/Icons.d.ts +6 -0
- package/date-input/Icons.js +75 -0
- package/date-input/YearPicker.d.ts +4 -0
- package/date-input/YearPicker.js +126 -0
- package/date-input/types.d.ts +67 -9
- package/dialog/Dialog.js +50 -53
- package/dialog/Dialog.stories.tsx +57 -2
- package/dialog/Dialog.test.js +70 -0
- package/dialog/types.d.ts +3 -2
- package/dropdown/Dropdown.d.ts +1 -1
- package/dropdown/Dropdown.js +248 -277
- package/dropdown/Dropdown.stories.tsx +438 -0
- package/dropdown/Dropdown.test.js +585 -0
- package/dropdown/DropdownMenu.d.ts +4 -0
- package/dropdown/DropdownMenu.js +70 -0
- package/dropdown/DropdownMenuItem.d.ts +4 -0
- package/dropdown/DropdownMenuItem.js +81 -0
- package/dropdown/types.d.ts +30 -19
- package/file-input/FileInput.d.ts +2 -2
- package/file-input/FileInput.js +182 -142
- package/file-input/FileInput.stories.tsx +618 -0
- package/file-input/FileInput.test.js +498 -0
- package/file-input/FileItem.d.ts +4 -14
- package/file-input/FileItem.js +46 -67
- package/file-input/types.d.ts +49 -7
- package/flex/Flex.d.ts +4 -0
- package/flex/Flex.js +69 -0
- package/flex/Flex.stories.tsx +103 -0
- package/flex/types.d.ts +32 -0
- package/flex/types.js +5 -0
- package/footer/Footer.d.ts +1 -1
- package/footer/Footer.js +32 -113
- package/footer/Footer.stories.tsx +228 -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 +22 -17
- package/header/Header.js +109 -130
- package/header/Header.stories.tsx +167 -36
- package/header/Header.test.js +79 -0
- package/header/Icons.d.ts +2 -0
- package/header/Icons.js +2 -2
- package/header/types.d.ts +3 -2
- package/heading/Heading.js +1 -1
- package/heading/Heading.stories.tsx +3 -2
- package/heading/Heading.test.js +186 -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 +162 -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 +3 -2
- package/link/Link.js +62 -87
- package/link/Link.stories.tsx +99 -52
- package/link/Link.test.js +83 -0
- package/link/types.d.ts +9 -29
- package/main.d.ts +12 -12
- package/main.js +64 -58
- package/number-input/NumberInput.js +14 -24
- package/number-input/NumberInput.stories.tsx +5 -5
- package/number-input/NumberInput.test.js +542 -0
- package/number-input/types.d.ts +17 -10
- package/package.json +21 -22
- package/paginator/Icons.d.ts +5 -0
- package/paginator/Icons.js +16 -28
- package/paginator/Paginator.js +21 -54
- package/paginator/Paginator.stories.tsx +24 -0
- package/paginator/Paginator.test.js +315 -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.js +23 -19
- package/password-input/PasswordInput.stories.tsx +3 -3
- package/password-input/PasswordInput.test.js +181 -0
- package/password-input/types.d.ts +26 -21
- package/progress-bar/ProgressBar.d.ts +2 -2
- package/progress-bar/ProgressBar.js +59 -53
- package/progress-bar/ProgressBar.stories.jsx +45 -12
- package/progress-bar/ProgressBar.test.js +110 -0
- package/progress-bar/types.d.ts +3 -4
- package/quick-nav/QuickNav.d.ts +4 -0
- package/quick-nav/QuickNav.js +117 -0
- package/quick-nav/QuickNav.stories.tsx +356 -0
- package/quick-nav/types.d.ts +21 -0
- package/quick-nav/types.js +5 -0
- package/radio-group/Radio.d.ts +4 -0
- package/radio-group/Radio.js +156 -0
- package/radio-group/RadioGroup.d.ts +4 -0
- package/radio-group/RadioGroup.js +283 -0
- package/radio-group/RadioGroup.stories.tsx +214 -0
- package/radio-group/RadioGroup.test.js +722 -0
- package/radio-group/types.d.ts +114 -0
- package/radio-group/types.js +5 -0
- package/resultsetTable/Icons.d.ts +7 -0
- package/resultsetTable/Icons.js +51 -0
- package/resultsetTable/ResultsetTable.d.ts +1 -1
- package/resultsetTable/ResultsetTable.js +53 -107
- package/resultsetTable/ResultsetTable.stories.tsx +300 -0
- package/resultsetTable/ResultsetTable.test.js +325 -0
- package/resultsetTable/types.d.ts +8 -4
- package/select/Icons.d.ts +10 -0
- package/select/Icons.js +93 -0
- package/select/Listbox.d.ts +4 -0
- package/select/Listbox.js +169 -0
- package/select/Option.d.ts +4 -0
- package/select/Option.js +97 -0
- package/select/Select.d.ts +4 -0
- package/select/Select.js +196 -397
- package/select/Select.stories.tsx +600 -201
- package/select/Select.test.js +2228 -0
- package/select/types.d.ts +210 -0
- package/select/types.js +5 -0
- package/sidenav/Sidenav.d.ts +6 -5
- package/sidenav/Sidenav.js +184 -54
- package/sidenav/Sidenav.stories.tsx +249 -132
- package/sidenav/Sidenav.test.js +44 -0
- package/sidenav/types.d.ts +50 -27
- package/slider/Slider.d.ts +2 -2
- package/slider/Slider.js +124 -98
- package/slider/Slider.stories.tsx +72 -9
- package/slider/Slider.test.js +250 -0
- package/slider/types.d.ts +10 -2
- package/spinner/Spinner.js +5 -5
- package/spinner/Spinner.stories.jsx +27 -0
- package/spinner/Spinner.test.js +64 -0
- package/switch/Switch.d.ts +2 -2
- package/switch/Switch.js +152 -69
- package/switch/Switch.stories.tsx +54 -43
- package/switch/Switch.test.js +225 -0
- package/switch/types.d.ts +12 -4
- package/table/Table.js +3 -3
- package/table/Table.stories.jsx +81 -1
- package/table/Table.test.js +26 -0
- package/tabs/Tab.d.ts +4 -0
- package/tabs/Tab.js +133 -0
- package/tabs/Tabs.d.ts +1 -1
- package/tabs/Tabs.js +364 -110
- package/tabs/Tabs.stories.tsx +226 -0
- package/tabs/Tabs.test.js +351 -0
- package/tabs/types.d.ts +39 -17
- package/tabs-nav/NavTabs.d.ts +8 -0
- package/tabs-nav/NavTabs.js +125 -0
- package/tabs-nav/NavTabs.stories.tsx +172 -0
- package/tabs-nav/NavTabs.test.js +82 -0
- package/tabs-nav/Tab.d.ts +4 -0
- package/tabs-nav/Tab.js +128 -0
- package/tabs-nav/types.d.ts +53 -0
- package/tabs-nav/types.js +5 -0
- package/tag/Tag.d.ts +1 -1
- package/tag/Tag.js +19 -29
- package/tag/Tag.stories.tsx +26 -29
- package/tag/Tag.test.js +60 -0
- package/tag/types.d.ts +23 -14
- package/text-input/Icons.d.ts +8 -0
- package/text-input/Icons.js +60 -0
- package/text-input/Suggestion.d.ts +4 -0
- package/text-input/Suggestion.js +84 -0
- package/text-input/Suggestions.d.ts +4 -0
- package/text-input/Suggestions.js +134 -0
- package/text-input/TextInput.js +231 -343
- package/text-input/TextInput.stories.tsx +569 -0
- package/text-input/TextInput.test.js +1724 -0
- package/text-input/types.d.ts +63 -23
- package/textarea/Textarea.d.ts +4 -0
- package/textarea/Textarea.js +39 -79
- package/textarea/Textarea.stories.jsx +37 -15
- 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 +69 -32
- 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 +1 -1
- package/wizard/Wizard.js +112 -58
- package/wizard/{Wizard.stories.jsx → Wizard.stories.tsx} +48 -19
- package/wizard/Wizard.test.js +141 -0
- package/wizard/types.d.ts +13 -12
- 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/chip/index.d.ts +0 -22
- package/common/RequiredComponent.js +0 -32
- package/date/Date.js +0 -373
- package/date/index.d.ts +0 -27
- package/footer/Footer.stories.jsx +0 -151
- package/input-text/Icons.js +0 -22
- package/input-text/InputText.js +0 -611
- package/input-text/index.d.ts +0 -36
- package/radio/Radio.d.ts +0 -4
- package/radio/Radio.js +0 -174
- package/radio/Radio.stories.tsx +0 -192
- package/radio/types.d.ts +0 -54
- package/select/index.d.ts +0 -131
- 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
|
@@ -0,0 +1,146 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
6
|
+
|
|
7
|
+
Object.defineProperty(exports, "__esModule", {
|
|
8
|
+
value: true
|
|
9
|
+
});
|
|
10
|
+
exports["default"] = void 0;
|
|
11
|
+
|
|
12
|
+
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
|
|
13
|
+
|
|
14
|
+
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
15
|
+
|
|
16
|
+
var _dayjs = _interopRequireDefault(require("dayjs"));
|
|
17
|
+
|
|
18
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
19
|
+
|
|
20
|
+
var _styledComponents = _interopRequireDefault(require("styled-components"));
|
|
21
|
+
|
|
22
|
+
var _Calendar = _interopRequireDefault(require("./Calendar"));
|
|
23
|
+
|
|
24
|
+
var _YearPicker = _interopRequireDefault(require("./YearPicker"));
|
|
25
|
+
|
|
26
|
+
var _useTranslatedLabels = _interopRequireDefault(require("../useTranslatedLabels"));
|
|
27
|
+
|
|
28
|
+
var _Icons = require("./Icons");
|
|
29
|
+
|
|
30
|
+
var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5;
|
|
31
|
+
|
|
32
|
+
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
33
|
+
|
|
34
|
+
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
35
|
+
|
|
36
|
+
var today = (0, _dayjs["default"])();
|
|
37
|
+
|
|
38
|
+
var DxcDatePicker = function DxcDatePicker(_ref) {
|
|
39
|
+
var date = _ref.date,
|
|
40
|
+
onDateSelect = _ref.onDateSelect,
|
|
41
|
+
id = _ref.id;
|
|
42
|
+
|
|
43
|
+
var _useState = (0, _react.useState)(date !== null && date !== void 0 && date.isValid() ? date : (0, _dayjs["default"])()),
|
|
44
|
+
_useState2 = (0, _slicedToArray2["default"])(_useState, 2),
|
|
45
|
+
innerDate = _useState2[0],
|
|
46
|
+
setInnerDate = _useState2[1];
|
|
47
|
+
|
|
48
|
+
var _useState3 = (0, _react.useState)("calendar"),
|
|
49
|
+
_useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
|
|
50
|
+
content = _useState4[0],
|
|
51
|
+
setContent = _useState4[1];
|
|
52
|
+
|
|
53
|
+
var selectedDate = date !== null && date !== void 0 && date.isValid() ? date : null;
|
|
54
|
+
var translatedLabels = (0, _useTranslatedLabels["default"])();
|
|
55
|
+
|
|
56
|
+
var handleDateSelect = function handleDateSelect(date) {
|
|
57
|
+
setInnerDate(date);
|
|
58
|
+
onDateSelect(date);
|
|
59
|
+
};
|
|
60
|
+
|
|
61
|
+
var handleOnYearSelect = function handleOnYearSelect(year) {
|
|
62
|
+
setInnerDate(innerDate.set("year", year));
|
|
63
|
+
setContent("calendar");
|
|
64
|
+
};
|
|
65
|
+
|
|
66
|
+
var handleMonthChange = function handleMonthChange(date) {
|
|
67
|
+
setInnerDate(date);
|
|
68
|
+
};
|
|
69
|
+
|
|
70
|
+
return /*#__PURE__*/_react["default"].createElement(DatePicker, {
|
|
71
|
+
id: id
|
|
72
|
+
}, /*#__PURE__*/_react["default"].createElement(PickerHeader, null, /*#__PURE__*/_react["default"].createElement(HeaderButton, {
|
|
73
|
+
"aria-label": translatedLabels.calendar.previousMonthTitle,
|
|
74
|
+
title: translatedLabels.calendar.previousMonthTitle,
|
|
75
|
+
onClick: function onClick() {
|
|
76
|
+
return handleMonthChange(innerDate.set("month", innerDate.get("month") - 1));
|
|
77
|
+
}
|
|
78
|
+
}, _Icons.leftCaret), /*#__PURE__*/_react["default"].createElement(HeaderYearTrigger, {
|
|
79
|
+
"aria-live": "polite",
|
|
80
|
+
onClick: function onClick() {
|
|
81
|
+
return setContent(function (content) {
|
|
82
|
+
return content === "yearPicker" ? "calendar" : "yearPicker";
|
|
83
|
+
});
|
|
84
|
+
}
|
|
85
|
+
}, /*#__PURE__*/_react["default"].createElement(HeaderYearTriggerLabel, null, translatedLabels.calendar.months[innerDate.get("month")], " ", innerDate.format("YYYY")), content === "yearPicker" ? _Icons.upCaret : _Icons.downCaret), /*#__PURE__*/_react["default"].createElement(HeaderButton, {
|
|
86
|
+
"aria-label": translatedLabels.calendar.nextMonthTitle,
|
|
87
|
+
title: translatedLabels.calendar.nextMonthTitle,
|
|
88
|
+
onClick: function onClick() {
|
|
89
|
+
return handleMonthChange(innerDate.set("month", innerDate.get("month") + 1));
|
|
90
|
+
}
|
|
91
|
+
}, _Icons.rightCaret)), content === "calendar" && /*#__PURE__*/_react["default"].createElement(_Calendar["default"], {
|
|
92
|
+
innerDate: innerDate,
|
|
93
|
+
selectedDate: selectedDate,
|
|
94
|
+
onInnerDateChange: setInnerDate,
|
|
95
|
+
onDaySelect: handleDateSelect,
|
|
96
|
+
today: today
|
|
97
|
+
}), content === "yearPicker" && /*#__PURE__*/_react["default"].createElement(_YearPicker["default"], {
|
|
98
|
+
selectedDate: selectedDate,
|
|
99
|
+
onYearSelect: handleOnYearSelect,
|
|
100
|
+
today: today
|
|
101
|
+
}));
|
|
102
|
+
};
|
|
103
|
+
|
|
104
|
+
var DatePicker = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n padding-top: 16px;\n background-color: ", ";\n box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);\n border: ", ";\n border-radius: 4px;\n width: fit-content;\n font-family: ", ";\n font-size: ", ";\n color: ", ";\n font-weight: ", ";\n"])), function (props) {
|
|
105
|
+
return props.theme.dateInput.pickerBackgroundColor;
|
|
106
|
+
}, function (props) {
|
|
107
|
+
return "".concat(props.theme.dateInput.pickerBorderWidth, " ").concat(props.theme.dateInput.pickerBorderStyle, "\n ").concat(props.theme.dateInput.pickerBorderColor);
|
|
108
|
+
}, function (props) {
|
|
109
|
+
return props.theme.dateInput.pickerFontFamily;
|
|
110
|
+
}, function (props) {
|
|
111
|
+
return props.theme.dateInput.pickerFontSize;
|
|
112
|
+
}, function (props) {
|
|
113
|
+
return props.theme.dateInput.pickerFontColor;
|
|
114
|
+
}, function (props) {
|
|
115
|
+
return props.theme.dateInput.pickerFontWeight;
|
|
116
|
+
});
|
|
117
|
+
|
|
118
|
+
var PickerHeader = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n box-sizing: border-box;\n display: flex;\n gap: 8px;\n align-items: center;\n justify-content: space-between;\n padding: 0px 16px;\n"])));
|
|
119
|
+
|
|
120
|
+
var HeaderButton = _styledComponents["default"].button(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n justify-content: center;\n width: 24px;\n height: 24px;\n padding: 0px;\n color: ", ";\n background-color: ", ";\n border-radius: 4px;\n border: none;\n cursor: pointer;\n\n &:hover {\n color: ", ";\n background-color: ", ";\n }\n &:focus {\n outline: ", ";\n }\n &:active {\n color: ", ";\n background-color: ", ";\n }\n svg {\n width: 24px;\n height: 24px;\n }\n"])), function (props) {
|
|
121
|
+
return props.theme.dateInput.pickerHeaderFontColor;
|
|
122
|
+
}, function (props) {
|
|
123
|
+
return props.theme.dateInput.pickerHeaderBackgroundColor;
|
|
124
|
+
}, function (props) {
|
|
125
|
+
return props.theme.dateInput.pickerHeaderHoverFontColor;
|
|
126
|
+
}, function (props) {
|
|
127
|
+
return props.theme.dateInput.pickerHeaderHoverBackgroundColor;
|
|
128
|
+
}, function (props) {
|
|
129
|
+
return "".concat(props.theme.dateInput.pickerFocusColor, " solid\n ").concat(props.theme.dateInput.pickerFocusWidth);
|
|
130
|
+
}, function (props) {
|
|
131
|
+
return props.theme.dateInput.pickerHeaderActiveFontColor;
|
|
132
|
+
}, function (props) {
|
|
133
|
+
return props.theme.dateInput.pickerHeaderActiveBackgroundColor;
|
|
134
|
+
});
|
|
135
|
+
|
|
136
|
+
var HeaderYearTrigger = (0, _styledComponents["default"])(HeaderButton)(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n gap: 8px;\n height: 40px;\n width: 172px;\n"])));
|
|
137
|
+
|
|
138
|
+
var HeaderYearTriggerLabel = _styledComponents["default"].span(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n justify-content: center;\n font-family: ", ";\n font-size: ", ";\n"])), function (props) {
|
|
139
|
+
return props.theme.dateInput.pickerFontFamily;
|
|
140
|
+
}, function (props) {
|
|
141
|
+
return props.theme.dateInput.pickerHeaderFontSize;
|
|
142
|
+
});
|
|
143
|
+
|
|
144
|
+
var _default = /*#__PURE__*/_react["default"].memo(DxcDatePicker);
|
|
145
|
+
|
|
146
|
+
exports["default"] = _default;
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports.upCaret = exports.rightCaret = exports.leftCaret = exports.downCaret = exports.calendarIcon = void 0;
|
|
9
|
+
|
|
10
|
+
var _react = _interopRequireDefault(require("react"));
|
|
11
|
+
|
|
12
|
+
var calendarIcon = /*#__PURE__*/_react["default"].createElement("svg", {
|
|
13
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
14
|
+
height: "24",
|
|
15
|
+
viewBox: "0 0 24 24",
|
|
16
|
+
width: "24",
|
|
17
|
+
fill: "currentColor"
|
|
18
|
+
}, /*#__PURE__*/_react["default"].createElement("path", {
|
|
19
|
+
d: "M0 0h24v24H0z",
|
|
20
|
+
fill: "none"
|
|
21
|
+
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
22
|
+
d: "M20 3h-1V1h-2v2H7V1H5v2H4c-1.1 0-2 .9-2 2v16c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm0 18H4V8h16v13z"
|
|
23
|
+
}));
|
|
24
|
+
|
|
25
|
+
exports.calendarIcon = calendarIcon;
|
|
26
|
+
|
|
27
|
+
var leftCaret = /*#__PURE__*/_react["default"].createElement("svg", {
|
|
28
|
+
fill: "currentColor",
|
|
29
|
+
focusable: "false",
|
|
30
|
+
viewBox: "0 0 24 24"
|
|
31
|
+
}, /*#__PURE__*/_react["default"].createElement("path", {
|
|
32
|
+
d: "M15.41 16.59L10.83 12l4.58-4.59L14 6l-6 6 6 6 1.41-1.41z"
|
|
33
|
+
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
34
|
+
fill: "none",
|
|
35
|
+
d: "M0 0h24v24H0V0z"
|
|
36
|
+
}));
|
|
37
|
+
|
|
38
|
+
exports.leftCaret = leftCaret;
|
|
39
|
+
|
|
40
|
+
var rightCaret = /*#__PURE__*/_react["default"].createElement("svg", {
|
|
41
|
+
fill: "currentColor",
|
|
42
|
+
focusable: "false",
|
|
43
|
+
viewBox: "0 0 24 24"
|
|
44
|
+
}, /*#__PURE__*/_react["default"].createElement("path", {
|
|
45
|
+
d: "M8.59 16.59L13.17 12 8.59 7.41 10 6l6 6-6 6-1.41-1.41z"
|
|
46
|
+
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
47
|
+
fill: "none",
|
|
48
|
+
d: "M0 0h24v24H0V0z"
|
|
49
|
+
}));
|
|
50
|
+
|
|
51
|
+
exports.rightCaret = rightCaret;
|
|
52
|
+
|
|
53
|
+
var downCaret = /*#__PURE__*/_react["default"].createElement("svg", {
|
|
54
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
55
|
+
width: "24",
|
|
56
|
+
height: "24",
|
|
57
|
+
viewBox: "0 0 24 24"
|
|
58
|
+
}, /*#__PURE__*/_react["default"].createElement("path", {
|
|
59
|
+
d: "M7.5 10L12.5 15L17.5 10H7.5Z",
|
|
60
|
+
fill: "currentColor"
|
|
61
|
+
}));
|
|
62
|
+
|
|
63
|
+
exports.downCaret = downCaret;
|
|
64
|
+
|
|
65
|
+
var upCaret = /*#__PURE__*/_react["default"].createElement("svg", {
|
|
66
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
67
|
+
height: "24",
|
|
68
|
+
width: "24",
|
|
69
|
+
viewBox: "0 0 24 24"
|
|
70
|
+
}, /*#__PURE__*/_react["default"].createElement("path", {
|
|
71
|
+
d: "m7 14 5-5 5 5Z",
|
|
72
|
+
fill: "currentColor"
|
|
73
|
+
}));
|
|
74
|
+
|
|
75
|
+
exports.upCaret = upCaret;
|
|
@@ -0,0 +1,126 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
6
|
+
|
|
7
|
+
Object.defineProperty(exports, "__esModule", {
|
|
8
|
+
value: true
|
|
9
|
+
});
|
|
10
|
+
exports["default"] = void 0;
|
|
11
|
+
|
|
12
|
+
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
|
|
13
|
+
|
|
14
|
+
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
15
|
+
|
|
16
|
+
var _dayjs = _interopRequireDefault(require("dayjs"));
|
|
17
|
+
|
|
18
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
19
|
+
|
|
20
|
+
var _styledComponents = _interopRequireDefault(require("styled-components"));
|
|
21
|
+
|
|
22
|
+
var _templateObject, _templateObject2;
|
|
23
|
+
|
|
24
|
+
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
25
|
+
|
|
26
|
+
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
27
|
+
|
|
28
|
+
var getYearsArray = function getYearsArray() {
|
|
29
|
+
var yearList = [];
|
|
30
|
+
|
|
31
|
+
for (var i = 1899; i <= 2100; i++) {
|
|
32
|
+
yearList.push(i);
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
return yearList;
|
|
36
|
+
};
|
|
37
|
+
|
|
38
|
+
var yearList = getYearsArray();
|
|
39
|
+
|
|
40
|
+
var YearPicker = function YearPicker(_ref) {
|
|
41
|
+
var onYearSelect = _ref.onYearSelect,
|
|
42
|
+
selectedDate = _ref.selectedDate,
|
|
43
|
+
today = _ref.today;
|
|
44
|
+
|
|
45
|
+
var _useState = (0, _react.useState)(selectedDate ? selectedDate.get("year") : (0, _dayjs["default"])().get("year")),
|
|
46
|
+
_useState2 = (0, _slicedToArray2["default"])(_useState, 2),
|
|
47
|
+
yearToFocus = _useState2[0],
|
|
48
|
+
setYearToFocus = _useState2[1];
|
|
49
|
+
|
|
50
|
+
(0, _react.useEffect)(function () {
|
|
51
|
+
var _yearToFocusEl$scroll;
|
|
52
|
+
|
|
53
|
+
var yearToFocusEl = document.getElementById("year_".concat(yearToFocus));
|
|
54
|
+
yearToFocusEl === null || yearToFocusEl === void 0 ? void 0 : (_yearToFocusEl$scroll = yearToFocusEl.scrollIntoView) === null || _yearToFocusEl$scroll === void 0 ? void 0 : _yearToFocusEl$scroll.call(yearToFocusEl, {
|
|
55
|
+
block: "nearest",
|
|
56
|
+
inline: "start"
|
|
57
|
+
});
|
|
58
|
+
yearToFocusEl === null || yearToFocusEl === void 0 ? void 0 : yearToFocusEl.focus();
|
|
59
|
+
}, [yearToFocus]);
|
|
60
|
+
|
|
61
|
+
var handleDayKeyboardEvent = function handleDayKeyboardEvent(event) {
|
|
62
|
+
switch (event.key) {
|
|
63
|
+
case "ArrowUp":
|
|
64
|
+
setYearToFocus(function (prev) {
|
|
65
|
+
return prev > 1899 ? prev - 1 : prev;
|
|
66
|
+
});
|
|
67
|
+
break;
|
|
68
|
+
|
|
69
|
+
case "ArrowDown":
|
|
70
|
+
setYearToFocus(function (prev) {
|
|
71
|
+
return prev < 2100 ? prev + 1 : prev;
|
|
72
|
+
});
|
|
73
|
+
break;
|
|
74
|
+
}
|
|
75
|
+
};
|
|
76
|
+
|
|
77
|
+
return /*#__PURE__*/_react["default"].createElement(YearPickerContainer, null, yearList.map(function (year) {
|
|
78
|
+
return /*#__PURE__*/_react["default"].createElement(YearPickerButton, {
|
|
79
|
+
"aria-label": year,
|
|
80
|
+
key: year,
|
|
81
|
+
selected: (selectedDate === null || selectedDate === void 0 ? void 0 : selectedDate.get("year")) === year,
|
|
82
|
+
"aria-selected": (selectedDate === null || selectedDate === void 0 ? void 0 : selectedDate.get("year")) === year,
|
|
83
|
+
tabIndex: yearToFocus === year ? 0 : -1,
|
|
84
|
+
isCurrentYear: today.get("year") === year,
|
|
85
|
+
onKeyDown: function onKeyDown(event) {
|
|
86
|
+
return handleDayKeyboardEvent(event);
|
|
87
|
+
},
|
|
88
|
+
id: "year_".concat(year),
|
|
89
|
+
onClick: function onClick() {
|
|
90
|
+
onYearSelect(year);
|
|
91
|
+
}
|
|
92
|
+
}, year);
|
|
93
|
+
}));
|
|
94
|
+
};
|
|
95
|
+
|
|
96
|
+
var YearPickerContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n box-sizing: border-box;\n display: flex;\n flex-direction: column;\n gap: 4px;\n align-items: center;\n overflow-y: scroll;\n width: 292px;\n height: 312px;\n padding: 2px 8px 8px 8px;\n"])));
|
|
97
|
+
|
|
98
|
+
var YearPickerButton = _styledComponents["default"].button(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n justify-content: center;\n width: 80px;\n min-height: 40px;\n line-height: 21px;\n background-color: transparent;\n border: none;\n border-radius: 50px;\n cursor: pointer;\n font-family: ", ";\n font-size: ", ";\n color: ", ";\n font-weight: ", ";\n\n ", "\n\n &:hover, &:focus, &:active {\n font-size: ", ";\n line-height: 36px;\n }\n &:hover {\n color: ", ";\n background-color: ", ";\n }\n &:focus {\n color: ", ";\n outline: ", ";\n }\n &:active {\n color: ", ";\n background-color: ", " !important;\n }\n"])), function (props) {
|
|
99
|
+
return props.theme.dateInput.pickerFontFamily;
|
|
100
|
+
}, function (props) {
|
|
101
|
+
return props.theme.dateInput.pickerFontSize;
|
|
102
|
+
}, function (props) {
|
|
103
|
+
return props.theme.dateInput.pickerFontColor;
|
|
104
|
+
}, function (props) {
|
|
105
|
+
return props.theme.dateInput.pickerFontWeight;
|
|
106
|
+
}, function (props) {
|
|
107
|
+
return props.selected ? "font-size: ".concat(props.theme.dateInput.pickerInteractedYearFontSize, ";\n line-height: 36px;\n color: ").concat(props.theme.dateInput.pickerSelectedFontColor, " !important;\n background-color: ").concat(props.theme.dateInput.pickerSelectedBackgroundColor, " !important;") : props.isCurrentYear ? "border: 1px solid ".concat(props.theme.dateInput.pickerCurrentDateBorderColor, "; \n color: ").concat(props.theme.dateInput.pickerCurrentYearFontColor, ";") : "";
|
|
108
|
+
}, function (props) {
|
|
109
|
+
return props.theme.dateInput.pickerInteractedYearFontSize;
|
|
110
|
+
}, function (props) {
|
|
111
|
+
return props.theme.dateInput.pickerHoverFontColor;
|
|
112
|
+
}, function (props) {
|
|
113
|
+
return props.theme.dateInput.pickerHoverBackgroundColor;
|
|
114
|
+
}, function (props) {
|
|
115
|
+
return props.theme.dateInput.pickerHoverFontColor;
|
|
116
|
+
}, function (props) {
|
|
117
|
+
return "".concat(props.theme.dateInput.pickerFocusColor, " solid\n ").concat(props.theme.dateInput.pickerFocusWidth);
|
|
118
|
+
}, function (props) {
|
|
119
|
+
return props.theme.dateInput.pickerActiveFontColor;
|
|
120
|
+
}, function (props) {
|
|
121
|
+
return props.theme.dateInput.pickerActiveBackgroundColor;
|
|
122
|
+
});
|
|
123
|
+
|
|
124
|
+
var _default = /*#__PURE__*/_react["default"].memo(YearPicker);
|
|
125
|
+
|
|
126
|
+
exports["default"] = _default;
|
package/date-input/types.d.ts
CHANGED
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { Dayjs } from "dayjs";
|
|
1
2
|
declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
|
|
2
3
|
declare type Margin = {
|
|
3
4
|
top?: Space;
|
|
@@ -14,6 +15,10 @@ declare type Props = {
|
|
|
14
15
|
* Name attribute of the input element.
|
|
15
16
|
*/
|
|
16
17
|
name?: string;
|
|
18
|
+
/**
|
|
19
|
+
* Initial value of the input element, only when it is uncontrolled.
|
|
20
|
+
*/
|
|
21
|
+
defaultValue?: string;
|
|
17
22
|
/**
|
|
18
23
|
* Value of the input element. If undefined, the component will be uncontrolled and the value will be managed internally by the component.
|
|
19
24
|
*/
|
|
@@ -50,28 +55,31 @@ declare type Props = {
|
|
|
50
55
|
* element of the component. An object including the string value, the
|
|
51
56
|
* error and the date value will be passed to this function.
|
|
52
57
|
* If the string value is a valid date, error will
|
|
53
|
-
* be
|
|
58
|
+
* be undefined. Also, if the string value is not a valid date, date will be undefined.
|
|
54
59
|
*/
|
|
55
60
|
onChange?: (val: {
|
|
56
61
|
value: string;
|
|
57
|
-
error
|
|
58
|
-
date
|
|
62
|
+
error?: string;
|
|
63
|
+
date?: Date;
|
|
59
64
|
}) => void;
|
|
60
65
|
/**
|
|
61
66
|
* This function will be called when the input element loses the focus.
|
|
62
67
|
* An object including the string value, the error and the date value
|
|
63
68
|
* will be passed to this function. If the string value is a valid date, error will
|
|
64
|
-
* be
|
|
69
|
+
* be undefined. Also, if the string value is not a valid date, date will be undefined.
|
|
65
70
|
*/
|
|
66
71
|
onBlur?: (val: {
|
|
67
72
|
value: string;
|
|
68
|
-
error
|
|
69
|
-
date
|
|
73
|
+
error?: string;
|
|
74
|
+
date?: Date;
|
|
70
75
|
}) => void;
|
|
71
76
|
/**
|
|
72
|
-
* If it is defined
|
|
73
|
-
* the error below the date input
|
|
74
|
-
*
|
|
77
|
+
* If it is a defined value and also a truthy string, the component will
|
|
78
|
+
* change its appearance, showing the error below the date input
|
|
79
|
+
* component. If the defined value is an empty string, it will reserve a
|
|
80
|
+
* space below the component for a future error, but it would not change
|
|
81
|
+
* its look. In case of being undefined or null, both the appearance and
|
|
82
|
+
* the space for the error message would not be modified.
|
|
75
83
|
*/
|
|
76
84
|
error?: string;
|
|
77
85
|
/**
|
|
@@ -93,6 +101,56 @@ declare type Props = {
|
|
|
93
101
|
*/
|
|
94
102
|
tabIndex?: number;
|
|
95
103
|
};
|
|
104
|
+
export declare type DatePickerPropsType = {
|
|
105
|
+
/**
|
|
106
|
+
* Initial selected date value. If invalid the actual date will be used instead.
|
|
107
|
+
*/
|
|
108
|
+
date: Dayjs;
|
|
109
|
+
/**
|
|
110
|
+
* Function called when a date is selected.
|
|
111
|
+
*/
|
|
112
|
+
onDateSelect: (date: Dayjs) => void;
|
|
113
|
+
/**
|
|
114
|
+
* Id assigned to the date picker.
|
|
115
|
+
*/
|
|
116
|
+
id: string;
|
|
117
|
+
};
|
|
118
|
+
export declare type CalendarPropsType = {
|
|
119
|
+
/**
|
|
120
|
+
* Initial selected date value. If invalid the actual date will be used instead.
|
|
121
|
+
*/
|
|
122
|
+
selectedDate: Dayjs;
|
|
123
|
+
/**
|
|
124
|
+
* Date showed by the calendar.
|
|
125
|
+
*/
|
|
126
|
+
innerDate: Dayjs;
|
|
127
|
+
/**
|
|
128
|
+
* Function called when the date showned needs to be updated
|
|
129
|
+
*/
|
|
130
|
+
onInnerDateChange: (date: Dayjs) => void;
|
|
131
|
+
/**
|
|
132
|
+
* Function called when a date is selected.
|
|
133
|
+
*/
|
|
134
|
+
onDaySelect: (date: Dayjs) => void;
|
|
135
|
+
/**
|
|
136
|
+
* Current date
|
|
137
|
+
*/
|
|
138
|
+
today: Dayjs;
|
|
139
|
+
};
|
|
140
|
+
export declare type YearPickerPropsType = {
|
|
141
|
+
/**
|
|
142
|
+
* Initial selected date value. If invalid the actual date will be used instead.
|
|
143
|
+
*/
|
|
144
|
+
selectedDate: Dayjs;
|
|
145
|
+
/**
|
|
146
|
+
* Function called when a year is selected.
|
|
147
|
+
*/
|
|
148
|
+
onYearSelect: (year: number) => void;
|
|
149
|
+
/**
|
|
150
|
+
* Current date
|
|
151
|
+
*/
|
|
152
|
+
today: Dayjs;
|
|
153
|
+
};
|
|
96
154
|
/**
|
|
97
155
|
* Reference to the component.
|
|
98
156
|
*/
|
package/dialog/Dialog.js
CHANGED
|
@@ -13,21 +13,17 @@ var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
|
|
|
13
13
|
|
|
14
14
|
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
|
|
15
15
|
|
|
16
|
-
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
17
|
-
|
|
18
16
|
var _react = _interopRequireWildcard(require("react"));
|
|
19
17
|
|
|
20
18
|
var _styledComponents = _interopRequireWildcard(require("styled-components"));
|
|
21
19
|
|
|
22
|
-
var _Dialog = _interopRequireDefault(require("@material-ui/core/Dialog"));
|
|
23
|
-
|
|
24
20
|
var _variables = require("../common/variables.js");
|
|
25
21
|
|
|
26
|
-
var _useTheme = _interopRequireDefault(require("../useTheme
|
|
22
|
+
var _useTheme = _interopRequireDefault(require("../useTheme"));
|
|
27
23
|
|
|
28
|
-
var _BackgroundColorContext = require("../BackgroundColorContext
|
|
24
|
+
var _BackgroundColorContext = require("../BackgroundColorContext");
|
|
29
25
|
|
|
30
|
-
var _templateObject, _templateObject2, _templateObject3, _templateObject4;
|
|
26
|
+
var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7;
|
|
31
27
|
|
|
32
28
|
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
33
29
|
|
|
@@ -41,15 +37,10 @@ var DxcDialog = function DxcDialog(_ref) {
|
|
|
41
37
|
_ref$overlay = _ref.overlay,
|
|
42
38
|
overlay = _ref$overlay === void 0 ? true : _ref$overlay,
|
|
43
39
|
onBackgroundClick = _ref.onBackgroundClick,
|
|
44
|
-
padding = _ref.padding,
|
|
40
|
+
_ref$padding = _ref.padding,
|
|
41
|
+
padding = _ref$padding === void 0 ? "small" : _ref$padding,
|
|
45
42
|
_ref$tabIndex = _ref.tabIndex,
|
|
46
43
|
tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
|
|
47
|
-
|
|
48
|
-
var _useState = (0, _react.useState)(false),
|
|
49
|
-
_useState2 = (0, _slicedToArray2["default"])(_useState, 2),
|
|
50
|
-
isResponsive = _useState2[0],
|
|
51
|
-
setIsResponsive = _useState2[1];
|
|
52
|
-
|
|
53
44
|
var colorsTheme = (0, _useTheme["default"])();
|
|
54
45
|
|
|
55
46
|
var handleClose = function handleClose() {
|
|
@@ -60,31 +51,37 @@ var DxcDialog = function DxcDialog(_ref) {
|
|
|
60
51
|
onBackgroundClick === null || onBackgroundClick === void 0 ? void 0 : onBackgroundClick();
|
|
61
52
|
};
|
|
62
53
|
|
|
63
|
-
var
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
handleResize(window.innerWidth);
|
|
54
|
+
var handleOnKeyDown = function handleOnKeyDown(event) {
|
|
55
|
+
if (event.key === "Escape") {
|
|
56
|
+
event.preventDefault();
|
|
57
|
+
handleClose();
|
|
58
|
+
}
|
|
69
59
|
};
|
|
70
60
|
|
|
71
61
|
(0, _react.useEffect)(function () {
|
|
72
|
-
|
|
73
|
-
|
|
62
|
+
if (isCloseVisible) {
|
|
63
|
+
window.addEventListener("keydown", handleOnKeyDown);
|
|
64
|
+
}
|
|
65
|
+
|
|
74
66
|
return function () {
|
|
75
|
-
window.removeEventListener("
|
|
67
|
+
window.removeEventListener("keydown", handleOnKeyDown);
|
|
76
68
|
};
|
|
77
|
-
}, []);
|
|
69
|
+
}, [isCloseVisible]);
|
|
78
70
|
return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
|
|
79
71
|
theme: colorsTheme.dialog
|
|
80
|
-
}, /*#__PURE__*/_react["default"].createElement(DialogContainer, {
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
72
|
+
}, /*#__PURE__*/_react["default"].createElement(BodyStyle, null), /*#__PURE__*/_react["default"].createElement(DialogContainer, {
|
|
73
|
+
role: "presentation"
|
|
74
|
+
}, overlay && /*#__PURE__*/_react["default"].createElement(Overlay, {
|
|
75
|
+
onClick: handleOverlayClick
|
|
76
|
+
}), /*#__PURE__*/_react["default"].createElement(Dialog, {
|
|
77
|
+
role: "dialog",
|
|
78
|
+
"aria-modal": overlay,
|
|
79
|
+
isCloseVisible: isCloseVisible
|
|
80
|
+
}, /*#__PURE__*/_react["default"].createElement(Children, {
|
|
81
|
+
padding: padding
|
|
82
|
+
}, /*#__PURE__*/_react["default"].createElement(_BackgroundColorContext.BackgroundColorProvider, {
|
|
83
|
+
color: colorsTheme.dialog.backgroundColor
|
|
84
|
+
}, children)), isCloseVisible && /*#__PURE__*/_react["default"].createElement(CloseIconContainer, {
|
|
88
85
|
onClick: handleClose,
|
|
89
86
|
tabIndex: tabIndex
|
|
90
87
|
}, /*#__PURE__*/_react["default"].createElement(CloseIcon, {
|
|
@@ -98,28 +95,34 @@ var DxcDialog = function DxcDialog(_ref) {
|
|
|
98
95
|
fill: "none"
|
|
99
96
|
}), /*#__PURE__*/_react["default"].createElement("path", {
|
|
100
97
|
d: "M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12 19 6.41z"
|
|
101
|
-
})))
|
|
102
|
-
color: colorsTheme.dialog.backgroundColor
|
|
103
|
-
}, children))));
|
|
98
|
+
}))))));
|
|
104
99
|
};
|
|
105
100
|
|
|
106
|
-
var
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
return props.
|
|
101
|
+
var BodyStyle = (0, _styledComponents.createGlobalStyle)(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n body {\n overflow: hidden;\n }\n"])));
|
|
102
|
+
|
|
103
|
+
var DialogContainer = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n justify-content: center;\n position: fixed;\n inset: 0px;\n height: 100%;\n z-index: 1300;\n"])));
|
|
104
|
+
|
|
105
|
+
var Overlay = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n position: fixed;\n inset: 0px;\n height: 100%;\n background-color: ", ";\n opacity: ", ";\n"])), function (props) {
|
|
106
|
+
return props.theme.overlayColor;
|
|
112
107
|
}, function (props) {
|
|
108
|
+
return props.theme.overlayOpacity;
|
|
109
|
+
});
|
|
110
|
+
|
|
111
|
+
var Dialog = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n justify-content: space-between;\n z-index: 1300;\n background-color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n ", "\n box-sizing: border-box;\n box-shadow: ", ";\n border-radius: 4px;\n position: relative;\n\n @media (min-width: ", "rem) {\n max-width: 80%;\n min-width: 800px;\n }\n\n @media (max-width: ", "rem) {\n //mobile phones\n max-width: 92%;\n min-width: 92%;\n }\n"])), function (props) {
|
|
113
112
|
return props.theme.backgroundColor;
|
|
114
113
|
}, function (props) {
|
|
115
|
-
return props.
|
|
114
|
+
return props.theme.fontFamily;
|
|
116
115
|
}, function (props) {
|
|
117
|
-
return props.
|
|
116
|
+
return props.theme.fontSize;
|
|
118
117
|
}, function (props) {
|
|
119
|
-
return props.
|
|
118
|
+
return props.theme.fontWeight;
|
|
120
119
|
}, function (props) {
|
|
121
|
-
return
|
|
120
|
+
return props.isCloseVisible && "min-height: 72px; padding-top: 24px;";
|
|
122
121
|
}, function (props) {
|
|
122
|
+
return "".concat(props.theme.boxShadowOffsetX, " ").concat(props.theme.boxShadowOffsetY, " ").concat(props.theme.boxShadowBlur, " ").concat(props.theme.boxShadowColor);
|
|
123
|
+
}, _variables.responsiveSizes.medium, _variables.responsiveSizes.medium);
|
|
124
|
+
|
|
125
|
+
var Children = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n width: 100%;\n padding: ", ";\n padding-top: ", ";\n padding-right: ", ";\n padding-bottom: ", ";\n padding-left: ", ";\n"])), function (props) {
|
|
123
126
|
return props.padding && (0, _typeof2["default"])(props.padding) !== "object" ? _variables.spaces[props.padding] : _variables.spaces["small"];
|
|
124
127
|
}, function (props) {
|
|
125
128
|
return props.padding && (0, _typeof2["default"])(props.padding) === "object" && props.padding.top ? _variables.spaces[props.padding.top] : "";
|
|
@@ -131,13 +134,7 @@ var DialogContainer = (0, _styledComponents["default"])(_Dialog["default"])(_tem
|
|
|
131
134
|
return props.padding && (0, _typeof2["default"])(props.padding) === "object" && props.padding.left ? _variables.spaces[props.padding.left] : "";
|
|
132
135
|
});
|
|
133
136
|
|
|
134
|
-
var
|
|
135
|
-
|
|
136
|
-
var CloseIconContainer = _styledComponents["default"].button(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n justify-content: flex-end;\n position: absolute;\n top: ", ";\n right: ", ";\n cursor: pointer;\n padding: 0;\n margin: 0;\n background: none;\n color: ", ";\n width: ", ";\n height: ", ";\n border: none;\n"])), function (props) {
|
|
137
|
-
return props.theme.closeIconTopPosition;
|
|
138
|
-
}, function (props) {
|
|
139
|
-
return props.theme.closeIconRightPosition;
|
|
140
|
-
}, function (props) {
|
|
137
|
+
var CloseIconContainer = _styledComponents["default"].button(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n cursor: pointer;\n padding: 0;\n margin: 0;\n background: none;\n border: none;\n position: absolute;\n top: 20px;\n right: 20px;\n color: ", ";\n width: ", ";\n height: ", ";\n"])), function (props) {
|
|
141
138
|
return props.theme.closeIconColor;
|
|
142
139
|
}, function (props) {
|
|
143
140
|
return props.theme.closeIconWidth;
|
|
@@ -145,7 +142,7 @@ var CloseIconContainer = _styledComponents["default"].button(_templateObject3 ||
|
|
|
145
142
|
return props.theme.closeIconHeight;
|
|
146
143
|
});
|
|
147
144
|
|
|
148
|
-
var CloseIcon = _styledComponents["default"].svg(
|
|
145
|
+
var CloseIcon = _styledComponents["default"].svg(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n background-color: ", ";\n width: ", ";\n height: ", ";\n border-radius: ", ";\n border-width: ", ";\n border-style: ", ";\n border-color: ", ";\n"])), function (props) {
|
|
149
146
|
return props.theme.closeIconBackgroundColor;
|
|
150
147
|
}, function (props) {
|
|
151
148
|
return props.theme.closeIconWidth;
|