@1money/component-ui 0.0.19 → 0.0.20
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/es/components/Alert/Alert.js +5 -6
- package/es/components/Alert/style/Alert.css +1 -1
- package/es/components/Button/Button.js +29 -1
- package/es/components/Button/constants.d.ts +14 -1
- package/es/components/Button/constants.js +23 -3
- package/es/components/Button/interface.d.ts +9 -0
- package/es/components/Cell/Cell.d.ts +5 -0
- package/es/components/Cell/Cell.js +57 -0
- package/es/components/Cell/index.d.ts +4 -0
- package/es/components/Cell/index.js +5 -0
- package/es/components/Cell/interface.d.ts +12 -0
- package/es/components/Cell/interface.js +2 -0
- package/es/components/Cell/style/Cell.css +1 -0
- package/es/components/Cell/style/css.js +2 -0
- package/es/components/Cell/style/index.d.ts +1 -0
- package/es/components/Cell/style/index.js +2 -0
- package/es/components/Dialog/Dialog.d.ts +4 -0
- package/es/components/Dialog/Dialog.js +383 -0
- package/es/components/Dialog/constants.d.ts +60 -0
- package/es/components/Dialog/constants.js +57 -0
- package/es/components/Dialog/index.d.ts +4 -0
- package/es/components/Dialog/index.js +5 -0
- package/es/components/{Modal → Dialog}/interface.d.ts +7 -7
- package/es/components/Dialog/interface.js +2 -0
- package/es/components/Dialog/style/Dialog.css +1 -0
- package/es/components/Dialog/style/css.js +2 -0
- package/es/components/Dialog/style/index.d.ts +1 -0
- package/es/components/Dialog/style/index.js +2 -0
- package/es/components/Divider/Divider.js +15 -18
- package/es/components/Divider/constants.d.ts +36 -0
- package/es/components/Divider/constants.js +41 -0
- package/es/components/Divider/interface.d.ts +2 -3
- package/es/components/Drawer/Drawer.js +13 -129
- package/es/components/Drawer/constants.d.ts +8 -5
- package/es/components/Drawer/constants.js +9 -6
- package/es/components/Drawer/hooks/index.d.ts +4 -0
- package/es/components/Drawer/hooks/index.js +5 -0
- package/es/components/Drawer/hooks/useBodyScrollLock.d.ts +1 -0
- package/es/components/Drawer/hooks/useBodyScrollLock.js +29 -0
- package/es/components/Drawer/hooks/useDialogFocus.d.ts +2 -0
- package/es/components/Drawer/hooks/useDialogFocus.js +22 -0
- package/es/components/Drawer/hooks/useDrawerTransition.d.ts +4 -0
- package/es/components/Drawer/hooks/useDrawerTransition.js +57 -0
- package/es/components/Drawer/hooks/useEscapeClose.d.ts +1 -0
- package/es/components/Drawer/hooks/useEscapeClose.js +16 -0
- package/es/components/ProForm/index.d.ts +2 -2
- package/es/components/ProForm/index.js +2 -2
- package/es/components/ProForm/interface.d.ts +3 -3
- package/es/components/ProForm/layouts/DialogForm.d.ts +3 -0
- package/es/components/ProForm/layouts/DialogForm.js +74 -0
- package/es/components/ProForm/layouts/index.d.ts +1 -1
- package/es/components/ProForm/layouts/index.js +2 -2
- package/es/components/ProForm/style/ProForm.css +1 -1
- package/es/components/Select/Select.js +5 -5
- package/es/components/Select/SelectFieldShell.js +7 -7
- package/es/components/Select/SelectOptionContent.js +5 -5
- package/es/components/Select/constants.d.ts +37 -13
- package/es/components/Select/constants.js +36 -20
- package/es/components/Select/style/Select.css +1 -1
- package/es/components/Switch/Switch.js +7 -7
- package/es/components/Switch/constants.d.ts +23 -9
- package/es/components/Switch/constants.js +26 -11
- package/es/components/Switch/interface.d.ts +2 -2
- package/es/index.css +1 -1
- package/es/index.d.ts +6 -4
- package/es/index.js +4 -3
- package/lib/components/Alert/Alert.js +5 -6
- package/lib/components/Alert/style/Alert.css +1 -1
- package/lib/components/Button/Button.js +29 -1
- package/lib/components/Button/constants.d.ts +14 -1
- package/lib/components/Button/constants.js +23 -3
- package/lib/components/Button/interface.d.ts +9 -0
- package/lib/components/Cell/Cell.d.ts +5 -0
- package/lib/components/Cell/Cell.js +66 -0
- package/lib/components/Cell/index.d.ts +4 -0
- package/lib/components/Cell/index.js +33 -0
- package/lib/components/Cell/interface.d.ts +12 -0
- package/lib/components/Cell/interface.js +6 -0
- package/lib/components/Cell/style/Cell.css +1 -0
- package/lib/components/Cell/style/css.js +4 -0
- package/lib/components/Cell/style/index.d.ts +1 -0
- package/lib/components/Cell/style/index.js +4 -0
- package/lib/components/Dialog/Dialog.d.ts +4 -0
- package/lib/components/Dialog/Dialog.js +390 -0
- package/lib/components/Dialog/constants.d.ts +60 -0
- package/lib/components/Dialog/constants.js +64 -0
- package/lib/components/Dialog/index.d.ts +4 -0
- package/lib/components/Dialog/index.js +33 -0
- package/lib/components/{Modal → Dialog}/interface.d.ts +7 -7
- package/lib/components/Dialog/interface.js +6 -0
- package/lib/components/Dialog/style/Dialog.css +1 -0
- package/lib/components/Dialog/style/css.js +4 -0
- package/lib/components/Dialog/style/index.d.ts +1 -0
- package/lib/components/Dialog/style/index.js +4 -0
- package/lib/components/Divider/Divider.js +16 -18
- package/lib/components/Divider/constants.d.ts +36 -0
- package/lib/components/Divider/constants.js +48 -0
- package/lib/components/Divider/interface.d.ts +2 -3
- package/lib/components/Drawer/Drawer.js +14 -130
- package/lib/components/Drawer/constants.d.ts +8 -5
- package/lib/components/Drawer/constants.js +10 -7
- package/lib/components/Drawer/hooks/index.d.ts +4 -0
- package/lib/components/Drawer/hooks/index.js +34 -0
- package/lib/components/Drawer/hooks/useBodyScrollLock.d.ts +1 -0
- package/lib/components/Drawer/hooks/useBodyScrollLock.js +35 -0
- package/lib/components/Drawer/hooks/useDialogFocus.d.ts +2 -0
- package/lib/components/Drawer/hooks/useDialogFocus.js +28 -0
- package/lib/components/Drawer/hooks/useDrawerTransition.d.ts +4 -0
- package/lib/components/Drawer/hooks/useDrawerTransition.js +64 -0
- package/lib/components/Drawer/hooks/useEscapeClose.d.ts +1 -0
- package/lib/components/Drawer/hooks/useEscapeClose.js +22 -0
- package/lib/components/ProForm/index.d.ts +2 -2
- package/lib/components/ProForm/index.js +8 -8
- package/lib/components/ProForm/interface.d.ts +3 -3
- package/lib/components/ProForm/layouts/DialogForm.d.ts +3 -0
- package/lib/components/ProForm/layouts/DialogForm.js +81 -0
- package/lib/components/ProForm/layouts/index.d.ts +1 -1
- package/lib/components/ProForm/layouts/index.js +6 -6
- package/lib/components/ProForm/style/ProForm.css +1 -1
- package/lib/components/Select/Select.js +4 -4
- package/lib/components/Select/SelectFieldShell.js +6 -6
- package/lib/components/Select/SelectOptionContent.js +4 -4
- package/lib/components/Select/constants.d.ts +37 -13
- package/lib/components/Select/constants.js +37 -21
- package/lib/components/Select/style/Select.css +1 -1
- package/lib/components/Switch/Switch.js +6 -6
- package/lib/components/Switch/constants.d.ts +23 -9
- package/lib/components/Switch/constants.js +27 -12
- package/lib/components/Switch/interface.d.ts +2 -2
- package/lib/index.css +1 -1
- package/lib/index.d.ts +6 -4
- package/lib/index.js +21 -14
- package/package.json +11 -6
- package/es/components/Modal/Modal.d.ts +0 -4
- package/es/components/Modal/Modal.js +0 -383
- package/es/components/Modal/constants.d.ts +0 -58
- package/es/components/Modal/constants.js +0 -55
- package/es/components/Modal/index.d.ts +0 -4
- package/es/components/Modal/index.js +0 -5
- package/es/components/Modal/interface.js +0 -2
- package/es/components/Modal/style/Modal.css +0 -1
- package/es/components/Modal/style/css.js +0 -2
- package/es/components/Modal/style/index.d.ts +0 -1
- package/es/components/Modal/style/index.js +0 -2
- package/es/components/ProForm/layouts/ModalForm.d.ts +0 -3
- package/es/components/ProForm/layouts/ModalForm.js +0 -74
- package/lib/components/Modal/Modal.d.ts +0 -4
- package/lib/components/Modal/Modal.js +0 -390
- package/lib/components/Modal/constants.d.ts +0 -58
- package/lib/components/Modal/constants.js +0 -62
- package/lib/components/Modal/index.d.ts +0 -4
- package/lib/components/Modal/index.js +0 -33
- package/lib/components/Modal/interface.js +0 -6
- package/lib/components/Modal/style/Modal.css +0 -1
- package/lib/components/Modal/style/css.js +0 -4
- package/lib/components/Modal/style/index.d.ts +0 -1
- package/lib/components/Modal/style/index.js +0 -4
- package/lib/components/ProForm/layouts/ModalForm.d.ts +0 -3
- package/lib/components/ProForm/layouts/ModalForm.js +0 -81
|
@@ -0,0 +1,390 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports["default"] = exports.Dialog = void 0;
|
|
8
|
+
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
9
|
+
var _jsxRuntime = require("react/jsx-runtime");
|
|
10
|
+
var _hooks = require("@1money/hooks");
|
|
11
|
+
var _classnames = _interopRequireDefault(require("classnames"));
|
|
12
|
+
var _react = require("react");
|
|
13
|
+
var _Button = require("../Button");
|
|
14
|
+
var _Icons = require("../Icons");
|
|
15
|
+
var _Portal = require("../Portal");
|
|
16
|
+
var _Typography = require("../Typography");
|
|
17
|
+
var _ref3 = require("../../utils/ref");
|
|
18
|
+
var _constants = require("./constants");
|
|
19
|
+
require("./style");
|
|
20
|
+
var __rest = void 0 && (void 0).__rest || function (s, e) {
|
|
21
|
+
var t = {};
|
|
22
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
|
|
23
|
+
if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
|
|
24
|
+
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];
|
|
25
|
+
}
|
|
26
|
+
return t;
|
|
27
|
+
};
|
|
28
|
+
var scrollLockCount = 0;
|
|
29
|
+
var getClassName = function getClassName(prefixCls, slot, modifier) {
|
|
30
|
+
var baseClassName = "".concat(_constants.DIALOG_NAMESPACE, "-").concat(prefixCls).concat(slot ? "-".concat(slot) : '');
|
|
31
|
+
return modifier ? "".concat(baseClassName, "-").concat(modifier) : baseClassName;
|
|
32
|
+
};
|
|
33
|
+
var setBodyOverflow = function setBodyOverflow(value) {
|
|
34
|
+
if (typeof document === 'undefined') return;
|
|
35
|
+
document.body.style.overflow = value;
|
|
36
|
+
};
|
|
37
|
+
var lockBodyScroll = function lockBodyScroll() {
|
|
38
|
+
scrollLockCount += 1;
|
|
39
|
+
setBodyOverflow(_constants.DIALOG_DEFAULTS.overflowHidden);
|
|
40
|
+
};
|
|
41
|
+
var unlockBodyScroll = function unlockBodyScroll() {
|
|
42
|
+
scrollLockCount = Math.max(0, scrollLockCount - 1);
|
|
43
|
+
if (scrollLockCount === 0) {
|
|
44
|
+
requestAnimationFrame(function () {
|
|
45
|
+
if (scrollLockCount === 0) {
|
|
46
|
+
setBodyOverflow(_constants.DIALOG_DEFAULTS.overflowReset);
|
|
47
|
+
}
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
};
|
|
51
|
+
var useBodyScrollLock = function useBodyScrollLock(locked) {
|
|
52
|
+
var isLockedRef = (0, _react.useRef)(false);
|
|
53
|
+
(0, _react.useEffect)(function () {
|
|
54
|
+
if (!locked || isLockedRef.current) return undefined;
|
|
55
|
+
isLockedRef.current = true;
|
|
56
|
+
lockBodyScroll();
|
|
57
|
+
return function () {
|
|
58
|
+
if (!isLockedRef.current) return;
|
|
59
|
+
isLockedRef.current = false;
|
|
60
|
+
unlockBodyScroll();
|
|
61
|
+
};
|
|
62
|
+
}, [locked]);
|
|
63
|
+
};
|
|
64
|
+
var usePresence = function usePresence(open, delay) {
|
|
65
|
+
var _useState = (0, _react.useState)(open),
|
|
66
|
+
_useState2 = (0, _slicedToArray2["default"])(_useState, 2),
|
|
67
|
+
mounted = _useState2[0],
|
|
68
|
+
setMounted = _useState2[1];
|
|
69
|
+
var closeTimerRef = (0, _react.useRef)(null);
|
|
70
|
+
(0, _react.useEffect)(function () {
|
|
71
|
+
return function () {
|
|
72
|
+
if (closeTimerRef.current !== null) {
|
|
73
|
+
window.clearTimeout(closeTimerRef.current);
|
|
74
|
+
}
|
|
75
|
+
};
|
|
76
|
+
}, []);
|
|
77
|
+
(0, _react.useEffect)(function () {
|
|
78
|
+
if (open) {
|
|
79
|
+
if (closeTimerRef.current !== null) {
|
|
80
|
+
window.clearTimeout(closeTimerRef.current);
|
|
81
|
+
closeTimerRef.current = null;
|
|
82
|
+
}
|
|
83
|
+
setMounted(true);
|
|
84
|
+
return;
|
|
85
|
+
}
|
|
86
|
+
if (!mounted) return;
|
|
87
|
+
closeTimerRef.current = window.setTimeout(function () {
|
|
88
|
+
setMounted(false);
|
|
89
|
+
closeTimerRef.current = null;
|
|
90
|
+
}, delay);
|
|
91
|
+
}, [delay, mounted, open]);
|
|
92
|
+
return mounted;
|
|
93
|
+
};
|
|
94
|
+
var useDialogFocus = function useDialogFocus(active, dialogRef) {
|
|
95
|
+
var previousActiveElementRef = (0, _react.useRef)(null);
|
|
96
|
+
(0, _react.useEffect)(function () {
|
|
97
|
+
if (!active || typeof document === 'undefined') return undefined;
|
|
98
|
+
previousActiveElementRef.current = document.activeElement instanceof HTMLElement ? document.activeElement : null;
|
|
99
|
+
var frame = window.requestAnimationFrame(function () {
|
|
100
|
+
var _a;
|
|
101
|
+
(_a = dialogRef.current) === null || _a === void 0 ? void 0 : _a.focus();
|
|
102
|
+
});
|
|
103
|
+
return function () {
|
|
104
|
+
window.cancelAnimationFrame(frame);
|
|
105
|
+
};
|
|
106
|
+
}, [active, dialogRef]);
|
|
107
|
+
(0, _react.useEffect)(function () {
|
|
108
|
+
var _a, _b;
|
|
109
|
+
if (active) return;
|
|
110
|
+
(_b = (_a = previousActiveElementRef.current) === null || _a === void 0 ? void 0 : _a.focus) === null || _b === void 0 ? void 0 : _b.call(_a);
|
|
111
|
+
previousActiveElementRef.current = null;
|
|
112
|
+
}, [active]);
|
|
113
|
+
};
|
|
114
|
+
var useEscapeClose = function useEscapeClose(enabled, onClose) {
|
|
115
|
+
(0, _react.useEffect)(function () {
|
|
116
|
+
if (!enabled || typeof document === 'undefined') return undefined;
|
|
117
|
+
var handleKeyDown = function handleKeyDown(event) {
|
|
118
|
+
if (event.key !== _constants.DIALOG_DEFAULTS.escapeKey) return;
|
|
119
|
+
event.preventDefault();
|
|
120
|
+
void (onClose === null || onClose === void 0 ? void 0 : onClose());
|
|
121
|
+
};
|
|
122
|
+
document.addEventListener(_constants.DIALOG_DEFAULTS.keydownEvent, handleKeyDown);
|
|
123
|
+
return function () {
|
|
124
|
+
document.removeEventListener(_constants.DIALOG_DEFAULTS.keydownEvent, handleKeyDown);
|
|
125
|
+
};
|
|
126
|
+
}, [enabled, onClose]);
|
|
127
|
+
};
|
|
128
|
+
var renderTypographyNode = function renderTypographyNode(node, renderText) {
|
|
129
|
+
if (node == null || typeof node === 'boolean') return null;
|
|
130
|
+
if (typeof node === 'string' || typeof node === 'number') {
|
|
131
|
+
return renderText(node);
|
|
132
|
+
}
|
|
133
|
+
return node;
|
|
134
|
+
};
|
|
135
|
+
var renderIllustrationNode = function renderIllustrationNode(illustration) {
|
|
136
|
+
if (!illustration) return null;
|
|
137
|
+
if (typeof illustration === 'string') {
|
|
138
|
+
return (0, _jsxRuntime.jsx)(_Icons.Icons, {
|
|
139
|
+
name: illustration,
|
|
140
|
+
size: _constants.DIALOG_DEFAULTS.illustrationSize
|
|
141
|
+
});
|
|
142
|
+
}
|
|
143
|
+
return /*#__PURE__*/(0, _react.isValidElement)(illustration) ? illustration : null;
|
|
144
|
+
};
|
|
145
|
+
var toVoidHandler = function toVoidHandler(action) {
|
|
146
|
+
return function () {
|
|
147
|
+
void (action === null || action === void 0 ? void 0 : action());
|
|
148
|
+
};
|
|
149
|
+
};
|
|
150
|
+
var createActionHandler = function createActionHandler(action, buttonClick) {
|
|
151
|
+
return function (event) {
|
|
152
|
+
buttonClick === null || buttonClick === void 0 ? void 0 : buttonClick(event);
|
|
153
|
+
if (event.defaultPrevented || !action) return;
|
|
154
|
+
void action();
|
|
155
|
+
};
|
|
156
|
+
};
|
|
157
|
+
var renderControlButton = function renderControlButton(prefixCls, type, iconNode, onClick) {
|
|
158
|
+
return (0, _jsxRuntime.jsx)("button", {
|
|
159
|
+
type: _constants.DIALOG_DEFAULTS.buttonHtmlType,
|
|
160
|
+
className: (0, _classnames["default"])(getClassName(prefixCls, _constants.DIALOG_SLOT.control), getClassName(prefixCls, _constants.DIALOG_SLOT.control, type)),
|
|
161
|
+
"aria-label": _constants.DIALOG_CONTROL_LABELS[type],
|
|
162
|
+
onClick: toVoidHandler(onClick),
|
|
163
|
+
children: iconNode
|
|
164
|
+
});
|
|
165
|
+
};
|
|
166
|
+
var renderActionButton = function renderActionButton(_ref) {
|
|
167
|
+
var prefixCls = _ref.prefixCls,
|
|
168
|
+
kind = _ref.kind,
|
|
169
|
+
text = _ref.text,
|
|
170
|
+
action = _ref.action,
|
|
171
|
+
buttonProps = _ref.buttonProps;
|
|
172
|
+
var _a;
|
|
173
|
+
if (text == null || !action) return null;
|
|
174
|
+
return (0, _jsxRuntime.jsx)(_Button.Button, Object.assign({}, buttonProps, {
|
|
175
|
+
type: _constants.DIALOG_DEFAULTS.buttonHtmlType,
|
|
176
|
+
size: _constants.DIALOG_DEFAULTS.buttonSize,
|
|
177
|
+
color: (_a = buttonProps === null || buttonProps === void 0 ? void 0 : buttonProps.color) !== null && _a !== void 0 ? _a : _constants.DIALOG_DEFAULT_BUTTON_COLORS[kind],
|
|
178
|
+
className: (0, _classnames["default"])(getClassName(prefixCls, _constants.DIALOG_SLOT.actionButton), getClassName(prefixCls, _constants.DIALOG_SLOT.actionButton, kind), buttonProps === null || buttonProps === void 0 ? void 0 : buttonProps.className),
|
|
179
|
+
style: buttonProps === null || buttonProps === void 0 ? void 0 : buttonProps.style,
|
|
180
|
+
onClick: createActionHandler(action, buttonProps === null || buttonProps === void 0 ? void 0 : buttonProps.onClick),
|
|
181
|
+
children: text
|
|
182
|
+
}));
|
|
183
|
+
};
|
|
184
|
+
var resolveFooterNode = function resolveFooterNode(_ref2) {
|
|
185
|
+
var footer = _ref2.footer,
|
|
186
|
+
size = _ref2.size,
|
|
187
|
+
cancelButton = _ref2.cancelButton,
|
|
188
|
+
okButton = _ref2.okButton;
|
|
189
|
+
if (footer === null) return null;
|
|
190
|
+
if (typeof footer === 'function') return footer(cancelButton, okButton);
|
|
191
|
+
if (footer !== undefined) return footer;
|
|
192
|
+
if (!cancelButton && !okButton) return null;
|
|
193
|
+
return size === _constants.DIALOG_SIZE.large ? (0, _jsxRuntime.jsxs)(_jsxRuntime.Fragment, {
|
|
194
|
+
children: [cancelButton, okButton]
|
|
195
|
+
}) : (0, _jsxRuntime.jsxs)(_jsxRuntime.Fragment, {
|
|
196
|
+
children: [okButton, cancelButton]
|
|
197
|
+
});
|
|
198
|
+
};
|
|
199
|
+
var DialogBase = /*#__PURE__*/(0, _react.forwardRef)(function (props, ref) {
|
|
200
|
+
var className = props.className,
|
|
201
|
+
style = props.style,
|
|
202
|
+
_props$prefixCls = props.prefixCls,
|
|
203
|
+
prefixCls = _props$prefixCls === void 0 ? _constants.DIALOG_DEFAULT_PREFIX : _props$prefixCls,
|
|
204
|
+
_props$open = props.open,
|
|
205
|
+
open = _props$open === void 0 ? false : _props$open,
|
|
206
|
+
_props$size = props.size,
|
|
207
|
+
size = _props$size === void 0 ? _constants.DIALOG_SIZE.small : _props$size,
|
|
208
|
+
_props$maskClosable = props.maskClosable,
|
|
209
|
+
maskClosable = _props$maskClosable === void 0 ? true : _props$maskClosable,
|
|
210
|
+
_props$showCloseIcon = props.showCloseIcon,
|
|
211
|
+
showCloseIcon = _props$showCloseIcon === void 0 ? true : _props$showCloseIcon,
|
|
212
|
+
_props$showBackIcon = props.showBackIcon,
|
|
213
|
+
showBackIcon = _props$showBackIcon === void 0 ? false : _props$showBackIcon,
|
|
214
|
+
_props$fullWidth = props.fullWidth,
|
|
215
|
+
fullWidth = _props$fullWidth === void 0 ? false : _props$fullWidth,
|
|
216
|
+
title = props.title,
|
|
217
|
+
description = props.description,
|
|
218
|
+
children = props.children,
|
|
219
|
+
illustration = props.illustration,
|
|
220
|
+
media = props.media,
|
|
221
|
+
closeIcon = props.closeIcon,
|
|
222
|
+
backIcon = props.backIcon,
|
|
223
|
+
footer = props.footer,
|
|
224
|
+
onOk = props.onOk,
|
|
225
|
+
onCancel = props.onCancel,
|
|
226
|
+
onBack = props.onBack,
|
|
227
|
+
_props$okText = props.okText,
|
|
228
|
+
okText = _props$okText === void 0 ? _constants.DIALOG_DEFAULTS.okText : _props$okText,
|
|
229
|
+
_props$cancelText = props.cancelText,
|
|
230
|
+
cancelText = _props$cancelText === void 0 ? _constants.DIALOG_DEFAULTS.cancelText : _props$cancelText,
|
|
231
|
+
rootStyle = props.rootStyle,
|
|
232
|
+
wrapperStyle = props.wrapperStyle,
|
|
233
|
+
bodyStyle = props.bodyStyle,
|
|
234
|
+
headerStyle = props.headerStyle,
|
|
235
|
+
contentStyle = props.contentStyle,
|
|
236
|
+
footerStyle = props.footerStyle,
|
|
237
|
+
cancelButtonProps = props.cancelButtonProps,
|
|
238
|
+
okButtonProps = props.okButtonProps,
|
|
239
|
+
rest = __rest(props, ["className", "style", "prefixCls", "open", "size", "maskClosable", "showCloseIcon", "showBackIcon", "fullWidth", "title", "description", "children", "illustration", "media", "closeIcon", "backIcon", "footer", "onOk", "onCancel", "onBack", "okText", "cancelText", "rootStyle", "wrapperStyle", "bodyStyle", "headerStyle", "contentStyle", "footerStyle", "cancelButtonProps", "okButtonProps"]);
|
|
240
|
+
var mounted = usePresence(open, _constants.DIALOG_DEFAULTS.closeTimeoutMs);
|
|
241
|
+
var dialogRef = (0, _react.useRef)(null);
|
|
242
|
+
var titleId = (0, _react.useId)();
|
|
243
|
+
var descriptionId = (0, _react.useId)();
|
|
244
|
+
var handleSetDialogRef = (0, _react.useCallback)(function (node) {
|
|
245
|
+
dialogRef.current = node;
|
|
246
|
+
(0, _ref3.fillRef)(ref, node);
|
|
247
|
+
}, [ref]);
|
|
248
|
+
var handleCancel = (0, _hooks.useEventCallback)(function () {
|
|
249
|
+
void (onCancel === null || onCancel === void 0 ? void 0 : onCancel());
|
|
250
|
+
});
|
|
251
|
+
var handleOk = (0, _hooks.useEventCallback)(function () {
|
|
252
|
+
void (onOk === null || onOk === void 0 ? void 0 : onOk());
|
|
253
|
+
});
|
|
254
|
+
var handleBack = (0, _hooks.useEventCallback)(function () {
|
|
255
|
+
void (onBack === null || onBack === void 0 ? void 0 : onBack());
|
|
256
|
+
});
|
|
257
|
+
var handleOverlayClick = (0, _hooks.useEventCallback)(function () {
|
|
258
|
+
if (!maskClosable) return;
|
|
259
|
+
handleCancel();
|
|
260
|
+
});
|
|
261
|
+
useBodyScrollLock(mounted && open);
|
|
262
|
+
useDialogFocus(mounted && open, dialogRef);
|
|
263
|
+
useEscapeClose(mounted && open, handleCancel);
|
|
264
|
+
var hasMedia = media != null;
|
|
265
|
+
var closeControlNode = showCloseIcon ? renderControlButton(prefixCls, _constants.DIALOG_CONTROL_TYPE.close, closeIcon !== null && closeIcon !== void 0 ? closeIcon : (0, _jsxRuntime.jsx)(_Icons.Icons, {
|
|
266
|
+
name: _constants.DIALOG_DEFAULT_ICONS[_constants.DIALOG_CONTROL_TYPE.close],
|
|
267
|
+
size: _constants.DIALOG_DEFAULTS.controlIconSize
|
|
268
|
+
}), handleCancel) : null;
|
|
269
|
+
var backControlNode = showBackIcon ? renderControlButton(prefixCls, _constants.DIALOG_CONTROL_TYPE.back, backIcon !== null && backIcon !== void 0 ? backIcon : (0, _jsxRuntime.jsx)(_Icons.Icons, {
|
|
270
|
+
name: _constants.DIALOG_DEFAULT_ICONS[_constants.DIALOG_CONTROL_TYPE.back],
|
|
271
|
+
size: _constants.DIALOG_DEFAULTS.controlIconSize
|
|
272
|
+
}), handleBack) : null;
|
|
273
|
+
var illustrationNode = renderIllustrationNode(illustration);
|
|
274
|
+
var titleNode = renderTypographyNode(title, function (value) {
|
|
275
|
+
return (0, _jsxRuntime.jsx)(_Typography.TypographyHeadline, {
|
|
276
|
+
size: "md",
|
|
277
|
+
as: "h2",
|
|
278
|
+
color: "default",
|
|
279
|
+
children: value
|
|
280
|
+
});
|
|
281
|
+
});
|
|
282
|
+
var descriptionNode = renderTypographyNode(description, function (value) {
|
|
283
|
+
return (0, _jsxRuntime.jsx)(_Typography.TypographyBody, {
|
|
284
|
+
size: "md",
|
|
285
|
+
as: "p",
|
|
286
|
+
strong: true,
|
|
287
|
+
color: "default-secondary",
|
|
288
|
+
children: value
|
|
289
|
+
});
|
|
290
|
+
});
|
|
291
|
+
var childrenNode = renderTypographyNode(children, function (value) {
|
|
292
|
+
return (0, _jsxRuntime.jsx)(_Typography.TypographyBody, {
|
|
293
|
+
size: "md",
|
|
294
|
+
as: "p",
|
|
295
|
+
strong: true,
|
|
296
|
+
color: "default-secondary",
|
|
297
|
+
children: value
|
|
298
|
+
});
|
|
299
|
+
});
|
|
300
|
+
var cancelButton = renderActionButton({
|
|
301
|
+
prefixCls: prefixCls,
|
|
302
|
+
kind: _constants.DIALOG_ACTION_KIND.cancel,
|
|
303
|
+
text: cancelText,
|
|
304
|
+
action: onCancel,
|
|
305
|
+
buttonProps: cancelButtonProps
|
|
306
|
+
});
|
|
307
|
+
var okButton = renderActionButton({
|
|
308
|
+
prefixCls: prefixCls,
|
|
309
|
+
kind: _constants.DIALOG_ACTION_KIND.ok,
|
|
310
|
+
text: okText,
|
|
311
|
+
action: onOk,
|
|
312
|
+
buttonProps: okButtonProps
|
|
313
|
+
});
|
|
314
|
+
var footerNode = resolveFooterNode({
|
|
315
|
+
footer: footer,
|
|
316
|
+
size: size,
|
|
317
|
+
cancelButton: cancelButton,
|
|
318
|
+
okButton: okButton
|
|
319
|
+
});
|
|
320
|
+
if (!mounted) return null;
|
|
321
|
+
return (0, _jsxRuntime.jsx)(_Portal.Portal, {
|
|
322
|
+
children: (0, _jsxRuntime.jsxs)("div", {
|
|
323
|
+
style: rootStyle,
|
|
324
|
+
className: (0, _classnames["default"])(getClassName(prefixCls, _constants.DIALOG_SLOT.root), getClassName(prefixCls, _constants.DIALOG_SLOT.root, open ? _constants.DIALOG_MODIFIER.open : _constants.DIALOG_MODIFIER.closed)),
|
|
325
|
+
children: [(0, _jsxRuntime.jsx)("div", {
|
|
326
|
+
"aria-hidden": "true",
|
|
327
|
+
className: getClassName(prefixCls, _constants.DIALOG_SLOT.overlay),
|
|
328
|
+
onClick: handleOverlayClick
|
|
329
|
+
}), (0, _jsxRuntime.jsx)("div", {
|
|
330
|
+
style: wrapperStyle,
|
|
331
|
+
className: getClassName(prefixCls, _constants.DIALOG_SLOT.wrapper),
|
|
332
|
+
children: (0, _jsxRuntime.jsxs)("div", Object.assign({}, rest, {
|
|
333
|
+
ref: handleSetDialogRef,
|
|
334
|
+
role: "dialog",
|
|
335
|
+
"aria-modal": "true",
|
|
336
|
+
"aria-labelledby": title ? titleId : undefined,
|
|
337
|
+
"aria-describedby": description ? descriptionId : undefined,
|
|
338
|
+
tabIndex: -1,
|
|
339
|
+
style: style,
|
|
340
|
+
className: (0, _classnames["default"])(getClassName(prefixCls), getClassName(prefixCls, undefined, size), fullWidth && getClassName(prefixCls, undefined, _constants.DIALOG_MODIFIER.fullWidth), hasMedia && getClassName(prefixCls, undefined, _constants.DIALOG_MODIFIER.withMedia), className),
|
|
341
|
+
children: [closeControlNode, hasMedia && (0, _jsxRuntime.jsx)("div", {
|
|
342
|
+
className: getClassName(prefixCls, _constants.DIALOG_SLOT.media),
|
|
343
|
+
children: media
|
|
344
|
+
}), (0, _jsxRuntime.jsxs)("div", {
|
|
345
|
+
className: getClassName(prefixCls, _constants.DIALOG_SLOT.inner),
|
|
346
|
+
children: [backControlNode && (0, _jsxRuntime.jsx)("div", {
|
|
347
|
+
style: headerStyle,
|
|
348
|
+
className: getClassName(prefixCls, _constants.DIALOG_SLOT.header),
|
|
349
|
+
children: backControlNode
|
|
350
|
+
}), (0, _jsxRuntime.jsxs)("div", {
|
|
351
|
+
style: bodyStyle,
|
|
352
|
+
className: getClassName(prefixCls, _constants.DIALOG_SLOT.body),
|
|
353
|
+
children: [(illustrationNode || titleNode || descriptionNode) && (0, _jsxRuntime.jsxs)("div", {
|
|
354
|
+
className: getClassName(prefixCls, _constants.DIALOG_SLOT.summary),
|
|
355
|
+
children: [illustrationNode && (0, _jsxRuntime.jsx)("div", {
|
|
356
|
+
className: getClassName(prefixCls, _constants.DIALOG_SLOT.illustration),
|
|
357
|
+
children: illustrationNode
|
|
358
|
+
}), (titleNode || descriptionNode) && (0, _jsxRuntime.jsxs)("div", {
|
|
359
|
+
className: getClassName(prefixCls, _constants.DIALOG_SLOT.copy),
|
|
360
|
+
children: [titleNode && (0, _jsxRuntime.jsx)("div", {
|
|
361
|
+
id: titleId,
|
|
362
|
+
className: getClassName(prefixCls, _constants.DIALOG_SLOT.title),
|
|
363
|
+
children: titleNode
|
|
364
|
+
}), descriptionNode && (0, _jsxRuntime.jsx)("div", {
|
|
365
|
+
id: descriptionId,
|
|
366
|
+
className: getClassName(prefixCls, _constants.DIALOG_SLOT.description),
|
|
367
|
+
children: descriptionNode
|
|
368
|
+
})]
|
|
369
|
+
})]
|
|
370
|
+
}), childrenNode && (0, _jsxRuntime.jsx)("div", {
|
|
371
|
+
style: contentStyle,
|
|
372
|
+
className: getClassName(prefixCls, _constants.DIALOG_SLOT.content),
|
|
373
|
+
children: childrenNode
|
|
374
|
+
})]
|
|
375
|
+
}), footerNode && (0, _jsxRuntime.jsx)("div", {
|
|
376
|
+
style: footerStyle,
|
|
377
|
+
className: (0, _classnames["default"])(getClassName(prefixCls, _constants.DIALOG_SLOT.footer), getClassName(prefixCls, _constants.DIALOG_SLOT.footer, size)),
|
|
378
|
+
children: footerNode
|
|
379
|
+
})]
|
|
380
|
+
})]
|
|
381
|
+
}))
|
|
382
|
+
})]
|
|
383
|
+
})
|
|
384
|
+
});
|
|
385
|
+
});
|
|
386
|
+
DialogBase.displayName = 'Dialog';
|
|
387
|
+
var Dialog = exports.Dialog = /*#__PURE__*/(0, _react.memo)(DialogBase);
|
|
388
|
+
Dialog.displayName = 'Dialog';
|
|
389
|
+
var _default = exports["default"] = Dialog;
|
|
390
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["components/Dialog/Dialog.js","components/src/components/Dialog/Dialog.tsx"],"names":["_jsxRuntime","require","_hooks","_classnames","_interopRequireDefault","_react","_Button","_Icons","_Portal","_Typography","_ref3","_constants","__rest","s","e","t","p","Object","prototype","hasOwnProperty","call","indexOf","getOwnPropertySymbols","i","length","propertyIsEnumerable","scrollLockCount","getClassName","prefixCls","slot","modifier","baseClassName","concat","DIALOG_NAMESPACE","setBodyOverflow","value","document","body","style","overflow","lockBodyScroll","DIALOG_DEFAULTS","overflowHidden","unlockBodyScroll","Math","max","requestAnimationFrame","overflowReset","useBodyScrollLock","locked","isLockedRef","useRef","useEffect","current","undefined","usePresence","open","delay","_useState","useState","_useState2","_slicedToArray2","mounted","setMounted","closeTimerRef","window","clearTimeout","setTimeout","useDialogFocus","active","dialogRef","previousActiveElementRef","activeElement","HTMLElement","frame","_a","focus","cancelAnimationFrame","_b","useEscapeClose","enabled","onClose","handleKeyDown","event","key","escapeKey","preventDefault","addEventListener","keydownEvent","removeEventListener","renderTypographyNode","node","renderText","renderIllustrationNode","illustration","_jsx","Icons","name","size","illustrationSize","isValidElement","toVoidHandler","action","createActionHandler","buttonClick","defaultPrevented","renderControlButton","type","iconNode","onClick","buttonHtmlType","className","classNames","DIALOG_SLOT","control","DIALOG_CONTROL_LABELS","children","renderActionButton","_ref","kind","text","buttonProps","Button","assign","buttonSize","color","DIALOG_DEFAULT_BUTTON_COLORS","actionButton","resolveFooterNode","_ref2","footer","cancelButton","okButton","DIALOG_SIZE","large","_jsxs","_Fragment","DialogBase","forwardRef","props","ref","_props$prefixCls","DIALOG_DEFAULT_PREFIX","_props$open","_props$size","small","_props$maskClosable","maskClosable","_props$showCloseIcon","showCloseIcon","_props$showBackIcon","showBackIcon","_props$fullWidth","fullWidth","title","description","media","closeIcon","backIcon","onOk","onCancel","onBack","_props$okText","okText","_props$cancelText","cancelText","rootStyle","wrapperStyle","bodyStyle","headerStyle","contentStyle","footerStyle","cancelButtonProps","okButtonProps","rest","closeTimeoutMs","titleId","useId","descriptionId","handleSetDialogRef","useCallback","fillRef","handleCancel","useEventCallback","handleOk","handleBack","handleOverlayClick","hasMedia","closeControlNode","DIALOG_CONTROL_TYPE","close","DIALOG_DEFAULT_ICONS","controlIconSize","backControlNode","back","illustrationNode","titleNode","TypographyHeadline","as","descriptionNode","TypographyBody","strong","childrenNode","DIALOG_ACTION_KIND","cancel","ok","footerNode","Portal","root","DIALOG_MODIFIER","closed","overlay","wrapper","role","tabIndex","withMedia","inner","header","summary","copy","id","content","displayName","Dialog","exports","memo","_default"],"mappings":"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","file":"components/Dialog/Dialog.js","sourcesContent":["var __rest = (this && this.__rest) || function (s, e) {\n    var t = {};\n    for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\n        t[p] = s[p];\n    if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\n        for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\n            if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\n                t[p[i]] = s[p[i]];\n        }\n    return t;\n};\nimport { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from \"react/jsx-runtime\";\nimport { useEventCallback } from '@1money/hooks';\nimport classNames from 'classnames';\nimport { forwardRef, isValidElement, memo, useCallback, useEffect, useId, useRef, useState, } from 'react';\nimport { Button } from '../Button';\nimport { Icons } from '../Icons';\nimport { Portal } from '../Portal';\nimport { TypographyBody, TypographyHeadline } from '../Typography';\nimport { fillRef } from '../../utils/ref';\nimport { DIALOG_ACTION_KIND, DIALOG_CONTROL_LABELS, DIALOG_CONTROL_TYPE, DIALOG_DEFAULT_BUTTON_COLORS, DIALOG_DEFAULT_ICONS, DIALOG_DEFAULT_PREFIX, DIALOG_DEFAULTS, DIALOG_MODIFIER, DIALOG_NAMESPACE, DIALOG_SIZE, DIALOG_SLOT, } from './constants';\nimport './style';\nlet scrollLockCount = 0;\nconst getClassName = (prefixCls, slot, modifier) => {\n    const baseClassName = `${DIALOG_NAMESPACE}-${prefixCls}${slot ? `-${slot}` : ''}`;\n    return modifier ? `${baseClassName}-${modifier}` : baseClassName;\n};\nconst setBodyOverflow = (value) => {\n    if (typeof document === 'undefined')\n        return;\n    document.body.style.overflow = value;\n};\nconst lockBodyScroll = () => {\n    scrollLockCount += 1;\n    setBodyOverflow(DIALOG_DEFAULTS.overflowHidden);\n};\nconst unlockBodyScroll = () => {\n    scrollLockCount = Math.max(0, scrollLockCount - 1);\n    if (scrollLockCount === 0) {\n        requestAnimationFrame(() => {\n            if (scrollLockCount === 0) {\n                setBodyOverflow(DIALOG_DEFAULTS.overflowReset);\n            }\n        });\n    }\n};\nconst useBodyScrollLock = (locked) => {\n    const isLockedRef = useRef(false);\n    useEffect(() => {\n        if (!locked || isLockedRef.current)\n            return undefined;\n        isLockedRef.current = true;\n        lockBodyScroll();\n        return () => {\n            if (!isLockedRef.current)\n                return;\n            isLockedRef.current = false;\n            unlockBodyScroll();\n        };\n    }, [locked]);\n};\nconst usePresence = (open, delay) => {\n    const [mounted, setMounted] = useState(open);\n    const closeTimerRef = useRef(null);\n    useEffect(() => {\n        return () => {\n            if (closeTimerRef.current !== null) {\n                window.clearTimeout(closeTimerRef.current);\n            }\n        };\n    }, []);\n    useEffect(() => {\n        if (open) {\n            if (closeTimerRef.current !== null) {\n                window.clearTimeout(closeTimerRef.current);\n                closeTimerRef.current = null;\n            }\n            setMounted(true);\n            return;\n        }\n        if (!mounted)\n            return;\n        closeTimerRef.current = window.setTimeout(() => {\n            setMounted(false);\n            closeTimerRef.current = null;\n        }, delay);\n    }, [delay, mounted, open]);\n    return mounted;\n};\nconst useDialogFocus = (active, dialogRef) => {\n    const previousActiveElementRef = useRef(null);\n    useEffect(() => {\n        if (!active || typeof document === 'undefined')\n            return undefined;\n        previousActiveElementRef.current =\n            document.activeElement instanceof HTMLElement ? document.activeElement : null;\n        const frame = window.requestAnimationFrame(() => {\n            var _a;\n            (_a = dialogRef.current) === null || _a === void 0 ? void 0 : _a.focus();\n        });\n        return () => {\n            window.cancelAnimationFrame(frame);\n        };\n    }, [active, dialogRef]);\n    useEffect(() => {\n        var _a, _b;\n        if (active)\n            return;\n        (_b = (_a = previousActiveElementRef.current) === null || _a === void 0 ? void 0 : _a.focus) === null || _b === void 0 ? void 0 : _b.call(_a);\n        previousActiveElementRef.current = null;\n    }, [active]);\n};\nconst useEscapeClose = (enabled, onClose) => {\n    useEffect(() => {\n        if (!enabled || typeof document === 'undefined')\n            return undefined;\n        const handleKeyDown = (event) => {\n            if (event.key !== DIALOG_DEFAULTS.escapeKey)\n                return;\n            event.preventDefault();\n            void (onClose === null || onClose === void 0 ? void 0 : onClose());\n        };\n        document.addEventListener(DIALOG_DEFAULTS.keydownEvent, handleKeyDown);\n        return () => {\n            document.removeEventListener(DIALOG_DEFAULTS.keydownEvent, handleKeyDown);\n        };\n    }, [enabled, onClose]);\n};\nconst renderTypographyNode = (node, renderText) => {\n    if (node == null || typeof node === 'boolean')\n        return null;\n    if (typeof node === 'string' || typeof node === 'number') {\n        return renderText(node);\n    }\n    return node;\n};\nconst renderIllustrationNode = (illustration) => {\n    if (!illustration)\n        return null;\n    if (typeof illustration === 'string') {\n        return _jsx(Icons, { name: illustration, size: DIALOG_DEFAULTS.illustrationSize });\n    }\n    return isValidElement(illustration) ? illustration : null;\n};\nconst toVoidHandler = (action) => () => {\n    void (action === null || action === void 0 ? void 0 : action());\n};\nconst createActionHandler = (action, buttonClick) => (event) => {\n    buttonClick === null || buttonClick === void 0 ? void 0 : buttonClick(event);\n    if (event.defaultPrevented || !action)\n        return;\n    void action();\n};\nconst renderControlButton = (prefixCls, type, iconNode, onClick) => (_jsx(\"button\", { type: DIALOG_DEFAULTS.buttonHtmlType, className: classNames(getClassName(prefixCls, DIALOG_SLOT.control), getClassName(prefixCls, DIALOG_SLOT.control, type)), \"aria-label\": DIALOG_CONTROL_LABELS[type], onClick: toVoidHandler(onClick), children: iconNode }));\nconst renderActionButton = ({ prefixCls, kind, text, action, buttonProps, }) => {\n    var _a;\n    if (text == null || !action)\n        return null;\n    return (_jsx(Button, Object.assign({}, buttonProps, { type: DIALOG_DEFAULTS.buttonHtmlType, size: DIALOG_DEFAULTS.buttonSize, color: (_a = buttonProps === null || buttonProps === void 0 ? void 0 : buttonProps.color) !== null && _a !== void 0 ? _a : DIALOG_DEFAULT_BUTTON_COLORS[kind], className: classNames(getClassName(prefixCls, DIALOG_SLOT.actionButton), getClassName(prefixCls, DIALOG_SLOT.actionButton, kind), buttonProps === null || buttonProps === void 0 ? void 0 : buttonProps.className), style: buttonProps === null || buttonProps === void 0 ? void 0 : buttonProps.style, onClick: createActionHandler(action, buttonProps === null || buttonProps === void 0 ? void 0 : buttonProps.onClick), children: text })));\n};\nconst resolveFooterNode = ({ footer, size, cancelButton, okButton, }) => {\n    if (footer === null)\n        return null;\n    if (typeof footer === 'function')\n        return footer(cancelButton, okButton);\n    if (footer !== undefined)\n        return footer;\n    if (!cancelButton && !okButton)\n        return null;\n    return size === DIALOG_SIZE.large\n        ? (_jsxs(_Fragment, { children: [cancelButton, okButton] }))\n        : (_jsxs(_Fragment, { children: [okButton, cancelButton] }));\n};\nconst DialogBase = forwardRef((props, ref) => {\n    const { className, style, prefixCls = DIALOG_DEFAULT_PREFIX, open = false, size = DIALOG_SIZE.small, maskClosable = true, showCloseIcon = true, showBackIcon = false, fullWidth = false, title, description, children, illustration, media, closeIcon, backIcon, footer, onOk, onCancel, onBack, okText = DIALOG_DEFAULTS.okText, cancelText = DIALOG_DEFAULTS.cancelText, rootStyle, wrapperStyle, bodyStyle, headerStyle, contentStyle, footerStyle, cancelButtonProps, okButtonProps } = props, rest = __rest(props, [\"className\", \"style\", \"prefixCls\", \"open\", \"size\", \"maskClosable\", \"showCloseIcon\", \"showBackIcon\", \"fullWidth\", \"title\", \"description\", \"children\", \"illustration\", \"media\", \"closeIcon\", \"backIcon\", \"footer\", \"onOk\", \"onCancel\", \"onBack\", \"okText\", \"cancelText\", \"rootStyle\", \"wrapperStyle\", \"bodyStyle\", \"headerStyle\", \"contentStyle\", \"footerStyle\", \"cancelButtonProps\", \"okButtonProps\"]);\n    const mounted = usePresence(open, DIALOG_DEFAULTS.closeTimeoutMs);\n    const dialogRef = useRef(null);\n    const titleId = useId();\n    const descriptionId = useId();\n    const handleSetDialogRef = useCallback((node) => {\n        dialogRef.current = node;\n        fillRef(ref, node);\n    }, [ref]);\n    const handleCancel = useEventCallback(() => {\n        void (onCancel === null || onCancel === void 0 ? void 0 : onCancel());\n    });\n    const handleOk = useEventCallback(() => {\n        void (onOk === null || onOk === void 0 ? void 0 : onOk());\n    });\n    const handleBack = useEventCallback(() => {\n        void (onBack === null || onBack === void 0 ? void 0 : onBack());\n    });\n    const handleOverlayClick = useEventCallback(() => {\n        if (!maskClosable)\n            return;\n        handleCancel();\n    });\n    useBodyScrollLock(mounted && open);\n    useDialogFocus(mounted && open, dialogRef);\n    useEscapeClose(mounted && open, handleCancel);\n    const hasMedia = media != null;\n    const closeControlNode = showCloseIcon\n        ? renderControlButton(prefixCls, DIALOG_CONTROL_TYPE.close, closeIcon !== null && closeIcon !== void 0 ? closeIcon : (_jsx(Icons, { name: DIALOG_DEFAULT_ICONS[DIALOG_CONTROL_TYPE.close], size: DIALOG_DEFAULTS.controlIconSize })), handleCancel)\n        : null;\n    const backControlNode = showBackIcon\n        ? renderControlButton(prefixCls, DIALOG_CONTROL_TYPE.back, backIcon !== null && backIcon !== void 0 ? backIcon : (_jsx(Icons, { name: DIALOG_DEFAULT_ICONS[DIALOG_CONTROL_TYPE.back], size: DIALOG_DEFAULTS.controlIconSize })), handleBack)\n        : null;\n    const illustrationNode = renderIllustrationNode(illustration);\n    const titleNode = renderTypographyNode(title, (value) => (_jsx(TypographyHeadline, { size: \"md\", as: \"h2\", color: \"default\", children: value })));\n    const descriptionNode = renderTypographyNode(description, (value) => (_jsx(TypographyBody, { size: \"md\", as: \"p\", strong: true, color: \"default-secondary\", children: value })));\n    const childrenNode = renderTypographyNode(children, (value) => (_jsx(TypographyBody, { size: \"md\", as: \"p\", strong: true, color: \"default-secondary\", children: value })));\n    const cancelButton = renderActionButton({\n        prefixCls,\n        kind: DIALOG_ACTION_KIND.cancel,\n        text: cancelText,\n        action: onCancel,\n        buttonProps: cancelButtonProps,\n    });\n    const okButton = renderActionButton({\n        prefixCls,\n        kind: DIALOG_ACTION_KIND.ok,\n        text: okText,\n        action: onOk,\n        buttonProps: okButtonProps,\n    });\n    const footerNode = resolveFooterNode({\n        footer,\n        size,\n        cancelButton,\n        okButton,\n    });\n    if (!mounted)\n        return null;\n    return (_jsx(Portal, { children: _jsxs(\"div\", { style: rootStyle, className: classNames(getClassName(prefixCls, DIALOG_SLOT.root), getClassName(prefixCls, DIALOG_SLOT.root, open ? DIALOG_MODIFIER.open : DIALOG_MODIFIER.closed)), children: [_jsx(\"div\", { \"aria-hidden\": \"true\", className: getClassName(prefixCls, DIALOG_SLOT.overlay), onClick: handleOverlayClick }), _jsx(\"div\", { style: wrapperStyle, className: getClassName(prefixCls, DIALOG_SLOT.wrapper), children: _jsxs(\"div\", Object.assign({}, rest, { ref: handleSetDialogRef, role: \"dialog\", \"aria-modal\": \"true\", \"aria-labelledby\": title ? titleId : undefined, \"aria-describedby\": description ? descriptionId : undefined, tabIndex: -1, style: style, className: classNames(getClassName(prefixCls), getClassName(prefixCls, undefined, size), fullWidth && getClassName(prefixCls, undefined, DIALOG_MODIFIER.fullWidth), hasMedia && getClassName(prefixCls, undefined, DIALOG_MODIFIER.withMedia), className), children: [closeControlNode, hasMedia && _jsx(\"div\", { className: getClassName(prefixCls, DIALOG_SLOT.media), children: media }), _jsxs(\"div\", { className: getClassName(prefixCls, DIALOG_SLOT.inner), children: [backControlNode && (_jsx(\"div\", { style: headerStyle, className: getClassName(prefixCls, DIALOG_SLOT.header), children: backControlNode })), _jsxs(\"div\", { style: bodyStyle, className: getClassName(prefixCls, DIALOG_SLOT.body), children: [(illustrationNode || titleNode || descriptionNode) && (_jsxs(\"div\", { className: getClassName(prefixCls, DIALOG_SLOT.summary), children: [illustrationNode && (_jsx(\"div\", { className: getClassName(prefixCls, DIALOG_SLOT.illustration), children: illustrationNode })), (titleNode || descriptionNode) && (_jsxs(\"div\", { className: getClassName(prefixCls, DIALOG_SLOT.copy), children: [titleNode && (_jsx(\"div\", { id: titleId, className: getClassName(prefixCls, DIALOG_SLOT.title), children: titleNode })), descriptionNode && (_jsx(\"div\", { id: descriptionId, className: getClassName(prefixCls, DIALOG_SLOT.description), children: descriptionNode }))] }))] })), childrenNode && (_jsx(\"div\", { style: contentStyle, className: getClassName(prefixCls, DIALOG_SLOT.content), children: childrenNode }))] }), footerNode && (_jsx(\"div\", { style: footerStyle, className: classNames(getClassName(prefixCls, DIALOG_SLOT.footer), getClassName(prefixCls, DIALOG_SLOT.footer, size)), children: footerNode }))] })] })) })] }) }));\n});\nDialogBase.displayName = 'Dialog';\nexport const Dialog = memo(DialogBase);\nDialog.displayName = 'Dialog';\nexport default Dialog;",null],"sourceRoot":"../../../../../../../../../src"}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
import type { ButtonProps } from "../Button";
|
|
2
|
+
import type { IconName } from "../Icons";
|
|
3
|
+
export declare const DIALOG_NAMESPACE = "om-component-ui";
|
|
4
|
+
export declare const DIALOG_DEFAULT_PREFIX = "dialog";
|
|
5
|
+
export declare const DIALOG_SIZE: {
|
|
6
|
+
readonly small: "small";
|
|
7
|
+
readonly large: "large";
|
|
8
|
+
};
|
|
9
|
+
export declare const DIALOG_SIZES: readonly ["small", "large"];
|
|
10
|
+
export declare const DIALOG_ACTION_KIND: {
|
|
11
|
+
readonly ok: "ok";
|
|
12
|
+
readonly cancel: "cancel";
|
|
13
|
+
};
|
|
14
|
+
export declare const DIALOG_CONTROL_TYPE: {
|
|
15
|
+
readonly back: "back";
|
|
16
|
+
readonly close: "close";
|
|
17
|
+
};
|
|
18
|
+
export declare const DIALOG_SLOT: {
|
|
19
|
+
readonly root: "root";
|
|
20
|
+
readonly overlay: "overlay";
|
|
21
|
+
readonly wrapper: "wrapper";
|
|
22
|
+
readonly control: "control";
|
|
23
|
+
readonly actionButton: "action-button";
|
|
24
|
+
readonly media: "media";
|
|
25
|
+
readonly inner: "inner";
|
|
26
|
+
readonly header: "header";
|
|
27
|
+
readonly body: "body";
|
|
28
|
+
readonly summary: "summary";
|
|
29
|
+
readonly illustration: "illustration";
|
|
30
|
+
readonly copy: "copy";
|
|
31
|
+
readonly title: "title";
|
|
32
|
+
readonly description: "description";
|
|
33
|
+
readonly content: "content";
|
|
34
|
+
readonly footer: "footer";
|
|
35
|
+
};
|
|
36
|
+
export declare const DIALOG_MODIFIER: {
|
|
37
|
+
readonly open: "open";
|
|
38
|
+
readonly closed: "closed";
|
|
39
|
+
readonly fullWidth: "full-width";
|
|
40
|
+
readonly withMedia: "with-media";
|
|
41
|
+
};
|
|
42
|
+
export declare const DIALOG_CONTROL_LABELS: Record<DialogControlType, string>;
|
|
43
|
+
export declare const DIALOG_DEFAULT_ICONS: Record<DialogControlType, IconName>;
|
|
44
|
+
export declare const DIALOG_DEFAULT_BUTTON_COLORS: Record<DialogActionKind, NonNullable<ButtonProps['color']>>;
|
|
45
|
+
export declare const DIALOG_DEFAULTS: {
|
|
46
|
+
readonly buttonHtmlType: "button";
|
|
47
|
+
readonly buttonSize: "large";
|
|
48
|
+
readonly closeTimeoutMs: 200;
|
|
49
|
+
readonly controlIconSize: 24;
|
|
50
|
+
readonly illustrationSize: 74;
|
|
51
|
+
readonly okText: "Confirm";
|
|
52
|
+
readonly cancelText: "Cancel";
|
|
53
|
+
readonly overflowHidden: "hidden";
|
|
54
|
+
readonly overflowReset: "";
|
|
55
|
+
readonly escapeKey: "Escape";
|
|
56
|
+
readonly keydownEvent: "keydown";
|
|
57
|
+
};
|
|
58
|
+
export type DialogSize = (typeof DIALOG_SIZES)[number];
|
|
59
|
+
export type DialogActionKind = (typeof DIALOG_ACTION_KIND)[keyof typeof DIALOG_ACTION_KIND];
|
|
60
|
+
export type DialogControlType = (typeof DIALOG_CONTROL_TYPE)[keyof typeof DIALOG_CONTROL_TYPE];
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.DIALOG_SLOT = exports.DIALOG_SIZES = exports.DIALOG_SIZE = exports.DIALOG_NAMESPACE = exports.DIALOG_MODIFIER = exports.DIALOG_DEFAULT_PREFIX = exports.DIALOG_DEFAULT_ICONS = exports.DIALOG_DEFAULT_BUTTON_COLORS = exports.DIALOG_DEFAULTS = exports.DIALOG_CONTROL_TYPE = exports.DIALOG_CONTROL_LABELS = exports.DIALOG_ACTION_KIND = void 0;
|
|
8
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
9
|
+
var DIALOG_NAMESPACE = exports.DIALOG_NAMESPACE = 'om-component-ui';
|
|
10
|
+
var DIALOG_DEFAULT_PREFIX = exports.DIALOG_DEFAULT_PREFIX = 'dialog';
|
|
11
|
+
var DIALOG_SIZE = exports.DIALOG_SIZE = {
|
|
12
|
+
small: 'small',
|
|
13
|
+
large: 'large'
|
|
14
|
+
};
|
|
15
|
+
var DIALOG_SIZES = exports.DIALOG_SIZES = [DIALOG_SIZE.small, DIALOG_SIZE.large];
|
|
16
|
+
var DIALOG_ACTION_KIND = exports.DIALOG_ACTION_KIND = {
|
|
17
|
+
ok: 'ok',
|
|
18
|
+
cancel: 'cancel'
|
|
19
|
+
};
|
|
20
|
+
var DIALOG_CONTROL_TYPE = exports.DIALOG_CONTROL_TYPE = {
|
|
21
|
+
back: 'back',
|
|
22
|
+
close: 'close'
|
|
23
|
+
};
|
|
24
|
+
var DIALOG_SLOT = exports.DIALOG_SLOT = {
|
|
25
|
+
root: 'root',
|
|
26
|
+
overlay: 'overlay',
|
|
27
|
+
wrapper: 'wrapper',
|
|
28
|
+
control: 'control',
|
|
29
|
+
actionButton: 'action-button',
|
|
30
|
+
media: 'media',
|
|
31
|
+
inner: 'inner',
|
|
32
|
+
header: 'header',
|
|
33
|
+
body: 'body',
|
|
34
|
+
summary: 'summary',
|
|
35
|
+
illustration: 'illustration',
|
|
36
|
+
copy: 'copy',
|
|
37
|
+
title: 'title',
|
|
38
|
+
description: 'description',
|
|
39
|
+
content: 'content',
|
|
40
|
+
footer: 'footer'
|
|
41
|
+
};
|
|
42
|
+
var DIALOG_MODIFIER = exports.DIALOG_MODIFIER = {
|
|
43
|
+
open: 'open',
|
|
44
|
+
closed: 'closed',
|
|
45
|
+
fullWidth: 'full-width',
|
|
46
|
+
withMedia: 'with-media'
|
|
47
|
+
};
|
|
48
|
+
var DIALOG_CONTROL_LABELS = exports.DIALOG_CONTROL_LABELS = (0, _defineProperty2["default"])((0, _defineProperty2["default"])({}, DIALOG_CONTROL_TYPE.back, 'Go back'), DIALOG_CONTROL_TYPE.close, 'Close dialog');
|
|
49
|
+
var DIALOG_DEFAULT_ICONS = exports.DIALOG_DEFAULT_ICONS = (0, _defineProperty2["default"])((0, _defineProperty2["default"])({}, DIALOG_CONTROL_TYPE.back, 'arrowLeft'), DIALOG_CONTROL_TYPE.close, 'cross');
|
|
50
|
+
var DIALOG_DEFAULT_BUTTON_COLORS = exports.DIALOG_DEFAULT_BUTTON_COLORS = (0, _defineProperty2["default"])((0, _defineProperty2["default"])({}, DIALOG_ACTION_KIND.cancel, 'grey'), DIALOG_ACTION_KIND.ok, 'primary');
|
|
51
|
+
var DIALOG_DEFAULTS = exports.DIALOG_DEFAULTS = {
|
|
52
|
+
buttonHtmlType: 'button',
|
|
53
|
+
buttonSize: 'large',
|
|
54
|
+
closeTimeoutMs: 200,
|
|
55
|
+
controlIconSize: 24,
|
|
56
|
+
illustrationSize: 74,
|
|
57
|
+
okText: 'Confirm',
|
|
58
|
+
cancelText: 'Cancel',
|
|
59
|
+
overflowHidden: 'hidden',
|
|
60
|
+
overflowReset: '',
|
|
61
|
+
escapeKey: 'Escape',
|
|
62
|
+
keydownEvent: 'keydown'
|
|
63
|
+
};
|
|
64
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNvbXBvbmVudHMvc3JjL2NvbXBvbmVudHMvRGlhbG9nL2NvbnN0YW50cy50cyIsImNvbXBvbmVudHMvRGlhbG9nL2NvbnN0YW50cy5qcyJdLCJuYW1lcyI6WyJESUFMT0dfTkFNRVNQQUNFIiwiZXhwb3J0cyIsIkRJQUxPR19ERUZBVUxUX1BSRUZJWCIsIkRJQUxPR19TSVpFIiwic21hbGwiLCJsYXJnZSIsIkRJQUxPR19TSVpFUyIsIkRJQUxPR19BQ1RJT05fS0lORCIsIm9rIiwiY2FuY2VsIiwiRElBTE9HX0NPTlRST0xfVFlQRSIsImJhY2siLCJjbG9zZSIsIkRJQUxPR19TTE9UIiwicm9vdCIsIm92ZXJsYXkiLCJ3cmFwcGVyIiwiY29udHJvbCIsImFjdGlvbkJ1dHRvbiIsIm1lZGlhIiwiaW5uZXIiLCJoZWFkZXIiLCJib2R5Iiwic3VtbWFyeSIsImlsbHVzdHJhdGlvbiIsImNvcHkiLCJ0aXRsZSIsImRlc2NyaXB0aW9uIiwiY29udGVudCIsImZvb3RlciIsIkRJQUxPR19NT0RJRklFUiIsIm9wZW4iLCJjbG9zZWQiLCJmdWxsV2lkdGgiLCJ3aXRoTWVkaWEiLCJESUFMT0dfQ09OVFJPTF9MQUJFTFMiLCJfZGVmaW5lUHJvcGVydHkyIiwiRElBTE9HX0RFRkFVTFRfSUNPTlMiLCJESUFMT0dfREVGQVVMVF9CVVRUT05fQ09MT1JTIiwiRElBTE9HX0RFRkFVTFRTIiwiYnV0dG9uSHRtbFR5cGUiLCJidXR0b25TaXplIiwiY2xvc2VUaW1lb3V0TXMiLCJjb250cm9sSWNvblNpemUiLCJpbGx1c3RyYXRpb25TaXplIiwib2tUZXh0IiwiY2FuY2VsVGV4dCIsIm92ZXJmbG93SGlkZGVuIiwib3ZlcmZsb3dSZXNldCIsImVzY2FwZUtleSIsImtleWRvd25FdmVudCJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7QUFHTyxJQUFNQSxnQkFBZ0IsR0FBQUMsT0FBQSxDQUFBRCxnQkFBQSxHQUFHLGlCQUFpQjtBQUMxQyxJQUFNRSxxQkFBcUIsR0FBQUQsT0FBQSxDQUFBQyxxQkFBQSxHQUFHLFFBQVE7QUFFdEMsSUFBTUMsV0FBVyxHQUFBRixPQUFBLENBQUFFLFdBQUEsR0FBRztFQUN6QkMsS0FBSyxFQUFFLE9BQU87RUFDZEMsS0FBSyxFQUFFO0FDSFQsQ0RJVTtBQUVILElBQU1DLFlBQVksR0FBQUwsT0FBQSxDQUFBSyxZQUFBLEdBQUcsQ0FBQ0gsV0FBVyxDQUFDQyxLQUFLLEVBQUVELFdBQVcsQ0FBQ0UsS0FBSyxDQUFVO0FBRXBFLElBQU1FLGtCQUFrQixHQUFBTixPQUFBLENBQUFNLGtCQUFBLEdBQUc7RUFDaENDLEVBQUUsRUFBRSxJQUFJO0VBQ1JDLE1BQU0sRUFBRTtBQ0xWLENETVU7QUFFSCxJQUFNQyxtQkFBbUIsR0FBQVQsT0FBQSxDQUFBUyxtQkFBQSxHQUFHO0VBQ2pDQyxJQUFJLEVBQUUsTUFBTTtFQUNaQyxLQUFLLEVBQUU7QUNOVCxDRE9VO0FBRUgsSUFBTUMsV0FBVyxHQUFBWixPQUFBLENBQUFZLFdBQUEsR0FBRztFQUN6QkMsSUFBSSxFQUFFLE1BQU07RUFDWkMsT0FBTyxFQUFFLFNBQVM7RUFDbEJDLE9BQU8sRUFBRSxTQUFTO0VBQ2xCQyxPQUFPLEVBQUUsU0FBUztFQUNsQkMsWUFBWSxFQUFFLGVBQWU7RUFDN0JDLEtBQUssRUFBRSxPQUFPO0VBQ2RDLEtBQUssRUFBRSxPQUFPO0VBQ2RDLE1BQU0sRUFBRSxRQUFRO0VBQ2hCQyxJQUFJLEVBQUUsTUFBTTtFQUNaQyxPQUFPLEVBQUUsU0FBUztFQUNsQkMsWUFBWSxFQUFFLGNBQWM7RUFDNUJDLElBQUksRUFBRSxNQUFNO0VBQ1pDLEtBQUssRUFBRSxPQUFPO0VBQ2RDLFdBQVcsRUFBRSxhQUFhO0VBQzFCQyxPQUFPLEVBQUUsU0FBUztFQUNsQkMsTUFBTSxFQUFFO0FDUFYsQ0RRVTtBQUVILElBQU1DLGVBQWUsR0FBQTdCLE9BQUEsQ0FBQTZCLGVBQUEsR0FBRztFQUM3QkMsSUFBSSxFQUFFLE1BQU07RUFDWkMsTUFBTSxFQUFFLFFBQVE7RUFDaEJDLFNBQVMsRUFBRSxZQUFZO0VBQ3ZCQyxTQUFTLEVBQUU7QUNSYixDRFNVO0FBRUgsSUFBTUMscUJBQXFCLEdBQUFsQyxPQUFBLENBQUFrQyxxQkFBQSxPQUFBQyxnQkFBQSxpQkFBQUEsZ0JBQUEsaUJBQy9CMUIsbUJBQW1CLENBQUNDLElBQUksRUFBRyxTQUFTLEdBQ3BDRCxtQkFBbUIsQ0FBQ0UsS0FBSyxFQUFHLGNBQWMsQ0FDNUM7QUFFTSxJQUFNeUIsb0JBQW9CLEdBQUFwQyxPQUFBLENBQUFvQyxvQkFBQSxPQUFBRCxnQkFBQSxpQkFBQUEsZ0JBQUEsaUJBQzlCMUIsbUJBQW1CLENBQUNDLElBQUksRUFBRyxXQUFXLEdBQ3RDRCxtQkFBbUIsQ0FBQ0UsS0FBSyxFQUFHLE9BQU8sQ0FDckM7QUFFTSxJQUFNMEIsNEJBQTRCLEdBQUFyQyxPQUFBLENBQUFxQyw0QkFBQSxPQUFBRixnQkFBQSxpQkFBQUEsZ0JBQUEsaUJBSXRDN0Isa0JBQWtCLENBQUNFLE1BQU0sRUFBRyxNQUFNLEdBQ2xDRixrQkFBa0IsQ0FBQ0MsRUFBRSxFQUFHLFNBQVMsQ0FDbkM7QUFFTSxJQUFNK0IsZUFBZSxHQUFBdEMsT0FBQSxDQUFBc0MsZUFBQSxHQUFHO0VBQzdCQyxjQUFjLEVBQUUsUUFBUTtFQUN4QkMsVUFBVSxFQUFFLE9BQWtEO0VBQzlEQyxjQUFjLEVBQUUsR0FBRztFQUNuQkMsZUFBZSxFQUFFLEVBQUU7RUFDbkJDLGdCQUFnQixFQUFFLEVBQUU7RUFDcEJDLE1BQU0sRUFBRSxTQUFTO0VBQ2pCQyxVQUFVLEVBQUUsUUFBUTtFQUNwQkMsY0FBYyxFQUFFLFFBQVE7RUFDeEJDLGFBQWEsRUFBRSxFQUFFO0VBQ2pCQyxTQUFTLEVBQUUsUUFBUTtFQUNuQkMsWUFBWSxFQUFFO0FDZmhCLENEZ0JVIiwiZmlsZSI6ImNvbXBvbmVudHMvRGlhbG9nL2NvbnN0YW50cy5qcyIsInNvdXJjZXNDb250ZW50IjpbbnVsbCwiZXhwb3J0IGNvbnN0IERJQUxPR19OQU1FU1BBQ0UgPSAnb20tY29tcG9uZW50LXVpJztcbmV4cG9ydCBjb25zdCBESUFMT0dfREVGQVVMVF9QUkVGSVggPSAnZGlhbG9nJztcbmV4cG9ydCBjb25zdCBESUFMT0dfU0laRSA9IHtcbiAgICBzbWFsbDogJ3NtYWxsJyxcbiAgICBsYXJnZTogJ2xhcmdlJyxcbn07XG5leHBvcnQgY29uc3QgRElBTE9HX1NJWkVTID0gW0RJQUxPR19TSVpFLnNtYWxsLCBESUFMT0dfU0laRS5sYXJnZV07XG5leHBvcnQgY29uc3QgRElBTE9HX0FDVElPTl9LSU5EID0ge1xuICAgIG9rOiAnb2snLFxuICAgIGNhbmNlbDogJ2NhbmNlbCcsXG59O1xuZXhwb3J0IGNvbnN0IERJQUxPR19DT05UUk9MX1RZUEUgPSB7XG4gICAgYmFjazogJ2JhY2snLFxuICAgIGNsb3NlOiAnY2xvc2UnLFxufTtcbmV4cG9ydCBjb25zdCBESUFMT0dfU0xPVCA9IHtcbiAgICByb290OiAncm9vdCcsXG4gICAgb3ZlcmxheTogJ292ZXJsYXknLFxuICAgIHdyYXBwZXI6ICd3cmFwcGVyJyxcbiAgICBjb250cm9sOiAnY29udHJvbCcsXG4gICAgYWN0aW9uQnV0dG9uOiAnYWN0aW9uLWJ1dHRvbicsXG4gICAgbWVkaWE6ICdtZWRpYScsXG4gICAgaW5uZXI6ICdpbm5lcicsXG4gICAgaGVhZGVyOiAnaGVhZGVyJyxcbiAgICBib2R5OiAnYm9keScsXG4gICAgc3VtbWFyeTogJ3N1bW1hcnknLFxuICAgIGlsbHVzdHJhdGlvbjogJ2lsbHVzdHJhdGlvbicsXG4gICAgY29weTogJ2NvcHknLFxuICAgIHRpdGxlOiAndGl0bGUnLFxuICAgIGRlc2NyaXB0aW9uOiAnZGVzY3JpcHRpb24nLFxuICAgIGNvbnRlbnQ6ICdjb250ZW50JyxcbiAgICBmb290ZXI6ICdmb290ZXInLFxufTtcbmV4cG9ydCBjb25zdCBESUFMT0dfTU9ESUZJRVIgPSB7XG4gICAgb3BlbjogJ29wZW4nLFxuICAgIGNsb3NlZDogJ2Nsb3NlZCcsXG4gICAgZnVsbFdpZHRoOiAnZnVsbC13aWR0aCcsXG4gICAgd2l0aE1lZGlhOiAnd2l0aC1tZWRpYScsXG59O1xuZXhwb3J0IGNvbnN0IERJQUxPR19DT05UUk9MX0xBQkVMUyA9IHtcbiAgICBbRElBTE9HX0NPTlRST0xfVFlQRS5iYWNrXTogJ0dvIGJhY2snLFxuICAgIFtESUFMT0dfQ09OVFJPTF9UWVBFLmNsb3NlXTogJ0Nsb3NlIGRpYWxvZycsXG59O1xuZXhwb3J0IGNvbnN0IERJQUxPR19ERUZBVUxUX0lDT05TID0ge1xuICAgIFtESUFMT0dfQ09OVFJPTF9UWVBFLmJhY2tdOiAnYXJyb3dMZWZ0JyxcbiAgICBbRElBTE9HX0NPTlRST0xfVFlQRS5jbG9zZV06ICdjcm9zcycsXG59O1xuZXhwb3J0IGNvbnN0IERJQUxPR19ERUZBVUxUX0JVVFRPTl9DT0xPUlMgPSB7XG4gICAgW0RJQUxPR19BQ1RJT05fS0lORC5jYW5jZWxdOiAnZ3JleScsXG4gICAgW0RJQUxPR19BQ1RJT05fS0lORC5va106ICdwcmltYXJ5Jyxcbn07XG5leHBvcnQgY29uc3QgRElBTE9HX0RFRkFVTFRTID0ge1xuICAgIGJ1dHRvbkh0bWxUeXBlOiAnYnV0dG9uJyxcbiAgICBidXR0b25TaXplOiAnbGFyZ2UnLFxuICAgIGNsb3NlVGltZW91dE1zOiAyMDAsXG4gICAgY29udHJvbEljb25TaXplOiAyNCxcbiAgICBpbGx1c3RyYXRpb25TaXplOiA3NCxcbiAgICBva1RleHQ6ICdDb25maXJtJyxcbiAgICBjYW5jZWxUZXh0OiAnQ2FuY2VsJyxcbiAgICBvdmVyZmxvd0hpZGRlbjogJ2hpZGRlbicsXG4gICAgb3ZlcmZsb3dSZXNldDogJycsXG4gICAgZXNjYXBlS2V5OiAnRXNjYXBlJyxcbiAgICBrZXlkb3duRXZlbnQ6ICdrZXlkb3duJyxcbn07Il0sInNvdXJjZVJvb3QiOiIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMifQ==
|