UNPKG

@j-ho/react-lazyload-image

Version:
666 lines (663 loc) 22.7 kB
import Se, { memo as cr, useRef as fr, useState as dr, useEffect as vr } from "react"; var N = { exports: {} }, F = {}; /** * @license React * react-jsx-runtime.production.min.js * * Copyright (c) Facebook, Inc. and its affiliates. * * This source code is licensed under the MIT license found in the * LICENSE file in the root directory of this source tree. */ var _e; function gr() { if (_e) return F; _e = 1; var w = Se, E = Symbol.for("react.element"), x = Symbol.for("react.fragment"), R = Object.prototype.hasOwnProperty, A = w.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner, I = { key: !0, ref: !0, __self: !0, __source: !0 }; function _(m, c, y) { var f, b = {}, C = null, M = null; y !== void 0 && (C = "" + y), c.key !== void 0 && (C = "" + c.key), c.ref !== void 0 && (M = c.ref); for (f in c) R.call(c, f) && !I.hasOwnProperty(f) && (b[f] = c[f]); if (m && m.defaultProps) for (f in c = m.defaultProps, c) b[f] === void 0 && (b[f] = c[f]); return { $$typeof: E, type: m, key: C, ref: M, props: b, _owner: A.current }; } return F.Fragment = x, F.jsx = _, F.jsxs = _, F; } var W = {}; /** * @license React * react-jsx-runtime.development.js * * Copyright (c) Facebook, Inc. and its affiliates. * * This source code is licensed under the MIT license found in the * LICENSE file in the root directory of this source tree. */ var Ce; function pr() { return Ce || (Ce = 1, process.env.NODE_ENV !== "production" && function() { var w = Se, E = Symbol.for("react.element"), x = Symbol.for("react.portal"), R = Symbol.for("react.fragment"), A = Symbol.for("react.strict_mode"), I = Symbol.for("react.profiler"), _ = Symbol.for("react.provider"), m = Symbol.for("react.context"), c = Symbol.for("react.forward_ref"), y = Symbol.for("react.suspense"), f = Symbol.for("react.suspense_list"), b = Symbol.for("react.memo"), C = Symbol.for("react.lazy"), M = Symbol.for("react.offscreen"), q = Symbol.iterator, we = "@@iterator"; function Ae(e) { if (e === null || typeof e != "object") return null; var r = q && e[q] || e[we]; return typeof r == "function" ? r : null; } var T = w.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED; function d(e) { { for (var r = arguments.length, t = new Array(r > 1 ? r - 1 : 0), n = 1; n < r; n++) t[n - 1] = arguments[n]; Te("error", e, t); } } function Te(e, r, t) { { var n = T.ReactDebugCurrentFrame, o = n.getStackAddendum(); o !== "" && (r += "%s", t = t.concat([o])); var u = t.map(function(i) { return String(i); }); u.unshift("Warning: " + r), Function.prototype.apply.call(console[e], console, u); } } var je = !1, Oe = !1, xe = !1, ke = !1, De = !1, X; X = Symbol.for("react.module.reference"); function Fe(e) { return !!(typeof e == "string" || typeof e == "function" || e === R || e === I || De || e === A || e === y || e === f || ke || e === M || je || Oe || xe || typeof e == "object" && e !== null && (e.$$typeof === C || e.$$typeof === b || e.$$typeof === _ || e.$$typeof === m || e.$$typeof === c || // This needs to include all possible module reference object // types supported by any Flight configuration anywhere since // we don't know which Flight build this will end up being used // with. e.$$typeof === X || e.getModuleId !== void 0)); } function We(e, r, t) { var n = e.displayName; if (n) return n; var o = r.displayName || r.name || ""; return o !== "" ? t + "(" + o + ")" : t; } function Q(e) { return e.displayName || "Context"; } function h(e) { if (e == null) return null; if (typeof e.tag == "number" && d("Received an unexpected object in getComponentNameFromType(). This is likely a bug in React. Please file an issue."), typeof e == "function") return e.displayName || e.name || null; if (typeof e == "string") return e; switch (e) { case R: return "Fragment"; case x: return "Portal"; case I: return "Profiler"; case A: return "StrictMode"; case y: return "Suspense"; case f: return "SuspenseList"; } if (typeof e == "object") switch (e.$$typeof) { case m: var r = e; return Q(r) + ".Consumer"; case _: var t = e; return Q(t._context) + ".Provider"; case c: return We(e, e.render, "ForwardRef"); case b: var n = e.displayName || null; return n !== null ? n : h(e.type) || "Memo"; case C: { var o = e, u = o._payload, i = o._init; try { return h(i(u)); } catch { return null; } } } return null; } var P = Object.assign, k = 0, ee, re, te, ne, ae, ie, oe; function ue() { } ue.__reactDisabledLog = !0; function Me() { { if (k === 0) { ee = console.log, re = console.info, te = console.warn, ne = console.error, ae = console.group, ie = console.groupCollapsed, oe = console.groupEnd; var e = { configurable: !0, enumerable: !0, value: ue, writable: !0 }; Object.defineProperties(console, { info: e, log: e, warn: e, error: e, group: e, groupCollapsed: e, groupEnd: e }); } k++; } } function Ye() { { if (k--, k === 0) { var e = { configurable: !0, enumerable: !0, writable: !0 }; Object.defineProperties(console, { log: P({}, e, { value: ee }), info: P({}, e, { value: re }), warn: P({}, e, { value: te }), error: P({}, e, { value: ne }), group: P({}, e, { value: ae }), groupCollapsed: P({}, e, { value: ie }), groupEnd: P({}, e, { value: oe }) }); } k < 0 && d("disabledDepth fell below zero. This is a bug in React. Please file an issue."); } } var $ = T.ReactCurrentDispatcher, G; function Y(e, r, t) { { if (G === void 0) try { throw Error(); } catch (o) { var n = o.stack.trim().match(/\n( *(at )?)/); G = n && n[1] || ""; } return ` ` + G + e; } } var z = !1, V; { var Ve = typeof WeakMap == "function" ? WeakMap : Map; V = new Ve(); } function se(e, r) { if (!e || z) return ""; { var t = V.get(e); if (t !== void 0) return t; } var n; z = !0; var o = Error.prepareStackTrace; Error.prepareStackTrace = void 0; var u; u = $.current, $.current = null, Me(); try { if (r) { var i = function() { throw Error(); }; if (Object.defineProperty(i.prototype, "props", { set: function() { throw Error(); } }), typeof Reflect == "object" && Reflect.construct) { try { Reflect.construct(i, []); } catch (g) { n = g; } Reflect.construct(e, [], i); } else { try { i.call(); } catch (g) { n = g; } e.call(i.prototype); } } else { try { throw Error(); } catch (g) { n = g; } e(); } } catch (g) { if (g && n && typeof g.stack == "string") { for (var a = g.stack.split(` `), v = n.stack.split(` `), s = a.length - 1, l = v.length - 1; s >= 1 && l >= 0 && a[s] !== v[l]; ) l--; for (; s >= 1 && l >= 0; s--, l--) if (a[s] !== v[l]) { if (s !== 1 || l !== 1) do if (s--, l--, l < 0 || a[s] !== v[l]) { var p = ` ` + a[s].replace(" at new ", " at "); return e.displayName && p.includes("<anonymous>") && (p = p.replace("<anonymous>", e.displayName)), typeof e == "function" && V.set(e, p), p; } while (s >= 1 && l >= 0); break; } } } finally { z = !1, $.current = u, Ye(), Error.prepareStackTrace = o; } var O = e ? e.displayName || e.name : "", S = O ? Y(O) : ""; return typeof e == "function" && V.set(e, S), S; } function Ze(e, r, t) { return se(e, !1); } function Le(e) { var r = e.prototype; return !!(r && r.isReactComponent); } function Z(e, r, t) { if (e == null) return ""; if (typeof e == "function") return se(e, Le(e)); if (typeof e == "string") return Y(e); switch (e) { case y: return Y("Suspense"); case f: return Y("SuspenseList"); } if (typeof e == "object") switch (e.$$typeof) { case c: return Ze(e.render); case b: return Z(e.type, r, t); case C: { var n = e, o = n._payload, u = n._init; try { return Z(u(o), r, t); } catch { } } } return ""; } var D = Object.prototype.hasOwnProperty, le = {}, ce = T.ReactDebugCurrentFrame; function L(e) { if (e) { var r = e._owner, t = Z(e.type, e._source, r ? r.type : null); ce.setExtraStackFrame(t); } else ce.setExtraStackFrame(null); } function Ne(e, r, t, n, o) { { var u = Function.call.bind(D); for (var i in e) if (u(e, i)) { var a = void 0; try { if (typeof e[i] != "function") { var v = Error((n || "React class") + ": " + t + " type `" + i + "` is invalid; it must be a function, usually from the `prop-types` package, but received `" + typeof e[i] + "`.This often happens because of typos such as `PropTypes.function` instead of `PropTypes.func`."); throw v.name = "Invariant Violation", v; } a = e[i](r, i, n, t, null, "SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED"); } catch (s) { a = s; } a && !(a instanceof Error) && (L(o), d("%s: type specification of %s `%s` is invalid; the type checker function must return `null` or an `Error` but returned a %s. You may have forgotten to pass an argument to the type checker creator (arrayOf, instanceOf, objectOf, oneOf, oneOfType, and shape all require an argument).", n || "React class", t, i, typeof a), L(null)), a instanceof Error && !(a.message in le) && (le[a.message] = !0, L(o), d("Failed %s type: %s", t, a.message), L(null)); } } } var $e = Array.isArray; function U(e) { return $e(e); } function Ge(e) { { var r = typeof Symbol == "function" && Symbol.toStringTag, t = r && e[Symbol.toStringTag] || e.constructor.name || "Object"; return t; } } function ze(e) { try { return fe(e), !1; } catch { return !0; } } function fe(e) { return "" + e; } function de(e) { if (ze(e)) return d("The provided key is an unsupported type %s. This value must be coerced to a string before before using it here.", Ge(e)), fe(e); } var ve = T.ReactCurrentOwner, Ue = { key: !0, ref: !0, __self: !0, __source: !0 }, ge, pe; function Je(e) { if (D.call(e, "ref")) { var r = Object.getOwnPropertyDescriptor(e, "ref").get; if (r && r.isReactWarning) return !1; } return e.ref !== void 0; } function Be(e) { if (D.call(e, "key")) { var r = Object.getOwnPropertyDescriptor(e, "key").get; if (r && r.isReactWarning) return !1; } return e.key !== void 0; } function He(e, r) { typeof e.ref == "string" && ve.current; } function Ke(e, r) { { var t = function() { ge || (ge = !0, d("%s: `key` is not a prop. Trying to access it will result in `undefined` being returned. If you need to access the same value within the child component, you should pass it as a different prop. (https://reactjs.org/link/special-props)", r)); }; t.isReactWarning = !0, Object.defineProperty(e, "key", { get: t, configurable: !0 }); } } function qe(e, r) { { var t = function() { pe || (pe = !0, d("%s: `ref` is not a prop. Trying to access it will result in `undefined` being returned. If you need to access the same value within the child component, you should pass it as a different prop. (https://reactjs.org/link/special-props)", r)); }; t.isReactWarning = !0, Object.defineProperty(e, "ref", { get: t, configurable: !0 }); } } var Xe = function(e, r, t, n, o, u, i) { var a = { // This tag allows us to uniquely identify this as a React Element $$typeof: E, // Built-in properties that belong on the element type: e, key: r, ref: t, props: i, // Record the component responsible for creating this element. _owner: u }; return a._store = {}, Object.defineProperty(a._store, "validated", { configurable: !1, enumerable: !1, writable: !0, value: !1 }), Object.defineProperty(a, "_self", { configurable: !1, enumerable: !1, writable: !1, value: n }), Object.defineProperty(a, "_source", { configurable: !1, enumerable: !1, writable: !1, value: o }), Object.freeze && (Object.freeze(a.props), Object.freeze(a)), a; }; function Qe(e, r, t, n, o) { { var u, i = {}, a = null, v = null; t !== void 0 && (de(t), a = "" + t), Be(r) && (de(r.key), a = "" + r.key), Je(r) && (v = r.ref, He(r, o)); for (u in r) D.call(r, u) && !Ue.hasOwnProperty(u) && (i[u] = r[u]); if (e && e.defaultProps) { var s = e.defaultProps; for (u in s) i[u] === void 0 && (i[u] = s[u]); } if (a || v) { var l = typeof e == "function" ? e.displayName || e.name || "Unknown" : e; a && Ke(i, l), v && qe(i, l); } return Xe(e, a, v, o, n, ve.current, i); } } var J = T.ReactCurrentOwner, be = T.ReactDebugCurrentFrame; function j(e) { if (e) { var r = e._owner, t = Z(e.type, e._source, r ? r.type : null); be.setExtraStackFrame(t); } else be.setExtraStackFrame(null); } var B; B = !1; function H(e) { return typeof e == "object" && e !== null && e.$$typeof === E; } function me() { { if (J.current) { var e = h(J.current.type); if (e) return ` Check the render method of \`` + e + "`."; } return ""; } } function er(e) { return ""; } var ye = {}; function rr(e) { { var r = me(); if (!r) { var t = typeof e == "string" ? e : e.displayName || e.name; t && (r = ` Check the top-level render call using <` + t + ">."); } return r; } } function Re(e, r) { { if (!e._store || e._store.validated || e.key != null) return; e._store.validated = !0; var t = rr(r); if (ye[t]) return; ye[t] = !0; var n = ""; e && e._owner && e._owner !== J.current && (n = " It was passed a child from " + h(e._owner.type) + "."), j(e), d('Each child in a list should have a unique "key" prop.%s%s See https://reactjs.org/link/warning-keys for more information.', t, n), j(null); } } function Ie(e, r) { { if (typeof e != "object") return; if (U(e)) for (var t = 0; t < e.length; t++) { var n = e[t]; H(n) && Re(n, r); } else if (H(e)) e._store && (e._store.validated = !0); else if (e) { var o = Ae(e); if (typeof o == "function" && o !== e.entries) for (var u = o.call(e), i; !(i = u.next()).done; ) H(i.value) && Re(i.value, r); } } } function tr(e) { { var r = e.type; if (r == null || typeof r == "string") return; var t; if (typeof r == "function") t = r.propTypes; else if (typeof r == "object" && (r.$$typeof === c || // Note: Memo only checks outer props here. // Inner props are checked in the reconciler. r.$$typeof === b)) t = r.propTypes; else return; if (t) { var n = h(r); Ne(t, e.props, "prop", n, e); } else if (r.PropTypes !== void 0 && !B) { B = !0; var o = h(r); d("Component %s declared `PropTypes` instead of `propTypes`. Did you misspell the property assignment?", o || "Unknown"); } typeof r.getDefaultProps == "function" && !r.getDefaultProps.isReactClassApproved && d("getDefaultProps is only used on classic React.createClass definitions. Use a static property named `defaultProps` instead."); } } function nr(e) { { for (var r = Object.keys(e.props), t = 0; t < r.length; t++) { var n = r[t]; if (n !== "children" && n !== "key") { j(e), d("Invalid prop `%s` supplied to `React.Fragment`. React.Fragment can only have `key` and `children` props.", n), j(null); break; } } e.ref !== null && (j(e), d("Invalid attribute `ref` supplied to `React.Fragment`."), j(null)); } } var he = {}; function Ee(e, r, t, n, o, u) { { var i = Fe(e); if (!i) { var a = ""; (e === void 0 || typeof e == "object" && e !== null && Object.keys(e).length === 0) && (a += " You likely forgot to export your component from the file it's defined in, or you might have mixed up default and named imports."); var v = er(); v ? a += v : a += me(); var s; e === null ? s = "null" : U(e) ? s = "array" : e !== void 0 && e.$$typeof === E ? (s = "<" + (h(e.type) || "Unknown") + " />", a = " Did you accidentally export a JSX literal instead of a component?") : s = typeof e, d("React.jsx: type is invalid -- expected a string (for built-in components) or a class/function (for composite components) but got: %s.%s", s, a); } var l = Qe(e, r, t, o, u); if (l == null) return l; if (i) { var p = r.children; if (p !== void 0) if (n) if (U(p)) { for (var O = 0; O < p.length; O++) Ie(p[O], e); Object.freeze && Object.freeze(p); } else d("React.jsx: Static children should always be an array. You are likely explicitly calling React.jsxs or React.jsxDEV. Use the Babel transform instead."); else Ie(p, e); } if (D.call(r, "key")) { var S = h(e), g = Object.keys(r).filter(function(lr) { return lr !== "key"; }), K = g.length > 0 ? "{key: someKey, " + g.join(": ..., ") + ": ...}" : "{key: someKey}"; if (!he[S + K]) { var sr = g.length > 0 ? "{" + g.join(": ..., ") + ": ...}" : "{}"; d(`A props object containing a "key" prop is being spread into JSX: let props = %s; <%s {...props} /> React keys must be passed directly to JSX without using spread: let props = %s; <%s key={someKey} {...props} />`, K, S, sr, S), he[S + K] = !0; } } return e === R ? nr(l) : tr(l), l; } } function ar(e, r, t) { return Ee(e, r, t, !0); } function ir(e, r, t) { return Ee(e, r, t, !1); } var or = ir, ur = ar; W.Fragment = R, W.jsx = or, W.jsxs = ur; }()), W; } var Pe; function br() { return Pe || (Pe = 1, process.env.NODE_ENV === "production" ? N.exports = gr() : N.exports = pr()), N.exports; } var mr = br(); const yr = cr( ({ src: w, placeholderSrc: E = "", // Default placeholder alt: x = "", threshold: R = 0.1, // Default threshold ...A }) => { const I = fr(null), [_, m] = dr(!1); vr(() => { if (!("IntersectionObserver" in window)) { m(!0); return; } const y = new IntersectionObserver( ([b]) => { b.isIntersecting && I.current && (m(!0), y.disconnect()); }, { threshold: R } // Use the threshold from props ), f = I.current; return f && y.observe(f), () => { y.disconnect(); }; }, [R]); const c = _ && w ? w : E; return /* @__PURE__ */ mr.jsx("img", { ref: I, src: c, alt: x, ...A }); } ); yr.displayName = "LazyImage"; export { yr as default };