UNPKG

react-sketch-ruler

Version:

> In using react, the zoom operation used for page presentation

989 lines (988 loc) 32.3 kB
import ge, { useState as $, memo as Ee, useMemo as k, useCallback as Ke, useEffect as J, useRef as te, useImperativeHandle as We } from "react"; var ye = { exports: {} }, le = {}; var Te; function Ze() { if (Te) return le; Te = 1; var e = Symbol.for("react.transitional.element"), t = Symbol.for("react.fragment"); function n(o, r, a) { var f = null; if (a !== void 0 && (f = "" + a), r.key !== void 0 && (f = "" + r.key), "key" in r) { a = {}; for (var m in r) m !== "key" && (a[m] = r[m]); } else a = r; return r = a.ref, { $$typeof: e, type: o, key: f, ref: r !== void 0 ? r : null, props: a }; } return le.Fragment = t, le.jsx = n, le.jsxs = n, le; } var Pe; function ke() { return Pe || (Pe = 1, ye.exports = Ze()), ye.exports; } var U = ke(); const Je = "", He = ""; typeof window < "u" && (window.NodeList && !NodeList.prototype.forEach && (NodeList.prototype.forEach = Array.prototype.forEach), typeof window.CustomEvent != "function" && (window.CustomEvent = function(e, t) { t = t || { bubbles: !1, cancelable: !1, detail: null }; var n = document.createEvent("CustomEvent"); return n.initCustomEvent(e, t.bubbles, t.cancelable, t.detail), n; })); function Be(e, t) { let n = e.length; for (; n--; ) if (e[n].pointerId === t.pointerId) return n; return -1; } function Ae(e, t) { let n; if (t.touches) { n = 0; for (const o of t.touches) o.pointerId = n++, Ae(e, o); return; } n = Be(e, t), n > -1 && e.splice(n, 1), e.push(t); } function _e(e, t) { if (t.touches) { for (; e.length; ) e.pop(); return; } const n = Be(e, t); n > -1 && e.splice(n, 1); } function Xe(e) { e = e.slice(0); let t = e.pop(), n; for (; n = e.pop(); ) t = { clientX: (n.clientX - t.clientX) / 2 + t.clientX, clientY: (n.clientY - t.clientY) / 2 + t.clientY }; return t; } function ve(e) { if (e.length < 2) return 0; const t = e[0], n = e[1]; return Math.sqrt( Math.pow(Math.abs(n.clientX - t.clientX), 2) + Math.pow(Math.abs(n.clientY - t.clientY), 2) ); } let ue = { down: "mousedown", move: "mousemove", up: "mouseup mouseleave" }; typeof window < "u" && (typeof window.PointerEvent == "function" ? ue = { down: "pointerdown", move: "pointermove", up: "pointerup pointerleave pointercancel" } : typeof window.TouchEvent == "function" && (ue = { down: "touchstart", move: "touchmove", up: "touchend touchcancel" })); function we(e, t, n, o) { ue[e].split(" ").forEach((r) => { t.addEventListener( r, n, o ); }); } function be(e, t, n) { ue[e].split(" ").forEach((o) => { t.removeEventListener(o, n); }); } const et = typeof document < "u" && !!document.documentMode; let Ne; function tt() { return Ne || (Ne = document.createElement("div").style); } const Le = ["webkit", "moz", "ms"], ce = {}; function Se(e) { if (ce[e]) return ce[e]; const t = tt(); if (e in t) return ce[e] = e; const n = e[0].toUpperCase() + e.slice(1); let o = Le.length; for (; o--; ) { const r = `${Le[o]}${n}`; if (r in t) return ce[e] = r; } } function de(e, t) { return parseFloat(t[Se(e)]) || 0; } function fe(e, t, n = window.getComputedStyle(e)) { const o = t === "border" ? "Width" : ""; return { left: de(`${t}Left${o}`, n), right: de(`${t}Right${o}`, n), top: de(`${t}Top${o}`, n), bottom: de(`${t}Bottom${o}`, n) }; } function re(e, t, n) { e.style[Se(t)] = n; } function nt(e, t) { const n = Se("transform"); re(e, "transition", `${n} ${t.duration}ms ${t.easing}`); } function ot(e, { x: t, y: n, scale: o, isSVG: r }, a) { if (re(e, "transform", `scale(${o}) translate(${t}px, ${n}px)`), r && et) { const f = window.getComputedStyle(e).getPropertyValue("transform"); e.setAttribute("transform", f); } } function me(e) { const t = e.parentNode, n = window.getComputedStyle(e), o = window.getComputedStyle(t), r = e.getBoundingClientRect(), a = t.getBoundingClientRect(); return { elem: { style: n, width: r.width, height: r.height, top: r.top, bottom: r.bottom, left: r.left, right: r.right, margin: fe(e, "margin", n), border: fe(e, "border", n) }, parent: { style: o, width: a.width, height: a.height, top: a.top, bottom: a.bottom, left: a.left, right: a.right, padding: fe(t, "padding", o), border: fe(t, "border", o) } }; } function rt(e) { let t = e; for (; t && t.parentNode; ) { if (t.parentNode === document) return !0; t = t.parentNode instanceof ShadowRoot ? t.parentNode.host : t.parentNode; } return !1; } function st(e) { return (e.getAttribute("class") || "").trim(); } function at(e, t) { return e.nodeType === 1 && ` ${st(e)} `.indexOf(` ${t} `) > -1; } function it(e, t) { for (let n = e; n != null; n = n.parentNode) if (at(n, t.excludeClass) || t.exclude.indexOf(n) > -1) return !0; return !1; } const lt = /^http:[\w\.\/]+svg$/; function ut(e) { return lt.test(e.namespaceURI) && e.nodeName.toLowerCase() !== "svg"; } function ct(e) { const t = {}; for (const n in e) e.hasOwnProperty(n) && (t[n] = e[n]); return t; } const Ye = { animate: !1, canvas: !1, cursor: "move", disablePan: !1, disableZoom: !1, disableXAxis: !1, disableYAxis: !1, duration: 200, easing: "ease-in-out", exclude: [], excludeClass: "panzoom-exclude", handleStartEvent: (e) => { e.preventDefault(), e.stopPropagation(); }, maxScale: 4, minScale: 0.125, overflow: "hidden", panOnlyWhenZoomed: !1, pinchAndPan: !1, relative: !1, setTransform: ot, startX: 0, startY: 0, startScale: 1, step: 0.3, touchAction: "none" }; function Ue(e, t) { if (!e) throw new Error("Panzoom requires an element as an argument"); if (e.nodeType !== 1) throw new Error("Panzoom requires an element with a nodeType of 1"); if (!rt(e)) throw new Error( "Panzoom should be called on elements that have been attached to the DOM" ); t = { ...Ye, ...t }; const n = ut(e), o = e.parentNode; o.style.overflow = t.overflow, o.style.userSelect = "none", o.style.touchAction = t.touchAction, (t.canvas ? o : e).style.cursor = t.cursor, e.style.userSelect = "none", e.style.touchAction = t.touchAction, re( e, "transformOrigin", typeof t.origin == "string" ? t.origin : n ? "0 0" : "50% 50%" ); function r() { o.style.overflow = "", o.style.userSelect = "", o.style.touchAction = "", o.style.cursor = "", e.style.cursor = "", e.style.userSelect = "", e.style.touchAction = "", re(e, "transformOrigin", ""); } function a(s = {}) { for (const l in s) s.hasOwnProperty(l) && (t[l] = s[l]); (s.hasOwnProperty("cursor") || s.hasOwnProperty("canvas")) && (o.style.cursor = e.style.cursor = "", (t.canvas ? o : e).style.cursor = t.cursor), s.hasOwnProperty("overflow") && (o.style.overflow = s.overflow), s.hasOwnProperty("touchAction") && (o.style.touchAction = s.touchAction, e.style.touchAction = s.touchAction); } let f = 0, m = 0, c = 1, X = !1; w(t.startScale, { animate: !1, force: !0 }), setTimeout(() => { v(t.startX, t.startY, { animate: !1, force: !0 }); }); function A(s, l, d) { if (d.silent) return; const h = new CustomEvent(s, { detail: l }); e.dispatchEvent(h); } function L(s, l, d) { const h = { x: f, y: m, scale: c, isSVG: n, originalEvent: d, dimsOut: {} }; typeof l.animate == "boolean" && (l.animate ? nt(e, l) : re(e, "transition", "none")), l.setTransform(e, h, l); function i() { const p = me(e); h.dimsOut = p, A(s, h, l), A("panzoomchange", h, l); } return l.animate ? setTimeout(() => { i(); }, l.duration + 50) : requestAnimationFrame(() => { i(); }), h; } function S(s, l, d, h) { const i = { ...t, ...h }, p = { x: f, y: m, opts: i }; if (!i.force && (i.disablePan || i.panOnlyWhenZoomed && c === i.startScale)) return p; if (s = parseFloat(s), l = parseFloat(l), i.disableXAxis || (p.x = (i.relative ? f : 0) + s), i.disableYAxis || (p.y = (i.relative ? m : 0) + l), i.contain) { const u = me(e), b = u.elem.width / c, D = u.elem.height / c, G = b * d, K = D * d, F = (G - b) / 2, Z = (K - D) / 2; if (i.contain === "inside") { const se = (-u.elem.margin.left - u.parent.padding.left + F) / d, ae = (u.parent.width - G - u.parent.padding.left - u.elem.margin.left - u.parent.border.left - u.parent.border.right + F) / d; p.x = Math.max(Math.min(p.x, ae), se); const ne = (-u.elem.margin.top - u.parent.padding.top + Z) / d, oe = (u.parent.height - K - u.parent.padding.top - u.elem.margin.top - u.parent.border.top - u.parent.border.bottom + Z) / d; p.y = Math.max(Math.min(p.y, oe), ne); } else if (i.contain === "outside") { const se = (-(G - u.parent.width) - u.parent.padding.left - u.parent.border.left - u.parent.border.right + F) / d, ae = (F - u.parent.padding.left) / d; p.x = Math.max(Math.min(p.x, ae), se); const ne = (-(K - u.parent.height) - u.parent.padding.top - u.parent.border.top - u.parent.border.bottom + Z) / d, oe = (Z - u.parent.padding.top) / d; p.y = Math.max(Math.min(p.y, oe), ne); } } return i.roundPixels && (p.x = Math.round(p.x), p.y = Math.round(p.y)), p; } function y(s, l) { const d = { ...t, ...l }, h = { scale: c, opts: d }; if (!d.force && d.disableZoom) return h; let i = t.minScale, p = t.maxScale; if (d.contain) { const u = me(e), b = u.elem.width / c, D = u.elem.height / c; if (b > 1 && D > 1) { const G = u.parent.width - u.parent.border.left - u.parent.border.right, K = u.parent.height - u.parent.border.top - u.parent.border.bottom, F = G / b, Z = K / D; t.contain === "inside" ? p = Math.min(p, F, Z) : t.contain === "outside" && (i = Math.max(i, F, Z)); } } return h.scale = Math.min(Math.max(s, i), p), h; } function v(s, l, d, h) { const i = S(s, l, c, d); return f !== i.x || m !== i.y ? (f = i.x, m = i.y, L("panzoompan", i.opts, h)) : { x: f, y: m, scale: c, isSVG: n, originalEvent: h }; } function w(s, l, d) { const h = y(s, l), i = h.opts; if (!i.force && i.disableZoom) return; s = h.scale; let p = f, u = m; if (i.focal) { const D = i.focal; p = (D.x / s - D.x / c + f * s) / s, u = (D.y / s - D.y / c + m * s) / s; } const b = S(p, u, s, { relative: !1, force: !0 }); return f = b.x, m = b.y, c = s, L("panzoomzoom", i, d); } function B(s, l) { const d = { ...t, animate: !0, ...l }; return w(c * Math.exp((s ? 1 : -1) * d.step), d); } function x(s) { return B(!0, s); } function z(s) { return B(!1, s); } function C(s, l, d, h) { const i = me(e), p = { width: i.parent.width - i.parent.padding.left - i.parent.padding.right - i.parent.border.left - i.parent.border.right, height: i.parent.height - i.parent.padding.top - i.parent.padding.bottom - i.parent.border.top - i.parent.border.bottom }; let u = l.clientX - i.parent.left - i.parent.padding.left - i.parent.border.left - i.elem.margin.left, b = l.clientY - i.parent.top - i.parent.padding.top - i.parent.border.top - i.elem.margin.top; n || (u -= i.elem.width / c / 2, b -= i.elem.height / c / 2); const D = { x: u / p.width * (p.width * s), y: b / p.height * (p.height * s) }; return w( s, { ...d, animate: !1, focal: D }, h ); } function T(s, l) { s.preventDefault(); const d = { ...t, ...l, animate: !1 }, h = (s.deltaY === 0 && s.deltaX ? s.deltaX : s.deltaY) < 0 ? 1 : -1, i = y( c * Math.exp(h * d.step / 3), d ).scale; return C(i, s, d, s); } function q(s) { const l = { ...t, animate: !0, force: !0, ...s }; c = y(l.startScale, l).scale; const d = S(l.startX, l.startY, c, l); return f = d.x, m = d.y, L("panzoomreset", l); } let V, N, g, P, E, j; const O = []; function I(s) { if (it(s.target, t)) return; Ae(O, s), X = !0, t.handleStartEvent(s), V = f, N = m, A( "panzoomstart", { x: f, y: m, scale: c, isSVG: n, originalEvent: s }, t ); const l = Xe(O); g = l.clientX, P = l.clientY, E = c, j = ve(O); } function W(s) { if (!X || V === void 0 || N === void 0 || g === void 0 || P === void 0) return; Ae(O, s); const l = Xe(O), d = O.length > 1; let h = c; if (d) { j === 0 && (j = ve(O)); const i = ve(O) - j; h = y(i * t.step / 80 + E).scale, C(h, l, { animate: !1 }, s); } (!d || t.pinchAndPan) && v( V + (l.clientX - g) / h, N + (l.clientY - P) / h, { animate: !1 }, s ); } function H(s) { O.length === 1 && A( "panzoomend", { x: f, y: m, scale: c, isSVG: n, originalEvent: s }, t ), _e(O, s), X && (X = !1, V = N = g = P = void 0); } let Q = !1; function _() { Q || (Q = !0, we("down", t.canvas ? o : e, I), we("move", document, W, { passive: !0 }), we("up", document, H, { passive: !0 })); } function ee() { Q = !1, be("down", t.canvas ? o : e, I), be("move", document, W), be("up", document, H); } return t.noBind || _(), { bind: _, destroy: ee, eventNames: ue, getPan: () => ({ x: f, y: m }), getScale: () => c, getOptions: () => ct(t), handleDown: I, handleMove: W, handleUp: H, pan: v, reset: q, resetStyle: r, setOptions: a, setStyle: (s, l) => re(e, s, l), zoom: w, zoomIn: x, zoomOut: z, zoomToPoint: C, zoomWithWheel: T }; } Ue.defaultOptions = Ye; function ze(e, t) { const [n, o] = $(0), [r, a] = $(0), f = { backgroundColor: e.palette.hoverBg, color: e.palette.hoverColor, [t ? "top" : "left"]: "-8px", [t ? "left" : "top"]: `${n + 10}px` }, m = (S) => { const y = S.nativeEvent.offsetX, v = S.nativeEvent.offsetY; o(t ? y : v); }, c = (S, y) => (S.stopPropagation(), new Promise((v) => { if (e.lockLine) return; const w = t ? S.clientY : S.clientX, B = y || r; let x = B; const z = (T) => { let N = ((t ? T.clientY : T.clientX) - w) / e.scale + B, g = N; const E = [...t ? e.snapsObj.h : e.snapsObj.v].sort( (j, O) => Math.abs(g - j) - Math.abs(g - O) ); E.length && Math.abs(E[0] - N) < e.snapThreshold / e.scale && (g = E[0], N = g), x = Math.round(N), a(Math.round(N)); }, C = () => { document.removeEventListener("mousemove", z), X(x, e.index), v(); }; document.addEventListener("mousemove", z), document.addEventListener("mouseup", C, { once: !0 }); })), X = (S, y) => { const v = t ? e.lines.h : e.lines.v, w = A(S); if (v) if (w) if (typeof y == "number") v.splice(y, 1), e.handleLine && e.handleLine(e.lines); else return; else typeof y != "number" ? (v.push(S), e.handleLine && e.handleLine(e.lines)) : (v[y] = S, e.handleLine && e.handleLine({ ...e.lines, [t ? "h" : "v"]: v })); }, A = (S) => { const y = t ? e.canvasHeight : e.canvasWidth; return S < 0 || S > y; }, L = A(r) ? "放开删除" : `${t ? "Y" : "X"}: ${r * e.rate}`; return { startValue: r, setStartValue: a, actionStyle: f, labelContent: L, handleMouseMove: m, handleMouseDown: c }; } const dt = (e) => e <= 0.25 ? 40 : e <= 0.5 ? 20 : e <= 1 ? 10 : e <= 2 ? 5 : e <= 4 ? 2 : 1; function ft(e, t, n, o, r, a) { a ? r.moveTo(e, 0) : r.moveTo(0, e), r.save(), a ? r.translate(e + 5, o * 0.2) : r.translate(n * 0.1, e + 32), a || r.rotate(-Math.PI / 2), r.fillText(Math.round(t).toString(), 4, 7), r.restore(), a ? r.lineTo(e, o) : r.lineTo(n, e), r.stroke(), r.closePath(), r.setTransform(1, 0, 0, 1, 0, 0); } function pe(e, t, n, o, r, a) { o.fillStyle = r.fontShadowColor, o.strokeStyle = r.longfgColor, o.save(), o.translate(e, t), a || o.rotate(-Math.PI / 2), o.strokeText(String(n), 0, 0), o.fillText(String(n), 0, 0), o.restore(); } const mt = (e, t, n, o, r, a) => { const { scale: f, width: m, height: c, ratio: X, palette: A, gridRatio: L, showShadowText: S } = r, { bgColor: y, fontColor: v, shadowColor: w, longfgColor: B } = A, x = a ? r.canvasWidth : r.canvasHeight; e.setTransform(1, 0, 0, 1, 0, 0), e.scale(X, X), e.clearRect(0, 0, m, c), e.fillStyle = y, e.fillRect(0, 0, m, c); const C = dt(f) * L * 10, T = C * f, q = Math.floor(t / C) * C, V = (q - t) / C * T, N = t + Math.ceil((a ? m : c) / f); if (o) { const g = (n - t) * f, P = o * f; if (e.fillStyle = w, a ? e.fillRect(g, 0, P, c) : e.fillRect(0, g, m, P), S) if (a) { pe(g, c * 0.4, Math.round(n), e, A, a); const E = (n + o - t) * f; pe( E, c * 0.4, Math.round(n + o), e, A, a ); } else { pe(m * 0.4, g, Math.round(n), e, A, a); const E = (n + o - t) * f; pe( m * 0.4, E, Math.round(n + o), e, A, a ); } } e.beginPath(), e.fillStyle = v, e.strokeStyle = B; for (let g = q, P = 0; g < N; g += C, P++) { const E = V + P * T + 0.5; if (g - C < x && g > x || g == x) { const j = V + P * T + 0.5 + (x - g) * f; ft(j, x, m, c, e, a); return; } g >= 0 && g <= x && (g == 0 ? a ? (e.moveTo(E, 0), e.lineTo(E, c)) : (e.moveTo(0, E), e.lineTo(m, E)) : a ? (e.moveTo(E, 20), e.lineTo(E, c / 1.3)) : (e.moveTo(20, E), e.lineTo(m / 1.3, E)), e.save(), g == 0 ? a ? e.translate(E - 15, c * 0.2) : e.translate(m * 0.3, E - 5) : a ? e.translate(E - 12, c * 0.05) : e.translate(m * 0.05, E + 12), a || e.rotate(-Math.PI / 2), x - g > C / 2 && (!S || o == 0 || Math.abs(g - n) > C / 2 && Math.abs(g - (n + o)) > C / 2) && e.fillText(g.toString(), 4, 9), e.restore()); } e.stroke(), e.closePath(); }; function pt(e, t) { let n; return function() { clearTimeout(n), n = setTimeout(() => { e(); }, t); }; } const ht = ({ scale: e, rate: t, palette: n, index: o, start: r, vertical: a, value: f, canvasWidth: m, canvasHeight: c, lines: X, isShowReferLine: A, snapThreshold: L, snapsObj: S, lockLine: y, handleLine: v }) => { const [w, B] = $(!1), [x, z] = $(!1), { startValue: C, setStartValue: T, actionStyle: q, handleMouseMove: V, handleMouseDown: N, labelContent: g } = ze( { palette: n, scale: e, snapsObj: S, lines: X, canvasWidth: m, canvasHeight: c, snapThreshold: L, lockLine: y, index: o, value: f, rate: t, handleLine: v }, a ), P = k(() => C >= r, [r, C, a]), E = k(() => { const { lineType: I, lockLineColor: W, lineColor: H } = n, Q = y ? W : H ?? "black", _ = y || x ? "none" : "auto", ee = A && !y ? a ? "ns-resize" : "ew-resize" : "default", s = a ? "borderTop" : "borderLeft", l = (C - r) * e; return { [s]: `1px ${I} ${Q}`, pointerEvents: _, cursor: ee, [a ? "top" : "left"]: `${l}px` }; }, [n, y, x, A, a, C, r, e]), j = Ke( pt(() => { z(!1); }, 1e3), [] ); J(() => { z(!0), j(); }, [e]), J(() => { T(f); }, [f]); const O = (I) => { I.stopPropagation(), y || B(!0); }; return /* @__PURE__ */ U.jsx( "div", { style: E, className: "line", onMouseEnter: O, onMouseMove: V, onMouseLeave: () => B(!1), onMouseDown: N, hidden: !P, children: /* @__PURE__ */ U.jsx("div", { className: "action", style: q, children: w && /* @__PURE__ */ U.jsx("span", { className: "value", children: g }) }) } ); }, gt = Ee(ht), yt = ({ scale: e, palette: t, vertical: n, start: o, width: r, height: a, selectStart: f, selectLength: m, canvasWidth: c, canvasHeight: X, rate: A, showShadowText: L, gridRatio: S, onDragStart: y }) => { const v = te(null), [w, B] = $(null), x = te(null); J(() => { if (v.current) { const T = v.current.getContext("2d"); B(T); } }, [v]), J(() => { if (v.current && w) { const T = typeof window < "u" && window.devicePixelRatio || 1; v.current.width = r * T, v.current.height = a * T, w.font = '11px -apple-system, "Helvetica Neue", ".SFNSText-Regular", "SF UI Text", Arial, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "WenQuanYi Zen Hei", sans-serif', w.lineWidth = 1, w.textBaseline = "middle"; } }, [w, r, a]), J(() => { const T = { scale: e / A, width: r, height: a, palette: t, canvasWidth: c * A, canvasHeight: X * A, ratio: typeof window < "u" && window.devicePixelRatio || 1, gridRatio: S, showShadowText: L }; w && (x.current !== null && cancelAnimationFrame(x.current), x.current = requestAnimationFrame(() => { mt(w, o * A, f, m, T, !n); })); }, [ e, A, r, a, t, c, X, S, w, o, f, m, n ]), J(() => () => { x.current !== null && cancelAnimationFrame(x.current); }, []); const z = k(() => ({ width: r + "px", height: a + "px", cursor: n ? "ew-resize" : "ns-resize", [n ? "borderRight" : "borderBottom"]: `1px solid ${t.borderColor || "#eeeeef"}` }), [n, t.borderColor]), C = (T) => y(T); return /* @__PURE__ */ U.jsx("canvas", { ref: v, className: "ruler", style: z, onMouseDown: C }); }, vt = Ee(yt), wt = ({ scale: e, thick: t, canvasWidth: n, canvasHeight: o, palette: r, vertical: a, width: f, height: m, start: c, startOther: X, lines: A, selectStart: L, selectLength: S, isShowReferLine: y, rate: v, snapThreshold: w, snapsObj: B, gridRatio: x, lockLine: z, propStyle: C, showShadowText: T, handleLine: q }) => { const [V, N] = $(z), [g, P] = $(!1), [E, j] = $(!1), { actionStyle: O, handleMouseMove: I, handleMouseDown: W, labelContent: H, startValue: Q, setStartValue: _ } = ze( { palette: r, scale: e, snapsObj: B, lines: A, canvasWidth: n, canvasHeight: o, snapThreshold: w, lockLine: V, rate: v, handleLine: q }, !a ), ee = a ? "v-container" : "h-container", s = k(() => a ? A.h : A.v, [a, A]), l = k(() => { const h = r.lineType, i = a ? "left" : "top", p = a ? "top" : "left", u = a ? "borderLeft" : "borderBottom", b = (Q - X) * e + t; return { [i]: b + "px", [p]: -t + "px", cursor: a ? "ew-resize" : "ns-resize", [u]: `1px ${h} ${r.lineColor}` }; }, [Q, X, a, r.lineType, e, r.lineColor, t]), d = async (h) => { const { offsetX: i, offsetY: p } = h.nativeEvent; P(!0), N(!1); const u = Math.round( X - t / e + (a ? i : p) / e ); _(u), await W(h, u), P(!1); }; return J(() => { N(z); }, [z]), /* @__PURE__ */ U.jsxs("div", { className: ee, style: C, children: [ /* @__PURE__ */ U.jsx( vt, { vertical: a, scale: e, width: f, height: m, start: c, showShadowText: T, canvasWidth: n, canvasHeight: o, selectStart: L, selectLength: S, palette: r, rate: v, onDragStart: d, gridRatio: x } ), y && /* @__PURE__ */ U.jsx("div", { className: "lines", children: s.map((h, i) => /* @__PURE__ */ U.jsx( gt, { lockLine: V, index: i, value: Math.floor(h), scale: e, start: c, canvasWidth: n, snapThreshold: w, snapsObj: B, canvasHeight: o, lines: A, palette: r, vertical: a, isShowReferLine: y, handleLine: q, rate: v }, `${h}-${i}` )) }), y && /* @__PURE__ */ U.jsx( "div", { className: "indicator", onMouseEnter: () => j(!0), onMouseMove: I, onMouseLeave: () => j(!1), hidden: !g, style: l, children: /* @__PURE__ */ U.jsx("div", { className: "action", style: O, children: E && /* @__PURE__ */ U.jsx("span", { className: "value", children: H }) }) } ) ] }); }, Oe = Ee(wt), bt = (e) => k( () => ({ bgColor: "#f6f7f9", longfgColor: "#BABBBC", fontColor: "#7D8694", // ruler font color fontShadowColor: "#106ebe", shadowColor: "#e9f7fe", // ruler shadow color lineColor: "#51d6a9", lineType: "solid", lockLineColor: "#d4d7dc", hoverBg: "#000", hoverColor: "#fff", borderColor: "#eeeeef", ...e }), [e] ), Et = ge.forwardRef( ({ showRuler: e = !0, scale: t = 1, rate: n = 1, thick: o = 16, width: r = 1400, height: a = 800, eyeIcon: f, closeEyeIcon: m, paddingRatio: c = 0.2, autoCenter: X = !0, showShadowText: A = !0, shadow: L = { x: 0, y: 0, width: 0, height: 0 }, lines: S = { h: [], v: [] }, isShowReferLine: y = !0, canvasWidth: v = 1e3, canvasHeight: w = 700, snapsObj: B = { h: [], v: [] }, palette: x, snapThreshold: z = 5, gridRatio: C = 1, lockLine: T = !1, selfHandle: q = !1, panzoomOption: V, children: N, onHandleCornerClick: g, updateScale: P, onZoomChange: E, handleLine: j }, O) => { const I = bt(x || {}), [W, H] = $(0), [Q, _] = $(0), [ee, s] = $("defaultCursor"), l = te(0), d = te(0), [h, i] = $(1), [p, u] = $(y), b = te(null), D = te(null), G = te(null), K = k(() => r - o, [r, o]), F = k(() => a - o, [a, o]), Z = { thick: o, lines: S, snapThreshold: z, snapsObj: B, isShowReferLine: p, canvasWidth: v, canvasHeight: w, rate: n, palette: I, gridRatio: C, showShadowText: A, lockLine: T, scale: h, handleLine: j }, se = k(() => ({ backgroundImage: p ? `url(${f || Je})` : `url(${m || He})`, width: `${o}px`, height: `${o}px`, borderRight: `1px solid ${I.borderColor}`, borderBottom: `1px solid ${I.borderColor}` }), [p, f, m, I]), ae = k(() => ({ background: I.bgColor, left: o + "px", top: o + "px", width: K + "px", height: F + "px" }), [F, K, I]), ne = (R) => { (R.ctrlKey || R.metaKey) && b.current && b.current.zoomWithWheel(R); }, oe = (R) => { const Y = document.activeElement; Y instanceof HTMLInputElement || Y instanceof HTMLTextAreaElement || Y?.classList.contains("monaco-editor") || Y?.getAttribute("contenteditable") === "true" || R.key === " " && (b.current && (s("grabCursor"), b.current.bind()), R.preventDefault()); }, Ce = (R) => { R.key === " " && b.current && (s("defaultCursor"), b.current.destroy()); }, xe = (R) => ({ noBind: !0, startScale: R, // cursor: 'default', startX: l.current, startY: d.current, smoothScroll: !0, canvas: !0, ...V }), he = (R) => { const Y = R.detail, { scale: M, dimsOut: ie } = Y; if (ie) { i(M), P && P(M); const Ge = (ie.parent.left - ie.elem.left) / M, Qe = (ie.parent.top - ie.elem.top) / M; H(Ge), E && E(Y), _(Qe); } }, Me = () => { const R = D.current; G.current && G.current.removeEventListener("panzoomchange", he), b.current && b.current.destroy(); let Y = t; X && (Y = Re(), i(Y), P && P(Y)); const M = Ue(R, xe(Y)); b.current = M, R && (G.current = R, G.current.addEventListener("panzoomchange", he)); }, Re = () => { const R = K * (1 - c) / v, Y = F * (1 - c) / w, M = Math.min(R, Y); return l.current = K / 2 - v / 2, M < 1 ? d.current = (w * M / 2 - w / 2) / M - (w * M - F) / M / 2 : M > 1 ? d.current = (w * M - w) / 2 / M + (F - w * M) / M / 2 : d.current = 0, M; }, Ve = () => b.current?.reset(), Ie = () => b.current?.zoomIn(), je = () => b.current?.zoomOut(), De = () => { const R = Re(); b.current?.setOptions(xe(R)); }, Fe = () => { u(!p), g && g(!p); }; We(O, () => ({ reset: Ve, zoomIn: Ie, zoomOut: je, initPanzoom: Me, panzoomInstance: b })), J(() => { u(y); }, [y]), J(() => (Me(), q || (document.addEventListener("wheel", ne, { passive: !1 }), document.addEventListener("keydown", oe), document.addEventListener("keyup", Ce)), () => { document.removeEventListener("wheel", ne), document.removeEventListener("keydown", oe), document.removeEventListener("keyup", Ce), G.current && G.current.removeEventListener("panzoomchange", he), b.current && (b.current.destroy(), b.current = null); }), [v, w, r, a, q]), J(() => { De(); }, [V]); const [qe, $e] = ge.Children.toArray(N).reduce( (R, Y) => { if (ge.isValidElement(Y)) { const M = Y; M.props.slot === "default" || !M.props.slot ? R[0] = M : M.props.slot === "btn" && (R[1] = M); } return R; }, [null, null] ); return /* @__PURE__ */ U.jsxs("div", { className: "sketch-ruler", id: "sketch-ruler", children: [ $e, /* @__PURE__ */ U.jsx("div", { className: "canvasedit-parent " + ee, style: ae, children: /* @__PURE__ */ U.jsx("div", { ref: D, className: "canvasedit " + ee, children: qe }) }), e && /* @__PURE__ */ U.jsx( Oe, { ...Z, width: r, propStyle: { marginLeft: o + "px", width: K + "px" }, height: o, start: W, startOther: Q, selectStart: L.x, selectLength: L.width, vertical: !1 } ), e && /* @__PURE__ */ U.jsx( Oe, { ...Z, propStyle: { marginTop: o + "px", top: 0, height: F + "px" }, width: o, height: a, start: Q, startOther: W, selectStart: L.y, selectLength: L.height, vertical: !0 } ), e && /* @__PURE__ */ U.jsx("a", { className: "corner", style: se, onClick: Fe }) ] }); } ); export { Et as default }; //# sourceMappingURL=index.js.map