@bifrostui/react 1.2.9-beta.0 → 1.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (57) hide show
  1. package/dist/Calendar/Calendar.js +48 -2
  2. package/dist/Calendar/Calendar.types.d.ts +12 -0
  3. package/dist/Countdown/Countdown.js +3 -0
  4. package/dist/Dialog/Dialog.d.ts +5 -0
  5. package/dist/Dialog/Dialog.js +140 -0
  6. package/dist/Dialog/Dialog.types.d.ts +98 -0
  7. package/dist/Dialog/Dialog.types.js +15 -0
  8. package/dist/Dialog/FunctionalDialog.d.ts +3 -0
  9. package/dist/Dialog/FunctionalDialog.js +168 -0
  10. package/dist/Dialog/index.css +66 -0
  11. package/dist/Dialog/index.d.ts +2 -0
  12. package/dist/Dialog/index.js +41 -0
  13. package/dist/Modal/Modal.miniapp.d.ts +1 -1
  14. package/dist/Radio/Radio.js +1 -1
  15. package/dist/Radio/RadioButtonIcon.d.ts +1 -6
  16. package/dist/Radio/RadioButtonIcon.js +0 -3
  17. package/dist/Toast/FunctionalToast.d.ts +3 -0
  18. package/dist/Toast/FunctionalToast.js +159 -0
  19. package/dist/Toast/Toast.css +55 -0
  20. package/dist/Toast/Toast.d.ts +5 -0
  21. package/dist/Toast/Toast.js +117 -0
  22. package/dist/Toast/Toast.types.d.ts +87 -0
  23. package/dist/Toast/Toast.types.js +15 -0
  24. package/dist/Toast/index.d.ts +2 -0
  25. package/dist/Toast/index.js +41 -0
  26. package/dist/Transition/Transition.miniapp.js +7 -1
  27. package/dist/index.d.ts +2 -0
  28. package/dist/index.js +5 -1
  29. package/es/Calendar/Calendar.js +54 -3
  30. package/es/Calendar/Calendar.types.d.ts +12 -0
  31. package/es/Countdown/Countdown.js +3 -0
  32. package/es/Dialog/Dialog.d.ts +5 -0
  33. package/es/Dialog/Dialog.js +113 -0
  34. package/es/Dialog/Dialog.types.d.ts +98 -0
  35. package/es/Dialog/Dialog.types.js +1 -0
  36. package/es/Dialog/FunctionalDialog.d.ts +3 -0
  37. package/es/Dialog/FunctionalDialog.js +141 -0
  38. package/es/Dialog/index.css +66 -0
  39. package/es/Dialog/index.d.ts +2 -0
  40. package/es/Dialog/index.js +6 -0
  41. package/es/Modal/Modal.miniapp.d.ts +1 -1
  42. package/es/Radio/Radio.js +1 -1
  43. package/es/Radio/RadioButtonIcon.d.ts +1 -6
  44. package/es/Radio/RadioButtonIcon.js +0 -3
  45. package/es/Toast/FunctionalToast.d.ts +3 -0
  46. package/es/Toast/FunctionalToast.js +132 -0
  47. package/es/Toast/Toast.css +55 -0
  48. package/es/Toast/Toast.d.ts +5 -0
  49. package/es/Toast/Toast.js +95 -0
  50. package/es/Toast/Toast.types.d.ts +87 -0
  51. package/es/Toast/Toast.types.js +1 -0
  52. package/es/Toast/index.d.ts +2 -0
  53. package/es/Toast/index.js +6 -0
  54. package/es/Transition/Transition.miniapp.js +7 -1
  55. package/es/index.d.ts +2 -0
  56. package/es/index.js +2 -0
  57. package/package.json +5 -5
@@ -0,0 +1,41 @@
1
+ var __create = Object.create;
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __getProtoOf = Object.getPrototypeOf;
6
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
7
+ var __export = (target, all) => {
8
+ for (var name in all)
9
+ __defProp(target, name, { get: all[name], enumerable: true });
10
+ };
11
+ var __copyProps = (to, from, except, desc) => {
12
+ if (from && typeof from === "object" || typeof from === "function") {
13
+ for (let key of __getOwnPropNames(from))
14
+ if (!__hasOwnProp.call(to, key) && key !== except)
15
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
16
+ }
17
+ return to;
18
+ };
19
+ var __reExport = (target, mod, secondTarget) => (__copyProps(target, mod, "default"), secondTarget && __copyProps(secondTarget, mod, "default"));
20
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
21
+ // If the importer is in node compatibility mode or this is not an ESM
22
+ // file that has been converted to a CommonJS file using a Babel-
23
+ // compatible transform (i.e. "__esModule" has not been set), then set
24
+ // "default" to the CommonJS "module.exports" for node compatibility.
25
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
26
+ mod
27
+ ));
28
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
+ var Dialog_exports = {};
30
+ __export(Dialog_exports, {
31
+ Dialog: () => import_FunctionalDialog.default,
32
+ default: () => import_FunctionalDialog.default
33
+ });
34
+ module.exports = __toCommonJS(Dialog_exports);
35
+ var import_FunctionalDialog = __toESM(require("./FunctionalDialog"));
36
+ __reExport(Dialog_exports, require("./Dialog.types"), module.exports);
37
+ // Annotate the CommonJS export names for ESM import in node:
38
+ 0 && (module.exports = {
39
+ Dialog,
40
+ ...require("./Dialog.types")
41
+ });
@@ -12,5 +12,5 @@ declare const Modal: React.ForwardRefExoticComponent<Omit<ViewProps & {
12
12
  keepMounted?: boolean;
13
13
  } & import("@bifrostui/types").ICommonProps & Omit<Omit<React.DetailedHTMLProps<React.HTMLAttributes<HTMLDivElement>, HTMLDivElement>, "ref"> & {
14
14
  ref?: React.Ref<HTMLDivElement>;
15
- }, "open" | keyof import("@bifrostui/types").ICommonProps | "container" | "disablePortal" | "hideBackdrop" | "BackdropProps" | "onClose" | "disableScrollLock" | "keepMounted">, "ref"> & React.RefAttributes<HTMLDivElement>>;
15
+ }, keyof import("@bifrostui/types").ICommonProps | "open" | "container" | "disablePortal" | "hideBackdrop" | "BackdropProps" | "onClose" | "disableScrollLock" | "keepMounted">, "ref"> & React.RefAttributes<HTMLDivElement>>;
16
16
  export default Modal;
@@ -115,7 +115,7 @@ const Radio = (0, import_react.forwardRef)((props, ref) => {
115
115
  console.error("RadioGroup\u6A21\u5F0F\u4E0BRadio\u987B\u4F20\u5165value\u5C5E\u6027");
116
116
  }
117
117
  const radioCheckIcon = checkedIcon || /* @__PURE__ */ import_react.default.createElement(import_RadioButtonIcon.default, { checked: true });
118
- const radioUncheckIcon = icon || /* @__PURE__ */ import_react.default.createElement(import_RadioButtonIcon.default, null);
118
+ const radioUncheckIcon = icon || /* @__PURE__ */ import_react.default.createElement(import_RadioButtonIcon.default, { checked: false });
119
119
  const radioDisabled = disabled !== void 0 ? disabled : groupContext == null ? void 0 : groupContext.disabled;
120
120
  const changeAction = (e, isChecked) => {
121
121
  var _a2;
@@ -1,12 +1,7 @@
1
1
  import { ISvgIconProps } from '@bifrostui/icons';
2
2
  import React from 'react';
3
3
  export interface IRadioButtonIconProps extends ISvgIconProps {
4
- checked?: boolean;
4
+ checked: boolean;
5
5
  }
6
6
  declare function RadioButtonIcon(props: IRadioButtonIconProps): React.JSX.Element;
7
- declare namespace RadioButtonIcon {
8
- var defaultProps: {
9
- checked: boolean;
10
- };
11
- }
12
7
  export default RadioButtonIcon;
@@ -63,7 +63,4 @@ function RadioButtonIcon(props) {
63
63
  )
64
64
  );
65
65
  }
66
- RadioButtonIcon.defaultProps = {
67
- checked: false
68
- };
69
66
  var RadioButtonIcon_default = RadioButtonIcon;
@@ -0,0 +1,3 @@
1
+ import { ToastInstance } from './Toast.types';
2
+ declare const Toast: ToastInstance;
3
+ export default Toast;
@@ -0,0 +1,159 @@
1
+ var __create = Object.create;
2
+ var __defProp = Object.defineProperty;
3
+ var __defProps = Object.defineProperties;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
6
+ var __getOwnPropNames = Object.getOwnPropertyNames;
7
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
8
+ var __getProtoOf = Object.getPrototypeOf;
9
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
10
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
11
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
12
+ var __spreadValues = (a, b) => {
13
+ for (var prop in b || (b = {}))
14
+ if (__hasOwnProp.call(b, prop))
15
+ __defNormalProp(a, prop, b[prop]);
16
+ if (__getOwnPropSymbols)
17
+ for (var prop of __getOwnPropSymbols(b)) {
18
+ if (__propIsEnum.call(b, prop))
19
+ __defNormalProp(a, prop, b[prop]);
20
+ }
21
+ return a;
22
+ };
23
+ var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
24
+ var __objRest = (source, exclude) => {
25
+ var target = {};
26
+ for (var prop in source)
27
+ if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
28
+ target[prop] = source[prop];
29
+ if (source != null && __getOwnPropSymbols)
30
+ for (var prop of __getOwnPropSymbols(source)) {
31
+ if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
32
+ target[prop] = source[prop];
33
+ }
34
+ return target;
35
+ };
36
+ var __export = (target, all) => {
37
+ for (var name in all)
38
+ __defProp(target, name, { get: all[name], enumerable: true });
39
+ };
40
+ var __copyProps = (to, from, except, desc) => {
41
+ if (from && typeof from === "object" || typeof from === "function") {
42
+ for (let key of __getOwnPropNames(from))
43
+ if (!__hasOwnProp.call(to, key) && key !== except)
44
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
45
+ }
46
+ return to;
47
+ };
48
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
49
+ // If the importer is in node compatibility mode or this is not an ESM
50
+ // file that has been converted to a CommonJS file using a Babel-
51
+ // compatible transform (i.e. "__esModule" has not been set), then set
52
+ // "default" to the CommonJS "module.exports" for node compatibility.
53
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
54
+ mod
55
+ ));
56
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
57
+ var FunctionalToast_exports = {};
58
+ __export(FunctionalToast_exports, {
59
+ default: () => FunctionalToast_default
60
+ });
61
+ module.exports = __toCommonJS(FunctionalToast_exports);
62
+ var import_utils = require("@bifrostui/utils");
63
+ var import_react = __toESM(require("react"));
64
+ var import_Toast = __toESM(require("./Toast"));
65
+ const toastCloses = [];
66
+ const formatProps = (props) => {
67
+ if (typeof props === "string") {
68
+ return { message: props };
69
+ }
70
+ return props;
71
+ };
72
+ const destroyAll = () => {
73
+ let closeToast = toastCloses.pop();
74
+ while (closeToast) {
75
+ closeToast();
76
+ closeToast = toastCloses.pop();
77
+ }
78
+ };
79
+ const functionalToast = (props) => {
80
+ const options = __spreadValues({
81
+ duration: 2e3,
82
+ position: "center",
83
+ allowMultiple: false,
84
+ disableClick: false
85
+ }, formatProps(props));
86
+ const instance = {
87
+ close: () => null
88
+ };
89
+ const rootWrapper = document.createElement("div");
90
+ if (options.disableClick) {
91
+ const styles = {
92
+ position: "fixed",
93
+ top: "0",
94
+ bottom: "0",
95
+ left: "0",
96
+ right: "0",
97
+ zIndex: "var(--bui-z-index-toast)"
98
+ };
99
+ Object.keys(styles).forEach((property) => {
100
+ rootWrapper.style[property] = styles[property];
101
+ });
102
+ }
103
+ const rootElement = (0, import_utils.getRootElement)();
104
+ rootElement.appendChild(rootWrapper);
105
+ const ToastComponent = () => {
106
+ const _a = options, { duration, allowMultiple, onClose } = _a, others = __objRest(_a, ["duration", "allowMultiple", "onClose"]);
107
+ const [open, setOpen] = (0, import_react.useState)(false);
108
+ let timer;
109
+ const fadeTimeout = {
110
+ enter: 350,
111
+ exit: 150
112
+ };
113
+ const close = (0, import_react.useCallback)(() => {
114
+ setOpen(false);
115
+ setTimeout(() => {
116
+ const unmountRes = (0, import_utils.unmount)(rootWrapper);
117
+ if (unmountRes && rootWrapper.parentNode) {
118
+ rootWrapper.parentNode.removeChild(rootWrapper);
119
+ }
120
+ }, fadeTimeout.exit);
121
+ onClose == null ? void 0 : onClose();
122
+ }, [rootWrapper]);
123
+ (0, import_react.useEffect)(() => {
124
+ setOpen(true);
125
+ if (!allowMultiple)
126
+ destroyAll();
127
+ toastCloses.push(close);
128
+ if (duration !== 0 && typeof duration === "number") {
129
+ timer = setTimeout(close, duration);
130
+ }
131
+ return () => {
132
+ clearTimeout(timer);
133
+ };
134
+ }, []);
135
+ instance.close = close;
136
+ return /* @__PURE__ */ import_react.default.createElement(
137
+ import_Toast.default,
138
+ __spreadProps(__spreadValues({}, others), {
139
+ open,
140
+ timeout: fadeTimeout,
141
+ onClose: close
142
+ })
143
+ );
144
+ };
145
+ (0, import_utils.render)(/* @__PURE__ */ import_react.default.createElement(ToastComponent, null), rootWrapper);
146
+ return instance;
147
+ };
148
+ ["warning", "loading", "success", "fail"].forEach((methodName) => {
149
+ functionalToast[methodName] = (options) => functionalToast(__spreadValues({
150
+ type: methodName
151
+ }, formatProps(options)));
152
+ });
153
+ functionalToast.clear = () => {
154
+ setTimeout(() => {
155
+ destroyAll();
156
+ });
157
+ };
158
+ const Toast = functionalToast;
159
+ var FunctionalToast_default = Toast;
@@ -0,0 +1,55 @@
1
+ .bui-toast {
2
+ --min-width: 86px;
3
+ --max-width: 80%;
4
+ --font-size: var(--bui-text-size-1);
5
+ --color: var(--bui-color-white);
6
+ --padding: var(--bui-spacing-xl);
7
+ --word-break: break-all;
8
+ --z-index: var(--bui-z-index-toast);
9
+ --position-top: 15%;
10
+ --position-bottom: 85%;
11
+ --background-color: rgba(0, 0, 0, 0.8);
12
+ --border-radius: var(--bui-shape-radius-default);
13
+ --text-align: center;
14
+ position: fixed;
15
+ left: 50%;
16
+ z-index: var(--z-index);
17
+ width: fit-content;
18
+ min-width: var(--min-width);
19
+ max-width: var(--max-width);
20
+ padding: var(--padding);
21
+ font-size: var(--font-size);
22
+ color: var(--color);
23
+ border-radius: var(--border-radius);
24
+ word-break: var(--word-break);
25
+ white-space: pre-wrap;
26
+ background-color: var(--background-color);
27
+ text-align: var(--text-align);
28
+ font-family: var(--bui-font-family);
29
+ }
30
+ .bui-toast.bui-toast-allow-click {
31
+ position: fixed;
32
+ right: unset;
33
+ bottom: unset;
34
+ }
35
+ .bui-toast-center {
36
+ top: 50%;
37
+ transform: translate(-50%, -50%);
38
+ }
39
+ .bui-toast-top {
40
+ top: var(--position-top);
41
+ transform: translate(-50%, calc(-1 * var(--position-top)));
42
+ }
43
+ .bui-toast-bottom {
44
+ top: var(--position-bottom);
45
+ transform: translate(-50%, calc(-1 * var(--position-bottom)));
46
+ }
47
+ .bui-toast-icon {
48
+ display: flex;
49
+ flex-direction: column;
50
+ align-items: center;
51
+ }
52
+ .bui-toast-icon .bui-svg-icon {
53
+ margin-bottom: 8px;
54
+ font-size: 30px;
55
+ }
@@ -0,0 +1,5 @@
1
+ import React from 'react';
2
+ import { ToastProps } from './Toast.types';
3
+ import './Toast.less';
4
+ declare const ToastComponent: React.ForwardRefExoticComponent<ToastProps & React.RefAttributes<HTMLDivElement>>;
5
+ export default ToastComponent;
@@ -0,0 +1,117 @@
1
+ var __create = Object.create;
2
+ var __defProp = Object.defineProperty;
3
+ var __defProps = Object.defineProperties;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
6
+ var __getOwnPropNames = Object.getOwnPropertyNames;
7
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
8
+ var __getProtoOf = Object.getPrototypeOf;
9
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
10
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
11
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
12
+ var __spreadValues = (a, b) => {
13
+ for (var prop in b || (b = {}))
14
+ if (__hasOwnProp.call(b, prop))
15
+ __defNormalProp(a, prop, b[prop]);
16
+ if (__getOwnPropSymbols)
17
+ for (var prop of __getOwnPropSymbols(b)) {
18
+ if (__propIsEnum.call(b, prop))
19
+ __defNormalProp(a, prop, b[prop]);
20
+ }
21
+ return a;
22
+ };
23
+ var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
24
+ var __objRest = (source, exclude) => {
25
+ var target = {};
26
+ for (var prop in source)
27
+ if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
28
+ target[prop] = source[prop];
29
+ if (source != null && __getOwnPropSymbols)
30
+ for (var prop of __getOwnPropSymbols(source)) {
31
+ if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
32
+ target[prop] = source[prop];
33
+ }
34
+ return target;
35
+ };
36
+ var __export = (target, all) => {
37
+ for (var name in all)
38
+ __defProp(target, name, { get: all[name], enumerable: true });
39
+ };
40
+ var __copyProps = (to, from, except, desc) => {
41
+ if (from && typeof from === "object" || typeof from === "function") {
42
+ for (let key of __getOwnPropNames(from))
43
+ if (!__hasOwnProp.call(to, key) && key !== except)
44
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
45
+ }
46
+ return to;
47
+ };
48
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
49
+ // If the importer is in node compatibility mode or this is not an ESM
50
+ // file that has been converted to a CommonJS file using a Babel-
51
+ // compatible transform (i.e. "__esModule" has not been set), then set
52
+ // "default" to the CommonJS "module.exports" for node compatibility.
53
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
54
+ mod
55
+ ));
56
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
57
+ var Toast_exports = {};
58
+ __export(Toast_exports, {
59
+ default: () => Toast_default
60
+ });
61
+ module.exports = __toCommonJS(Toast_exports);
62
+ var import_clsx = __toESM(require("clsx"));
63
+ var import_react = __toESM(require("react"));
64
+ var import_icons = require("@bifrostui/icons");
65
+ var import_Fade = __toESM(require("../Fade"));
66
+ var import_Toast2 = require("./Toast.css");
67
+ const prefixCls = "bui-toast";
68
+ const ToastComponent = /* @__PURE__ */ import_react.default.forwardRef(
69
+ (props, ref) => {
70
+ const _a = props, {
71
+ className,
72
+ style,
73
+ open,
74
+ type,
75
+ icon,
76
+ message,
77
+ position = "center",
78
+ disableClick = false
79
+ } = _a, others = __objRest(_a, [
80
+ "className",
81
+ "style",
82
+ "open",
83
+ "type",
84
+ "icon",
85
+ "message",
86
+ "position",
87
+ "disableClick"
88
+ ]);
89
+ const iconMap = {
90
+ fail: /* @__PURE__ */ import_react.default.createElement(import_icons.ErrorCircleFilledBoldIcon, { htmlColor: "#ffffff" }),
91
+ loading: /* @__PURE__ */ import_react.default.createElement(import_icons.AccessTimeCircleFilledBoldIcon, { htmlColor: "#ffffff" }),
92
+ warning: /* @__PURE__ */ import_react.default.createElement(import_icons.AlertCircleFilledBoldIcon, { htmlColor: "#ffffff" }),
93
+ success: /* @__PURE__ */ import_react.default.createElement(import_icons.SuccessCircleFilledBoldIcon, { htmlColor: "#ffffff" })
94
+ };
95
+ const iconDom = iconMap[type] || icon;
96
+ return /* @__PURE__ */ import_react.default.createElement(import_Fade.default, __spreadProps(__spreadValues({}, others), { in: open, appear: false, unmountOnExit: true }), /* @__PURE__ */ import_react.default.createElement(
97
+ "div",
98
+ {
99
+ className: (0, import_clsx.default)(
100
+ prefixCls,
101
+ `${prefixCls}-${position}`,
102
+ {
103
+ [`${prefixCls}-icon`]: !!iconDom,
104
+ [`${prefixCls}-allow-click`]: !disableClick
105
+ },
106
+ className
107
+ ),
108
+ ref,
109
+ style
110
+ },
111
+ iconDom,
112
+ message
113
+ ));
114
+ }
115
+ );
116
+ ToastComponent.displayName = "BuiToast";
117
+ var Toast_default = ToastComponent;
@@ -0,0 +1,87 @@
1
+ import React from 'react';
2
+ import { FadeProps } from '../Fade/Fade.types';
3
+ /**
4
+ * 提示类型
5
+ */
6
+ export type ToastType = 'loading' | 'success' | 'fail' | 'warning';
7
+ export interface ToastProps extends FadeProps {
8
+ /**
9
+ * 是否展示
10
+ */
11
+ open?: boolean;
12
+ /**
13
+ * 提示类型
14
+ */
15
+ type?: ToastType;
16
+ /**
17
+ * toast内容,支持使用`\n`换行
18
+ */
19
+ message?: string;
20
+ /**
21
+ * 展示时长(ms),值为 0 时,toast 不会消失
22
+ * @default 2000
23
+ */
24
+ duration?: number;
25
+ /**
26
+ * 展示位置
27
+ * @default center
28
+ */
29
+ position?: 'top' | 'center' | 'bottom';
30
+ /**
31
+ * 是否允许同时存在多个Toast
32
+ * @default false
33
+ */
34
+ allowMultiple?: boolean;
35
+ /**
36
+ * 自定义图标
37
+ */
38
+ icon?: React.ReactNode;
39
+ /**
40
+ * 展示Toast时,页面内容是否可以点击
41
+ * @default false
42
+ */
43
+ disableClick?: boolean;
44
+ /**
45
+ * 关闭时的回调函数
46
+ */
47
+ onClose?: () => void;
48
+ }
49
+ /**
50
+ * 函数式调用配置参数
51
+ */
52
+ export type ToastOptions = Omit<ToastProps, 'type' | 'open'> | string;
53
+ /**
54
+ * 函数式调用返回值类型
55
+ */
56
+ export type ToastReturnType = {
57
+ /**
58
+ * 关闭当前提示
59
+ */
60
+ close: () => void;
61
+ };
62
+ /**
63
+ * Toast Instance
64
+ */
65
+ export interface ToastInstance {
66
+ (options: ToastOptions): ToastReturnType;
67
+ /**
68
+ * 警告提示
69
+ */
70
+ warning: (options: ToastOptions) => ToastReturnType;
71
+ /**
72
+ * 加载提示
73
+ */
74
+ loading: (options: ToastOptions) => ToastReturnType;
75
+ /**
76
+ * 成功提示
77
+ */
78
+ success: (options: ToastOptions) => ToastReturnType;
79
+ /**
80
+ * 失败提示
81
+ */
82
+ fail: (options: ToastOptions) => ToastReturnType;
83
+ /**
84
+ * 清空提示
85
+ */
86
+ clear: () => void;
87
+ }
@@ -0,0 +1,15 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
+ var __getOwnPropNames = Object.getOwnPropertyNames;
4
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
5
+ var __copyProps = (to, from, except, desc) => {
6
+ if (from && typeof from === "object" || typeof from === "function") {
7
+ for (let key of __getOwnPropNames(from))
8
+ if (!__hasOwnProp.call(to, key) && key !== except)
9
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
10
+ }
11
+ return to;
12
+ };
13
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
14
+ var Toast_types_exports = {};
15
+ module.exports = __toCommonJS(Toast_types_exports);
@@ -0,0 +1,2 @@
1
+ export { default, default as Toast } from './FunctionalToast';
2
+ export * from './Toast.types';
@@ -0,0 +1,41 @@
1
+ var __create = Object.create;
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __getProtoOf = Object.getPrototypeOf;
6
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
7
+ var __export = (target, all) => {
8
+ for (var name in all)
9
+ __defProp(target, name, { get: all[name], enumerable: true });
10
+ };
11
+ var __copyProps = (to, from, except, desc) => {
12
+ if (from && typeof from === "object" || typeof from === "function") {
13
+ for (let key of __getOwnPropNames(from))
14
+ if (!__hasOwnProp.call(to, key) && key !== except)
15
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
16
+ }
17
+ return to;
18
+ };
19
+ var __reExport = (target, mod, secondTarget) => (__copyProps(target, mod, "default"), secondTarget && __copyProps(secondTarget, mod, "default"));
20
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
21
+ // If the importer is in node compatibility mode or this is not an ESM
22
+ // file that has been converted to a CommonJS file using a Babel-
23
+ // compatible transform (i.e. "__esModule" has not been set), then set
24
+ // "default" to the CommonJS "module.exports" for node compatibility.
25
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
26
+ mod
27
+ ));
28
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
+ var Toast_exports = {};
30
+ __export(Toast_exports, {
31
+ Toast: () => import_FunctionalToast.default,
32
+ default: () => import_FunctionalToast.default
33
+ });
34
+ module.exports = __toCommonJS(Toast_exports);
35
+ var import_FunctionalToast = __toESM(require("./FunctionalToast"));
36
+ __reExport(Toast_exports, require("./Toast.types"), module.exports);
37
+ // Annotate the CommonJS export names for ESM import in node:
38
+ 0 && (module.exports = {
39
+ Toast,
40
+ ...require("./Toast.types")
41
+ });
@@ -53,7 +53,13 @@ var import_react = __toESM(require("react"));
53
53
  var import_TransitionCore = __toESM(require("./TransitionCore"));
54
54
  const Transition = /* @__PURE__ */ import_react.default.forwardRef(
55
55
  (props, ref) => {
56
- return /* @__PURE__ */ import_react.default.createElement(import_TransitionCore.default, __spreadProps(__spreadValues({}, props), { nextTick: import_taro.default.nextTick, ref }));
56
+ return /* @__PURE__ */ import_react.default.createElement(
57
+ import_TransitionCore.default,
58
+ __spreadProps(__spreadValues({}, props), {
59
+ nextTick: (cb) => setTimeout(() => import_taro.default.nextTick(cb), 16),
60
+ ref
61
+ })
62
+ );
57
63
  }
58
64
  );
59
65
  Transition.displayName = "BuiTransition";
package/dist/index.d.ts CHANGED
@@ -38,3 +38,5 @@ export * from './TabBar';
38
38
  export * from './Countdown';
39
39
  export * from './CitySelector';
40
40
  export * from './Picker';
41
+ export * from './Toast';
42
+ export * from './Dialog';
package/dist/index.js CHANGED
@@ -54,6 +54,8 @@ __reExport(src_exports, require("./TabBar"), module.exports);
54
54
  __reExport(src_exports, require("./Countdown"), module.exports);
55
55
  __reExport(src_exports, require("./CitySelector"), module.exports);
56
56
  __reExport(src_exports, require("./Picker"), module.exports);
57
+ __reExport(src_exports, require("./Toast"), module.exports);
58
+ __reExport(src_exports, require("./Dialog"), module.exports);
57
59
  // Annotate the CommonJS export names for ESM import in node:
58
60
  0 && (module.exports = {
59
61
  ...require("./ActionSheet"),
@@ -95,5 +97,7 @@ __reExport(src_exports, require("./Picker"), module.exports);
95
97
  ...require("./TabBar"),
96
98
  ...require("./Countdown"),
97
99
  ...require("./CitySelector"),
98
- ...require("./Picker")
100
+ ...require("./Picker"),
101
+ ...require("./Toast"),
102
+ ...require("./Dialog")
99
103
  });