ono-react-element 0.0.17 → 0.0.18
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/dist/es/AutoSliderList-eb1CVc8b.js +30 -1
- package/dist/es/AvatarCrop-DrA-SARP.js +65 -1
- package/dist/es/Button-BsWI818a.js +29 -1
- package/dist/es/Card3D-DMvCSUhe.js +18 -1
- package/dist/es/Checkbox-daBabj14.js +19 -1
- package/dist/es/InjunctiveBox-DUNoNHCO.js +11 -1
- package/dist/es/Input-DLOeg2pz.js +80 -1
- package/dist/es/List-UAKCMuGC.js +19 -1
- package/dist/es/MenuButton-DHkU5Bq7.js +17 -1
- package/dist/es/Message-BGDILiLc.js +105 -1
- package/dist/es/Modal-BsI-8rap.js +37 -1
- package/dist/es/Pagination-m71H2tfS.js +17 -1
- package/dist/es/PortalRenderer-CDAzQJgm.js +19 -1
- package/dist/es/Radio-D_GKVoOC.js +25 -1
- package/dist/es/ScrollableTabs--449B73p.js +34 -1
- package/dist/es/Select-B11NvK-I.js +34 -1
- package/dist/es/SvgImg-CZwq2D7J.js +14 -1
- package/dist/es/Switch-BBHMaxoZ.js +34 -1
- package/dist/es/TemplateDialog-PQxjmAJa.js +45 -1
- package/dist/es/Toast-CQEsbqUJ.js +42 -1
- package/dist/es/Tooltip-CgttMIcX.js +29 -1
- package/dist/es/VirtualList-CdhqyHFQ.js +60 -1
- package/dist/es/Waterfall-CY3QkL5m.js +50 -1
- package/dist/es/colorUtils.ts-DYuRvCXZ.js +145 -1
- package/dist/es/common.ts-vX9A6Rye.js +154 -1
- package/dist/es/dependencies-CbQbPZZ-.js +15524 -1
- package/dist/es/event-CtX9rswE.js +28 -1
- package/dist/es/fileFormatConversion.ts-tUlewYon.js +38 -1
- package/dist/es/formatTimeUtils.ts-CkdWJ_Sl.js +32 -1
- package/dist/es/index.js +123 -1
- package/dist/es/useClickOutSide.tsx-CMvd2uTW.js +15 -1
- package/dist/es/useCountdown.tsx-Btzj-keH.js +16 -1
- package/dist/es/useEventListener.tsx-BBGVcI5T.js +12 -1
- package/dist/es/useGetElementSize.tsx-Dtshth0Y.js +22 -1
- package/dist/es/useKeyPress.tsx-Db44HXXz.js +18 -1
- package/dist/es/useMouseClick.tsx-C7uAH4n4.js +12 -1
- package/dist/es/useTheme.tsx-C5b7BRYz.js +24 -1
- package/dist/es/useThemePro.tsx-DQuSI8J7.js +20 -1
- package/dist/es/viewTransitionUtils.ts-CHa9uBpi.js +19 -1
- package/package.json +1 -1
|
@@ -1 +1,30 @@
|
|
|
1
|
-
import{j as t}from "./dependencies-CbQbPZZ-.js";
|
|
1
|
+
import { j as t } from "./dependencies-CbQbPZZ-.js";
|
|
2
|
+
import { u as e } from "./useGetElementSize.tsx-Dtshth0Y.js";
|
|
3
|
+
import { p as i } from "./common.ts-vX9A6Rye.js";
|
|
4
|
+
import { useState as o, useRef as r, useMemo as n, useEffect as s, cloneElement as l } from "react";
|
|
5
|
+
var a = ((t2) => (t2.Horizontal = "Horizontal", t2.Vertical = "Vertical", t2))(a || {});
|
|
6
|
+
const c = ({ list: c2, style: d, disable: f, children: m, sliderBox: u, className: p, sliderStyle: h, duration: x = 300, sliderClassName: w, currentIndex: y = 0, direction: j = a.Horizontal, sliderTransitionTimingFunction: z = "ease-in-out" }) => {
|
|
7
|
+
const [g, H] = o(false), [T, $] = o(0), [v, A] = o({ t: 0, l: 0 }), [C, N] = o({ w: 0, h: 0 }), b = r(null), B = r(null), S = n(() => ["width", "height", "transform"].map((t2) => `${t2} ${x / 1e3}s ${z}`).join(","), [j, x, z]), k = n(() => ({ width: C.w, height: C.h, transition: g ? S : "initial", transform: `translate(${v.l}px, ${v.t}px)` }), [C, v]), { w: D, h: E } = e();
|
|
8
|
+
return s(() => {
|
|
9
|
+
$(y);
|
|
10
|
+
}, [y]), s(() => {
|
|
11
|
+
(() => {
|
|
12
|
+
if ("number" != typeof T) return;
|
|
13
|
+
if (!b.current || !B.current) return;
|
|
14
|
+
const t2 = Array.from(b.current.children).slice(1);
|
|
15
|
+
t2.forEach((t3) => {
|
|
16
|
+
t3.style.position = "relative", t3.style.cursor = f ? "not-allowed" : "pointer", t3.style.zIndex = "1";
|
|
17
|
+
});
|
|
18
|
+
const e2 = window.getComputedStyle(b.current), o2 = { t: "Horizontal" === j ? i(e2.paddingTop) : t2[T].offsetTop, l: "Horizontal" === j ? t2[T].offsetLeft : i(e2.paddingLeft) };
|
|
19
|
+
A(o2), N({ w: t2[T].offsetWidth, h: t2[T].offsetHeight }), setTimeout(() => H(true), x);
|
|
20
|
+
})();
|
|
21
|
+
}, [T, D, E, f]), t.jsxs("ul", { ref: b, className: ["ono-auto-slider-list-container", p, f ? "ono-auto-slider-list-is-disable" : ""].filter(Boolean).join(" "), style: { flexDirection: "Horizontal" === j ? "row" : "column", ...d }, children: [t.jsx("li", { ref: B, className: ["ono-auto-slider-list-slider", w].filter(Boolean).join(" "), style: { ...h, ...k }, children: u }), c2.map((t2, e2) => l(m({ item: t2, index: e2, isActive: e2 === T }), { onClick: (i2) => {
|
|
22
|
+
if (f) return;
|
|
23
|
+
const o2 = m({ item: t2, index: e2, isActive: e2 === T }).props.onClick;
|
|
24
|
+
o2 && o2(i2), $(e2);
|
|
25
|
+
} }))] });
|
|
26
|
+
};
|
|
27
|
+
export {
|
|
28
|
+
c as A,
|
|
29
|
+
a as D
|
|
30
|
+
};
|
|
@@ -1 +1,65 @@
|
|
|
1
|
-
import{j as t}from "./dependencies-CbQbPZZ-.js";
|
|
1
|
+
import { j as t } from "./dependencies-CbQbPZZ-.js";
|
|
2
|
+
import { useState as e, useRef as a, useEffect as n } from "react";
|
|
3
|
+
const r = ({ imageFile: r2, cvsW: l2 = 520, maskBG: s = "rgba(0, 0, 0, 0.5)", border: i = "4px solid #fff", wheelScale: o = 0.1, setCtx: c, maskInfo: w, setMaskInfo: h, imageStartState: g, setImageStartState: d, imageState: m, setImageState: u }) => {
|
|
4
|
+
const [f, x] = e(), [p, b] = e({ w: 0, h: 0 }), [S, v] = e({ w: 0, h: 0 }), [I, y] = e({ x: 0, y: 0 }), [j, M] = e(false), k = a(null), C = a(null), R = (t2, e2) => {
|
|
5
|
+
e2((e3) => ({ ...e3, ...t2 }));
|
|
6
|
+
}, B = () => {
|
|
7
|
+
const t2 = i.split(" ");
|
|
8
|
+
let e2 = 0;
|
|
9
|
+
return t2.forEach((t3) => {
|
|
10
|
+
t3.includes("px") && (e2 = Number(t3.split("px")[0]));
|
|
11
|
+
}), e2;
|
|
12
|
+
}, D = () => {
|
|
13
|
+
M(false), m.l > w.l && R({ l: w.l }, u), m.t > w.l && R({ t: w.l }, u), -m.l > m.w - w.l - w.w && R({ l: -(m.w - w.l - w.w) }, u), -m.t > m.h - w.l - w.w && R({ t: -(m.h - w.l - w.w) }, u);
|
|
14
|
+
};
|
|
15
|
+
return n(() => {
|
|
16
|
+
(() => {
|
|
17
|
+
if (!k.current) return;
|
|
18
|
+
const { width: t2 } = k.current.getBoundingClientRect();
|
|
19
|
+
((t3) => {
|
|
20
|
+
const e2 = new Image();
|
|
21
|
+
e2.src = "string" == typeof r2 ? r2 : URL.createObjectURL(r2), e2.onload = () => {
|
|
22
|
+
var _a;
|
|
23
|
+
let a2 = 1, n2 = e2.width, r3 = e2.height;
|
|
24
|
+
n2 > r3 ? (a2 = n2 / t3, n2 = t3, r3 /= a2, R({ w: r3 }, h)) : (a2 = r3 / t3, r3 = t3, n2 /= a2, R({ w: n2 }, h));
|
|
25
|
+
const l3 = (t3 - n2) / 2, s2 = (t3 - r3) / 2;
|
|
26
|
+
R({ w: e2.width, h: e2.height }, v), x(e2), R({ w: n2, h: r3, t: s2, l: l3 }, u), d({ w: n2, h: r3, t: s2, l: l3 }), R(l3 > s2 ? { l: l3 } : { l: s2 }, h), c((_a = C.current) == null ? void 0 : _a.getContext("2d"));
|
|
27
|
+
};
|
|
28
|
+
})(t2), b({ w: t2, h: t2 });
|
|
29
|
+
})();
|
|
30
|
+
}, [k]), n(() => {
|
|
31
|
+
if (!C.current || !f) return;
|
|
32
|
+
const t2 = C.current.getContext("2d");
|
|
33
|
+
t2 && (t2.clearRect(0, 0, C.current.width, C.current.height), t2.drawImage(f, m.l, m.t, m.w, m.h));
|
|
34
|
+
}, [C, f, m]), t.jsxs("div", { ref: k, className: "ono-avatar-canvas", style: { width: l2, cursor: j ? "grabbing" : "grab" }, onWheel: (t2) => {
|
|
35
|
+
t2.preventDefault(), t2.stopPropagation();
|
|
36
|
+
const e2 = t2.deltaY < 0 ? "in" : "out", a2 = ((t3, e3) => {
|
|
37
|
+
let a3 = t3 + ("in" === e3 ? t3 * o : -t3 * o);
|
|
38
|
+
return a3 > S.w && (a3 = S.w), a3 < g.w && (a3 = g.w), a3;
|
|
39
|
+
})(m.w, e2), n2 = a2 / S.w;
|
|
40
|
+
R({ w: a2, h: S.h * n2 }, u), D();
|
|
41
|
+
}, onMouseUp: D, onMouseLeave: D, children: [t.jsx("canvas", { width: p.w, height: p.h, ref: C, onMouseDown: (t2) => {
|
|
42
|
+
R({ x: t2.clientX, y: t2.clientY }, y), M(true);
|
|
43
|
+
}, onMouseMove: (t2) => {
|
|
44
|
+
if (j) {
|
|
45
|
+
const e2 = t2.clientX - I.x, a2 = t2.clientY - I.y;
|
|
46
|
+
(Math.abs(e2) > 10 || Math.abs(a2) > 10) && (R({ t: m.t + a2, l: m.l + e2 }, u), R({ x: t2.clientX, y: t2.clientY }, y));
|
|
47
|
+
}
|
|
48
|
+
} }), f && t.jsx("div", { className: "ono-avatar-mask", children: t.jsx("div", { style: { border: i, boxShadow: `${s} 0 0 0 10000px`, width: `${w.w + 2 * B()}px`, height: `${w.w + 2 * B()}px` } }) })] });
|
|
49
|
+
}, l = ({ imageFile: a2, cvsW: n2 = 520, maskBG: l2 = "rgba(0, 0, 0, 0.5)", border: s = "4px solid #fff", wheelScale: i = 0.1, children: o }) => {
|
|
50
|
+
const [c, w] = e({ w: 0, h: 0, t: 0, l: 0 }), [h, g] = e({ w: 0, h: 0, t: 0, l: 0 }), [d, m] = e({ w: 0, l: 0 }), [u, f] = e();
|
|
51
|
+
return t.jsxs(t.Fragment, { children: [t.jsx(r, { imageFile: a2, cvsW: n2, maskBG: l2, border: s, wheelScale: i, maskInfo: d, setMaskInfo: m, setCtx: f, imageStartState: c, setImageStartState: w, imageState: h, setImageState: g }), o == null ? void 0 : o({ handleConfirm: (t2, e2) => {
|
|
52
|
+
if (!u) return;
|
|
53
|
+
const a3 = u.getImageData(d.l, d.l, d.w, d.w), n3 = document.createElement("canvas"), r2 = n3.getContext("2d");
|
|
54
|
+
if (n3.width = d.w, n3.height = d.w, !r2) return;
|
|
55
|
+
const { imageSaveType: l3 = "png", dataSaveType: s2 = "base64", quality: i2 = 100 } = e2 || {};
|
|
56
|
+
r2.putImageData(a3, 0, 0, 0, 0, d.w, d.w), "base64" === s2 ? t2(n3.toDataURL(`image/${l3}`, i2 / 100)) : "blob" === s2 && n3.toBlob((e3) => {
|
|
57
|
+
if (e3) return t2(e3);
|
|
58
|
+
}, `image/${l3}`, i2 / 100);
|
|
59
|
+
}, handleReduction: (t2) => {
|
|
60
|
+
g({ w: c.w, h: c.h, t: c.t, l: c.l }), t2 == null ? void 0 : t2();
|
|
61
|
+
} })] });
|
|
62
|
+
};
|
|
63
|
+
export {
|
|
64
|
+
l as A
|
|
65
|
+
};
|
|
@@ -1 +1,29 @@
|
|
|
1
|
-
import{j as n}from "./dependencies-CbQbPZZ-.js";
|
|
1
|
+
import { j as n } from "./dependencies-CbQbPZZ-.js";
|
|
2
|
+
import { t as o } from "./common.ts-vX9A6Rye.js";
|
|
3
|
+
import { forwardRef as t, useState as e, useRef as i, useEffect as r } from "react";
|
|
4
|
+
const s = t(({ onClick: t2, children: s2, disabled: c, loading: a, plain: l, shape: d = "default", htmlType: u = "button", type: p = "primary", throttleDuration: m, className: f, style: h, icon: g }, b) => {
|
|
5
|
+
const [j, y] = e(false), x = i(null), C = i(null), v = t2 ? o(t2, m ? "number" == typeof m ? m : 500 : 0) : void 0;
|
|
6
|
+
return r(() => {
|
|
7
|
+
(() => {
|
|
8
|
+
if (!C.current) return;
|
|
9
|
+
const n2 = C.current;
|
|
10
|
+
a ? (y(true), n2.classList.add("ono-loading-start")) : (setTimeout(() => {
|
|
11
|
+
y(false);
|
|
12
|
+
}, 300), n2.classList.remove("ono-loading-start"), n2.classList.add("ono-loading-end"));
|
|
13
|
+
})();
|
|
14
|
+
}, [a, C]), r(() => {
|
|
15
|
+
(() => {
|
|
16
|
+
if (!x.current) return;
|
|
17
|
+
const n2 = x.current, o2 = n2.getBoundingClientRect();
|
|
18
|
+
n2.style.setProperty("--btn-height", o2.height + "px");
|
|
19
|
+
})();
|
|
20
|
+
}, [x]), r(() => {
|
|
21
|
+
b && x && ("function" == typeof b ? b(x.current) : b.current = x.current);
|
|
22
|
+
}, [b, x]), n.jsxs("button", { ref: x, className: [`ono-btn-${p}`, a || j ? "ono-is-loading" : "", a || g ? "ono-is-icon" : "", c ? "ono-btn-is-disabled" : "", "round" === d ? "ono-is-round" : "circle" === d ? "ono-is-circle" : "", l ? "ono-is-plain" : "", f ?? ""].filter(Boolean).join(" "), type: u, disabled: ("function" == typeof c ? c() : c) || !!a, style: h, onClick: v, children: [(() => {
|
|
23
|
+
const o2 = n.jsx("span", { ref: C, className: "ono-btn-icon", children: n.jsx("span", { children: "object" == typeof a ? a.icon : n.jsx("svg", { viewBox: "0 0 1024 1024", focusable: "false", "data-icon": "loading", width: "1em", height: "1em", fill: "currentColor", "aria-hidden": "true", children: n.jsx("path", { d: "M988 548c-19.9 0-36-16.1-36-36 0-59.4-11.6-117-34.6-171.3a440.45 440.45 0 00-94.3-139.9 437.71 437.71 0 00-139.9-94.3C629 83.6 571.4 72 512 72c-19.9 0-36-16.1-36-36s16.1-36 36-36c69.1 0 136.2 13.5 199.3 40.3C772.3 66 827 103 874 150c47 47 83.9 101.8 109.7 162.7 26.7 63.1 40.2 130.2 40.2 199.3.1 19.9-16 36-35.9 36z" }) }) }) });
|
|
24
|
+
return a || j ? o2 : g ? n.jsx("span", { children: g }) : n.jsx(n.Fragment, {});
|
|
25
|
+
})(), s2] });
|
|
26
|
+
});
|
|
27
|
+
export {
|
|
28
|
+
s as B
|
|
29
|
+
};
|
|
@@ -1 +1,18 @@
|
|
|
1
|
-
import{j as e}from "./dependencies-CbQbPZZ-.js";
|
|
1
|
+
import { j as e } from "./dependencies-CbQbPZZ-.js";
|
|
2
|
+
import { useState as r, useRef as t, useEffect as s } from "react";
|
|
3
|
+
const o = ({ src: o2, children: n, enlarge: c = false, scale: a = 1.1, shadow: d, xRange: l = [-10, 10], yRange: i = [-10, 10], borderRadius: u = 20 }) => {
|
|
4
|
+
const [y, f] = r(false), p = t(null), g = (e2, r2, t2) => r2 / t2 * (e2[1] - e2[0]) + e2[0];
|
|
5
|
+
return s(() => {
|
|
6
|
+
p.current && d && p.current.style.setProperty("--sd", d);
|
|
7
|
+
}, [p.current]), s(() => {
|
|
8
|
+
if (!n && !o2) throw new Error("请传入children或者src属性");
|
|
9
|
+
}, [n, o2]), e.jsx("div", { ref: p, className: "ono-card", style: { borderRadius: u, transform: `perspective(500px) scale(${y && c ? a : 1}) rotateX(var(--rx, 0deg)) rotateY(var(--ry, 0deg))` }, onMouseEnter: () => f(true), onMouseMove: (e2) => {
|
|
10
|
+
const { offsetX: r2, offsetY: t2 } = e2.nativeEvent, { offsetWidth: s2, offsetHeight: o3 } = p.current, n2 = g(l, t2, o3), c2 = -g(i, r2, s2);
|
|
11
|
+
p.current.style.setProperty("--rx", `${n2}deg`), p.current.style.setProperty("--ry", `${c2}deg`);
|
|
12
|
+
}, onMouseLeave: () => {
|
|
13
|
+
f(false), p.current.style.setProperty("--rx", "0deg"), p.current.style.setProperty("--ry", "0deg");
|
|
14
|
+
}, children: n ?? e.jsx("img", { src: o2, alt: "图片" }) });
|
|
15
|
+
};
|
|
16
|
+
export {
|
|
17
|
+
o as C
|
|
18
|
+
};
|
|
@@ -1 +1,19 @@
|
|
|
1
|
-
import{j as e}from "./dependencies-CbQbPZZ-.js";
|
|
1
|
+
import { j as e } from "./dependencies-CbQbPZZ-.js";
|
|
2
|
+
import { useState as r, useRef as t, useEffect as n } from "react";
|
|
3
|
+
const o = ({ id: o2, style: c, checked: l, onChange: a, className: i, indeterminate: s = false, checkedColor: d = "#0077cc", indeterminateStyle: m = "line", indeterminateColor: u = "#0077cc" }) => {
|
|
4
|
+
const [h, p] = r(""), y = t(null), C = [{ value: d, name: "checkedColor" }, { value: u, name: "indeterminateColor" }];
|
|
5
|
+
return n(() => {
|
|
6
|
+
(() => {
|
|
7
|
+
if (!y.current) return;
|
|
8
|
+
const e2 = getComputedStyle(y.current);
|
|
9
|
+
h || p(e2.borderColor), y.current.style.height = e2.width, [{ value: e2.width, name: "w" }, { value: l || s ? d : h, name: "border-color" }, ...C].forEach(({ value: e3, name: r2 }) => {
|
|
10
|
+
e3 && ((e4, r3, t2) => {
|
|
11
|
+
"string" == typeof e4 ? t2.style.setProperty(`--${r3}`, e4) : t2.style.setProperty(`--${r3}`, `${e4}px`);
|
|
12
|
+
})(e3, r2, y.current);
|
|
13
|
+
});
|
|
14
|
+
})(), y.current && (y.current.indeterminate = s);
|
|
15
|
+
}, [y, i, c, s]), e.jsx("input", { id: o2, type: "checkbox", ref: y, checked: l, onChange: a, className: [i, "line" === m ? "ono-checkbox-line" : "ono-checkbox-border"].filter(Boolean).join(" "), style: c });
|
|
16
|
+
};
|
|
17
|
+
export {
|
|
18
|
+
o as C
|
|
19
|
+
};
|
|
@@ -1 +1,11 @@
|
|
|
1
|
-
import{j as e,R as o}from "./dependencies-CbQbPZZ-.js";
|
|
1
|
+
import { j as e, R as o } from "./dependencies-CbQbPZZ-.js";
|
|
2
|
+
import { u as n } from "./useEventListener.tsx-BBGVcI5T.js";
|
|
3
|
+
let s, t = null;
|
|
4
|
+
const l = ({ className: o2, content: s2, style: l2, onClick: u2, onDoubleClick: i2, onContextMenu: c, onMouseDown: r, onMouseUp: a, onMouseEnter: M, onMouseLeave: d, onMouseMove: m, isClickBoxToClose: p }) => (n("click", () => {
|
|
5
|
+
p && t && (t.remove(), t = null);
|
|
6
|
+
}), e.jsx("div", { className: o2, style: l2, onClick: u2, onDoubleClick: i2, onContextMenu: c, onMouseDown: r, onMouseUp: a, onMouseEnter: M, onMouseLeave: d, onMouseMove: m, children: "function" == typeof s2 ? s2((e2) => {
|
|
7
|
+
t && (t.remove(), t = null, e2 && e2());
|
|
8
|
+
}) : s2 })), u = (o2) => (i(o2.isSingle || false).render(e.jsx(l, { ...o2 })), t), i = (e2) => (e2 && t && s || (t = document.createElement("div"), document.body.appendChild(t), s = o.createRoot(t)), s);
|
|
9
|
+
export {
|
|
10
|
+
u as i
|
|
11
|
+
};
|
|
@@ -1 +1,80 @@
|
|
|
1
|
-
import{j as e}from "./dependencies-CbQbPZZ-.js";
|
|
1
|
+
import { j as e } from "./dependencies-CbQbPZZ-.js";
|
|
2
|
+
import { useState as o, useRef as t, useEffect as n } from "react";
|
|
3
|
+
import { u as a } from "./useKeyPress.tsx-Db44HXXz.js";
|
|
4
|
+
const s = () => e.jsx("svg", { className: "ono-input-icon", viewBox: "64 64 896 896", focusable: "false", "data-icon": "close-circle", fill: "currentColor", "aria-hidden": "true", children: e.jsx("path", { d: "M512 64c247.4 0 448 200.6 448 448S759.4 960 512 960 64 759.4 64 512 264.6 64 512 64zm127.98 274.82h-.04l-.08.06L512 466.75 384.14 338.88c-.04-.05-.06-.06-.08-.06a.12.12 0 00-.07 0c-.03 0-.05.01-.09.05l-45.02 45.02a.2.2 0 00-.05.09.12.12 0 000 .07v.02a.27.27 0 00.06.06L466.75 512 338.88 639.86c-.05.04-.06.06-.06.08a.12.12 0 000 .07c0 .03.01.05.05.09l45.02 45.02a.2.2 0 00.09.05.12.12 0 00.07 0c.02 0 .04-.01.08-.05L512 557.25l127.86 127.87c.04.04.06.05.08.05a.12.12 0 00.07 0c.03 0 .05-.01.09-.05l45.02-45.02a.2.2 0 00.05-.09.12.12 0 000-.07v-.02a.27.27 0 00-.05-.06L557.25 512l127.87-127.86c.04-.04.05-.06.05-.08a.12.12 0 000-.07c0-.03-.01-.05-.05-.09l-45.02-45.02a.2.2 0 00-.09-.05.12.12 0 00-.07 0z" }) }), r = ({ open: o2 }) => e.jsx("svg", { viewBox: "64 64 896 896", focusable: "false", "data-icon": o2 ? "eye" : "eye-invisible", fill: "currentColor", "aria-hidden": "true", className: "ono-input-icon", children: o2 ? e.jsx("path", { d: "M942.2 486.2C847.4 286.5 704.1 186 512 186c-192.2 0-335.4 100.5-430.2 300.3a60.3 60.3 0 000 51.5C176.6 737.5 319.9 838 512 838c192.2 0 335.4-100.5 430.2-300.3 7.7-16.2 7.7-35 0-51.5zM512 766c-161.3 0-279.4-81.8-362.7-254C232.6 339.8 350.7 258 512 258c161.3 0 279.4 81.8 362.7 254C791.5 684.2 673.4 766 512 766zm-4-430c-97.2 0-176 78.8-176 176s78.8 176 176 176 176-78.8 176-176-78.8-176-176-176zm0 288c-61.9 0-112-50.1-112-112s50.1-112 112-112 112 50.1 112 112-50.1 112-112 112z" }) : e.jsxs(e.Fragment, { children: [e.jsx("path", { d: "M942.2 486.2Q889.47 375.11 816.7 305l-50.88 50.88C807.31 395.53 843.45 447.4 874.7 512 791.5 684.2 673.4 766 512 766q-72.67 0-133.87-22.38L323 798.75Q408 838 512 838q288.3 0 430.2-300.3a60.29 60.29 0 000-51.5zm-63.57-320.64L836 122.88a8 8 0 00-11.32 0L715.31 232.2Q624.86 186 512 186q-288.3 0-430.2 300.3a60.3 60.3 0 000 51.5q56.69 119.4 136.5 191.41L112.48 835a8 8 0 000 11.31L155.17 889a8 8 0 0011.31 0l712.15-712.12a8 8 0 000-11.32zM149.3 512C232.6 339.8 350.7 258 512 258c54.54 0 104.13 9.36 149.12 28.39l-70.3 70.3a176 176 0 00-238.13 238.13l-83.42 83.42C223.1 637.49 183.3 582.28 149.3 512zm246.7 0a112.11 112.11 0 01146.2-106.69L401.31 546.2A112 112 0 01396 512z" }), e.jsx("path", { d: "M508 624c-3.46 0-6.87-.16-10.25-.47l-52.82 52.82a176.09 176.09 0 00227.42-227.42l-52.82 52.82c.31 3.38.47 6.79.47 10.25a111.94 111.94 0 01-112 112z" })] }) }), l = ({ id: a2, name: l2, max: i2, min: c, maxLength: d, minLength: u, type: p = "text", className: m, defaultValue: h, placeholder: x, readonly: f, autocomplete: y = "off", autofocus: g, form: v, disabled: b, clearable: C, showPassword: j, prepend: w, append: N, prefix: L, suffix: z, showCount: S, border: B = "1px solid #5644b8", boxShadow: M = "0 0 0 2px #7969d11a", value: P = "", onChange: k, onFocus: F, onBlur: E, onClear: O }) => {
|
|
5
|
+
const [q, D] = o(P), [Q, R] = o(false), [Y, V] = o(false), W = t(null), $ = C && !b && q, A = j && !b;
|
|
6
|
+
return n(() => {
|
|
7
|
+
W.current && (W.current.style.setProperty("--ono-input-border", B), W.current.style.setProperty("--ono-input-box-shadow", M));
|
|
8
|
+
}, [W]), n(() => {
|
|
9
|
+
D(P);
|
|
10
|
+
}, [P]), e.jsxs("div", { className: ["ono-input", "ono-input-border", b ? "ono-input-is-disabled" : ""].filter(Boolean).join(" "), children: [w && e.jsx("div", { className: "ono-prepend", children: w }), e.jsxs("div", { ref: W, className: ["ono-input-wrapper", Q ? "ono-input-is-focus" : "", m].filter(Boolean).join(" "), onMouseDown: (e2) => {
|
|
11
|
+
"INPUT" !== e2.target.tagName && e2.preventDefault();
|
|
12
|
+
}, children: [L && e.jsx("span", { className: "ono-prefix", children: L }), e.jsx("input", { id: a2, max: i2, min: c, name: l2, maxLength: d, minLength: u, defaultValue: h, className: "ono-input-inner", type: j ? Y ? "text" : "password" : p, placeholder: x, readOnly: f, autoComplete: y, autoFocus: g, form: v, disabled: b, onFocus: (e2) => {
|
|
13
|
+
F == null ? void 0 : F(e2), R(true);
|
|
14
|
+
}, onBlur: (e2) => {
|
|
15
|
+
E == null ? void 0 : E(e2), R(false);
|
|
16
|
+
}, value: q, onChange: (e2) => {
|
|
17
|
+
k == null ? void 0 : k(e2), D(e2.target.value);
|
|
18
|
+
} }), (z || $ || A || S) && e.jsxs("span", { className: "ono-suffix", children: [z, $ && e.jsx("button", { className: "ono-clear-icon", onClick: () => {
|
|
19
|
+
O == null ? void 0 : O(), D("");
|
|
20
|
+
}, children: e.jsx(s, {}) }), A && e.jsx("button", { className: "ono-eye-icon", onClick: () => V(!Y), children: e.jsx(r, { open: Y }) }), S && d && e.jsxs("p", { className: "ono-count", children: [q.length, "/", d] })] })] }), N && e.jsx("div", { className: "ono-append", children: N })] });
|
|
21
|
+
}, i = ({ id: s2, name: r2, rows: l2, maxLength: i2, minLength: c, className: d, placeholder: u, readonly: p, resize: m = true, autocomplete: h = "off", autofocus: x, form: f, disabled: y, autoSize: g, showCount: v, border: b = "1px solid #5644b8", boxShadow: C = "0 0 0 2px #7969d11a", value: j = "", onChange: w }) => {
|
|
22
|
+
const [N, L] = o(j), [z, S] = o(false), [B, M] = o([j]), [P, k] = o(0), F = t(null), E = (e2) => {
|
|
23
|
+
const o2 = B.slice(0, P + 1);
|
|
24
|
+
o2.push(e2), M(o2), k(o2.length - 1);
|
|
25
|
+
}, O = [{ key: "CommandOrControl+z", handler: (e2) => {
|
|
26
|
+
document.activeElement === F.current && (e2.preventDefault(), (() => {
|
|
27
|
+
if (P > 0 && F.current) {
|
|
28
|
+
const e3 = P - 1, o2 = B[e3];
|
|
29
|
+
if (F.current.value = o2, L(o2), k(e3), w) {
|
|
30
|
+
const e4 = { target: F.current };
|
|
31
|
+
w(e4);
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
})());
|
|
35
|
+
}, deps: [B] }, { key: "CommandOrControl+d", handler: (e2) => {
|
|
36
|
+
if (F.current && document.activeElement === F.current) {
|
|
37
|
+
e2.preventDefault();
|
|
38
|
+
const o2 = ((e3) => {
|
|
39
|
+
const { value: o3, selectionStart: t2, selectionEnd: n2 } = e3, a2 = o3.substring(0, t2) + o3.substring(n2);
|
|
40
|
+
return e3.value = a2, e3.setSelectionRange(t2, t2), a2;
|
|
41
|
+
})(F.current);
|
|
42
|
+
if (L(o2), E(o2), w) {
|
|
43
|
+
const e3 = { target: F.current };
|
|
44
|
+
w(e3);
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
}, deps: [B] }];
|
|
48
|
+
return O.forEach(({ key: e2, handler: o2, deps: t2 }) => a(e2, o2, { target: F.current, deps: t2 })), n(() => {
|
|
49
|
+
L(j);
|
|
50
|
+
}, [j]), n(() => {
|
|
51
|
+
(() => {
|
|
52
|
+
if (!F.current) return;
|
|
53
|
+
const e2 = F.current;
|
|
54
|
+
((e3, o2, t2, n2, a2) => {
|
|
55
|
+
const s3 = e3.parentNode;
|
|
56
|
+
e3.style.resize = o2 ? "none" : t2 ? "vertical" : "none", s3.style.setProperty("--ono-input-border", n2), s3.style.setProperty("--ono-input-box-shadow", a2), s3.style.setProperty("--ono-input-height", "auto");
|
|
57
|
+
})(e2, g || false, m, b, C), g && ((e3, o2) => {
|
|
58
|
+
const { minRows: t2 = 2, maxRows: n2 } = "object" == typeof o2 ? o2 : {}, a2 = document.createElement("div");
|
|
59
|
+
a2.style.position = "absolute", a2.style.visibility = "hidden", a2.style.whiteSpace = "pre-wrap", a2.style.wordWrap = "break-word", a2.style.width = `${e3.clientWidth}px`, a2.style.font = getComputedStyle(e3).font, a2.style.padding = getComputedStyle(e3).padding, a2.style.border = getComputedStyle(e3).border, a2.style.boxSizing = "border-box", document.body.appendChild(a2);
|
|
60
|
+
const s3 = 34 * t2;
|
|
61
|
+
let r3 = s3;
|
|
62
|
+
if (e3.value) {
|
|
63
|
+
a2.textContent = e3.value;
|
|
64
|
+
const o3 = a2.offsetHeight;
|
|
65
|
+
r3 = Math.max(s3, o3), n2 && r3 > 34 * n2 ? (r3 = 34 * n2, e3.style.overflowY = "auto") : e3.style.overflowY = "hidden";
|
|
66
|
+
} else e3.style.overflowY = "hidden";
|
|
67
|
+
e3.style.height = `${r3}px`, e3.style.resize = o2 ? "none" : "vertical", document.body.removeChild(a2), Math.floor(r3 / 34);
|
|
68
|
+
})(e2, g);
|
|
69
|
+
})();
|
|
70
|
+
}, [F, g, N]), e.jsxs("div", { className: ["ono-textarea", y ? "ono-input-is-disabled" : ""].filter(Boolean).join(" "), children: [e.jsx("div", { className: ["ono-textarea-wrapper", z ? "none" === b ? "" : "ono-input-is-focus" : "", d].filter(Boolean).join(" "), onClick: () => {
|
|
71
|
+
var _a;
|
|
72
|
+
return (_a = F.current) == null ? void 0 : _a.focus();
|
|
73
|
+
}, children: e.jsx("textarea", { ref: F, className: "ono-textarea-inner", id: s2, rows: l2, name: r2, maxLength: i2, minLength: c, placeholder: u, readOnly: p, autoComplete: h, autoFocus: x, form: f, disabled: y, onFocus: () => S(true), onBlur: () => S(false), value: N, onChange: (e2) => {
|
|
74
|
+
L(e2.target.value), E(e2.target.value), w == null ? void 0 : w(e2);
|
|
75
|
+
} }) }), v && i2 && e.jsx("p", { className: "ono-count-bar", onClick: (e2) => e2.stopPropagation(), children: N.length + "/" + i2 })] });
|
|
76
|
+
};
|
|
77
|
+
export {
|
|
78
|
+
l as O,
|
|
79
|
+
i as a
|
|
80
|
+
};
|
package/dist/es/List-UAKCMuGC.js
CHANGED
|
@@ -1 +1,19 @@
|
|
|
1
|
-
import{useState as e,useEffect as t}from "react";
|
|
1
|
+
import { useState as e, useEffect as t } from "react";
|
|
2
|
+
const n = ({ list: n2, children: r2, fallback: s, deps: l = [], insertBetweenDom: o }) => {
|
|
3
|
+
const [c, a] = e([]);
|
|
4
|
+
return t(() => {
|
|
5
|
+
(async () => {
|
|
6
|
+
if (!n2) return;
|
|
7
|
+
a(s);
|
|
8
|
+
const e2 = "function" == typeof n2 ? await n2() : n2;
|
|
9
|
+
a(e2.length > 0 ? ((e3, t2) => t2 ? e3.reduce((n3, r3, s2) => (n3.push(r3), s2 < e3.length - 1 && n3.push(t2(s2)), n3), []) : e3)(((e3) => e3.map(r2).filter((e4) => e4))(e2), o) : s);
|
|
10
|
+
})();
|
|
11
|
+
}, [...l]), c;
|
|
12
|
+
}, r = ({ list: e2, children: t2, fallback: n2, insertBetweenDom: r2 }) => (() => {
|
|
13
|
+
const s = "function" == typeof e2 ? e2() : e2;
|
|
14
|
+
return s.length > 0 ? ((e3, t3) => t3 ? e3.reduce((n3, r3, s2) => (n3.push(r3), s2 < e3.length - 1 && n3.push(t3(s2)), n3), []) : e3)(((e3) => e3.map(t2).filter(Boolean))(s), r2) : n2;
|
|
15
|
+
})();
|
|
16
|
+
export {
|
|
17
|
+
n as A,
|
|
18
|
+
r as L
|
|
19
|
+
};
|
|
@@ -1 +1,17 @@
|
|
|
1
|
-
import{j as t}from "./dependencies-CbQbPZZ-.js";
|
|
1
|
+
import { j as t } from "./dependencies-CbQbPZZ-.js";
|
|
2
|
+
import { useState as e, useEffect as r } from "react";
|
|
3
|
+
const a = ({ active: a2, onchange: n, w: s = "40px", duration: o = 400, clr: i = "#f5f5f5", bgc: l = "#342A7C" }) => {
|
|
4
|
+
const [d, c] = e(false), h = (t2, e2) => {
|
|
5
|
+
let r2;
|
|
6
|
+
const a3 = t2.split("");
|
|
7
|
+
return "x" === a3[a3.length - 1] && (r2 = Number(a3.slice(0, -2).join("")) * e2 + "px"), r2;
|
|
8
|
+
}, m = { width: h(s, 0.6), height: h(s, 0.06), left: h(s, d ? 0.11 : 0.2), borderRadius: h(s, 1), background: i, transition: `all ${o / 1e3}s` }, u = [{ ...m, width: h(s, d ? 0.8 : 0.5), height: h(s, d ? 0.05 : 0.06), transform: d ? "translateY(0) rotate(45deg)" : `translateY(-${h(s, 0.22)})` }, { ...m, width: h(s, d ? 0.8 : 0.3), height: h(s, d ? 0.05 : 0.06), transform: d ? "translateY(0) rotate(315deg)" : `translateY(${h(s, 0.22)})` }, { ...m, left: "auto", transform: d ? `translateX(${h(s, 1.1)})` : "translateX(0)" }];
|
|
9
|
+
return r(() => {
|
|
10
|
+
c(!!a2);
|
|
11
|
+
}, [a2]), t.jsx("button", { className: "ono-menu-button", style: { width: s, height: s, background: l, borderRadius: h(s, 0.2) }, onClick: () => requestAnimationFrame(() => {
|
|
12
|
+
n == null ? void 0 : n(!d), c(!d);
|
|
13
|
+
}), children: u.map((e2, r2) => t.jsx("span", { style: { ...e2 } }, r2)) });
|
|
14
|
+
};
|
|
15
|
+
export {
|
|
16
|
+
a as M
|
|
17
|
+
};
|
|
@@ -1 +1,105 @@
|
|
|
1
|
-
import{j as e}from "./dependencies-CbQbPZZ-.js";
|
|
1
|
+
import { j as e } from "./dependencies-CbQbPZZ-.js";
|
|
2
|
+
import { useState as s, useRef as o, useMemo as t, useCallback as n, useEffect as r } from "react";
|
|
3
|
+
import { p as a } from "./PortalRenderer-CDAzQJgm.js";
|
|
4
|
+
let i = 1;
|
|
5
|
+
const c = [], l = (e2, s2, o2) => (0 === c.length && (i = 1), p(s2.instancesKey || "", e2, { id: `${o2}-${i++}`, key: s2.instancesKey || "", reactNode: e2, props: s2, offsetOptions: { topOffset: 0, height: 0, bottomOffset: 0 } }), c), d = (e2) => {
|
|
6
|
+
const s2 = c.findIndex((s3) => s3.id === e2);
|
|
7
|
+
return s2 <= 0 ? 0 : c[s2 - 1].offsetOptions.bottomOffset;
|
|
8
|
+
}, p = (e2, s2, o2) => {
|
|
9
|
+
const t2 = (e3) => a(s2, { zIndex: 999 + i - 1, ...e3.props, id: e3.id }, e3.id, "ono-message-root");
|
|
10
|
+
if (!e2) {
|
|
11
|
+
const e3 = t2(o2);
|
|
12
|
+
c.push({ ...o2, props: { ...o2.props, id: o2.id, destroy: e3 }, destroy: e3 });
|
|
13
|
+
}
|
|
14
|
+
let n2 = false;
|
|
15
|
+
const r2 = c.map((s3) => {
|
|
16
|
+
if (s3.key === e2) {
|
|
17
|
+
n2 = true;
|
|
18
|
+
const e3 = { ...s3.props, ...o2.props };
|
|
19
|
+
return { ...s3, props: e3 };
|
|
20
|
+
}
|
|
21
|
+
{
|
|
22
|
+
const e3 = t2(s3);
|
|
23
|
+
return { ...s3, props: { ...s3.props, id: s3.id, destroy: e3 }, destroy: e3 };
|
|
24
|
+
}
|
|
25
|
+
});
|
|
26
|
+
if (Object.assign(c, r2), !n2) {
|
|
27
|
+
const e3 = t2(o2);
|
|
28
|
+
c.push({ ...o2, props: { ...o2.props, id: o2.id, destroy: e3 }, destroy: e3 });
|
|
29
|
+
}
|
|
30
|
+
}, f = { info: { light: "#1677ff", dark: "#1677ff" }, success: { light: "#52c41a", dark: "#49aa19" }, error: { light: "#ff4d4f", dark: "#a61d24" }, warning: { light: "#faad14", dark: "#d89614" }, loading: { light: "#9254de", dark: "#f5f5f5" } }, u = (e2, s2) => f[e2][s2], m = (s2) => {
|
|
31
|
+
switch (s2) {
|
|
32
|
+
case "success":
|
|
33
|
+
return e.jsx("svg", { className: "ono-type-icon", viewBox: "0 0 1024 1024", focusable: "false", "data-icon": "check-circle", fill: u(s2, "light"), "aria-hidden": "true", children: e.jsx("path", { d: "M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm193.5 301.7l-210.6 292a31.8 31.8 0 01-51.7 0L318.5 484.9c-3.8-5.3 0-12.7 6.5-12.7h46.9c10.2 0 19.9 4.9 25.9 13.3l71.2 98.8 157.2-218c6-8.3 15.6-13.3 25.9-13.3H699c6.5 0 10.3 7.4 6.5 12.7z" }) });
|
|
34
|
+
case "error":
|
|
35
|
+
return e.jsx("svg", { className: "ono-type-icon", viewBox: "0 0 1024 1024", focusable: "false", "data-icon": "close-circle", fill: u(s2, "light"), "aria-hidden": "true", children: e.jsx("path", { d: "M512 64c247.4 0 448 200.6 448 448S759.4 960 512 960 64 759.4 64 512 264.6 64 512 64zm127.98 274.82h-.04l-.08.06L512 466.75 384.14 338.88c-.04-.05-.06-.06-.08-.06a.12.12 0 00-.07 0c-.03 0-.05.01-.09.05l-45.02 45.02a.2.2 0 00-.05.09.12.12 0 000 .07v.02a.27.27 0 00.06.06L466.75 512 338.88 639.86c-.05.04-.06.06-.06.08a.12.12 0 000 .07c0 .03.01.05.05.09l45.02 45.02a.2.2 0 00.09.05.12.12 0 00.07 0c.02 0 .04-.01.08-.05L512 557.25l127.86 127.87c.04.04.06.05.08.05a.12.12 0 00.07 0c.03 0 .05-.01.09-.05l45.02-45.02a.2.2 0 00.05-.09.12.12 0 000-.07v-.02a.27.27 0 00-.05-.06L557.25 512l127.87-127.86c.04-.04.05-.06.05-.08a.12.12 0 000-.07c0-.03-.01-.05-.05-.09l-45.02-45.02a.2.2 0 00-.09-.05.12.12 0 00-.07 0z" }) });
|
|
36
|
+
case "loading":
|
|
37
|
+
return e.jsx("svg", { className: ["ono-info-icon", "ono-loading"].join(" "), viewBox: "0 0 1024 1024", focusable: "false", "data-icon": "loading", fill: u(s2, "light"), "aria-hidden": "true", children: e.jsx("path", { d: "M988 548c-19.9 0-36-16.1-36-36 0-59.4-11.6-117-34.6-171.3a440.45 440.45 0 00-94.3-139.9 437.71 437.71 0 00-139.9-94.3C629 83.6 571.4 72 512 72c-19.9 0-36-16.1-36-36s16.1-36 36-36c69.1 0 136.2 13.5 199.3 40.3C772.3 66 827 103 874 150c47 47 83.9 101.8 109.7 162.7 26.7 63.1 40.2 130.2 40.2 199.3.1 19.9-16 36-35.9 36z" }) });
|
|
38
|
+
default:
|
|
39
|
+
return e.jsx("svg", { className: "ono-info-icon", viewBox: "64 64 896 896", focusable: "false", "data-icon": "exclamation-circle", fill: u(s2, "light"), "aria-hidden": "true", children: e.jsx("path", { d: "M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm-32 232c0-4.4 3.6-8 8-8h48c4.4 0 8 3.6 8 8v272c0 4.4-3.6 8-8 8h-48c-4.4 0-8-3.6-8-8V296zm32 440a48.01 48.01 0 010-96 48.01 48.01 0 010 96z" }) });
|
|
40
|
+
}
|
|
41
|
+
}, g = ({ handleDestroy: s2 }) => e.jsx("button", { onClick: s2, children: e.jsx("svg", { className: "ono-clear-icon", viewBox: "64 64 896 896", focusable: "false", "data-icon": "close-circle", fill: "currentColor", "aria-hidden": "true", children: e.jsx("path", { d: "M512 64c247.4 0 448 200.6 448 448S759.4 960 512 960 64 759.4 64 512 264.6 64 512 64zm127.98 274.82h-.04l-.08.06L512 466.75 384.14 338.88c-.04-.05-.06-.06-.08-.06a.12.12 0 00-.07 0c-.03 0-.05.01-.09.05l-45.02 45.02a.2.2 0 00-.05.09.12.12 0 000 .07v.02a.27.27 0 00.06.06L466.75 512 338.88 639.86c-.05.04-.06.06-.06.08a.12.12 0 000 .07c0 .03.01.05.05.09l45.02 45.02a.2.2 0 00.09.05.12.12 0 00.07 0c.02 0 .04-.01.08-.05L512 557.25l127.86 127.87c.04.04.06.05.08.05a.12.12 0 00.07 0c.03 0 .05-.01.09-.05l45.02-45.02a.2.2 0 00.05-.09.12.12 0 000-.07v-.02a.27.27 0 00-.05-.06L557.25 512l127.87-127.86c.04-.04.05-.06.05-.08a.12.12 0 000-.07c0-.03-.01-.05-.05-.09l-45.02-45.02a.2.2 0 00-.09-.05.12.12 0 00-.07 0z" }) }) }), h = ({ id: a2, instancesKey: i2, duration: l2 = 3e3, speed: p2 = 300, offset: f2 = 20, message: u2, type: h2, plain: y2 = true, showClose: x2 = false, zIndex: j, onClose: v = () => {
|
|
42
|
+
}, destroy: C }) => {
|
|
43
|
+
const [, w] = s(false), [z, k] = s(0), [L, O] = s(((e2) => {
|
|
44
|
+
const s2 = c.findIndex((s3) => s3.id === e2);
|
|
45
|
+
return s2 <= 0 ? 0 : c[s2 - 1].offsetOptions.topOffset;
|
|
46
|
+
})(a2)), [b, B] = s({ duration: l2, speed: p2, message: u2, type: h2, showClose: x2, onClose: v }), I = o(null), M = o(null), N = o(null), $ = L + z, K = t(() => ({ transform: `translate(-50%, ${L}px)`, transition: `transform ${p2}ms ease-in-out`, zIndex: j }), [L, p2]), S = () => {
|
|
47
|
+
N.current && (N.current.classList.remove("ono-message-enter"), N.current.classList.add("ono-message-leave"), N.current.style.transform = `translate(-50%, ${d(a2) - z}px)`, ((e2) => {
|
|
48
|
+
const s2 = c.findIndex((s3) => s3.id === e2);
|
|
49
|
+
-1 !== s2 && c.splice(s2, 1);
|
|
50
|
+
})(a2), setTimeout(() => C(b.onClose), p2));
|
|
51
|
+
}, T = (e2, s2, o2) => {
|
|
52
|
+
"loading" !== e2 && (I.current = setTimeout(S, s2 - o2));
|
|
53
|
+
}, D = () => {
|
|
54
|
+
const e2 = d(a2);
|
|
55
|
+
w((s2) => (s2 && O(e2 + f2), true)), requestAnimationFrame(D);
|
|
56
|
+
}, F = n(() => {
|
|
57
|
+
if ("loading" === b.type) {
|
|
58
|
+
if (M.current) return;
|
|
59
|
+
M.current = setTimeout(() => {
|
|
60
|
+
var _a;
|
|
61
|
+
M.current = null;
|
|
62
|
+
const e2 = (s2 = i2 || "") ? (_a = c.find((e3) => e3.key === s2)) == null ? void 0 : _a.props : null;
|
|
63
|
+
var s2;
|
|
64
|
+
e2 && (((e3) => {
|
|
65
|
+
B((s3) => ({ ...s3, ...e3 }));
|
|
66
|
+
})({ ...e2 }), T(b.type, e2.duration || b.duration, e2.speed || b.speed), F());
|
|
67
|
+
}, 100);
|
|
68
|
+
}
|
|
69
|
+
}, [b]);
|
|
70
|
+
return r(() => {
|
|
71
|
+
T(b.type, b.duration, b.speed), D(), F();
|
|
72
|
+
}, [b.type, b.duration, b.speed]), r(() => {
|
|
73
|
+
(() => {
|
|
74
|
+
if (!N.current) return;
|
|
75
|
+
const { height: e2 } = N.current.getBoundingClientRect();
|
|
76
|
+
N.current.style.setProperty("--speed", `${b.speed}ms`), k(e2);
|
|
77
|
+
})();
|
|
78
|
+
}, [N]), r(() => {
|
|
79
|
+
((e2, s2) => {
|
|
80
|
+
const o2 = c.findIndex((s3) => s3.id === e2);
|
|
81
|
+
o2 < 0 || (c[o2].offsetOptions = s2);
|
|
82
|
+
})(a2, { topOffset: L, height: z, bottomOffset: $ });
|
|
83
|
+
}, [$]), e.jsx("div", { ref: N, className: ["ono-message", `ono-message-${b.type}`, "ono-message-enter", y2 ? "" : "ono-message-color"].filter(Boolean).join(" "), style: K, onMouseEnter: () => {
|
|
84
|
+
I.current && (clearTimeout(I.current), I.current = null);
|
|
85
|
+
}, onMouseLeave: () => T(b.type, b.duration, b.speed), children: "function" == typeof b.message ? b.message(m(b.type), b.showClose && e.jsx(g, { handleDestroy: S })) : e.jsxs(e.Fragment, { children: [m(b.type), e.jsx("div", { children: b.message }), b.showClose && e.jsx(g, { handleDestroy: S })] }) });
|
|
86
|
+
}, y = (e2) => {
|
|
87
|
+
if ("string" == typeof e2) return { message: e2 };
|
|
88
|
+
{
|
|
89
|
+
const s2 = { ...e2, instancesKey: e2.key };
|
|
90
|
+
return delete s2.key, { ...s2 };
|
|
91
|
+
}
|
|
92
|
+
}, x = { info: (e2) => {
|
|
93
|
+
l(h, { ...y(e2), type: "info" }, "ono-message");
|
|
94
|
+
}, success: (e2) => {
|
|
95
|
+
l(h, { ...y(e2), type: "success" }, "ono-message");
|
|
96
|
+
}, warning: (e2) => {
|
|
97
|
+
l(h, { ...y(e2), type: "warning" }, "ono-message");
|
|
98
|
+
}, error: (e2) => {
|
|
99
|
+
l(h, { ...y(e2), type: "error" }, "ono-message");
|
|
100
|
+
}, loading: (e2) => {
|
|
101
|
+
l(h, { ...y(e2), type: "loading" }, "ono-message");
|
|
102
|
+
} };
|
|
103
|
+
export {
|
|
104
|
+
x as m
|
|
105
|
+
};
|
|
@@ -1 +1,37 @@
|
|
|
1
|
-
import{j as o}from "./dependencies-CbQbPZZ-.js";
|
|
1
|
+
import { j as o } from "./dependencies-CbQbPZZ-.js";
|
|
2
|
+
import { a as e } from "./colorUtils.ts-DYuRvCXZ.js";
|
|
3
|
+
import { useState as n, useRef as l, useEffect as a } from "react";
|
|
4
|
+
import { p as t } from "./PortalRenderer-CDAzQJgm.js";
|
|
5
|
+
import { B as r } from "./Button-BsWI818a.js";
|
|
6
|
+
const s = ({ title: t2 = "This is a modal title", icon: s2, content: i2 = "This is a modal content", okText: c = "confirm", cancelText: d = "cancel", confirmDisabled: m, cancelDisabled: h, position: x, onConfirm: b, onCancel: f, mask: u = true, maskClosable: p = false, width: j, btnClr: C, footer: v = ({ OkBtn: e2, CancelBtn: n2 }) => o.jsxs(o.Fragment, { children: [o.jsx(n2, {}), o.jsx(e2, {})] }), modalBody: y, destroy: B }) => {
|
|
7
|
+
const [g, w] = n(false), k = l(null), N = l(null), P = [{ label: "themeColor", value: C || "" }, { label: "themeHoverColor", value: C && e(C, "light", 10) || "" }, { label: "themeActiveColor", value: C && e(C, "dark", 20) || "" }, { label: "themeDisabledClr", value: C && e(C, "light", 20) || "" }], T = () => {
|
|
8
|
+
if (x) {
|
|
9
|
+
if (!N.current) return;
|
|
10
|
+
N.current.classList.remove("ono-modal-enter"), N.current.classList.add("ono-modal-leave"), setTimeout(() => {
|
|
11
|
+
B();
|
|
12
|
+
}, 300);
|
|
13
|
+
} else B();
|
|
14
|
+
};
|
|
15
|
+
return a(() => (k.current && (u ? k.current.showModal() : k.current.show()), () => {
|
|
16
|
+
k.current && k.current.close();
|
|
17
|
+
}), [k.current, u]), a(() => {
|
|
18
|
+
(() => {
|
|
19
|
+
if (!N.current) return;
|
|
20
|
+
const o2 = N.current.style;
|
|
21
|
+
j && o2.setProperty("--width", j + "px"), x && (o2.setProperty("--left", (x.x / window.innerWidth * 100).toFixed(2) + "%"), o2.setProperty("--top", (x.y / window.innerHeight * 100).toFixed(2) + "%")), C && P.forEach((e2) => o2.setProperty(`--${e2.label}`, e2.value));
|
|
22
|
+
})();
|
|
23
|
+
}, [N]), o.jsx("dialog", { ref: k, className: "ono-modal", onClick: () => p && T(), children: y ? y(T) : o.jsxs("div", { ref: N, className: ["ono-modal-box", x ? "ono-modal-enter" : ""].join(" "), onClick: (o2) => o2.stopPropagation(), children: [o.jsxs("div", { className: "ono-modal-box-body", children: [s2 ?? o.jsx("div", { className: "ono-modal-box-body-icon", children: o.jsx("svg", { color: "#faad14", viewBox: "64 64 896 896", focusable: "false", "data-icon": "exclamation-circle", width: "22px", height: "22px", fill: "currentColor", "aria-hidden": "true", style: { marginInlineEnd: "12px" }, children: o.jsx("path", { d: "M512 64C264.6 64 64 264.6 64 512s200.6 448 448 448 448-200.6 448-448S759.4 64 512 64zm-32 232c0-4.4 3.6-8 8-8h48c4.4 0 8 3.6 8 8v272c0 4.4-3.6 8-8 8h-48c-4.4 0-8-3.6-8-8V296zm32 440a48.01 48.01 0 010-96 48.01 48.01 0 010 96z" }) }) }), o.jsxs("div", { className: "ono-modal-box-body-contentBar", children: [o.jsx("h1", { className: "ono-modal-box-body-contentBar-title", children: t2 }), o.jsx("p", { className: "ono-modal-box-body-contentBar-content", children: i2 })] })] }), v && o.jsx("div", { className: "ono-modal-box-footer", children: v({ OkBtn: () => o.jsx(r, { className: "ono-modal-box-footer-confirmBtn", loading: g, disabled: m, onClick: async () => {
|
|
24
|
+
w(true);
|
|
25
|
+
try {
|
|
26
|
+
const o2 = b == null ? void 0 : b();
|
|
27
|
+
o2 instanceof Promise && await o2;
|
|
28
|
+
} finally {
|
|
29
|
+
w(false), T();
|
|
30
|
+
}
|
|
31
|
+
}, children: c ?? "Confirm" }), CancelBtn: () => o.jsx(r, { className: "ono-modal-box-footer-cancelBtn", disabled: h || g, onClick: () => {
|
|
32
|
+
f == null ? void 0 : f(), T();
|
|
33
|
+
}, children: d ?? "Cancel" }), handleClose: () => T() }) })] }) });
|
|
34
|
+
}, i = (o2) => t(s, o2, "ono-modal");
|
|
35
|
+
export {
|
|
36
|
+
i as M
|
|
37
|
+
};
|
|
@@ -1 +1,17 @@
|
|
|
1
|
-
import{j as n}from "./dependencies-CbQbPZZ-.js";
|
|
1
|
+
import { j as n } from "./dependencies-CbQbPZZ-.js";
|
|
2
|
+
const a = ({ firstBtn: a2, lastBtn: i, currentPage: o, total: e, prevBtn: t, nextBtn: s, styles: l, className: c, children: r, onChange: p, pageBtnClassName: g, pageBtnActiveClassName: d, hiddenNextBtnOnLastPage: h, hiddenPrevBtnOnFirstPage: m }) => {
|
|
3
|
+
const b = Math.max(1, Math.min(o, e));
|
|
4
|
+
return n.jsxs("ul", { className: `ono-pagination ${c}`, style: l, children: [a2 && n.jsx("li", { className: a2 ? "ono-pagination-base" : "ono-pagination-btn", onClick: () => p(1), children: a2 }), m && 1 === o ? null : n.jsx("li", { className: "ono-pagination-base", style: { cursor: 1 !== o ? "pointer" : "no-drop" }, onClick: () => {
|
|
5
|
+
o <= 1 || p(o - 1);
|
|
6
|
+
}, children: t ? "function" == typeof t ? t(1 !== o) : t : n.jsx("div", { className: t ? "ono-pagination-base" : "ono-pagination-btn", children: "prevBtn" }) }), (() => {
|
|
7
|
+
const a3 = Array.from({ length: e }, (a4, i3) => n.jsx("li", { className: "ono-pagination-base", onClick: () => p(i3 + 1), children: r ? r({ page: i3 + 1, isActive: o === i3 + 1 }) : n.jsx("div", { className: `ono-pagination-base ${g ?? "ono-pagination-btn"} ${b === i3 + 1 ? d ?? "ono-pagination-btn-active" : ""}`, children: i3 + 1 }) }, i3 + 1));
|
|
8
|
+
if (a3.length <= 7) return a3;
|
|
9
|
+
const i2 = e - 1, t2 = b, s2 = t2 >= e - 2;
|
|
10
|
+
return t2 <= 3 ? [...a3.slice(0, 3 === t2 ? 4 : 3), "...", a3[i2]] : s2 ? [a3[0], "...", ...a3.slice(t2 === e - 2 ? -4 : -3)] : [a3[0], "...", ...a3.slice(t2 - 2, t2 + 1), "...", a3[i2]];
|
|
11
|
+
})(), h && o === e ? null : n.jsx("li", { className: "ono-pagination-base", style: { cursor: o !== e ? "pointer" : "no-drop" }, onClick: () => {
|
|
12
|
+
p(o >= e ? e : o + 1);
|
|
13
|
+
}, children: s ? "function" == typeof s ? s(o !== e) : s : n.jsx("div", { className: s ? "ono-pagination-base" : "ono-pagination-btn", children: "nextBtn" }) }), i && n.jsx("li", { className: i ? "ono-pagination-base" : "ono-pagination-btn", onClick: () => p(e), children: i })] });
|
|
14
|
+
};
|
|
15
|
+
export {
|
|
16
|
+
a as P
|
|
17
|
+
};
|
|
@@ -1 +1,19 @@
|
|
|
1
|
-
import{j as e,R as t}from "./dependencies-CbQbPZZ-.js";
|
|
1
|
+
import { j as e, R as t } from "./dependencies-CbQbPZZ-.js";
|
|
2
|
+
const n = (n2, d, o, r) => {
|
|
3
|
+
const { target: a, root: c } = ((e2, t2) => {
|
|
4
|
+
let n3 = null, d2 = null;
|
|
5
|
+
return t2 && (n3 = document.getElementById(t2), n3 || (n3 = document.createElement("div"), n3.id = t2, document.body.appendChild(n3))), e2 ? (d2 = document.getElementById(e2), d2 || (d2 = document.createElement("div"), d2.id = e2, n3 ? n3.appendChild(d2) : document.body.appendChild(d2))) : (d2 = document.createElement("div"), n3 ? n3.appendChild(d2) : document.body.appendChild(d2)), { target: d2, root: n3 };
|
|
6
|
+
})(o, r), m = (e2) => {
|
|
7
|
+
var _a;
|
|
8
|
+
"function" == typeof e2 && e2(), o ? (_a = document.getElementById(o)) == null ? void 0 : _a.remove() : a.remove(), requestAnimationFrame(() => c && 0 === c.children.length && c.remove());
|
|
9
|
+
};
|
|
10
|
+
if (void 0 !== a.__reactContainer$) a.__reactContainer$.render(e.jsx(n2, { ...{ ...d, destroy: m } }));
|
|
11
|
+
else {
|
|
12
|
+
const o2 = t.createRoot(a);
|
|
13
|
+
a.__reactContainer$ = o2, o2.render(e.jsx(n2, { ...{ ...d, destroy: m } }));
|
|
14
|
+
}
|
|
15
|
+
return m;
|
|
16
|
+
};
|
|
17
|
+
export {
|
|
18
|
+
n as p
|
|
19
|
+
};
|