[ Index ] |
PHP Cross Reference of WordPress Trunk (Updated Daily) |
[Summary view] [Print] [Text view]
1 /******/ var __webpack_modules__ = ({ 2 3 /***/ 622: 4 /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { 5 6 /* harmony export */ __webpack_require__.d(__webpack_exports__, { 7 /* harmony export */ Ob: () => (/* binding */ J), 8 /* harmony export */ Qv: () => (/* binding */ G), 9 /* harmony export */ XX: () => (/* binding */ E), 10 /* harmony export */ fF: () => (/* binding */ l), 11 /* harmony export */ h: () => (/* binding */ _), 12 /* harmony export */ q6: () => (/* binding */ K), 13 /* harmony export */ uA: () => (/* binding */ x), 14 /* harmony export */ zO: () => (/* binding */ u) 15 /* harmony export */ }); 16 /* unused harmony exports Fragment, createElement, createRef, toChildArray */ 17 var n,l,t,u,i,r,o,e,f,c,s,a,h,p={},v=[],y=/acit|ex(?:s|g|n|p|$)|rph|grid|ows|mnc|ntw|ine[ch]|zoo|^ord|itera/i,d=Array.isArray;function w(n,l){for(var t in l)n[t]=l[t];return n}function g(n){n&&n.parentNode&&n.parentNode.removeChild(n)}function _(l,t,u){var i,r,o,e={};for(o in t)"key"==o?i=t[o]:"ref"==o?r=t[o]:e[o]=t[o];if(arguments.length>2&&(e.children=arguments.length>3?n.call(arguments,2):u),"function"==typeof l&&null!=l.defaultProps)for(o in l.defaultProps)void 0===e[o]&&(e[o]=l.defaultProps[o]);return m(l,e,i,r,null)}function m(n,u,i,r,o){var e={type:n,props:u,key:i,ref:r,__k:null,__:null,__b:0,__e:null,__c:null,constructor:void 0,__v:null==o?++t:o,__i:-1,__u:0};return null==o&&null!=l.vnode&&l.vnode(e),e}function b(){return{current:null}}function k(n){return n.children}function x(n,l){this.props=n,this.context=l}function S(n,l){if(null==l)return n.__?S(n.__,n.__i+1):null;for(var t;l<n.__k.length;l++)if(null!=(t=n.__k[l])&&null!=t.__e)return t.__e;return"function"==typeof n.type?S(n):null}function C(n){var l,t;if(null!=(n=n.__)&&null!=n.__c){for(n.__e=n.__c.base=null,l=0;l<n.__k.length;l++)if(null!=(t=n.__k[l])&&null!=t.__e){n.__e=n.__c.base=t.__e;break}return C(n)}}function M(n){(!n.__d&&(n.__d=!0)&&i.push(n)&&!$.__r++||r!==l.debounceRendering)&&((r=l.debounceRendering)||o)($)}function $(){for(var n,t,u,r,o,f,c,s=1;i.length;)i.length>s&&i.sort(e),n=i.shift(),s=i.length,n.__d&&(u=void 0,o=(r=(t=n).__v).__e,f=[],c=[],t.__P&&((u=w({},r)).__v=r.__v+1,l.vnode&&l.vnode(u),O(t.__P,u,r,t.__n,t.__P.namespaceURI,32&r.__u?[o]:null,f,null==o?S(r):o,!!(32&r.__u),c),u.__v=r.__v,u.__.__k[u.__i]=u,z(f,u,c),u.__e!=o&&C(u)));$.__r=0}function I(n,l,t,u,i,r,o,e,f,c,s){var a,h,y,d,w,g,_=u&&u.__k||v,m=l.length;for(f=P(t,l,_,f,m),a=0;a<m;a++)null!=(y=t.__k[a])&&(h=-1===y.__i?p:_[y.__i]||p,y.__i=a,g=O(n,y,h,i,r,o,e,f,c,s),d=y.__e,y.ref&&h.ref!=y.ref&&(h.ref&&q(h.ref,null,y),s.push(y.ref,y.__c||d,y)),null==w&&null!=d&&(w=d),4&y.__u||h.__k===y.__k?f=A(y,f,n):"function"==typeof y.type&&void 0!==g?f=g:d&&(f=d.nextSibling),y.__u&=-7);return t.__e=w,f}function P(n,l,t,u,i){var r,o,e,f,c,s=t.length,a=s,h=0;for(n.__k=new Array(i),r=0;r<i;r++)null!=(o=l[r])&&"boolean"!=typeof o&&"function"!=typeof o?(f=r+h,(o=n.__k[r]="string"==typeof o||"number"==typeof o||"bigint"==typeof o||o.constructor==String?m(null,o,null,null,null):d(o)?m(k,{children:o},null,null,null):void 0===o.constructor&&o.__b>0?m(o.type,o.props,o.key,o.ref?o.ref:null,o.__v):o).__=n,o.__b=n.__b+1,e=null,-1!==(c=o.__i=L(o,t,f,a))&&(a--,(e=t[c])&&(e.__u|=2)),null==e||null===e.__v?(-1==c&&(i>s?h--:i<s&&h++),"function"!=typeof o.type&&(o.__u|=4)):c!=f&&(c==f-1?h--:c==f+1?h++:(c>f?h--:h++,o.__u|=4))):n.__k[r]=null;if(a)for(r=0;r<s;r++)null!=(e=t[r])&&0==(2&e.__u)&&(e.__e==u&&(u=S(e)),B(e,e));return u}function A(n,l,t){var u,i;if("function"==typeof n.type){for(u=n.__k,i=0;u&&i<u.length;i++)u[i]&&(u[i].__=n,l=A(u[i],l,t));return l}n.__e!=l&&(l&&n.type&&!t.contains(l)&&(l=S(n)),t.insertBefore(n.__e,l||null),l=n.__e);do{l=l&&l.nextSibling}while(null!=l&&8==l.nodeType);return l}function H(n,l){return l=l||[],null==n||"boolean"==typeof n||(d(n)?n.some(function(n){H(n,l)}):l.push(n)),l}function L(n,l,t,u){var i,r,o=n.key,e=n.type,f=l[t];if(null===f&&null==n.key||f&&o==f.key&&e===f.type&&0==(2&f.__u))return t;if(u>(null!=f&&0==(2&f.__u)?1:0))for(i=t-1,r=t+1;i>=0||r<l.length;){if(i>=0){if((f=l[i])&&0==(2&f.__u)&&o==f.key&&e===f.type)return i;i--}if(r<l.length){if((f=l[r])&&0==(2&f.__u)&&o==f.key&&e===f.type)return r;r++}}return-1}function T(n,l,t){"-"==l[0]?n.setProperty(l,null==t?"":t):n[l]=null==t?"":"number"!=typeof t||y.test(l)?t:t+"px"}function j(n,l,t,u,i){var r;n:if("style"==l)if("string"==typeof t)n.style.cssText=t;else{if("string"==typeof u&&(n.style.cssText=u=""),u)for(l in u)t&&l in t||T(n.style,l,"");if(t)for(l in t)u&&t[l]===u[l]||T(n.style,l,t[l])}else if("o"==l[0]&&"n"==l[1])r=l!=(l=l.replace(f,"$1")),l=l.toLowerCase()in n||"onFocusOut"==l||"onFocusIn"==l?l.toLowerCase().slice(2):l.slice(2),n.l||(n.l={}),n.l[l+r]=t,t?u?t.t=u.t:(t.t=c,n.addEventListener(l,r?a:s,r)):n.removeEventListener(l,r?a:s,r);else{if("http://www.w3.org/2000/svg"==i)l=l.replace(/xlink(H|:h)/,"h").replace(/sName$/,"s");else if("width"!=l&&"height"!=l&&"href"!=l&&"list"!=l&&"form"!=l&&"tabIndex"!=l&&"download"!=l&&"rowSpan"!=l&&"colSpan"!=l&&"role"!=l&&"popover"!=l&&l in n)try{n[l]=null==t?"":t;break n}catch(n){}"function"==typeof t||(null==t||!1===t&&"-"!=l[4]?n.removeAttribute(l):n.setAttribute(l,"popover"==l&&1==t?"":t))}}function F(n){return function(t){if(this.l){var u=this.l[t.type+n];if(null==t.u)t.u=c++;else if(t.u<u.t)return;return u(l.event?l.event(t):t)}}}function O(n,t,u,i,r,o,e,f,c,s){var a,h,p,v,y,_,m,b,S,C,M,$,P,A,H,L,T,j=t.type;if(void 0!==t.constructor)return null;128&u.__u&&(c=!!(32&u.__u),o=[f=t.__e=u.__e]),(a=l.__b)&&a(t);n:if("function"==typeof j)try{if(b=t.props,S="prototype"in j&&j.prototype.render,C=(a=j.contextType)&&i[a.__c],M=a?C?C.props.value:a.__:i,u.__c?m=(h=t.__c=u.__c).__=h.__E:(S?t.__c=h=new j(b,M):(t.__c=h=new x(b,M),h.constructor=j,h.render=D),C&&C.sub(h),h.props=b,h.state||(h.state={}),h.context=M,h.__n=i,p=h.__d=!0,h.__h=[],h._sb=[]),S&&null==h.__s&&(h.__s=h.state),S&&null!=j.getDerivedStateFromProps&&(h.__s==h.state&&(h.__s=w({},h.__s)),w(h.__s,j.getDerivedStateFromProps(b,h.__s))),v=h.props,y=h.state,h.__v=t,p)S&&null==j.getDerivedStateFromProps&&null!=h.componentWillMount&&h.componentWillMount(),S&&null!=h.componentDidMount&&h.__h.push(h.componentDidMount);else{if(S&&null==j.getDerivedStateFromProps&&b!==v&&null!=h.componentWillReceiveProps&&h.componentWillReceiveProps(b,M),!h.__e&&(null!=h.shouldComponentUpdate&&!1===h.shouldComponentUpdate(b,h.__s,M)||t.__v==u.__v)){for(t.__v!=u.__v&&(h.props=b,h.state=h.__s,h.__d=!1),t.__e=u.__e,t.__k=u.__k,t.__k.some(function(n){n&&(n.__=t)}),$=0;$<h._sb.length;$++)h.__h.push(h._sb[$]);h._sb=[],h.__h.length&&e.push(h);break n}null!=h.componentWillUpdate&&h.componentWillUpdate(b,h.__s,M),S&&null!=h.componentDidUpdate&&h.__h.push(function(){h.componentDidUpdate(v,y,_)})}if(h.context=M,h.props=b,h.__P=n,h.__e=!1,P=l.__r,A=0,S){for(h.state=h.__s,h.__d=!1,P&&P(t),a=h.render(h.props,h.state,h.context),H=0;H<h._sb.length;H++)h.__h.push(h._sb[H]);h._sb=[]}else do{h.__d=!1,P&&P(t),a=h.render(h.props,h.state,h.context),h.state=h.__s}while(h.__d&&++A<25);h.state=h.__s,null!=h.getChildContext&&(i=w(w({},i),h.getChildContext())),S&&!p&&null!=h.getSnapshotBeforeUpdate&&(_=h.getSnapshotBeforeUpdate(v,y)),L=a,null!=a&&a.type===k&&null==a.key&&(L=N(a.props.children)),f=I(n,d(L)?L:[L],t,u,i,r,o,e,f,c,s),h.base=t.__e,t.__u&=-161,h.__h.length&&e.push(h),m&&(h.__E=h.__=null)}catch(n){if(t.__v=null,c||null!=o)if(n.then){for(t.__u|=c?160:128;f&&8==f.nodeType&&f.nextSibling;)f=f.nextSibling;o[o.indexOf(f)]=null,t.__e=f}else for(T=o.length;T--;)g(o[T]);else t.__e=u.__e,t.__k=u.__k;l.__e(n,t,u)}else null==o&&t.__v==u.__v?(t.__k=u.__k,t.__e=u.__e):f=t.__e=V(u.__e,t,u,i,r,o,e,c,s);return(a=l.diffed)&&a(t),128&t.__u?void 0:f}function z(n,t,u){for(var i=0;i<u.length;i++)q(u[i],u[++i],u[++i]);l.__c&&l.__c(t,n),n.some(function(t){try{n=t.__h,t.__h=[],n.some(function(n){n.call(t)})}catch(n){l.__e(n,t.__v)}})}function N(n){return"object"!=typeof n||null==n?n:d(n)?n.map(N):w({},n)}function V(t,u,i,r,o,e,f,c,s){var a,h,v,y,w,_,m,b=i.props,k=u.props,x=u.type;if("svg"==x?o="http://www.w3.org/2000/svg":"math"==x?o="http://www.w3.org/1998/Math/MathML":o||(o="http://www.w3.org/1999/xhtml"),null!=e)for(a=0;a<e.length;a++)if((w=e[a])&&"setAttribute"in w==!!x&&(x?w.localName==x:3==w.nodeType)){t=w,e[a]=null;break}if(null==t){if(null==x)return document.createTextNode(k);t=document.createElementNS(o,x,k.is&&k),c&&(l.__m&&l.__m(u,e),c=!1),e=null}if(null===x)b===k||c&&t.data===k||(t.data=k);else{if(e=e&&n.call(t.childNodes),b=i.props||p,!c&&null!=e)for(b={},a=0;a<t.attributes.length;a++)b[(w=t.attributes[a]).name]=w.value;for(a in b)if(w=b[a],"children"==a);else if("dangerouslySetInnerHTML"==a)v=w;else if(!(a in k)){if("value"==a&&"defaultValue"in k||"checked"==a&&"defaultChecked"in k)continue;j(t,a,null,w,o)}for(a in k)w=k[a],"children"==a?y=w:"dangerouslySetInnerHTML"==a?h=w:"value"==a?_=w:"checked"==a?m=w:c&&"function"!=typeof w||b[a]===w||j(t,a,w,b[a],o);if(h)c||v&&(h.__html===v.__html||h.__html===t.innerHTML)||(t.innerHTML=h.__html),u.__k=[];else if(v&&(t.innerHTML=""),I("template"===u.type?t.content:t,d(y)?y:[y],u,i,r,"foreignObject"==x?"http://www.w3.org/1999/xhtml":o,e,f,e?e[0]:i.__k&&S(i,0),c,s),null!=e)for(a=e.length;a--;)g(e[a]);c||(a="value","progress"==x&&null==_?t.removeAttribute("value"):void 0!==_&&(_!==t[a]||"progress"==x&&!_||"option"==x&&_!==b[a])&&j(t,a,_,b[a],o),a="checked",void 0!==m&&m!==t[a]&&j(t,a,m,b[a],o))}return t}function q(n,t,u){try{if("function"==typeof n){var i="function"==typeof n.__u;i&&n.__u(),i&&null==t||(n.__u=n(t))}else n.current=t}catch(n){l.__e(n,u)}}function B(n,t,u){var i,r;if(l.unmount&&l.unmount(n),(i=n.ref)&&(i.current&&i.current!==n.__e||q(i,null,t)),null!=(i=n.__c)){if(i.componentWillUnmount)try{i.componentWillUnmount()}catch(n){l.__e(n,t)}i.base=i.__P=null}if(i=n.__k)for(r=0;r<i.length;r++)i[r]&&B(i[r],t,u||"function"!=typeof n.type);u||g(n.__e),n.__c=n.__=n.__e=void 0}function D(n,l,t){return this.constructor(n,t)}function E(t,u,i){var r,o,e,f;u==document&&(u=document.documentElement),l.__&&l.__(t,u),o=(r="function"==typeof i)?null:i&&i.__k||u.__k,e=[],f=[],O(u,t=(!r&&i||u).__k=_(k,null,[t]),o||p,p,u.namespaceURI,!r&&i?[i]:o?null:u.firstChild?n.call(u.childNodes):null,e,!r&&i?i:o?o.__e:u.firstChild,r,f),z(e,t,f)}function G(n,l){E(n,l,G)}function J(l,t,u){var i,r,o,e,f=w({},l.props);for(o in l.type&&l.type.defaultProps&&(e=l.type.defaultProps),t)"key"==o?i=t[o]:"ref"==o?r=t[o]:f[o]=void 0===t[o]&&void 0!==e?e[o]:t[o];return arguments.length>2&&(f.children=arguments.length>3?n.call(arguments,2):u),m(l.type,f,i||l.key,r||l.ref,null)}function K(n){function l(n){var t,u;return this.getChildContext||(t=new Set,(u={})[l.__c]=this,this.getChildContext=function(){return u},this.componentWillUnmount=function(){t=null},this.shouldComponentUpdate=function(n){this.props.value!==n.value&&t.forEach(function(n){n.__e=!0,M(n)})},this.sub=function(n){t.add(n);var l=n.componentWillUnmount;n.componentWillUnmount=function(){t&&t.delete(n),l&&l.call(n)}}),n.children}return l.__c="__cC"+h++,l.__=n,l.Provider=l.__l=(l.Consumer=function(n,l){return n.children(l)}).contextType=l,l}n=v.slice,l={__e:function(n,l,t,u){for(var i,r,o;l=l.__;)if((i=l.__c)&&!i.__)try{if((r=i.constructor)&&null!=r.getDerivedStateFromError&&(i.setState(r.getDerivedStateFromError(n)),o=i.__d),null!=i.componentDidCatch&&(i.componentDidCatch(n,u||{}),o=i.__d),o)return i.__E=i}catch(l){n=l}throw n}},t=0,u=function(n){return null!=n&&null==n.constructor},x.prototype.setState=function(n,l){var t;t=null!=this.__s&&this.__s!==this.state?this.__s:this.__s=w({},this.state),"function"==typeof n&&(n=n(w({},t),this.props)),n&&w(t,n),null!=n&&this.__v&&(l&&this._sb.push(l),M(this))},x.prototype.forceUpdate=function(n){this.__v&&(this.__e=!0,n&&this.__h.push(n),M(this))},x.prototype.render=k,i=[],o="function"==typeof Promise?Promise.prototype.then.bind(Promise.resolve()):setTimeout,e=function(n,l){return n.__v.__b-l.__v.__b},$.__r=0,f=/(PointerCapture)$|Capture$/i,c=0,s=F(!1),a=F(!0),h=0; 18 19 20 /***/ }) 21 22 /******/ }); 23 /************************************************************************/ 24 /******/ // The module cache 25 /******/ var __webpack_module_cache__ = {}; 26 /******/ 27 /******/ // The require function 28 /******/ function __webpack_require__(moduleId) { 29 /******/ // Check if module is in cache 30 /******/ var cachedModule = __webpack_module_cache__[moduleId]; 31 /******/ if (cachedModule !== undefined) { 32 /******/ return cachedModule.exports; 33 /******/ } 34 /******/ // Create a new module (and put it into the cache) 35 /******/ var module = __webpack_module_cache__[moduleId] = { 36 /******/ // no module.id needed 37 /******/ // no module.loaded needed 38 /******/ exports: {} 39 /******/ }; 40 /******/ 41 /******/ // Execute the module function 42 /******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__); 43 /******/ 44 /******/ // Return the exports of the module 45 /******/ return module.exports; 46 /******/ } 47 /******/ 48 /************************************************************************/ 49 /******/ /* webpack/runtime/define property getters */ 50 /******/ (() => { 51 /******/ // define getter functions for harmony exports 52 /******/ __webpack_require__.d = (exports, definition) => { 53 /******/ for(var key in definition) { 54 /******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { 55 /******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); 56 /******/ } 57 /******/ } 58 /******/ }; 59 /******/ })(); 60 /******/ 61 /******/ /* webpack/runtime/hasOwnProperty shorthand */ 62 /******/ (() => { 63 /******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop)) 64 /******/ })(); 65 /******/ 66 /************************************************************************/ 67 var __webpack_exports__ = {}; 68 69 // EXPORTS 70 __webpack_require__.d(__webpack_exports__, { 71 zj: () => (/* reexport */ getConfig), 72 SD: () => (/* reexport */ getContext), 73 V6: () => (/* reexport */ getElement), 74 $K: () => (/* reexport */ getServerContext), 75 vT: () => (/* reexport */ getServerState), 76 jb: () => (/* binding */ privateApis), 77 yT: () => (/* reexport */ splitTask), 78 M_: () => (/* reexport */ store), 79 hb: () => (/* reexport */ useCallback), 80 vJ: () => (/* reexport */ useEffect), 81 ip: () => (/* reexport */ useInit), 82 Nf: () => (/* reexport */ useLayoutEffect), 83 Kr: () => (/* reexport */ useMemo), 84 li: () => (/* reexport */ A), 85 J0: () => (/* reexport */ d), 86 FH: () => (/* reexport */ useWatch), 87 v4: () => (/* reexport */ withScope), 88 mh: () => (/* reexport */ withSyncEvent) 89 }); 90 91 // EXTERNAL MODULE: ./node_modules/preact/dist/preact.module.js 92 var preact_module = __webpack_require__(622); 93 ;// ./node_modules/preact/hooks/dist/hooks.module.js 94 var hooks_module_t,r,hooks_module_u,i,hooks_module_o=0,hooks_module_f=[],hooks_module_c=preact_module/* options */.fF,e=hooks_module_c.__b,a=hooks_module_c.__r,v=hooks_module_c.diffed,l=hooks_module_c.__c,m=hooks_module_c.unmount,s=hooks_module_c.__;function p(n,t){hooks_module_c.__h&&hooks_module_c.__h(r,n,hooks_module_o||t),hooks_module_o=0;var u=r.__H||(r.__H={__:[],__h:[]});return n>=u.__.length&&u.__.push({}),u.__[n]}function d(n){return hooks_module_o=1,h(D,n)}function h(n,u,i){var o=p(hooks_module_t++,2);if(o.t=n,!o.__c&&(o.__=[i?i(u):D(void 0,u),function(n){var t=o.__N?o.__N[0]:o.__[0],r=o.t(t,n);t!==r&&(o.__N=[r,o.__[1]],o.__c.setState({}))}],o.__c=r,!r.__f)){var f=function(n,t,r){if(!o.__c.__H)return!0;var u=o.__c.__H.__.filter(function(n){return!!n.__c});if(u.every(function(n){return!n.__N}))return!c||c.call(this,n,t,r);var i=o.__c.props!==n;return u.forEach(function(n){if(n.__N){var t=n.__[0];n.__=n.__N,n.__N=void 0,t!==n.__[0]&&(i=!0)}}),c&&c.call(this,n,t,r)||i};r.__f=!0;var c=r.shouldComponentUpdate,e=r.componentWillUpdate;r.componentWillUpdate=function(n,t,r){if(this.__e){var u=c;c=void 0,f(n,t,r),c=u}e&&e.call(this,n,t,r)},r.shouldComponentUpdate=f}return o.__N||o.__}function y(n,u){var i=p(hooks_module_t++,3);!hooks_module_c.__s&&C(i.__H,u)&&(i.__=n,i.u=u,r.__H.__h.push(i))}function _(n,u){var i=p(hooks_module_t++,4);!hooks_module_c.__s&&C(i.__H,u)&&(i.__=n,i.u=u,r.__h.push(i))}function A(n){return hooks_module_o=5,T(function(){return{current:n}},[])}function F(n,t,r){hooks_module_o=6,_(function(){if("function"==typeof n){var r=n(t());return function(){n(null),r&&"function"==typeof r&&r()}}if(n)return n.current=t(),function(){return n.current=null}},null==r?r:r.concat(n))}function T(n,r){var u=p(hooks_module_t++,7);return C(u.__H,r)&&(u.__=n(),u.__H=r,u.__h=n),u.__}function q(n,t){return hooks_module_o=8,T(function(){return n},t)}function x(n){var u=r.context[n.__c],i=p(hooks_module_t++,9);return i.c=n,u?(null==i.__&&(i.__=!0,u.sub(r)),u.props.value):n.__}function P(n,t){hooks_module_c.useDebugValue&&hooks_module_c.useDebugValue(t?t(n):n)}function b(n){var u=p(hooks_module_t++,10),i=d();return u.__=n,r.componentDidCatch||(r.componentDidCatch=function(n,t){u.__&&u.__(n,t),i[1](n)}),[i[0],function(){i[1](void 0)}]}function g(){var n=p(hooks_module_t++,11);if(!n.__){for(var u=r.__v;null!==u&&!u.__m&&null!==u.__;)u=u.__;var i=u.__m||(u.__m=[0,0]);n.__="P"+i[0]+"-"+i[1]++}return n.__}function j(){for(var n;n=hooks_module_f.shift();)if(n.__P&&n.__H)try{n.__H.__h.forEach(z),n.__H.__h.forEach(B),n.__H.__h=[]}catch(t){n.__H.__h=[],hooks_module_c.__e(t,n.__v)}}hooks_module_c.__b=function(n){r=null,e&&e(n)},hooks_module_c.__=function(n,t){n&&t.__k&&t.__k.__m&&(n.__m=t.__k.__m),s&&s(n,t)},hooks_module_c.__r=function(n){a&&a(n),hooks_module_t=0;var i=(r=n.__c).__H;i&&(hooks_module_u===r?(i.__h=[],r.__h=[],i.__.forEach(function(n){n.__N&&(n.__=n.__N),n.u=n.__N=void 0})):(i.__h.forEach(z),i.__h.forEach(B),i.__h=[],hooks_module_t=0)),hooks_module_u=r},hooks_module_c.diffed=function(n){v&&v(n);var t=n.__c;t&&t.__H&&(t.__H.__h.length&&(1!==hooks_module_f.push(t)&&i===hooks_module_c.requestAnimationFrame||((i=hooks_module_c.requestAnimationFrame)||w)(j)),t.__H.__.forEach(function(n){n.u&&(n.__H=n.u),n.u=void 0})),hooks_module_u=r=null},hooks_module_c.__c=function(n,t){t.some(function(n){try{n.__h.forEach(z),n.__h=n.__h.filter(function(n){return!n.__||B(n)})}catch(r){t.some(function(n){n.__h&&(n.__h=[])}),t=[],hooks_module_c.__e(r,n.__v)}}),l&&l(n,t)},hooks_module_c.unmount=function(n){m&&m(n);var t,r=n.__c;r&&r.__H&&(r.__H.__.forEach(function(n){try{z(n)}catch(n){t=n}}),r.__H=void 0,t&&hooks_module_c.__e(t,r.__v))};var k="function"==typeof requestAnimationFrame;function w(n){var t,r=function(){clearTimeout(u),k&&cancelAnimationFrame(t),setTimeout(n)},u=setTimeout(r,100);k&&(t=requestAnimationFrame(r))}function z(n){var t=r,u=n.__c;"function"==typeof u&&(n.__c=void 0,u()),r=t}function B(n){var t=r;n.__c=n.__(),r=t}function C(n,t){return!n||n.length!==t.length||t.some(function(t,r){return t!==n[r]})}function D(n,t){return"function"==typeof t?t(n):t} 95 96 ;// ./node_modules/@preact/signals-core/dist/signals-core.module.js 97 var signals_core_module_i=Symbol.for("preact-signals");function signals_core_module_t(){if(!(signals_core_module_s>1)){var i,t=!1;while(void 0!==signals_core_module_h){var r=signals_core_module_h;signals_core_module_h=void 0;signals_core_module_f++;while(void 0!==r){var o=r.o;r.o=void 0;r.f&=-3;if(!(8&r.f)&&signals_core_module_c(r))try{r.c()}catch(r){if(!t){i=r;t=!0}}r=o}}signals_core_module_f=0;signals_core_module_s--;if(t)throw i}else signals_core_module_s--}function signals_core_module_r(i){if(signals_core_module_s>0)return i();signals_core_module_s++;try{return i()}finally{signals_core_module_t()}}var signals_core_module_o=void 0;function n(i){var t=signals_core_module_o;signals_core_module_o=void 0;try{return i()}finally{signals_core_module_o=t}}var signals_core_module_h=void 0,signals_core_module_s=0,signals_core_module_f=0,signals_core_module_v=0;function signals_core_module_e(i){if(void 0!==signals_core_module_o){var t=i.n;if(void 0===t||t.t!==signals_core_module_o){t={i:0,S:i,p:signals_core_module_o.s,n:void 0,t:signals_core_module_o,e:void 0,x:void 0,r:t};if(void 0!==signals_core_module_o.s)signals_core_module_o.s.n=t;signals_core_module_o.s=t;i.n=t;if(32&signals_core_module_o.f)i.S(t);return t}else if(-1===t.i){t.i=0;if(void 0!==t.n){t.n.p=t.p;if(void 0!==t.p)t.p.n=t.n;t.p=signals_core_module_o.s;t.n=void 0;signals_core_module_o.s.n=t;signals_core_module_o.s=t}return t}}}function signals_core_module_u(i){this.v=i;this.i=0;this.n=void 0;this.t=void 0}signals_core_module_u.prototype.brand=signals_core_module_i;signals_core_module_u.prototype.h=function(){return!0};signals_core_module_u.prototype.S=function(i){if(this.t!==i&&void 0===i.e){i.x=this.t;if(void 0!==this.t)this.t.e=i;this.t=i}};signals_core_module_u.prototype.U=function(i){if(void 0!==this.t){var t=i.e,r=i.x;if(void 0!==t){t.x=r;i.e=void 0}if(void 0!==r){r.e=t;i.x=void 0}if(i===this.t)this.t=r}};signals_core_module_u.prototype.subscribe=function(i){var t=this;return E(function(){var r=t.value,n=signals_core_module_o;signals_core_module_o=void 0;try{i(r)}finally{signals_core_module_o=n}})};signals_core_module_u.prototype.valueOf=function(){return this.value};signals_core_module_u.prototype.toString=function(){return this.value+""};signals_core_module_u.prototype.toJSON=function(){return this.value};signals_core_module_u.prototype.peek=function(){var i=signals_core_module_o;signals_core_module_o=void 0;try{return this.value}finally{signals_core_module_o=i}};Object.defineProperty(signals_core_module_u.prototype,"value",{get:function(){var i=signals_core_module_e(this);if(void 0!==i)i.i=this.i;return this.v},set:function(i){if(i!==this.v){if(signals_core_module_f>100)throw new Error("Cycle detected");this.v=i;this.i++;signals_core_module_v++;signals_core_module_s++;try{for(var r=this.t;void 0!==r;r=r.x)r.t.N()}finally{signals_core_module_t()}}}});function signals_core_module_d(i){return new signals_core_module_u(i)}function signals_core_module_c(i){for(var t=i.s;void 0!==t;t=t.n)if(t.S.i!==t.i||!t.S.h()||t.S.i!==t.i)return!0;return!1}function signals_core_module_a(i){for(var t=i.s;void 0!==t;t=t.n){var r=t.S.n;if(void 0!==r)t.r=r;t.S.n=t;t.i=-1;if(void 0===t.n){i.s=t;break}}}function signals_core_module_l(i){var t=i.s,r=void 0;while(void 0!==t){var o=t.p;if(-1===t.i){t.S.U(t);if(void 0!==o)o.n=t.n;if(void 0!==t.n)t.n.p=o}else r=t;t.S.n=t.r;if(void 0!==t.r)t.r=void 0;t=o}i.s=r}function signals_core_module_y(i){signals_core_module_u.call(this,void 0);this.x=i;this.s=void 0;this.g=signals_core_module_v-1;this.f=4}(signals_core_module_y.prototype=new signals_core_module_u).h=function(){this.f&=-3;if(1&this.f)return!1;if(32==(36&this.f))return!0;this.f&=-5;if(this.g===signals_core_module_v)return!0;this.g=signals_core_module_v;this.f|=1;if(this.i>0&&!signals_core_module_c(this)){this.f&=-2;return!0}var i=signals_core_module_o;try{signals_core_module_a(this);signals_core_module_o=this;var t=this.x();if(16&this.f||this.v!==t||0===this.i){this.v=t;this.f&=-17;this.i++}}catch(i){this.v=i;this.f|=16;this.i++}signals_core_module_o=i;signals_core_module_l(this);this.f&=-2;return!0};signals_core_module_y.prototype.S=function(i){if(void 0===this.t){this.f|=36;for(var t=this.s;void 0!==t;t=t.n)t.S.S(t)}signals_core_module_u.prototype.S.call(this,i)};signals_core_module_y.prototype.U=function(i){if(void 0!==this.t){signals_core_module_u.prototype.U.call(this,i);if(void 0===this.t){this.f&=-33;for(var t=this.s;void 0!==t;t=t.n)t.S.U(t)}}};signals_core_module_y.prototype.N=function(){if(!(2&this.f)){this.f|=6;for(var i=this.t;void 0!==i;i=i.x)i.t.N()}};Object.defineProperty(signals_core_module_y.prototype,"value",{get:function(){if(1&this.f)throw new Error("Cycle detected");var i=signals_core_module_e(this);this.h();if(void 0!==i)i.i=this.i;if(16&this.f)throw this.v;return this.v}});function signals_core_module_w(i){return new signals_core_module_y(i)}function signals_core_module_(i){var r=i.u;i.u=void 0;if("function"==typeof r){signals_core_module_s++;var n=signals_core_module_o;signals_core_module_o=void 0;try{r()}catch(t){i.f&=-2;i.f|=8;signals_core_module_g(i);throw t}finally{signals_core_module_o=n;signals_core_module_t()}}}function signals_core_module_g(i){for(var t=i.s;void 0!==t;t=t.n)t.S.U(t);i.x=void 0;i.s=void 0;signals_core_module_(i)}function signals_core_module_p(i){if(signals_core_module_o!==this)throw new Error("Out-of-order effect");signals_core_module_l(this);signals_core_module_o=i;this.f&=-2;if(8&this.f)signals_core_module_g(this);signals_core_module_t()}function signals_core_module_b(i){this.x=i;this.u=void 0;this.s=void 0;this.o=void 0;this.f=32}signals_core_module_b.prototype.c=function(){var i=this.S();try{if(8&this.f)return;if(void 0===this.x)return;var t=this.x();if("function"==typeof t)this.u=t}finally{i()}};signals_core_module_b.prototype.S=function(){if(1&this.f)throw new Error("Cycle detected");this.f|=1;this.f&=-9;signals_core_module_(this);signals_core_module_a(this);signals_core_module_s++;var i=signals_core_module_o;signals_core_module_o=this;return signals_core_module_p.bind(this,i)};signals_core_module_b.prototype.N=function(){if(!(2&this.f)){this.f|=2;this.o=signals_core_module_h;signals_core_module_h=this}};signals_core_module_b.prototype.d=function(){this.f|=8;if(!(1&this.f))signals_core_module_g(this)};function E(i){var t=new signals_core_module_b(i);try{t.c()}catch(i){t.d();throw i}return t.d.bind(t)} 98 ;// ./node_modules/@preact/signals/dist/signals.module.js 99 var signals_module_v,signals_module_s;function signals_module_l(i,n){preact_module/* options */.fF[i]=n.bind(null,preact_module/* options */.fF[i]||function(){})}function signals_module_d(i){if(signals_module_s)signals_module_s();signals_module_s=i&&i.S()}function signals_module_h(i){var r=this,f=i.data,o=useSignal(f);o.value=f;var e=T(function(){var i=r.__v;while(i=i.__)if(i.__c){i.__c.__$f|=4;break}r.__$u.c=function(){var i,t=r.__$u.S(),f=e.value;t();if((0,preact_module/* isValidElement */.zO)(f)||3!==(null==(i=r.base)?void 0:i.nodeType)){r.__$f|=1;r.setState({})}else r.base.data=f};return signals_core_module_w(function(){var i=o.value.value;return 0===i?0:!0===i?"":i||""})},[]);return e.value}signals_module_h.displayName="_st";Object.defineProperties(signals_core_module_u.prototype,{constructor:{configurable:!0,value:void 0},type:{configurable:!0,value:signals_module_h},props:{configurable:!0,get:function(){return{data:this}}},__b:{configurable:!0,value:1}});signals_module_l("__b",function(i,r){if("string"==typeof r.type){var n,t=r.props;for(var f in t)if("children"!==f){var o=t[f];if(o instanceof signals_core_module_u){if(!n)r.__np=n={};n[f]=o;t[f]=o.peek()}}}i(r)});signals_module_l("__r",function(i,r){signals_module_d();var n,t=r.__c;if(t){t.__$f&=-2;if(void 0===(n=t.__$u))t.__$u=n=function(i){var r;E(function(){r=this});r.c=function(){t.__$f|=1;t.setState({})};return r}()}signals_module_v=t;signals_module_d(n);i(r)});signals_module_l("__e",function(i,r,n,t){signals_module_d();signals_module_v=void 0;i(r,n,t)});signals_module_l("diffed",function(i,r){signals_module_d();signals_module_v=void 0;var n;if("string"==typeof r.type&&(n=r.__e)){var t=r.__np,f=r.props;if(t){var o=n.U;if(o)for(var e in o){var u=o[e];if(void 0!==u&&!(e in t)){u.d();o[e]=void 0}}else n.U=o={};for(var a in t){var c=o[a],s=t[a];if(void 0===c){c=signals_module_p(n,a,s,f);o[a]=c}else c.o(s,f)}}}i(r)});function signals_module_p(i,r,n,t){var f=r in i&&void 0===i.ownerSVGElement,o=signals_core_module_d(n);return{o:function(i,r){o.value=i;t=r},d:E(function(){var n=o.value.value;if(t[r]!==n){t[r]=n;if(f)i[r]=n;else if(n)i.setAttribute(r,n);else i.removeAttribute(r)}})}}signals_module_l("unmount",function(i,r){if("string"==typeof r.type){var n=r.__e;if(n){var t=n.U;if(t){n.U=void 0;for(var f in t){var o=t[f];if(o)o.d()}}}}else{var e=r.__c;if(e){var u=e.__$u;if(u){e.__$u=void 0;u.d()}}}i(r)});signals_module_l("__h",function(i,r,n,t){if(t<3||9===t)r.__$f|=2;i(r,n,t)});preact_module/* Component */.uA.prototype.shouldComponentUpdate=function(i,r){var n=this.__$u,t=n&&void 0!==n.s;for(var f in r)return!0;if(this.__f||"boolean"==typeof this.u&&!0===this.u){if(!(t||2&this.__$f||4&this.__$f))return!0;if(1&this.__$f)return!0}else{if(!(t||4&this.__$f))return!0;if(3&this.__$f)return!0}for(var o in i)if("__source"!==o&&i[o]!==this.props[o])return!0;for(var e in this.props)if(!(e in i))return!0;return!1};function useSignal(i){return T(function(){return signals_core_module_d(i)},[])}function useComputed(i){var r=f(i);r.current=i;signals_module_v.__$f|=4;return t(function(){return u(function(){return r.current()})},[])}function useSignalEffect(i){var r=f(i);r.current=i;o(function(){return c(function(){return r.current()})},[])} 100 ;// ./node_modules/@wordpress/interactivity/build-module/namespaces.js 101 const namespaceStack = []; 102 const getNamespace = () => namespaceStack.slice(-1)[0]; 103 const setNamespace = namespace => { 104 namespaceStack.push(namespace); 105 }; 106 const resetNamespace = () => { 107 namespaceStack.pop(); 108 }; 109 110 ;// ./node_modules/@wordpress/interactivity/build-module/scopes.js 111 /** 112 * External dependencies 113 */ 114 115 /** 116 * Internal dependencies 117 */ 118 119 // Store stacks for the current scope and the default namespaces and export APIs 120 // to interact with them. 121 const scopeStack = []; 122 const getScope = () => scopeStack.slice(-1)[0]; 123 const setScope = scope => { 124 scopeStack.push(scope); 125 }; 126 const resetScope = () => { 127 scopeStack.pop(); 128 }; 129 130 // Wrap the element props to prevent modifications. 131 const immutableMap = new WeakMap(); 132 const immutableError = () => { 133 throw new Error('Please use `data-wp-bind` to modify the attributes of an element.'); 134 }; 135 const immutableHandlers = { 136 get(target, key, receiver) { 137 const value = Reflect.get(target, key, receiver); 138 return !!value && typeof value === 'object' ? deepImmutable(value) : value; 139 }, 140 set: immutableError, 141 deleteProperty: immutableError 142 }; 143 const deepImmutable = target => { 144 if (!immutableMap.has(target)) { 145 immutableMap.set(target, new Proxy(target, immutableHandlers)); 146 } 147 return immutableMap.get(target); 148 }; 149 150 /** 151 * Retrieves the context inherited by the element evaluating a function from the 152 * store. The returned value depends on the element and the namespace where the 153 * function calling `getContext()` exists. 154 * 155 * @param namespace Store namespace. By default, the namespace where the calling 156 * function exists is used. 157 * @return The context content. 158 */ 159 const getContext = namespace => { 160 const scope = getScope(); 161 if (true) { 162 if (!scope) { 163 throw Error('Cannot call `getContext()` when there is no scope. If you are using an async function, please consider using a generator instead. If you are using some sort of async callbacks, like `setTimeout`, please wrap the callback with `withScope(callback)`.'); 164 } 165 } 166 return scope.context[namespace || getNamespace()]; 167 }; 168 169 /** 170 * Retrieves a representation of the element where a function from the store 171 * is being evaluated. Such representation is read-only, and contains a 172 * reference to the DOM element, its props and a local reactive state. 173 * 174 * @return Element representation. 175 */ 176 const getElement = () => { 177 const scope = getScope(); 178 if (true) { 179 if (!scope) { 180 throw Error('Cannot call `getElement()` when there is no scope. If you are using an async function, please consider using a generator instead. If you are using some sort of async callbacks, like `setTimeout`, please wrap the callback with `withScope(callback)`.'); 181 } 182 } 183 const { 184 ref, 185 attributes 186 } = scope; 187 return Object.freeze({ 188 ref: ref.current, 189 attributes: deepImmutable(attributes) 190 }); 191 }; 192 193 /** 194 * Retrieves the part of the inherited context defined and updated from the 195 * server. 196 * 197 * The object returned is read-only, and includes the context defined in PHP 198 * with `wp_interactivity_data_wp_context()`, including the corresponding 199 * inherited properties. When `actions.navigate()` is called, this object is 200 * updated to reflect the changes in the new visited page, without affecting the 201 * context returned by `getContext()`. Directives can subscribe to those changes 202 * to update the context if needed. 203 * 204 * @example 205 * ```js 206 * store('...', { 207 * callbacks: { 208 * updateServerContext() { 209 * const context = getContext(); 210 * const serverContext = getServerContext(); 211 * // Override some property with the new value that came from the server. 212 * context.overridableProp = serverContext.overridableProp; 213 * }, 214 * }, 215 * }); 216 * ``` 217 * 218 * @param namespace Store namespace. By default, the namespace where the calling 219 * function exists is used. 220 * @return The server context content. 221 */ 222 const getServerContext = namespace => { 223 const scope = getScope(); 224 if (true) { 225 if (!scope) { 226 throw Error('Cannot call `getServerContext()` when there is no scope. If you are using an async function, please consider using a generator instead. If you are using some sort of async callbacks, like `setTimeout`, please wrap the callback with `withScope(callback)`.'); 227 } 228 } 229 return scope.serverContext[namespace || getNamespace()]; 230 }; 231 232 ;// ./node_modules/@wordpress/interactivity/build-module/utils.js 233 /** 234 * External dependencies 235 */ 236 237 238 239 /** 240 * Internal dependencies 241 */ 242 243 244 /** 245 * Executes a callback function after the next frame is rendered. 246 * 247 * @param callback The callback function to be executed. 248 * @return A promise that resolves after the callback function is executed. 249 */ 250 const afterNextFrame = callback => { 251 return new Promise(resolve => { 252 const done = () => { 253 clearTimeout(timeout); 254 window.cancelAnimationFrame(raf); 255 setTimeout(() => { 256 callback(); 257 resolve(); 258 }); 259 }; 260 const timeout = setTimeout(done, 100); 261 const raf = window.requestAnimationFrame(done); 262 }); 263 }; 264 265 /** 266 * Returns a promise that resolves after yielding to main. 267 * 268 * @return Promise<void> 269 */ 270 const splitTask = typeof window.scheduler?.yield === 'function' ? window.scheduler.yield.bind(window.scheduler) : () => { 271 return new Promise(resolve => { 272 setTimeout(resolve, 0); 273 }); 274 }; 275 276 /** 277 * Creates a Flusher object that can be used to flush computed values and notify listeners. 278 * 279 * Using the mangled properties: 280 * this.c: this._callback 281 * this.x: this._compute 282 * https://github.com/preactjs/signals/blob/main/mangle.json 283 * 284 * @param compute The function that computes the value to be flushed. 285 * @param notify The function that notifies listeners when the value is flushed. 286 * @return The Flusher object with `flush` and `dispose` properties. 287 */ 288 function createFlusher(compute, notify) { 289 let flush = () => undefined; 290 const dispose = E(function () { 291 flush = this.c.bind(this); 292 this.x = compute; 293 this.c = notify; 294 return compute(); 295 }); 296 return { 297 flush, 298 dispose 299 }; 300 } 301 302 /** 303 * Custom hook that executes a callback function whenever a signal is triggered. 304 * Version of `useSignalEffect` with a `useEffect`-like execution. This hook 305 * implementation comes from this PR, but we added short-cirtuiting to avoid 306 * infinite loops: https://github.com/preactjs/signals/pull/290 307 * 308 * @param callback The callback function to be executed. 309 */ 310 function utils_useSignalEffect(callback) { 311 y(() => { 312 let eff = null; 313 let isExecuting = false; 314 const notify = async () => { 315 if (eff && !isExecuting) { 316 isExecuting = true; 317 await afterNextFrame(eff.flush); 318 isExecuting = false; 319 } 320 }; 321 eff = createFlusher(callback, notify); 322 return eff.dispose; 323 }, []); 324 } 325 326 /** 327 * Returns the passed function wrapped with the current scope so it is 328 * accessible whenever the function runs. This is primarily to make the scope 329 * available inside hook callbacks. 330 * 331 * Asynchronous functions should use generators that yield promises instead of awaiting them. 332 * See the documentation for details: https://developer.wordpress.org/block-editor/reference-guides/packages/packages-interactivity/packages-interactivity-api-reference/#the-store 333 * 334 * @param func The passed function. 335 * @return The wrapped function. 336 */ 337 338 function withScope(func) { 339 const scope = getScope(); 340 const ns = getNamespace(); 341 let wrapped; 342 if (func?.constructor?.name === 'GeneratorFunction') { 343 wrapped = async (...args) => { 344 const gen = func(...args); 345 let value; 346 let it; 347 while (true) { 348 setNamespace(ns); 349 setScope(scope); 350 try { 351 it = gen.next(value); 352 } finally { 353 resetScope(); 354 resetNamespace(); 355 } 356 try { 357 value = await it.value; 358 } catch (e) { 359 setNamespace(ns); 360 setScope(scope); 361 gen.throw(e); 362 } finally { 363 resetScope(); 364 resetNamespace(); 365 } 366 if (it.done) { 367 break; 368 } 369 } 370 return value; 371 }; 372 } else { 373 wrapped = (...args) => { 374 setNamespace(ns); 375 setScope(scope); 376 try { 377 return func(...args); 378 } finally { 379 resetNamespace(); 380 resetScope(); 381 } 382 }; 383 } 384 385 // If function was annotated via `withSyncEvent()`, maintain the annotation. 386 const syncAware = func; 387 if (syncAware.sync) { 388 const syncAwareWrapped = wrapped; 389 syncAwareWrapped.sync = true; 390 return syncAwareWrapped; 391 } 392 return wrapped; 393 } 394 395 /** 396 * Accepts a function that contains imperative code which runs whenever any of 397 * the accessed _reactive_ properties (e.g., values from the global state or the 398 * context) is modified. 399 * 400 * This hook makes the element's scope available so functions like 401 * `getElement()` and `getContext()` can be used inside the passed callback. 402 * 403 * @param callback The hook callback. 404 */ 405 function useWatch(callback) { 406 utils_useSignalEffect(withScope(callback)); 407 } 408 409 /** 410 * Accepts a function that contains imperative code which runs only after the 411 * element's first render, mainly useful for initialization logic. 412 * 413 * This hook makes the element's scope available so functions like 414 * `getElement()` and `getContext()` can be used inside the passed callback. 415 * 416 * @param callback The hook callback. 417 */ 418 function useInit(callback) { 419 y(withScope(callback), []); 420 } 421 422 /** 423 * Accepts a function that contains imperative, possibly effectful code. The 424 * effects run after browser paint, without blocking it. 425 * 426 * This hook is equivalent to Preact's `useEffect` and makes the element's scope 427 * available so functions like `getElement()` and `getContext()` can be used 428 * inside the passed callback. 429 * 430 * @param callback Imperative function that can return a cleanup 431 * function. 432 * @param inputs If present, effect will only activate if the 433 * values in the list change (using `===`). 434 */ 435 function useEffect(callback, inputs) { 436 y(withScope(callback), inputs); 437 } 438 439 /** 440 * Accepts a function that contains imperative, possibly effectful code. Use 441 * this to read layout from the DOM and synchronously re-render. 442 * 443 * This hook is equivalent to Preact's `useLayoutEffect` and makes the element's 444 * scope available so functions like `getElement()` and `getContext()` can be 445 * used inside the passed callback. 446 * 447 * @param callback Imperative function that can return a cleanup 448 * function. 449 * @param inputs If present, effect will only activate if the 450 * values in the list change (using `===`). 451 */ 452 function useLayoutEffect(callback, inputs) { 453 _(withScope(callback), inputs); 454 } 455 456 /** 457 * Returns a memoized version of the callback that only changes if one of the 458 * inputs has changed (using `===`). 459 * 460 * This hook is equivalent to Preact's `useCallback` and makes the element's 461 * scope available so functions like `getElement()` and `getContext()` can be 462 * used inside the passed callback. 463 * 464 * @param callback Callback function. 465 * @param inputs If present, the callback will only be updated if the 466 * values in the list change (using `===`). 467 * 468 * @return The callback function. 469 */ 470 function useCallback(callback, inputs) { 471 return q(withScope(callback), inputs); 472 } 473 474 /** 475 * Pass a factory function and an array of inputs. `useMemo` will only recompute 476 * the memoized value when one of the inputs has changed. 477 * 478 * This hook is equivalent to Preact's `useMemo` and makes the element's scope 479 * available so functions like `getElement()` and `getContext()` can be used 480 * inside the passed factory function. 481 * 482 * @param factory Factory function that returns that value for memoization. 483 * @param inputs If present, the factory will only be run to recompute if 484 * the values in the list change (using `===`). 485 * 486 * @return The memoized value. 487 */ 488 function useMemo(factory, inputs) { 489 return T(withScope(factory), inputs); 490 } 491 492 /** 493 * Creates a root fragment by replacing a node or an array of nodes in a parent element. 494 * For wrapperless hydration. 495 * See https://gist.github.com/developit/f4c67a2ede71dc2fab7f357f39cff28c 496 * 497 * @param parent The parent element where the nodes will be replaced. 498 * @param replaceNode The node or array of nodes to replace in the parent element. 499 * @return The created root fragment. 500 */ 501 const createRootFragment = (parent, replaceNode) => { 502 replaceNode = [].concat(replaceNode); 503 const sibling = replaceNode[replaceNode.length - 1].nextSibling; 504 function insert(child, root) { 505 parent.insertBefore(child, root || sibling); 506 } 507 return parent.__k = { 508 nodeType: 1, 509 parentNode: parent, 510 firstChild: replaceNode[0], 511 childNodes: replaceNode, 512 insertBefore: insert, 513 appendChild: insert, 514 removeChild(c) { 515 parent.removeChild(c); 516 } 517 }; 518 }; 519 520 /** 521 * Transforms a kebab-case string to camelCase. 522 * 523 * @param str The kebab-case string to transform to camelCase. 524 * @return The transformed camelCase string. 525 */ 526 function kebabToCamelCase(str) { 527 return str.replace(/^-+|-+$/g, '').toLowerCase().replace(/-([a-z])/g, function (_match, group1) { 528 return group1.toUpperCase(); 529 }); 530 } 531 const logged = new Set(); 532 533 /** 534 * Shows a warning with `message` if environment is not `production`. 535 * 536 * Based on the `@wordpress/warning` package. 537 * 538 * @param message Message to show in the warning. 539 */ 540 const warn = message => { 541 if (true) { 542 if (logged.has(message)) { 543 return; 544 } 545 546 // eslint-disable-next-line no-console 547 console.warn(message); 548 549 // Throwing an error and catching it immediately to improve debugging 550 // A consumer can use 'pause on caught exceptions' 551 try { 552 throw Error(message); 553 } catch (e) { 554 // Do nothing. 555 } 556 logged.add(message); 557 } 558 }; 559 560 /** 561 * Checks if the passed `candidate` is a plain object with just the `Object` 562 * prototype. 563 * 564 * @param candidate The item to check. 565 * @return Whether `candidate` is a plain object. 566 */ 567 const isPlainObject = candidate => Boolean(candidate && typeof candidate === 'object' && candidate.constructor === Object); 568 569 /** 570 * Indicates that the passed `callback` requires synchronous access to the event object. 571 * 572 * @param callback The event callback. 573 * @return Altered event callback. 574 */ 575 function withSyncEvent(callback) { 576 const syncAware = callback; 577 syncAware.sync = true; 578 return syncAware; 579 } 580 581 ;// ./node_modules/@wordpress/interactivity/build-module/proxies/registry.js 582 /** 583 * Proxies for each object. 584 */ 585 const objToProxy = new WeakMap(); 586 const proxyToObj = new WeakMap(); 587 588 /** 589 * Namespaces for each created proxy. 590 */ 591 const proxyToNs = new WeakMap(); 592 593 /** 594 * Object types that can be proxied. 595 */ 596 const supported = new Set([Object, Array]); 597 598 /** 599 * Returns a proxy to the passed object with the given handlers, assigning the 600 * specified namespace to it. If a proxy for the passed object was created 601 * before, that proxy is returned. 602 * 603 * @param namespace The namespace that will be associated to this proxy. 604 * @param obj The object to proxify. 605 * @param handlers Handlers that the proxy will use. 606 * 607 * @throws Error if the object cannot be proxified. Use {@link shouldProxy} to 608 * check if a proxy can be created for a specific object. 609 * 610 * @return The created proxy. 611 */ 612 const createProxy = (namespace, obj, handlers) => { 613 if (!shouldProxy(obj)) { 614 throw Error('This object cannot be proxified.'); 615 } 616 if (!objToProxy.has(obj)) { 617 const proxy = new Proxy(obj, handlers); 618 objToProxy.set(obj, proxy); 619 proxyToObj.set(proxy, obj); 620 proxyToNs.set(proxy, namespace); 621 } 622 return objToProxy.get(obj); 623 }; 624 625 /** 626 * Returns the proxy for the given object. If there is no associated proxy, the 627 * function returns `undefined`. 628 * 629 * @param obj Object from which to know the proxy. 630 * @return Associated proxy or `undefined`. 631 */ 632 const getProxyFromObject = obj => objToProxy.get(obj); 633 634 /** 635 * Gets the namespace associated with the given proxy. 636 * 637 * Proxies have a namespace assigned upon creation. See {@link createProxy}. 638 * 639 * @param proxy Proxy. 640 * @return Namespace. 641 */ 642 const getNamespaceFromProxy = proxy => proxyToNs.get(proxy); 643 644 /** 645 * Checks if a given object can be proxied. 646 * 647 * @param candidate Object to know whether it can be proxied. 648 * @return True if the passed instance can be proxied. 649 */ 650 const shouldProxy = candidate => { 651 if (typeof candidate !== 'object' || candidate === null) { 652 return false; 653 } 654 return !proxyToNs.has(candidate) && supported.has(candidate.constructor); 655 }; 656 657 /** 658 * Returns the target object for the passed proxy. If the passed object is not a registered proxy, the 659 * function returns `undefined`. 660 * 661 * @param proxy Proxy from which to know the target. 662 * @return The target object or `undefined`. 663 */ 664 const getObjectFromProxy = proxy => proxyToObj.get(proxy); 665 666 ;// ./node_modules/@wordpress/interactivity/build-module/proxies/signals.js 667 /** 668 * External dependencies 669 */ 670 671 672 /** 673 * Internal dependencies 674 */ 675 676 677 678 679 680 /** 681 * Identifier for property computeds not associated to any scope. 682 */ 683 const NO_SCOPE = {}; 684 685 /** 686 * Structure that manages reactivity for a property in a state object. It uses 687 * signals to keep track of property value or getter modifications. 688 */ 689 class PropSignal { 690 /** 691 * Proxy that holds the property this PropSignal is associated with. 692 */ 693 694 /** 695 * Relation of computeds by scope. These computeds are read-only signals 696 * that depend on whether the property is a value or a getter and, 697 * therefore, can return different values depending on the scope in which 698 * the getter is accessed. 699 */ 700 701 /** 702 * Signal with the value assigned to the related property. 703 */ 704 705 /** 706 * Signal with the getter assigned to the related property. 707 */ 708 709 /** 710 * Structure that manages reactivity for a property in a state object, using 711 * signals to keep track of property value or getter modifications. 712 * 713 * @param owner Proxy that holds the property this instance is associated 714 * with. 715 */ 716 constructor(owner) { 717 this.owner = owner; 718 this.computedsByScope = new WeakMap(); 719 } 720 721 /** 722 * Changes the internal value. If a getter was set before, it is set to 723 * `undefined`. 724 * 725 * @param value New value. 726 */ 727 setValue(value) { 728 this.update({ 729 value 730 }); 731 } 732 733 /** 734 * Changes the internal getter. If a value was set before, it is set to 735 * `undefined`. 736 * 737 * @param getter New getter. 738 */ 739 setGetter(getter) { 740 this.update({ 741 get: getter 742 }); 743 } 744 745 /** 746 * Returns the computed that holds the result of evaluating the prop in the 747 * current scope. 748 * 749 * These computeds are read-only signals that depend on whether the property 750 * is a value or a getter and, therefore, can return different values 751 * depending on the scope in which the getter is accessed. 752 * 753 * @return Computed that depends on the scope. 754 */ 755 getComputed() { 756 const scope = getScope() || NO_SCOPE; 757 if (!this.valueSignal && !this.getterSignal) { 758 this.update({}); 759 } 760 if (!this.computedsByScope.has(scope)) { 761 const callback = () => { 762 const getter = this.getterSignal?.value; 763 return getter ? getter.call(this.owner) : this.valueSignal?.value; 764 }; 765 setNamespace(getNamespaceFromProxy(this.owner)); 766 this.computedsByScope.set(scope, signals_core_module_w(withScope(callback))); 767 resetNamespace(); 768 } 769 return this.computedsByScope.get(scope); 770 } 771 772 /** 773 * Update the internal signals for the value and the getter of the 774 * corresponding prop. 775 * 776 * @param param0 777 * @param param0.get New getter. 778 * @param param0.value New value. 779 */ 780 update({ 781 get, 782 value 783 }) { 784 if (!this.valueSignal) { 785 this.valueSignal = signals_core_module_d(value); 786 this.getterSignal = signals_core_module_d(get); 787 } else if (value !== this.valueSignal.peek() || get !== this.getterSignal.peek()) { 788 signals_core_module_r(() => { 789 this.valueSignal.value = value; 790 this.getterSignal.value = get; 791 }); 792 } 793 } 794 } 795 796 ;// ./node_modules/@wordpress/interactivity/build-module/proxies/state.js 797 /** 798 * External dependencies 799 */ 800 801 802 /** 803 * Internal dependencies 804 */ 805 806 807 808 809 810 /** 811 * Set of built-in symbols. 812 */ 813 const wellKnownSymbols = new Set(Object.getOwnPropertyNames(Symbol).map(key => Symbol[key]).filter(value => typeof value === 'symbol')); 814 815 /** 816 * Relates each proxy with a map of {@link PropSignal} instances, representing 817 * the proxy's accessed properties. 818 */ 819 const proxyToProps = new WeakMap(); 820 821 /** 822 * Checks whether a {@link PropSignal | `PropSignal`} instance exists for the 823 * given property in the passed proxy. 824 * 825 * @param proxy Proxy of a state object or array. 826 * @param key The property key. 827 * @return `true` when it exists; false otherwise. 828 */ 829 const hasPropSignal = (proxy, key) => proxyToProps.has(proxy) && proxyToProps.get(proxy).has(key); 830 const readOnlyProxies = new WeakSet(); 831 832 /** 833 * Returns the {@link PropSignal | `PropSignal`} instance associated with the 834 * specified prop in the passed proxy. 835 * 836 * The `PropSignal` instance is generated if it doesn't exist yet, using the 837 * `initial` parameter to initialize the internal signals. 838 * 839 * @param proxy Proxy of a state object or array. 840 * @param key The property key. 841 * @param initial Initial data for the `PropSignal` instance. 842 * @return The `PropSignal` instance. 843 */ 844 const getPropSignal = (proxy, key, initial) => { 845 if (!proxyToProps.has(proxy)) { 846 proxyToProps.set(proxy, new Map()); 847 } 848 key = typeof key === 'number' ? `$key}` : key; 849 const props = proxyToProps.get(proxy); 850 if (!props.has(key)) { 851 const ns = getNamespaceFromProxy(proxy); 852 const prop = new PropSignal(proxy); 853 props.set(key, prop); 854 if (initial) { 855 const { 856 get, 857 value 858 } = initial; 859 if (get) { 860 prop.setGetter(get); 861 } else { 862 const readOnly = readOnlyProxies.has(proxy); 863 prop.setValue(shouldProxy(value) ? proxifyState(ns, value, { 864 readOnly 865 }) : value); 866 } 867 } 868 } 869 return props.get(key); 870 }; 871 872 /** 873 * Relates each proxied object (i.e., the original object) with a signal that 874 * tracks changes in the number of properties. 875 */ 876 const objToIterable = new WeakMap(); 877 878 /** 879 * When this flag is `true`, it avoids any signal subscription, overriding state 880 * props' "reactive" behavior. 881 */ 882 let peeking = false; 883 884 /** 885 * Handlers for reactive objects and arrays in the state. 886 */ 887 const stateHandlers = { 888 get(target, key, receiver) { 889 /* 890 * The property should not be reactive for the following cases: 891 * 1. While using the `peek` function to read the property. 892 * 2. The property exists but comes from the Object or Array prototypes. 893 * 3. The property key is a known symbol. 894 */ 895 if (peeking || !target.hasOwnProperty(key) && key in target || typeof key === 'symbol' && wellKnownSymbols.has(key)) { 896 return Reflect.get(target, key, receiver); 897 } 898 899 // At this point, the property should be reactive. 900 const desc = Object.getOwnPropertyDescriptor(target, key); 901 const prop = getPropSignal(receiver, key, desc); 902 const result = prop.getComputed().value; 903 904 /* 905 * Check if the property is a synchronous function. If it is, set the 906 * default namespace. Synchronous functions always run in the proper scope, 907 * which is set by the Directives component. 908 */ 909 if (typeof result === 'function') { 910 const ns = getNamespaceFromProxy(receiver); 911 return (...args) => { 912 setNamespace(ns); 913 try { 914 return result.call(receiver, ...args); 915 } finally { 916 resetNamespace(); 917 } 918 }; 919 } 920 return result; 921 }, 922 set(target, key, value, receiver) { 923 if (readOnlyProxies.has(receiver)) { 924 return false; 925 } 926 setNamespace(getNamespaceFromProxy(receiver)); 927 try { 928 return Reflect.set(target, key, value, receiver); 929 } finally { 930 resetNamespace(); 931 } 932 }, 933 defineProperty(target, key, desc) { 934 if (readOnlyProxies.has(getProxyFromObject(target))) { 935 return false; 936 } 937 const isNew = !(key in target); 938 const result = Reflect.defineProperty(target, key, desc); 939 if (result) { 940 const receiver = getProxyFromObject(target); 941 const prop = getPropSignal(receiver, key); 942 const { 943 get, 944 value 945 } = desc; 946 if (get) { 947 prop.setGetter(get); 948 } else { 949 const ns = getNamespaceFromProxy(receiver); 950 prop.setValue(shouldProxy(value) ? proxifyState(ns, value) : value); 951 } 952 if (isNew && objToIterable.has(target)) { 953 objToIterable.get(target).value++; 954 } 955 956 /* 957 * Modify the `length` property value only if the related 958 * `PropSignal` exists, which means that there are subscriptions to 959 * this property. 960 */ 961 if (Array.isArray(target) && proxyToProps.get(receiver)?.has('length')) { 962 const length = getPropSignal(receiver, 'length'); 963 length.setValue(target.length); 964 } 965 } 966 return result; 967 }, 968 deleteProperty(target, key) { 969 if (readOnlyProxies.has(getProxyFromObject(target))) { 970 return false; 971 } 972 const result = Reflect.deleteProperty(target, key); 973 if (result) { 974 const prop = getPropSignal(getProxyFromObject(target), key); 975 prop.setValue(undefined); 976 if (objToIterable.has(target)) { 977 objToIterable.get(target).value++; 978 } 979 } 980 return result; 981 }, 982 ownKeys(target) { 983 if (!objToIterable.has(target)) { 984 objToIterable.set(target, signals_core_module_d(0)); 985 } 986 /* 987 *This subscribes to the signal while preventing the minifier from 988 * deleting this line in production. 989 */ 990 objToIterable._ = objToIterable.get(target).value; 991 return Reflect.ownKeys(target); 992 } 993 }; 994 995 /** 996 * Returns the proxy associated with the given state object, creating it if it 997 * does not exist. 998 * 999 * @param namespace The namespace that will be associated to this proxy. 1000 * @param obj The object to proxify. 1001 * @param options Options. 1002 * @param options.readOnly Read-only. 1003 * 1004 * @throws Error if the object cannot be proxified. Use {@link shouldProxy} to 1005 * check if a proxy can be created for a specific object. 1006 * 1007 * @return The associated proxy. 1008 */ 1009 const proxifyState = (namespace, obj, options) => { 1010 const proxy = createProxy(namespace, obj, stateHandlers); 1011 if (options?.readOnly) { 1012 readOnlyProxies.add(proxy); 1013 } 1014 return proxy; 1015 }; 1016 1017 /** 1018 * Reads the value of the specified property without subscribing to it. 1019 * 1020 * @param obj The object to read the property from. 1021 * @param key The property key. 1022 * @return The property value. 1023 */ 1024 const peek = (obj, key) => { 1025 peeking = true; 1026 try { 1027 return obj[key]; 1028 } finally { 1029 peeking = false; 1030 } 1031 }; 1032 1033 /** 1034 * Internal recursive implementation for {@link deepMerge | `deepMerge`}. 1035 * 1036 * @param target The target object. 1037 * @param source The source object containing new values and props. 1038 * @param override Whether existing props should be overwritten or not (`true` 1039 * by default). 1040 */ 1041 const deepMergeRecursive = (target, source, override = true) => { 1042 // If target is not a plain object and the source is, we don't need to merge 1043 // them because the source will be used as the new value of the target. 1044 if (!(isPlainObject(target) && isPlainObject(source))) { 1045 return; 1046 } 1047 let hasNewKeys = false; 1048 for (const key in source) { 1049 const isNew = !(key in target); 1050 hasNewKeys = hasNewKeys || isNew; 1051 const desc = Object.getOwnPropertyDescriptor(source, key); 1052 const proxy = getProxyFromObject(target); 1053 const propSignal = !!proxy && hasPropSignal(proxy, key) && getPropSignal(proxy, key); 1054 1055 // Handle getters and setters 1056 if (typeof desc.get === 'function' || typeof desc.set === 'function') { 1057 if (override || isNew) { 1058 // Because we are setting a getter or setter, we need to use 1059 // Object.defineProperty to define the property on the target object. 1060 Object.defineProperty(target, key, { 1061 ...desc, 1062 configurable: true, 1063 enumerable: true 1064 }); 1065 // Update the getter in the property signal if it exists 1066 if (desc.get && propSignal) { 1067 propSignal.setGetter(desc.get); 1068 } 1069 } 1070 1071 // Handle nested objects 1072 } else if (isPlainObject(source[key])) { 1073 const targetValue = Object.getOwnPropertyDescriptor(target, key)?.value; 1074 if (isNew || override && !isPlainObject(targetValue)) { 1075 // Create a new object if the property is new or needs to be overridden 1076 target[key] = {}; 1077 if (propSignal) { 1078 // Create a new proxified state for the nested object 1079 const ns = getNamespaceFromProxy(proxy); 1080 propSignal.setValue(proxifyState(ns, target[key])); 1081 } 1082 deepMergeRecursive(target[key], source[key], override); 1083 } 1084 // Both target and source are plain objects, merge them recursively 1085 else if (isPlainObject(targetValue)) { 1086 deepMergeRecursive(target[key], source[key], override); 1087 } 1088 1089 // Handle primitive values and non-plain objects 1090 } else if (override || isNew) { 1091 Object.defineProperty(target, key, desc); 1092 if (propSignal) { 1093 const { 1094 value 1095 } = desc; 1096 const ns = getNamespaceFromProxy(proxy); 1097 // Proxify the value if necessary before setting it in the signal 1098 propSignal.setValue(shouldProxy(value) ? proxifyState(ns, value) : value); 1099 } 1100 } 1101 } 1102 if (hasNewKeys && objToIterable.has(target)) { 1103 objToIterable.get(target).value++; 1104 } 1105 }; 1106 1107 /** 1108 * Recursively update prop values inside the passed `target` and nested plain 1109 * objects, using the values present in `source`. References to plain objects 1110 * are kept, only updating props containing primitives or arrays. Arrays are 1111 * replaced instead of merged or concatenated. 1112 * 1113 * If the `override` parameter is set to `false`, then all values in `target` 1114 * are preserved, and only new properties from `source` are added. 1115 * 1116 * @param target The target object. 1117 * @param source The source object containing new values and props. 1118 * @param override Whether existing props should be overwritten or not (`true` 1119 * by default). 1120 */ 1121 const deepMerge = (target, source, override = true) => signals_core_module_r(() => deepMergeRecursive(getObjectFromProxy(target) || target, source, override)); 1122 1123 ;// ./node_modules/@wordpress/interactivity/build-module/proxies/store.js 1124 /** 1125 * Internal dependencies 1126 */ 1127 1128 /** 1129 * External dependencies 1130 */ 1131 1132 1133 1134 /** 1135 * Identifies the store proxies handling the root objects of each store. 1136 */ 1137 const storeRoots = new WeakSet(); 1138 1139 /** 1140 * Handlers for store proxies. 1141 */ 1142 const storeHandlers = { 1143 get: (target, key, receiver) => { 1144 const result = Reflect.get(target, key); 1145 const ns = getNamespaceFromProxy(receiver); 1146 1147 /* 1148 * Check if the proxy is the store root and no key with that name exist. In 1149 * that case, return an empty object for the requested key. 1150 */ 1151 if (typeof result === 'undefined' && storeRoots.has(receiver)) { 1152 const obj = {}; 1153 Reflect.set(target, key, obj); 1154 return proxifyStore(ns, obj, false); 1155 } 1156 1157 /* 1158 * Check if the property is a function. If it is, add the store 1159 * namespace to the stack and wrap the function with the current scope. 1160 * The `withScope` util handles both synchronous functions and generator 1161 * functions. 1162 */ 1163 if (typeof result === 'function') { 1164 setNamespace(ns); 1165 const scoped = withScope(result); 1166 resetNamespace(); 1167 return scoped; 1168 } 1169 1170 // Check if the property is an object. If it is, proxyify it. 1171 if (isPlainObject(result) && shouldProxy(result)) { 1172 return proxifyStore(ns, result, false); 1173 } 1174 return result; 1175 } 1176 }; 1177 1178 /** 1179 * Returns the proxy associated with the given store object, creating it if it 1180 * does not exist. 1181 * 1182 * @param namespace The namespace that will be associated to this proxy. 1183 * @param obj The object to proxify. 1184 * 1185 * @param isRoot Whether the passed object is the store root object. 1186 * @throws Error if the object cannot be proxified. Use {@link shouldProxy} to 1187 * check if a proxy can be created for a specific object. 1188 * 1189 * @return The associated proxy. 1190 */ 1191 const proxifyStore = (namespace, obj, isRoot = true) => { 1192 const proxy = createProxy(namespace, obj, storeHandlers); 1193 if (proxy && isRoot) { 1194 storeRoots.add(proxy); 1195 } 1196 return proxy; 1197 }; 1198 1199 ;// ./node_modules/@wordpress/interactivity/build-module/proxies/context.js 1200 const contextObjectToProxy = new WeakMap(); 1201 const contextObjectToFallback = new WeakMap(); 1202 const contextProxies = new WeakSet(); 1203 const descriptor = Reflect.getOwnPropertyDescriptor; 1204 1205 // TODO: Use the proxy registry to avoid multiple proxies on the same object. 1206 const contextHandlers = { 1207 get: (target, key) => { 1208 const fallback = contextObjectToFallback.get(target); 1209 // Always subscribe to prop changes in the current context. 1210 const currentProp = target[key]; 1211 1212 /* 1213 * Return the value from `target` if it exists, or from `fallback` 1214 * otherwise. This way, in the case the property doesn't exist either in 1215 * `target` or `fallback`, it also subscribes to changes in the parent 1216 * context. 1217 */ 1218 return key in target ? currentProp : fallback[key]; 1219 }, 1220 set: (target, key, value) => { 1221 const fallback = contextObjectToFallback.get(target); 1222 1223 // If the property exists in the current context, modify it. Otherwise, 1224 // add it to the current context. 1225 const obj = key in target || !(key in fallback) ? target : fallback; 1226 obj[key] = value; 1227 return true; 1228 }, 1229 ownKeys: target => [...new Set([...Object.keys(contextObjectToFallback.get(target)), ...Object.keys(target)])], 1230 getOwnPropertyDescriptor: (target, key) => descriptor(target, key) || descriptor(contextObjectToFallback.get(target), key), 1231 has: (target, key) => Reflect.has(target, key) || Reflect.has(contextObjectToFallback.get(target), key) 1232 }; 1233 1234 /** 1235 * Wrap a context object with a proxy to reproduce the context stack. The proxy 1236 * uses the passed `inherited` context as a fallback to look up for properties 1237 * that don't exist in the given context. Also, updated properties are modified 1238 * where they are defined, or added to the main context when they don't exist. 1239 * 1240 * @param current Current context. 1241 * @param inherited Inherited context, used as fallback. 1242 * 1243 * @return The wrapped context object. 1244 */ 1245 const proxifyContext = (current, inherited = {}) => { 1246 if (contextProxies.has(current)) { 1247 throw Error('This object cannot be proxified.'); 1248 } 1249 // Update the fallback object reference when it changes. 1250 contextObjectToFallback.set(current, inherited); 1251 if (!contextObjectToProxy.has(current)) { 1252 const proxy = new Proxy(current, contextHandlers); 1253 contextObjectToProxy.set(current, proxy); 1254 contextProxies.add(proxy); 1255 } 1256 return contextObjectToProxy.get(current); 1257 }; 1258 1259 ;// ./node_modules/@wordpress/interactivity/build-module/proxies/index.js 1260 /** 1261 * Internal dependencies 1262 */ 1263 1264 1265 1266 1267 ;// ./node_modules/@wordpress/interactivity/build-module/store.js 1268 /** 1269 * Internal dependencies 1270 */ 1271 1272 /** 1273 * External dependencies 1274 */ 1275 1276 1277 const stores = new Map(); 1278 const rawStores = new Map(); 1279 const storeLocks = new Map(); 1280 const storeConfigs = new Map(); 1281 const serverStates = new Map(); 1282 1283 /** 1284 * Get the defined config for the store with the passed namespace. 1285 * 1286 * @param namespace Store's namespace from which to retrieve the config. 1287 * @return Defined config for the given namespace. 1288 */ 1289 const getConfig = namespace => storeConfigs.get(namespace || getNamespace()) || {}; 1290 1291 /** 1292 * Get the part of the state defined and updated from the server. 1293 * 1294 * The object returned is read-only, and includes the state defined in PHP with 1295 * `wp_interactivity_state()`. When using `actions.navigate()`, this object is 1296 * updated to reflect the changes in its properties, without affecting the state 1297 * returned by `store()`. Directives can subscribe to those changes to update 1298 * the state if needed. 1299 * 1300 * @example 1301 * ```js 1302 * const { state } = store('myStore', { 1303 * callbacks: { 1304 * updateServerState() { 1305 * const serverState = getServerState(); 1306 * // Override some property with the new value that came from the server. 1307 * state.overridableProp = serverState.overridableProp; 1308 * }, 1309 * }, 1310 * }); 1311 * ``` 1312 * 1313 * @param namespace Store's namespace from which to retrieve the server state. 1314 * @return The server state for the given namespace. 1315 */ 1316 const getServerState = namespace => { 1317 const ns = namespace || getNamespace(); 1318 if (!serverStates.has(ns)) { 1319 serverStates.set(ns, proxifyState(ns, {}, { 1320 readOnly: true 1321 })); 1322 } 1323 return serverStates.get(ns); 1324 }; 1325 const universalUnlock = 'I acknowledge that using a private store means my plugin will inevitably break on the next store release.'; 1326 1327 /** 1328 * Extends the Interactivity API global store adding the passed properties to 1329 * the given namespace. It also returns stable references to the namespace 1330 * content. 1331 * 1332 * These props typically consist of `state`, which is the reactive part of the 1333 * store ― which means that any directive referencing a state property will be 1334 * re-rendered anytime it changes ― and function properties like `actions` and 1335 * `callbacks`, mostly used for event handlers. These props can then be 1336 * referenced by any directive to make the HTML interactive. 1337 * 1338 * @example 1339 * ```js 1340 * const { state } = store( 'counter', { 1341 * state: { 1342 * value: 0, 1343 * get double() { return state.value * 2; }, 1344 * }, 1345 * actions: { 1346 * increment() { 1347 * state.value += 1; 1348 * }, 1349 * }, 1350 * } ); 1351 * ``` 1352 * 1353 * The code from the example above allows blocks to subscribe and interact with 1354 * the store by using directives in the HTML, e.g.: 1355 * 1356 * ```html 1357 * <div data-wp-interactive="counter"> 1358 * <button 1359 * data-wp-text="state.double" 1360 * data-wp-on--click="actions.increment" 1361 * > 1362 * 0 1363 * </button> 1364 * </div> 1365 * ``` 1366 * @param namespace The store namespace to interact with. 1367 * @param storePart Properties to add to the store namespace. 1368 * @param options Options for the given namespace. 1369 * 1370 * @return A reference to the namespace content. 1371 */ 1372 1373 // Overload for when the types are inferred. 1374 1375 // Overload for when types are passed via generics and they contain state. 1376 1377 // Overload for when types are passed via generics and they don't contain state. 1378 1379 // Overload for when types are divided into multiple parts. 1380 1381 function store(namespace, { 1382 state = {}, 1383 ...block 1384 } = {}, { 1385 lock = false 1386 } = {}) { 1387 if (!stores.has(namespace)) { 1388 // Lock the store if the passed lock is different from the universal 1389 // unlock. Once the lock is set (either false, true, or a given string), 1390 // it cannot change. 1391 if (lock !== universalUnlock) { 1392 storeLocks.set(namespace, lock); 1393 } 1394 const rawStore = { 1395 state: proxifyState(namespace, isPlainObject(state) ? state : {}), 1396 ...block 1397 }; 1398 const proxifiedStore = proxifyStore(namespace, rawStore); 1399 rawStores.set(namespace, rawStore); 1400 stores.set(namespace, proxifiedStore); 1401 } else { 1402 // Lock the store if it wasn't locked yet and the passed lock is 1403 // different from the universal unlock. If no lock is given, the store 1404 // will be public and won't accept any lock from now on. 1405 if (lock !== universalUnlock && !storeLocks.has(namespace)) { 1406 storeLocks.set(namespace, lock); 1407 } else { 1408 const storeLock = storeLocks.get(namespace); 1409 const isLockValid = lock === universalUnlock || lock !== true && lock === storeLock; 1410 if (!isLockValid) { 1411 if (!storeLock) { 1412 throw Error('Cannot lock a public store'); 1413 } else { 1414 throw Error('Cannot unlock a private store with an invalid lock code'); 1415 } 1416 } 1417 } 1418 const target = rawStores.get(namespace); 1419 deepMerge(target, block); 1420 deepMerge(target.state, state); 1421 } 1422 return stores.get(namespace); 1423 } 1424 const parseServerData = (dom = document) => { 1425 var _dom$getElementById; 1426 const jsonDataScriptTag = // Preferred Script Module data passing form 1427 (_dom$getElementById = dom.getElementById('wp-script-module-data-@wordpress/interactivity')) !== null && _dom$getElementById !== void 0 ? _dom$getElementById : 1428 // Legacy form 1429 dom.getElementById('wp-interactivity-data'); 1430 if (jsonDataScriptTag?.textContent) { 1431 try { 1432 return JSON.parse(jsonDataScriptTag.textContent); 1433 } catch {} 1434 } 1435 return {}; 1436 }; 1437 const populateServerData = data => { 1438 if (isPlainObject(data?.state)) { 1439 Object.entries(data.state).forEach(([namespace, state]) => { 1440 const st = store(namespace, {}, { 1441 lock: universalUnlock 1442 }); 1443 deepMerge(st.state, state, false); 1444 deepMerge(getServerState(namespace), state); 1445 }); 1446 } 1447 if (isPlainObject(data?.config)) { 1448 Object.entries(data.config).forEach(([namespace, config]) => { 1449 storeConfigs.set(namespace, config); 1450 }); 1451 } 1452 }; 1453 1454 // Parse and populate the initial state and config. 1455 const data = parseServerData(); 1456 populateServerData(data); 1457 1458 ;// ./node_modules/@wordpress/interactivity/build-module/hooks.js 1459 // eslint-disable-next-line eslint-comments/disable-enable-pair 1460 /* eslint-disable react-hooks/exhaustive-deps */ 1461 1462 /** 1463 * External dependencies 1464 */ 1465 1466 1467 /** 1468 * Internal dependencies 1469 */ 1470 1471 1472 1473 function isNonDefaultDirectiveSuffix(entry) { 1474 return entry.suffix !== null; 1475 } 1476 function isDefaultDirectiveSuffix(entry) { 1477 return entry.suffix === null; 1478 } 1479 // Main context. 1480 const context = (0,preact_module/* createContext */.q6)({ 1481 client: {}, 1482 server: {} 1483 }); 1484 1485 // WordPress Directives. 1486 const directiveCallbacks = {}; 1487 const directivePriorities = {}; 1488 1489 /** 1490 * Register a new directive type in the Interactivity API runtime. 1491 * 1492 * @example 1493 * ```js 1494 * directive( 1495 * 'alert', // Name without the `data-wp-` prefix. 1496 * ( { directives: { alert }, element, evaluate } ) => { 1497 * const defaultEntry = alert.find( isDefaultDirectiveSuffix ); 1498 * element.props.onclick = () => { alert( evaluate( defaultEntry ) ); } 1499 * } 1500 * ) 1501 * ``` 1502 * 1503 * The previous code registers a custom directive type for displaying an alert 1504 * message whenever an element using it is clicked. The message text is obtained 1505 * from the store under the inherited namespace, using `evaluate`. 1506 * 1507 * When the HTML is processed by the Interactivity API, any element containing 1508 * the `data-wp-alert` directive will have the `onclick` event handler, e.g., 1509 * 1510 * ```html 1511 * <div data-wp-interactive="messages"> 1512 * <button data-wp-alert="state.alert">Click me!</button> 1513 * </div> 1514 * ``` 1515 * Note that, in the previous example, the directive callback gets the path 1516 * value (`state.alert`) from the directive entry with suffix `null`. A 1517 * custom suffix can also be specified by appending `--` to the directive 1518 * attribute, followed by the suffix, like in the following HTML snippet: 1519 * 1520 * ```html 1521 * <div data-wp-interactive="myblock"> 1522 * <button 1523 * data-wp-color--text="state.text" 1524 * data-wp-color--background="state.background" 1525 * >Click me!</button> 1526 * </div> 1527 * ``` 1528 * 1529 * This could be an hypothetical implementation of the custom directive used in 1530 * the snippet above. 1531 * 1532 * @example 1533 * ```js 1534 * directive( 1535 * 'color', // Name without prefix and suffix. 1536 * ( { directives: { color: colors }, ref, evaluate } ) => 1537 * colors.forEach( ( color ) => { 1538 * if ( color.suffix = 'text' ) { 1539 * ref.style.setProperty( 1540 * 'color', 1541 * evaluate( color.text ) 1542 * ); 1543 * } 1544 * if ( color.suffix = 'background' ) { 1545 * ref.style.setProperty( 1546 * 'background-color', 1547 * evaluate( color.background ) 1548 * ); 1549 * } 1550 * } ); 1551 * } 1552 * ) 1553 * ``` 1554 * 1555 * @param name Directive name, without the `data-wp-` prefix. 1556 * @param callback Function that runs the directive logic. 1557 * @param options Options object. 1558 * @param options.priority Option to control the directive execution order. The 1559 * lesser, the highest priority. Default is `10`. 1560 */ 1561 const directive = (name, callback, { 1562 priority = 10 1563 } = {}) => { 1564 directiveCallbacks[name] = callback; 1565 directivePriorities[name] = priority; 1566 }; 1567 1568 // Resolve the path to some property of the store object. 1569 const resolve = (path, namespace) => { 1570 if (!namespace) { 1571 warn(`Namespace missing for "$path}". The value for that path won't be resolved.`); 1572 return; 1573 } 1574 let resolvedStore = stores.get(namespace); 1575 if (typeof resolvedStore === 'undefined') { 1576 resolvedStore = store(namespace, {}, { 1577 lock: universalUnlock 1578 }); 1579 } 1580 const current = { 1581 ...resolvedStore, 1582 context: getScope().context[namespace] 1583 }; 1584 try { 1585 // TODO: Support lazy/dynamically initialized stores 1586 return path.split('.').reduce((acc, key) => acc[key], current); 1587 } catch (e) {} 1588 }; 1589 1590 // Generate the evaluate function. 1591 const getEvaluate = ({ 1592 scope 1593 }) => 1594 // TODO: When removing the temporarily remaining `value( ...args )` call below, remove the `...args` parameter too. 1595 (entry, ...args) => { 1596 let { 1597 value: path, 1598 namespace 1599 } = entry; 1600 if (typeof path !== 'string') { 1601 throw new Error('The `value` prop should be a string path'); 1602 } 1603 // If path starts with !, remove it and save a flag. 1604 const hasNegationOperator = path[0] === '!' && !!(path = path.slice(1)); 1605 setScope(scope); 1606 const value = resolve(path, namespace); 1607 // Functions are returned without invoking them. 1608 if (typeof value === 'function') { 1609 // Except if they have a negation operator present, for backward compatibility. 1610 // This pattern is strongly discouraged and deprecated, and it will be removed in a near future release. 1611 // TODO: Remove this condition to effectively ignore negation operator when provided with a function. 1612 if (hasNegationOperator) { 1613 warn('Using a function with a negation operator is deprecated and will stop working in WordPress 6.9. Please use derived state instead.'); 1614 const functionResult = !value(...args); 1615 resetScope(); 1616 return functionResult; 1617 } 1618 // Reset scope before return and wrap the function so it will still run within the correct scope. 1619 resetScope(); 1620 return (...functionArgs) => { 1621 setScope(scope); 1622 const functionResult = value(...functionArgs); 1623 resetScope(); 1624 return functionResult; 1625 }; 1626 } 1627 const result = value; 1628 resetScope(); 1629 return hasNegationOperator ? !result : result; 1630 }; 1631 1632 // Separate directives by priority. The resulting array contains objects 1633 // of directives grouped by same priority, and sorted in ascending order. 1634 const getPriorityLevels = directives => { 1635 const byPriority = Object.keys(directives).reduce((obj, name) => { 1636 if (directiveCallbacks[name]) { 1637 const priority = directivePriorities[name]; 1638 (obj[priority] = obj[priority] || []).push(name); 1639 } 1640 return obj; 1641 }, {}); 1642 return Object.entries(byPriority).sort(([p1], [p2]) => parseInt(p1) - parseInt(p2)).map(([, arr]) => arr); 1643 }; 1644 1645 // Component that wraps each priority level of directives of an element. 1646 const Directives = ({ 1647 directives, 1648 priorityLevels: [currentPriorityLevel, ...nextPriorityLevels], 1649 element, 1650 originalProps, 1651 previousScope 1652 }) => { 1653 // Initialize the scope of this element. These scopes are different per each 1654 // level because each level has a different context, but they share the same 1655 // element ref, state and props. 1656 const scope = A({}).current; 1657 scope.evaluate = q(getEvaluate({ 1658 scope 1659 }), []); 1660 const { 1661 client, 1662 server 1663 } = x(context); 1664 scope.context = client; 1665 scope.serverContext = server; 1666 /* eslint-disable react-hooks/rules-of-hooks */ 1667 scope.ref = previousScope?.ref || A(null); 1668 /* eslint-enable react-hooks/rules-of-hooks */ 1669 1670 // Create a fresh copy of the vnode element and add the props to the scope, 1671 // named as attributes (HTML Attributes). 1672 element = (0,preact_module/* cloneElement */.Ob)(element, { 1673 ref: scope.ref 1674 }); 1675 scope.attributes = element.props; 1676 1677 // Recursively render the wrapper for the next priority level. 1678 const children = nextPriorityLevels.length > 0 ? (0,preact_module.h)(Directives, { 1679 directives, 1680 priorityLevels: nextPriorityLevels, 1681 element, 1682 originalProps, 1683 previousScope: scope 1684 }) : element; 1685 const props = { 1686 ...originalProps, 1687 children 1688 }; 1689 const directiveArgs = { 1690 directives, 1691 props, 1692 element, 1693 context, 1694 evaluate: scope.evaluate 1695 }; 1696 setScope(scope); 1697 for (const directiveName of currentPriorityLevel) { 1698 const wrapper = directiveCallbacks[directiveName]?.(directiveArgs); 1699 if (wrapper !== undefined) { 1700 props.children = wrapper; 1701 } 1702 } 1703 resetScope(); 1704 return props.children; 1705 }; 1706 1707 // Preact Options Hook called each time a vnode is created. 1708 const old = preact_module/* options */.fF.vnode; 1709 preact_module/* options */.fF.vnode = vnode => { 1710 if (vnode.props.__directives) { 1711 const props = vnode.props; 1712 const directives = props.__directives; 1713 if (directives.key) { 1714 vnode.key = directives.key.find(isDefaultDirectiveSuffix).value; 1715 } 1716 delete props.__directives; 1717 const priorityLevels = getPriorityLevels(directives); 1718 if (priorityLevels.length > 0) { 1719 vnode.props = { 1720 directives, 1721 priorityLevels, 1722 originalProps: props, 1723 type: vnode.type, 1724 element: (0,preact_module.h)(vnode.type, props), 1725 top: true 1726 }; 1727 vnode.type = Directives; 1728 } 1729 } 1730 if (old) { 1731 old(vnode); 1732 } 1733 }; 1734 1735 ;// ./node_modules/@wordpress/interactivity/build-module/directives.js 1736 // eslint-disable-next-line eslint-comments/disable-enable-pair 1737 /* eslint-disable react-hooks/exhaustive-deps */ 1738 1739 /** 1740 * External dependencies 1741 */ 1742 1743 1744 1745 /** 1746 * Internal dependencies 1747 */ 1748 1749 1750 1751 1752 1753 /** 1754 * Recursively clone the passed object. 1755 * 1756 * @param source Source object. 1757 * @return Cloned object. 1758 */ 1759 function deepClone(source) { 1760 if (isPlainObject(source)) { 1761 return Object.fromEntries(Object.entries(source).map(([key, value]) => [key, deepClone(value)])); 1762 } 1763 if (Array.isArray(source)) { 1764 return source.map(i => deepClone(i)); 1765 } 1766 return source; 1767 } 1768 1769 /** 1770 * Wraps event object to warn about access of synchronous properties and methods. 1771 * 1772 * For all store actions attached to an event listener the event object is proxied via this function, unless the action 1773 * uses the `withSyncEvent()` utility to indicate that it requires synchronous access to the event object. 1774 * 1775 * At the moment, the proxied event only emits warnings when synchronous properties or methods are being accessed. In 1776 * the future this will be changed and result in an error. The current temporary behavior allows implementers to update 1777 * their relevant actions to use `withSyncEvent()`. 1778 * 1779 * For additional context, see https://github.com/WordPress/gutenberg/issues/64944. 1780 * 1781 * @param event Event object. 1782 * @return Proxied event object. 1783 */ 1784 function wrapEventAsync(event) { 1785 const handler = { 1786 get(target, prop, receiver) { 1787 const value = target[prop]; 1788 switch (prop) { 1789 case 'currentTarget': 1790 warn(`Accessing the synchronous event.$prop} property in a store action without wrapping it in withSyncEvent() is deprecated and will stop working in WordPress 6.9. Please wrap the store action in withSyncEvent().`); 1791 break; 1792 case 'preventDefault': 1793 case 'stopImmediatePropagation': 1794 case 'stopPropagation': 1795 warn(`Using the synchronous event.$prop}() function in a store action without wrapping it in withSyncEvent() is deprecated and will stop working in WordPress 6.9. Please wrap the store action in withSyncEvent().`); 1796 break; 1797 } 1798 if (value instanceof Function) { 1799 return function (...args) { 1800 return value.apply(this === receiver ? target : this, args); 1801 }; 1802 } 1803 return value; 1804 } 1805 }; 1806 return new Proxy(event, handler); 1807 } 1808 const newRule = /(?:([\u0080-\uFFFF\w-%@]+) *:? *([^{;]+?);|([^;}{]*?) *{)|(}\s*)/g; 1809 const ruleClean = /\/\*[^]*?\*\/| +/g; 1810 const ruleNewline = /\n+/g; 1811 const empty = ' '; 1812 1813 /** 1814 * Convert a css style string into a object. 1815 * 1816 * Made by Cristian Bote (@cristianbote) for Goober. 1817 * https://unpkg.com/browse/goober@2.1.13/src/core/astish.js 1818 * 1819 * @param val CSS string. 1820 * @return CSS object. 1821 */ 1822 const cssStringToObject = val => { 1823 const tree = [{}]; 1824 let block, left; 1825 while (block = newRule.exec(val.replace(ruleClean, ''))) { 1826 if (block[4]) { 1827 tree.shift(); 1828 } else if (block[3]) { 1829 left = block[3].replace(ruleNewline, empty).trim(); 1830 tree.unshift(tree[0][left] = tree[0][left] || {}); 1831 } else { 1832 tree[0][block[1]] = block[2].replace(ruleNewline, empty).trim(); 1833 } 1834 } 1835 return tree[0]; 1836 }; 1837 1838 /** 1839 * Creates a directive that adds an event listener to the global window or 1840 * document object. 1841 * 1842 * @param type 'window' or 'document' 1843 */ 1844 const getGlobalEventDirective = type => { 1845 return ({ 1846 directives, 1847 evaluate 1848 }) => { 1849 directives[`on-$type}`].filter(isNonDefaultDirectiveSuffix).forEach(entry => { 1850 const eventName = entry.suffix.split('--', 1)[0]; 1851 useInit(() => { 1852 const cb = event => { 1853 const result = evaluate(entry); 1854 if (typeof result === 'function') { 1855 if (!result?.sync) { 1856 event = wrapEventAsync(event); 1857 } 1858 result(event); 1859 } 1860 }; 1861 const globalVar = type === 'window' ? window : document; 1862 globalVar.addEventListener(eventName, cb); 1863 return () => globalVar.removeEventListener(eventName, cb); 1864 }); 1865 }); 1866 }; 1867 }; 1868 1869 /** 1870 * Creates a directive that adds an async event listener to the global window or 1871 * document object. 1872 * 1873 * @param type 'window' or 'document' 1874 */ 1875 const getGlobalAsyncEventDirective = type => { 1876 return ({ 1877 directives, 1878 evaluate 1879 }) => { 1880 directives[`on-async-$type}`].filter(isNonDefaultDirectiveSuffix).forEach(entry => { 1881 const eventName = entry.suffix.split('--', 1)[0]; 1882 useInit(() => { 1883 const cb = async event => { 1884 await splitTask(); 1885 const result = evaluate(entry); 1886 if (typeof result === 'function') { 1887 result(event); 1888 } 1889 }; 1890 const globalVar = type === 'window' ? window : document; 1891 globalVar.addEventListener(eventName, cb, { 1892 passive: true 1893 }); 1894 return () => globalVar.removeEventListener(eventName, cb); 1895 }); 1896 }); 1897 }; 1898 }; 1899 /* harmony default export */ const directives = (() => { 1900 // data-wp-context 1901 directive('context', ({ 1902 directives: { 1903 context 1904 }, 1905 props: { 1906 children 1907 }, 1908 context: inheritedContext 1909 }) => { 1910 const { 1911 Provider 1912 } = inheritedContext; 1913 const defaultEntry = context.find(isDefaultDirectiveSuffix); 1914 const { 1915 client: inheritedClient, 1916 server: inheritedServer 1917 } = x(inheritedContext); 1918 const ns = defaultEntry.namespace; 1919 const client = A(proxifyState(ns, {})); 1920 const server = A(proxifyState(ns, {}, { 1921 readOnly: true 1922 })); 1923 1924 // No change should be made if `defaultEntry` does not exist. 1925 const contextStack = T(() => { 1926 const result = { 1927 client: { 1928 ...inheritedClient 1929 }, 1930 server: { 1931 ...inheritedServer 1932 } 1933 }; 1934 if (defaultEntry) { 1935 const { 1936 namespace, 1937 value 1938 } = defaultEntry; 1939 // Check that the value is a JSON object. Send a console warning if not. 1940 if (!isPlainObject(value)) { 1941 warn(`The value of data-wp-context in "$namespace}" store must be a valid stringified JSON object.`); 1942 } 1943 deepMerge(client.current, deepClone(value), false); 1944 deepMerge(server.current, deepClone(value)); 1945 result.client[namespace] = proxifyContext(client.current, inheritedClient[namespace]); 1946 result.server[namespace] = proxifyContext(server.current, inheritedServer[namespace]); 1947 } 1948 return result; 1949 }, [defaultEntry, inheritedClient, inheritedServer]); 1950 return (0,preact_module.h)(Provider, { 1951 value: contextStack 1952 }, children); 1953 }, { 1954 priority: 5 1955 }); 1956 1957 // data-wp-watch--[name] 1958 directive('watch', ({ 1959 directives: { 1960 watch 1961 }, 1962 evaluate 1963 }) => { 1964 watch.forEach(entry => { 1965 useWatch(() => { 1966 let start; 1967 if (false) {} 1968 let result = evaluate(entry); 1969 if (typeof result === 'function') { 1970 result = result(); 1971 } 1972 if (false) {} 1973 return result; 1974 }); 1975 }); 1976 }); 1977 1978 // data-wp-init--[name] 1979 directive('init', ({ 1980 directives: { 1981 init 1982 }, 1983 evaluate 1984 }) => { 1985 init.forEach(entry => { 1986 // TODO: Replace with useEffect to prevent unneeded scopes. 1987 useInit(() => { 1988 let start; 1989 if (false) {} 1990 let result = evaluate(entry); 1991 if (typeof result === 'function') { 1992 result = result(); 1993 } 1994 if (false) {} 1995 return result; 1996 }); 1997 }); 1998 }); 1999 2000 // data-wp-on--[event] 2001 directive('on', ({ 2002 directives: { 2003 on 2004 }, 2005 element, 2006 evaluate 2007 }) => { 2008 const events = new Map(); 2009 on.filter(isNonDefaultDirectiveSuffix).forEach(entry => { 2010 const event = entry.suffix.split('--')[0]; 2011 if (!events.has(event)) { 2012 events.set(event, new Set()); 2013 } 2014 events.get(event).add(entry); 2015 }); 2016 events.forEach((entries, eventType) => { 2017 const existingHandler = element.props[`on$eventType}`]; 2018 element.props[`on$eventType}`] = event => { 2019 entries.forEach(entry => { 2020 if (existingHandler) { 2021 existingHandler(event); 2022 } 2023 let start; 2024 if (false) {} 2025 const result = evaluate(entry); 2026 if (typeof result === 'function') { 2027 if (!result?.sync) { 2028 event = wrapEventAsync(event); 2029 } 2030 result(event); 2031 } 2032 if (false) {} 2033 }); 2034 }; 2035 }); 2036 }); 2037 2038 // data-wp-on-async--[event] 2039 directive('on-async', ({ 2040 directives: { 2041 'on-async': onAsync 2042 }, 2043 element, 2044 evaluate 2045 }) => { 2046 const events = new Map(); 2047 onAsync.filter(isNonDefaultDirectiveSuffix).forEach(entry => { 2048 const event = entry.suffix.split('--')[0]; 2049 if (!events.has(event)) { 2050 events.set(event, new Set()); 2051 } 2052 events.get(event).add(entry); 2053 }); 2054 events.forEach((entries, eventType) => { 2055 const existingHandler = element.props[`on$eventType}`]; 2056 element.props[`on$eventType}`] = event => { 2057 if (existingHandler) { 2058 existingHandler(event); 2059 } 2060 entries.forEach(async entry => { 2061 await splitTask(); 2062 const result = evaluate(entry); 2063 if (typeof result === 'function') { 2064 result(event); 2065 } 2066 }); 2067 }; 2068 }); 2069 }); 2070 2071 // data-wp-on-window--[event] 2072 directive('on-window', getGlobalEventDirective('window')); 2073 // data-wp-on-document--[event] 2074 directive('on-document', getGlobalEventDirective('document')); 2075 2076 // data-wp-on-async-window--[event] 2077 directive('on-async-window', getGlobalAsyncEventDirective('window')); 2078 // data-wp-on-async-document--[event] 2079 directive('on-async-document', getGlobalAsyncEventDirective('document')); 2080 2081 // data-wp-class--[classname] 2082 directive('class', ({ 2083 directives: { 2084 class: classNames 2085 }, 2086 element, 2087 evaluate 2088 }) => { 2089 classNames.filter(isNonDefaultDirectiveSuffix).forEach(entry => { 2090 const className = entry.suffix; 2091 let result = evaluate(entry); 2092 if (typeof result === 'function') { 2093 result = result(); 2094 } 2095 const currentClass = element.props.class || ''; 2096 const classFinder = new RegExp(`(^|\\s)$className}(\\s|$)`, 'g'); 2097 if (!result) { 2098 element.props.class = currentClass.replace(classFinder, ' ').trim(); 2099 } else if (!classFinder.test(currentClass)) { 2100 element.props.class = currentClass ? `$currentClass} $className}` : className; 2101 } 2102 useInit(() => { 2103 /* 2104 * This seems necessary because Preact doesn't change the class 2105 * names on the hydration, so we have to do it manually. It doesn't 2106 * need deps because it only needs to do it the first time. 2107 */ 2108 if (!result) { 2109 element.ref.current.classList.remove(className); 2110 } else { 2111 element.ref.current.classList.add(className); 2112 } 2113 }); 2114 }); 2115 }); 2116 2117 // data-wp-style--[style-prop] 2118 directive('style', ({ 2119 directives: { 2120 style 2121 }, 2122 element, 2123 evaluate 2124 }) => { 2125 style.filter(isNonDefaultDirectiveSuffix).forEach(entry => { 2126 const styleProp = entry.suffix; 2127 let result = evaluate(entry); 2128 if (typeof result === 'function') { 2129 result = result(); 2130 } 2131 element.props.style = element.props.style || {}; 2132 if (typeof element.props.style === 'string') { 2133 element.props.style = cssStringToObject(element.props.style); 2134 } 2135 if (!result) { 2136 delete element.props.style[styleProp]; 2137 } else { 2138 element.props.style[styleProp] = result; 2139 } 2140 useInit(() => { 2141 /* 2142 * This seems necessary because Preact doesn't change the styles on 2143 * the hydration, so we have to do it manually. It doesn't need deps 2144 * because it only needs to do it the first time. 2145 */ 2146 if (!result) { 2147 element.ref.current.style.removeProperty(styleProp); 2148 } else { 2149 element.ref.current.style[styleProp] = result; 2150 } 2151 }); 2152 }); 2153 }); 2154 2155 // data-wp-bind--[attribute] 2156 directive('bind', ({ 2157 directives: { 2158 bind 2159 }, 2160 element, 2161 evaluate 2162 }) => { 2163 bind.filter(isNonDefaultDirectiveSuffix).forEach(entry => { 2164 const attribute = entry.suffix; 2165 let result = evaluate(entry); 2166 if (typeof result === 'function') { 2167 result = result(); 2168 } 2169 element.props[attribute] = result; 2170 2171 /* 2172 * This is necessary because Preact doesn't change the attributes on the 2173 * hydration, so we have to do it manually. It only needs to do it the 2174 * first time. After that, Preact will handle the changes. 2175 */ 2176 useInit(() => { 2177 const el = element.ref.current; 2178 2179 /* 2180 * We set the value directly to the corresponding HTMLElement instance 2181 * property excluding the following special cases. We follow Preact's 2182 * logic: https://github.com/preactjs/preact/blob/ea49f7a0f9d1ff2c98c0bdd66aa0cbc583055246/src/diff/props.js#L110-L129 2183 */ 2184 if (attribute === 'style') { 2185 if (typeof result === 'string') { 2186 el.style.cssText = result; 2187 } 2188 return; 2189 } else if (attribute !== 'width' && attribute !== 'height' && attribute !== 'href' && attribute !== 'list' && attribute !== 'form' && 2190 /* 2191 * The value for `tabindex` follows the parsing rules for an 2192 * integer. If that fails, or if the attribute isn't present, then 2193 * the browsers should "follow platform conventions to determine if 2194 * the element should be considered as a focusable area", 2195 * practically meaning that most elements get a default of `-1` (not 2196 * focusable), but several also get a default of `0` (focusable in 2197 * order after all elements with a positive `tabindex` value). 2198 * 2199 * @see https://html.spec.whatwg.org/#tabindex-value 2200 */ 2201 attribute !== 'tabIndex' && attribute !== 'download' && attribute !== 'rowSpan' && attribute !== 'colSpan' && attribute !== 'role' && attribute in el) { 2202 try { 2203 el[attribute] = result === null || result === undefined ? '' : result; 2204 return; 2205 } catch (err) {} 2206 } 2207 /* 2208 * aria- and data- attributes have no boolean representation. 2209 * A `false` value is different from the attribute not being 2210 * present, so we can't remove it. 2211 * We follow Preact's logic: https://github.com/preactjs/preact/blob/ea49f7a0f9d1ff2c98c0bdd66aa0cbc583055246/src/diff/props.js#L131C24-L136 2212 */ 2213 if (result !== null && result !== undefined && (result !== false || attribute[4] === '-')) { 2214 el.setAttribute(attribute, result); 2215 } else { 2216 el.removeAttribute(attribute); 2217 } 2218 }); 2219 }); 2220 }); 2221 2222 // data-wp-ignore 2223 directive('ignore', ({ 2224 element: { 2225 type: Type, 2226 props: { 2227 innerHTML, 2228 ...rest 2229 } 2230 } 2231 }) => { 2232 // Preserve the initial inner HTML. 2233 const cached = T(() => innerHTML, []); 2234 return (0,preact_module.h)(Type, { 2235 dangerouslySetInnerHTML: { 2236 __html: cached 2237 }, 2238 ...rest 2239 }); 2240 }); 2241 2242 // data-wp-text 2243 directive('text', ({ 2244 directives: { 2245 text 2246 }, 2247 element, 2248 evaluate 2249 }) => { 2250 const entry = text.find(isDefaultDirectiveSuffix); 2251 if (!entry) { 2252 element.props.children = null; 2253 return; 2254 } 2255 try { 2256 let result = evaluate(entry); 2257 if (typeof result === 'function') { 2258 result = result(); 2259 } 2260 element.props.children = typeof result === 'object' ? null : result.toString(); 2261 } catch (e) { 2262 element.props.children = null; 2263 } 2264 }); 2265 2266 // data-wp-run 2267 directive('run', ({ 2268 directives: { 2269 run 2270 }, 2271 evaluate 2272 }) => { 2273 run.forEach(entry => { 2274 let result = evaluate(entry); 2275 if (typeof result === 'function') { 2276 result = result(); 2277 } 2278 return result; 2279 }); 2280 }); 2281 2282 // data-wp-each--[item] 2283 directive('each', ({ 2284 directives: { 2285 each, 2286 'each-key': eachKey 2287 }, 2288 context: inheritedContext, 2289 element, 2290 evaluate 2291 }) => { 2292 if (element.type !== 'template') { 2293 return; 2294 } 2295 const { 2296 Provider 2297 } = inheritedContext; 2298 const inheritedValue = x(inheritedContext); 2299 const [entry] = each; 2300 const { 2301 namespace 2302 } = entry; 2303 let iterable = evaluate(entry); 2304 if (typeof iterable === 'function') { 2305 iterable = iterable(); 2306 } 2307 if (typeof iterable?.[Symbol.iterator] !== 'function') { 2308 return; 2309 } 2310 const itemProp = isNonDefaultDirectiveSuffix(entry) ? kebabToCamelCase(entry.suffix) : 'item'; 2311 const result = []; 2312 for (const item of iterable) { 2313 const itemContext = proxifyContext(proxifyState(namespace, {}), inheritedValue.client[namespace]); 2314 const mergedContext = { 2315 client: { 2316 ...inheritedValue.client, 2317 [namespace]: itemContext 2318 }, 2319 server: { 2320 ...inheritedValue.server 2321 } 2322 }; 2323 2324 // Set the item after proxifying the context. 2325 mergedContext.client[namespace][itemProp] = item; 2326 const scope = { 2327 ...getScope(), 2328 context: mergedContext.client, 2329 serverContext: mergedContext.server 2330 }; 2331 const key = eachKey ? getEvaluate({ 2332 scope 2333 })(eachKey[0]) : item; 2334 result.push((0,preact_module.h)(Provider, { 2335 value: mergedContext, 2336 key 2337 }, element.props.content)); 2338 } 2339 return result; 2340 }, { 2341 priority: 20 2342 }); 2343 directive('each-child', () => null, { 2344 priority: 1 2345 }); 2346 }); 2347 2348 ;// ./node_modules/@wordpress/interactivity/build-module/constants.js 2349 const directivePrefix = 'wp'; 2350 2351 ;// ./node_modules/@wordpress/interactivity/build-module/vdom.js 2352 /** 2353 * External dependencies 2354 */ 2355 2356 /** 2357 * Internal dependencies 2358 */ 2359 2360 2361 const ignoreAttr = `data-$directivePrefix}-ignore`; 2362 const islandAttr = `data-$directivePrefix}-interactive`; 2363 const fullPrefix = `data-$directivePrefix}-`; 2364 const namespaces = []; 2365 const currentNamespace = () => { 2366 var _namespaces; 2367 return (_namespaces = namespaces[namespaces.length - 1]) !== null && _namespaces !== void 0 ? _namespaces : null; 2368 }; 2369 const isObject = item => Boolean(item && typeof item === 'object' && item.constructor === Object); 2370 2371 // Regular expression for directive parsing. 2372 const directiveParser = new RegExp(`^data-$directivePrefix}-` + 2373 // ${p} must be a prefix string, like 'wp'. 2374 // Match alphanumeric characters including hyphen-separated 2375 // segments. It excludes underscore intentionally to prevent confusion. 2376 // E.g., "custom-directive". 2377 '([a-z0-9]+(?:-[a-z0-9]+)*)' + 2378 // (Optional) Match '--' followed by any alphanumeric characters. It 2379 // excludes underscore intentionally to prevent confusion, but it can 2380 // contain multiple hyphens. E.g., "--custom-prefix--with-more-info". 2381 '(?:--([a-z0-9_-]+))?$', 'i' // Case insensitive. 2382 ); 2383 2384 // Regular expression for reference parsing. It can contain a namespace before 2385 // the reference, separated by `::`, like `some-namespace::state.somePath`. 2386 // Namespaces can contain any alphanumeric characters, hyphens, underscores or 2387 // forward slashes. References don't have any restrictions. 2388 const nsPathRegExp = /^([\w_\/-]+)::(.+)$/; 2389 const hydratedIslands = new WeakSet(); 2390 2391 /** 2392 * Recursive function that transforms a DOM tree into vDOM. 2393 * 2394 * @param root The root element or node to start traversing on. 2395 * @return The resulting vDOM tree. 2396 */ 2397 function toVdom(root) { 2398 const treeWalker = document.createTreeWalker(root, 205 // TEXT + CDATA_SECTION + COMMENT + PROCESSING_INSTRUCTION + ELEMENT 2399 ); 2400 function walk(node) { 2401 const { 2402 nodeType 2403 } = node; 2404 2405 // TEXT_NODE (3) 2406 if (nodeType === 3) { 2407 return [node.data]; 2408 } 2409 2410 // CDATA_SECTION_NODE (4) 2411 if (nodeType === 4) { 2412 var _nodeValue; 2413 const next = treeWalker.nextSibling(); 2414 node.replaceWith(new window.Text((_nodeValue = node.nodeValue) !== null && _nodeValue !== void 0 ? _nodeValue : '')); 2415 return [node.nodeValue, next]; 2416 } 2417 2418 // COMMENT_NODE (8) || PROCESSING_INSTRUCTION_NODE (7) 2419 if (nodeType === 8 || nodeType === 7) { 2420 const next = treeWalker.nextSibling(); 2421 node.remove(); 2422 return [null, next]; 2423 } 2424 const elementNode = node; 2425 const { 2426 attributes 2427 } = elementNode; 2428 const localName = elementNode.localName; 2429 const props = {}; 2430 const children = []; 2431 const directives = []; 2432 let ignore = false; 2433 let island = false; 2434 for (let i = 0; i < attributes.length; i++) { 2435 const attributeName = attributes[i].name; 2436 const attributeValue = attributes[i].value; 2437 if (attributeName[fullPrefix.length] && attributeName.slice(0, fullPrefix.length) === fullPrefix) { 2438 if (attributeName === ignoreAttr) { 2439 ignore = true; 2440 } else { 2441 var _regexResult$, _regexResult$2; 2442 const regexResult = nsPathRegExp.exec(attributeValue); 2443 const namespace = (_regexResult$ = regexResult?.[1]) !== null && _regexResult$ !== void 0 ? _regexResult$ : null; 2444 let value = (_regexResult$2 = regexResult?.[2]) !== null && _regexResult$2 !== void 0 ? _regexResult$2 : attributeValue; 2445 try { 2446 const parsedValue = JSON.parse(value); 2447 value = isObject(parsedValue) ? parsedValue : value; 2448 } catch {} 2449 if (attributeName === islandAttr) { 2450 island = true; 2451 const islandNamespace = 2452 // eslint-disable-next-line no-nested-ternary 2453 typeof value === 'string' ? value : typeof value?.namespace === 'string' ? value.namespace : null; 2454 namespaces.push(islandNamespace); 2455 } else { 2456 directives.push([attributeName, namespace, value]); 2457 } 2458 } 2459 } else if (attributeName === 'ref') { 2460 continue; 2461 } 2462 props[attributeName] = attributeValue; 2463 } 2464 if (ignore && !island) { 2465 return [(0,preact_module.h)(localName, { 2466 ...props, 2467 innerHTML: elementNode.innerHTML, 2468 __directives: { 2469 ignore: true 2470 } 2471 })]; 2472 } 2473 if (island) { 2474 hydratedIslands.add(elementNode); 2475 } 2476 if (directives.length) { 2477 props.__directives = directives.reduce((obj, [name, ns, value]) => { 2478 const directiveMatch = directiveParser.exec(name); 2479 if (directiveMatch === null) { 2480 warn(`Found malformed directive name: $name}.`); 2481 return obj; 2482 } 2483 const prefix = directiveMatch[1] || ''; 2484 const suffix = directiveMatch[2] || null; 2485 obj[prefix] = obj[prefix] || []; 2486 obj[prefix].push({ 2487 namespace: ns !== null && ns !== void 0 ? ns : currentNamespace(), 2488 value: value, 2489 suffix 2490 }); 2491 return obj; 2492 }, {}); 2493 } 2494 if (localName === 'template') { 2495 props.content = [...elementNode.content.childNodes].map(childNode => toVdom(childNode)); 2496 } else { 2497 let child = treeWalker.firstChild(); 2498 if (child) { 2499 while (child) { 2500 const [vnode, nextChild] = walk(child); 2501 if (vnode) { 2502 children.push(vnode); 2503 } 2504 child = nextChild || treeWalker.nextSibling(); 2505 } 2506 treeWalker.parentNode(); 2507 } 2508 } 2509 2510 // Restore previous namespace. 2511 if (island) { 2512 namespaces.pop(); 2513 } 2514 return [(0,preact_module.h)(localName, props, children)]; 2515 } 2516 return walk(treeWalker.currentNode); 2517 } 2518 2519 ;// ./node_modules/@wordpress/interactivity/build-module/init.js 2520 /** 2521 * External dependencies 2522 */ 2523 2524 /** 2525 * Internal dependencies 2526 */ 2527 2528 2529 2530 2531 // Keep the same root fragment for each interactive region node. 2532 const regionRootFragments = new WeakMap(); 2533 const getRegionRootFragment = region => { 2534 if (!region.parentElement) { 2535 throw Error('The passed region should be an element with a parent.'); 2536 } 2537 if (!regionRootFragments.has(region)) { 2538 regionRootFragments.set(region, createRootFragment(region.parentElement, region)); 2539 } 2540 return regionRootFragments.get(region); 2541 }; 2542 2543 // Initial vDOM regions associated with its DOM element. 2544 const initialVdom = new WeakMap(); 2545 2546 // Initialize the router with the initial DOM. 2547 const init = async () => { 2548 const nodes = document.querySelectorAll(`[data-$directivePrefix}-interactive]`); 2549 2550 /* 2551 * This `await` with setTimeout is required to apparently ensure that the interactive blocks have their stores 2552 * fully initialized prior to hydrating the blocks. If this is not present, then an error occurs, for example: 2553 * > view.js:46 Uncaught (in promise) ReferenceError: Cannot access 'state' before initialization 2554 * This occurs when splitTask() is implemented with scheduler.yield() as opposed to setTimeout(), as with the former 2555 * split tasks are added to the front of the task queue whereas with the latter they are added to the end of the queue. 2556 */ 2557 await new Promise(resolve => { 2558 setTimeout(resolve, 0); 2559 }); 2560 for (const node of nodes) { 2561 if (!hydratedIslands.has(node)) { 2562 await splitTask(); 2563 const fragment = getRegionRootFragment(node); 2564 const vdom = toVdom(node); 2565 initialVdom.set(node, vdom); 2566 await splitTask(); 2567 (0,preact_module/* hydrate */.Qv)(vdom, fragment); 2568 } 2569 } 2570 }; 2571 2572 ;// ./node_modules/@wordpress/interactivity/build-module/index.js 2573 /** 2574 * External dependencies 2575 */ 2576 2577 2578 2579 /** 2580 * Internal dependencies 2581 */ 2582 2583 2584 2585 2586 2587 2588 2589 2590 2591 2592 2593 2594 const requiredConsent = 'I acknowledge that using private APIs means my theme or plugin will inevitably break in the next version of WordPress.'; 2595 const privateApis = lock => { 2596 if (lock === requiredConsent) { 2597 return { 2598 directivePrefix: directivePrefix, 2599 getRegionRootFragment: getRegionRootFragment, 2600 initialVdom: initialVdom, 2601 toVdom: toVdom, 2602 directive: directive, 2603 getNamespace: getNamespace, 2604 h: preact_module.h, 2605 cloneElement: preact_module/* cloneElement */.Ob, 2606 render: preact_module/* render */.XX, 2607 proxifyState: proxifyState, 2608 parseServerData: parseServerData, 2609 populateServerData: populateServerData, 2610 batch: signals_core_module_r 2611 }; 2612 } 2613 throw new Error('Forbidden access.'); 2614 }; 2615 directives(); 2616 init(); 2617 2618 var __webpack_exports__getConfig = __webpack_exports__.zj; 2619 var __webpack_exports__getContext = __webpack_exports__.SD; 2620 var __webpack_exports__getElement = __webpack_exports__.V6; 2621 var __webpack_exports__getServerContext = __webpack_exports__.$K; 2622 var __webpack_exports__getServerState = __webpack_exports__.vT; 2623 var __webpack_exports__privateApis = __webpack_exports__.jb; 2624 var __webpack_exports__splitTask = __webpack_exports__.yT; 2625 var __webpack_exports__store = __webpack_exports__.M_; 2626 var __webpack_exports__useCallback = __webpack_exports__.hb; 2627 var __webpack_exports__useEffect = __webpack_exports__.vJ; 2628 var __webpack_exports__useInit = __webpack_exports__.ip; 2629 var __webpack_exports__useLayoutEffect = __webpack_exports__.Nf; 2630 var __webpack_exports__useMemo = __webpack_exports__.Kr; 2631 var __webpack_exports__useRef = __webpack_exports__.li; 2632 var __webpack_exports__useState = __webpack_exports__.J0; 2633 var __webpack_exports__useWatch = __webpack_exports__.FH; 2634 var __webpack_exports__withScope = __webpack_exports__.v4; 2635 var __webpack_exports__withSyncEvent = __webpack_exports__.mh; 2636 export { __webpack_exports__getConfig as getConfig, __webpack_exports__getContext as getContext, __webpack_exports__getElement as getElement, __webpack_exports__getServerContext as getServerContext, __webpack_exports__getServerState as getServerState, __webpack_exports__privateApis as privateApis, __webpack_exports__splitTask as splitTask, __webpack_exports__store as store, __webpack_exports__useCallback as useCallback, __webpack_exports__useEffect as useEffect, __webpack_exports__useInit as useInit, __webpack_exports__useLayoutEffect as useLayoutEffect, __webpack_exports__useMemo as useMemo, __webpack_exports__useRef as useRef, __webpack_exports__useState as useState, __webpack_exports__useWatch as useWatch, __webpack_exports__withScope as withScope, __webpack_exports__withSyncEvent as withSyncEvent };
title
Description
Body
title
Description
Body
title
Description
Body
title
Body
Generated : Thu Apr 3 08:20:01 2025 | Cross-referenced by PHPXref |