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