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