[ Index ] |
PHP Cross Reference of WordPress Trunk (Updated Daily) |
[Summary view] [Print] [Text view]
1 /******/ (() => { // webpackBootstrap 2 /******/ "use strict"; 3 /******/ var __webpack_modules__ = ({ 4 5 /***/ 66: 6 /***/ ((module) => { 7 8 9 10 var isMergeableObject = function isMergeableObject(value) { 11 return isNonNullObject(value) 12 && !isSpecial(value) 13 }; 14 15 function isNonNullObject(value) { 16 return !!value && typeof value === 'object' 17 } 18 19 function isSpecial(value) { 20 var stringValue = Object.prototype.toString.call(value); 21 22 return stringValue === '[object RegExp]' 23 || stringValue === '[object Date]' 24 || isReactElement(value) 25 } 26 27 // see https://github.com/facebook/react/blob/b5ac963fb791d1298e7f396236383bc955f916c1/src/isomorphic/classic/element/ReactElement.js#L21-L25 28 var canUseSymbol = typeof Symbol === 'function' && Symbol.for; 29 var REACT_ELEMENT_TYPE = canUseSymbol ? Symbol.for('react.element') : 0xeac7; 30 31 function isReactElement(value) { 32 return value.$$typeof === REACT_ELEMENT_TYPE 33 } 34 35 function emptyTarget(val) { 36 return Array.isArray(val) ? [] : {} 37 } 38 39 function cloneUnlessOtherwiseSpecified(value, options) { 40 return (options.clone !== false && options.isMergeableObject(value)) 41 ? deepmerge(emptyTarget(value), value, options) 42 : value 43 } 44 45 function defaultArrayMerge(target, source, options) { 46 return target.concat(source).map(function(element) { 47 return cloneUnlessOtherwiseSpecified(element, options) 48 }) 49 } 50 51 function getMergeFunction(key, options) { 52 if (!options.customMerge) { 53 return deepmerge 54 } 55 var customMerge = options.customMerge(key); 56 return typeof customMerge === 'function' ? customMerge : deepmerge 57 } 58 59 function getEnumerableOwnPropertySymbols(target) { 60 return Object.getOwnPropertySymbols 61 ? Object.getOwnPropertySymbols(target).filter(function(symbol) { 62 return Object.propertyIsEnumerable.call(target, symbol) 63 }) 64 : [] 65 } 66 67 function getKeys(target) { 68 return Object.keys(target).concat(getEnumerableOwnPropertySymbols(target)) 69 } 70 71 function propertyIsOnObject(object, property) { 72 try { 73 return property in object 74 } catch(_) { 75 return false 76 } 77 } 78 79 // Protects from prototype poisoning and unexpected merging up the prototype chain. 80 function propertyIsUnsafe(target, key) { 81 return propertyIsOnObject(target, key) // Properties are safe to merge if they don't exist in the target yet, 82 && !(Object.hasOwnProperty.call(target, key) // unsafe if they exist up the prototype chain, 83 && Object.propertyIsEnumerable.call(target, key)) // and also unsafe if they're nonenumerable. 84 } 85 86 function mergeObject(target, source, options) { 87 var destination = {}; 88 if (options.isMergeableObject(target)) { 89 getKeys(target).forEach(function(key) { 90 destination[key] = cloneUnlessOtherwiseSpecified(target[key], options); 91 }); 92 } 93 getKeys(source).forEach(function(key) { 94 if (propertyIsUnsafe(target, key)) { 95 return 96 } 97 98 if (propertyIsOnObject(target, key) && options.isMergeableObject(source[key])) { 99 destination[key] = getMergeFunction(key, options)(target[key], source[key], options); 100 } else { 101 destination[key] = cloneUnlessOtherwiseSpecified(source[key], options); 102 } 103 }); 104 return destination 105 } 106 107 function deepmerge(target, source, options) { 108 options = options || {}; 109 options.arrayMerge = options.arrayMerge || defaultArrayMerge; 110 options.isMergeableObject = options.isMergeableObject || isMergeableObject; 111 // cloneUnlessOtherwiseSpecified is added to `options` so that custom arrayMerge() 112 // implementations can use it. The caller may not replace it. 113 options.cloneUnlessOtherwiseSpecified = cloneUnlessOtherwiseSpecified; 114 115 var sourceIsArray = Array.isArray(source); 116 var targetIsArray = Array.isArray(target); 117 var sourceAndTargetTypesMatch = sourceIsArray === targetIsArray; 118 119 if (!sourceAndTargetTypesMatch) { 120 return cloneUnlessOtherwiseSpecified(source, options) 121 } else if (sourceIsArray) { 122 return options.arrayMerge(target, source, options) 123 } else { 124 return mergeObject(target, source, options) 125 } 126 } 127 128 deepmerge.all = function deepmergeAll(array, options) { 129 if (!Array.isArray(array)) { 130 throw new Error('first argument should be an array') 131 } 132 133 return array.reduce(function(prev, next) { 134 return deepmerge(prev, next, options) 135 }, {}) 136 }; 137 138 var deepmerge_1 = deepmerge; 139 140 module.exports = deepmerge_1; 141 142 143 /***/ }), 144 145 /***/ 3249: 146 /***/ ((module) => { 147 148 149 150 function _typeof(obj) { 151 if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { 152 _typeof = function (obj) { 153 return typeof obj; 154 }; 155 } else { 156 _typeof = function (obj) { 157 return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; 158 }; 159 } 160 161 return _typeof(obj); 162 } 163 164 function _classCallCheck(instance, Constructor) { 165 if (!(instance instanceof Constructor)) { 166 throw new TypeError("Cannot call a class as a function"); 167 } 168 } 169 170 function _defineProperties(target, props) { 171 for (var i = 0; i < props.length; i++) { 172 var descriptor = props[i]; 173 descriptor.enumerable = descriptor.enumerable || false; 174 descriptor.configurable = true; 175 if ("value" in descriptor) descriptor.writable = true; 176 Object.defineProperty(target, descriptor.key, descriptor); 177 } 178 } 179 180 function _createClass(Constructor, protoProps, staticProps) { 181 if (protoProps) _defineProperties(Constructor.prototype, protoProps); 182 if (staticProps) _defineProperties(Constructor, staticProps); 183 return Constructor; 184 } 185 186 /** 187 * Given an instance of EquivalentKeyMap, returns its internal value pair tuple 188 * for a key, if one exists. The tuple members consist of the last reference 189 * value for the key (used in efficient subsequent lookups) and the value 190 * assigned for the key at the leaf node. 191 * 192 * @param {EquivalentKeyMap} instance EquivalentKeyMap instance. 193 * @param {*} key The key for which to return value pair. 194 * 195 * @return {?Array} Value pair, if exists. 196 */ 197 function getValuePair(instance, key) { 198 var _map = instance._map, 199 _arrayTreeMap = instance._arrayTreeMap, 200 _objectTreeMap = instance._objectTreeMap; // Map keeps a reference to the last object-like key used to set the 201 // value, which can be used to shortcut immediately to the value. 202 203 if (_map.has(key)) { 204 return _map.get(key); 205 } // Sort keys to ensure stable retrieval from tree. 206 207 208 var properties = Object.keys(key).sort(); // Tree by type to avoid conflicts on numeric object keys, empty value. 209 210 var map = Array.isArray(key) ? _arrayTreeMap : _objectTreeMap; 211 212 for (var i = 0; i < properties.length; i++) { 213 var property = properties[i]; 214 map = map.get(property); 215 216 if (map === undefined) { 217 return; 218 } 219 220 var propertyValue = key[property]; 221 map = map.get(propertyValue); 222 223 if (map === undefined) { 224 return; 225 } 226 } 227 228 var valuePair = map.get('_ekm_value'); 229 230 if (!valuePair) { 231 return; 232 } // If reached, it implies that an object-like key was set with another 233 // reference, so delete the reference and replace with the current. 234 235 236 _map.delete(valuePair[0]); 237 238 valuePair[0] = key; 239 map.set('_ekm_value', valuePair); 240 241 _map.set(key, valuePair); 242 243 return valuePair; 244 } 245 /** 246 * Variant of a Map object which enables lookup by equivalent (deeply equal) 247 * object and array keys. 248 */ 249 250 251 var EquivalentKeyMap = 252 /*#__PURE__*/ 253 function () { 254 /** 255 * Constructs a new instance of EquivalentKeyMap. 256 * 257 * @param {Iterable.<*>} iterable Initial pair of key, value for map. 258 */ 259 function EquivalentKeyMap(iterable) { 260 _classCallCheck(this, EquivalentKeyMap); 261 262 this.clear(); 263 264 if (iterable instanceof EquivalentKeyMap) { 265 // Map#forEach is only means of iterating with support for IE11. 266 var iterablePairs = []; 267 iterable.forEach(function (value, key) { 268 iterablePairs.push([key, value]); 269 }); 270 iterable = iterablePairs; 271 } 272 273 if (iterable != null) { 274 for (var i = 0; i < iterable.length; i++) { 275 this.set(iterable[i][0], iterable[i][1]); 276 } 277 } 278 } 279 /** 280 * Accessor property returning the number of elements. 281 * 282 * @return {number} Number of elements. 283 */ 284 285 286 _createClass(EquivalentKeyMap, [{ 287 key: "set", 288 289 /** 290 * Add or update an element with a specified key and value. 291 * 292 * @param {*} key The key of the element to add. 293 * @param {*} value The value of the element to add. 294 * 295 * @return {EquivalentKeyMap} Map instance. 296 */ 297 value: function set(key, value) { 298 // Shortcut non-object-like to set on internal Map. 299 if (key === null || _typeof(key) !== 'object') { 300 this._map.set(key, value); 301 302 return this; 303 } // Sort keys to ensure stable assignment into tree. 304 305 306 var properties = Object.keys(key).sort(); 307 var valuePair = [key, value]; // Tree by type to avoid conflicts on numeric object keys, empty value. 308 309 var map = Array.isArray(key) ? this._arrayTreeMap : this._objectTreeMap; 310 311 for (var i = 0; i < properties.length; i++) { 312 var property = properties[i]; 313 314 if (!map.has(property)) { 315 map.set(property, new EquivalentKeyMap()); 316 } 317 318 map = map.get(property); 319 var propertyValue = key[property]; 320 321 if (!map.has(propertyValue)) { 322 map.set(propertyValue, new EquivalentKeyMap()); 323 } 324 325 map = map.get(propertyValue); 326 } // If an _ekm_value exists, there was already an equivalent key. Before 327 // overriding, ensure that the old key reference is removed from map to 328 // avoid memory leak of accumulating equivalent keys. This is, in a 329 // sense, a poor man's WeakMap, while still enabling iterability. 330 331 332 var previousValuePair = map.get('_ekm_value'); 333 334 if (previousValuePair) { 335 this._map.delete(previousValuePair[0]); 336 } 337 338 map.set('_ekm_value', valuePair); 339 340 this._map.set(key, valuePair); 341 342 return this; 343 } 344 /** 345 * Returns a specified element. 346 * 347 * @param {*} key The key of the element to return. 348 * 349 * @return {?*} The element associated with the specified key or undefined 350 * if the key can't be found. 351 */ 352 353 }, { 354 key: "get", 355 value: function get(key) { 356 // Shortcut non-object-like to get from internal Map. 357 if (key === null || _typeof(key) !== 'object') { 358 return this._map.get(key); 359 } 360 361 var valuePair = getValuePair(this, key); 362 363 if (valuePair) { 364 return valuePair[1]; 365 } 366 } 367 /** 368 * Returns a boolean indicating whether an element with the specified key 369 * exists or not. 370 * 371 * @param {*} key The key of the element to test for presence. 372 * 373 * @return {boolean} Whether an element with the specified key exists. 374 */ 375 376 }, { 377 key: "has", 378 value: function has(key) { 379 if (key === null || _typeof(key) !== 'object') { 380 return this._map.has(key); 381 } // Test on the _presence_ of the pair, not its value, as even undefined 382 // can be a valid member value for a key. 383 384 385 return getValuePair(this, key) !== undefined; 386 } 387 /** 388 * Removes the specified element. 389 * 390 * @param {*} key The key of the element to remove. 391 * 392 * @return {boolean} Returns true if an element existed and has been 393 * removed, or false if the element does not exist. 394 */ 395 396 }, { 397 key: "delete", 398 value: function _delete(key) { 399 if (!this.has(key)) { 400 return false; 401 } // This naive implementation will leave orphaned child trees. A better 402 // implementation should traverse and remove orphans. 403 404 405 this.set(key, undefined); 406 return true; 407 } 408 /** 409 * Executes a provided function once per each key/value pair, in insertion 410 * order. 411 * 412 * @param {Function} callback Function to execute for each element. 413 * @param {*} thisArg Value to use as `this` when executing 414 * `callback`. 415 */ 416 417 }, { 418 key: "forEach", 419 value: function forEach(callback) { 420 var _this = this; 421 422 var thisArg = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : this; 423 424 this._map.forEach(function (value, key) { 425 // Unwrap value from object-like value pair. 426 if (key !== null && _typeof(key) === 'object') { 427 value = value[1]; 428 } 429 430 callback.call(thisArg, value, key, _this); 431 }); 432 } 433 /** 434 * Removes all elements. 435 */ 436 437 }, { 438 key: "clear", 439 value: function clear() { 440 this._map = new Map(); 441 this._arrayTreeMap = new Map(); 442 this._objectTreeMap = new Map(); 443 } 444 }, { 445 key: "size", 446 get: function get() { 447 return this._map.size; 448 } 449 }]); 450 451 return EquivalentKeyMap; 452 }(); 453 454 module.exports = EquivalentKeyMap; 455 456 457 /***/ }) 458 459 /******/ }); 460 /************************************************************************/ 461 /******/ // The module cache 462 /******/ var __webpack_module_cache__ = {}; 463 /******/ 464 /******/ // The require function 465 /******/ function __webpack_require__(moduleId) { 466 /******/ // Check if module is in cache 467 /******/ var cachedModule = __webpack_module_cache__[moduleId]; 468 /******/ if (cachedModule !== undefined) { 469 /******/ return cachedModule.exports; 470 /******/ } 471 /******/ // Create a new module (and put it into the cache) 472 /******/ var module = __webpack_module_cache__[moduleId] = { 473 /******/ // no module.id needed 474 /******/ // no module.loaded needed 475 /******/ exports: {} 476 /******/ }; 477 /******/ 478 /******/ // Execute the module function 479 /******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__); 480 /******/ 481 /******/ // Return the exports of the module 482 /******/ return module.exports; 483 /******/ } 484 /******/ 485 /************************************************************************/ 486 /******/ /* webpack/runtime/compat get default export */ 487 /******/ (() => { 488 /******/ // getDefaultExport function for compatibility with non-harmony modules 489 /******/ __webpack_require__.n = (module) => { 490 /******/ var getter = module && module.__esModule ? 491 /******/ () => (module['default']) : 492 /******/ () => (module); 493 /******/ __webpack_require__.d(getter, { a: getter }); 494 /******/ return getter; 495 /******/ }; 496 /******/ })(); 497 /******/ 498 /******/ /* webpack/runtime/define property getters */ 499 /******/ (() => { 500 /******/ // define getter functions for harmony exports 501 /******/ __webpack_require__.d = (exports, definition) => { 502 /******/ for(var key in definition) { 503 /******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { 504 /******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); 505 /******/ } 506 /******/ } 507 /******/ }; 508 /******/ })(); 509 /******/ 510 /******/ /* webpack/runtime/hasOwnProperty shorthand */ 511 /******/ (() => { 512 /******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop)) 513 /******/ })(); 514 /******/ 515 /******/ /* webpack/runtime/make namespace object */ 516 /******/ (() => { 517 /******/ // define __esModule on exports 518 /******/ __webpack_require__.r = (exports) => { 519 /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { 520 /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); 521 /******/ } 522 /******/ Object.defineProperty(exports, '__esModule', { value: true }); 523 /******/ }; 524 /******/ })(); 525 /******/ 526 /************************************************************************/ 527 var __webpack_exports__ = {}; 528 // ESM COMPAT FLAG 529 __webpack_require__.r(__webpack_exports__); 530 531 // EXPORTS 532 __webpack_require__.d(__webpack_exports__, { 533 AsyncModeProvider: () => (/* reexport */ async_mode_provider_context), 534 RegistryConsumer: () => (/* reexport */ RegistryConsumer), 535 RegistryProvider: () => (/* reexport */ context), 536 combineReducers: () => (/* binding */ build_module_combineReducers), 537 controls: () => (/* reexport */ controls), 538 createReduxStore: () => (/* reexport */ createReduxStore), 539 createRegistry: () => (/* reexport */ createRegistry), 540 createRegistryControl: () => (/* reexport */ createRegistryControl), 541 createRegistrySelector: () => (/* reexport */ createRegistrySelector), 542 createSelector: () => (/* reexport */ rememo), 543 dispatch: () => (/* reexport */ dispatch_dispatch), 544 plugins: () => (/* reexport */ plugins_namespaceObject), 545 register: () => (/* binding */ register), 546 registerGenericStore: () => (/* binding */ registerGenericStore), 547 registerStore: () => (/* binding */ registerStore), 548 resolveSelect: () => (/* binding */ build_module_resolveSelect), 549 select: () => (/* reexport */ select_select), 550 subscribe: () => (/* binding */ subscribe), 551 suspendSelect: () => (/* binding */ suspendSelect), 552 use: () => (/* binding */ use), 553 useDispatch: () => (/* reexport */ use_dispatch), 554 useRegistry: () => (/* reexport */ useRegistry), 555 useSelect: () => (/* reexport */ useSelect), 556 useSuspenseSelect: () => (/* reexport */ useSuspenseSelect), 557 withDispatch: () => (/* reexport */ with_dispatch), 558 withRegistry: () => (/* reexport */ with_registry), 559 withSelect: () => (/* reexport */ with_select) 560 }); 561 562 // NAMESPACE OBJECT: ./node_modules/@wordpress/data/build-module/redux-store/metadata/selectors.js 563 var selectors_namespaceObject = {}; 564 __webpack_require__.r(selectors_namespaceObject); 565 __webpack_require__.d(selectors_namespaceObject, { 566 countSelectorsByStatus: () => (countSelectorsByStatus), 567 getCachedResolvers: () => (getCachedResolvers), 568 getIsResolving: () => (getIsResolving), 569 getResolutionError: () => (getResolutionError), 570 getResolutionState: () => (getResolutionState), 571 hasFinishedResolution: () => (hasFinishedResolution), 572 hasResolutionFailed: () => (hasResolutionFailed), 573 hasResolvingSelectors: () => (hasResolvingSelectors), 574 hasStartedResolution: () => (hasStartedResolution), 575 isResolving: () => (isResolving) 576 }); 577 578 // NAMESPACE OBJECT: ./node_modules/@wordpress/data/build-module/redux-store/metadata/actions.js 579 var actions_namespaceObject = {}; 580 __webpack_require__.r(actions_namespaceObject); 581 __webpack_require__.d(actions_namespaceObject, { 582 failResolution: () => (failResolution), 583 failResolutions: () => (failResolutions), 584 finishResolution: () => (finishResolution), 585 finishResolutions: () => (finishResolutions), 586 invalidateResolution: () => (invalidateResolution), 587 invalidateResolutionForStore: () => (invalidateResolutionForStore), 588 invalidateResolutionForStoreSelector: () => (invalidateResolutionForStoreSelector), 589 startResolution: () => (startResolution), 590 startResolutions: () => (startResolutions) 591 }); 592 593 // NAMESPACE OBJECT: ./node_modules/@wordpress/data/build-module/plugins/index.js 594 var plugins_namespaceObject = {}; 595 __webpack_require__.r(plugins_namespaceObject); 596 __webpack_require__.d(plugins_namespaceObject, { 597 persistence: () => (persistence) 598 }); 599 600 ;// external ["wp","deprecated"] 601 const external_wp_deprecated_namespaceObject = window["wp"]["deprecated"]; 602 var external_wp_deprecated_default = /*#__PURE__*/__webpack_require__.n(external_wp_deprecated_namespaceObject); 603 ;// ./node_modules/@babel/runtime/helpers/esm/typeof.js 604 function _typeof(o) { 605 "@babel/helpers - typeof"; 606 607 return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { 608 return typeof o; 609 } : function (o) { 610 return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; 611 }, _typeof(o); 612 } 613 ;// ./node_modules/@babel/runtime/helpers/esm/toPrimitive.js 614 615 function _toPrimitive(input, hint) { 616 if (_typeof(input) !== "object" || input === null) return input; 617 var prim = input[Symbol.toPrimitive]; 618 if (prim !== undefined) { 619 var res = prim.call(input, hint || "default"); 620 if (_typeof(res) !== "object") return res; 621 throw new TypeError("@@toPrimitive must return a primitive value."); 622 } 623 return (hint === "string" ? String : Number)(input); 624 } 625 ;// ./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js 626 627 628 function _toPropertyKey(arg) { 629 var key = _toPrimitive(arg, "string"); 630 return _typeof(key) === "symbol" ? key : String(key); 631 } 632 ;// ./node_modules/@babel/runtime/helpers/esm/defineProperty.js 633 634 function _defineProperty(obj, key, value) { 635 key = _toPropertyKey(key); 636 if (key in obj) { 637 Object.defineProperty(obj, key, { 638 value: value, 639 enumerable: true, 640 configurable: true, 641 writable: true 642 }); 643 } else { 644 obj[key] = value; 645 } 646 return obj; 647 } 648 ;// ./node_modules/@babel/runtime/helpers/esm/objectSpread2.js 649 650 function ownKeys(e, r) { 651 var t = Object.keys(e); 652 if (Object.getOwnPropertySymbols) { 653 var o = Object.getOwnPropertySymbols(e); 654 r && (o = o.filter(function (r) { 655 return Object.getOwnPropertyDescriptor(e, r).enumerable; 656 })), t.push.apply(t, o); 657 } 658 return t; 659 } 660 function _objectSpread2(e) { 661 for (var r = 1; r < arguments.length; r++) { 662 var t = null != arguments[r] ? arguments[r] : {}; 663 r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { 664 _defineProperty(e, r, t[r]); 665 }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { 666 Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); 667 }); 668 } 669 return e; 670 } 671 ;// ./node_modules/redux/es/redux.js 672 673 674 /** 675 * Adapted from React: https://github.com/facebook/react/blob/master/packages/shared/formatProdErrorMessage.js 676 * 677 * Do not require this module directly! Use normal throw error calls. These messages will be replaced with error codes 678 * during build. 679 * @param {number} code 680 */ 681 function formatProdErrorMessage(code) { 682 return "Minified Redux error #" + code + "; visit https://redux.js.org/Errors?code=" + code + " for the full message or " + 'use the non-minified dev environment for full errors. '; 683 } 684 685 // Inlined version of the `symbol-observable` polyfill 686 var $$observable = (function () { 687 return typeof Symbol === 'function' && Symbol.observable || '@@observable'; 688 })(); 689 690 /** 691 * These are private action types reserved by Redux. 692 * For any unknown actions, you must return the current state. 693 * If the current state is undefined, you must return the initial state. 694 * Do not reference these action types directly in your code. 695 */ 696 var randomString = function randomString() { 697 return Math.random().toString(36).substring(7).split('').join('.'); 698 }; 699 700 var ActionTypes = { 701 INIT: "@@redux/INIT" + randomString(), 702 REPLACE: "@@redux/REPLACE" + randomString(), 703 PROBE_UNKNOWN_ACTION: function PROBE_UNKNOWN_ACTION() { 704 return "@@redux/PROBE_UNKNOWN_ACTION" + randomString(); 705 } 706 }; 707 708 /** 709 * @param {any} obj The object to inspect. 710 * @returns {boolean} True if the argument appears to be a plain object. 711 */ 712 function isPlainObject(obj) { 713 if (typeof obj !== 'object' || obj === null) return false; 714 var proto = obj; 715 716 while (Object.getPrototypeOf(proto) !== null) { 717 proto = Object.getPrototypeOf(proto); 718 } 719 720 return Object.getPrototypeOf(obj) === proto; 721 } 722 723 // Inlined / shortened version of `kindOf` from https://github.com/jonschlinkert/kind-of 724 function miniKindOf(val) { 725 if (val === void 0) return 'undefined'; 726 if (val === null) return 'null'; 727 var type = typeof val; 728 729 switch (type) { 730 case 'boolean': 731 case 'string': 732 case 'number': 733 case 'symbol': 734 case 'function': 735 { 736 return type; 737 } 738 } 739 740 if (Array.isArray(val)) return 'array'; 741 if (isDate(val)) return 'date'; 742 if (isError(val)) return 'error'; 743 var constructorName = ctorName(val); 744 745 switch (constructorName) { 746 case 'Symbol': 747 case 'Promise': 748 case 'WeakMap': 749 case 'WeakSet': 750 case 'Map': 751 case 'Set': 752 return constructorName; 753 } // other 754 755 756 return type.slice(8, -1).toLowerCase().replace(/\s/g, ''); 757 } 758 759 function ctorName(val) { 760 return typeof val.constructor === 'function' ? val.constructor.name : null; 761 } 762 763 function isError(val) { 764 return val instanceof Error || typeof val.message === 'string' && val.constructor && typeof val.constructor.stackTraceLimit === 'number'; 765 } 766 767 function isDate(val) { 768 if (val instanceof Date) return true; 769 return typeof val.toDateString === 'function' && typeof val.getDate === 'function' && typeof val.setDate === 'function'; 770 } 771 772 function kindOf(val) { 773 var typeOfVal = typeof val; 774 775 if (false) {} 776 777 return typeOfVal; 778 } 779 780 /** 781 * @deprecated 782 * 783 * **We recommend using the `configureStore` method 784 * of the `@reduxjs/toolkit` package**, which replaces `createStore`. 785 * 786 * Redux Toolkit is our recommended approach for writing Redux logic today, 787 * including store setup, reducers, data fetching, and more. 788 * 789 * **For more details, please read this Redux docs page:** 790 * **https://redux.js.org/introduction/why-rtk-is-redux-today** 791 * 792 * `configureStore` from Redux Toolkit is an improved version of `createStore` that 793 * simplifies setup and helps avoid common bugs. 794 * 795 * You should not be using the `redux` core package by itself today, except for learning purposes. 796 * The `createStore` method from the core `redux` package will not be removed, but we encourage 797 * all users to migrate to using Redux Toolkit for all Redux code. 798 * 799 * If you want to use `createStore` without this visual deprecation warning, use 800 * the `legacy_createStore` import instead: 801 * 802 * `import { legacy_createStore as createStore} from 'redux'` 803 * 804 */ 805 806 function createStore(reducer, preloadedState, enhancer) { 807 var _ref2; 808 809 if (typeof preloadedState === 'function' && typeof enhancer === 'function' || typeof enhancer === 'function' && typeof arguments[3] === 'function') { 810 throw new Error( true ? formatProdErrorMessage(0) : 0); 811 } 812 813 if (typeof preloadedState === 'function' && typeof enhancer === 'undefined') { 814 enhancer = preloadedState; 815 preloadedState = undefined; 816 } 817 818 if (typeof enhancer !== 'undefined') { 819 if (typeof enhancer !== 'function') { 820 throw new Error( true ? formatProdErrorMessage(1) : 0); 821 } 822 823 return enhancer(createStore)(reducer, preloadedState); 824 } 825 826 if (typeof reducer !== 'function') { 827 throw new Error( true ? formatProdErrorMessage(2) : 0); 828 } 829 830 var currentReducer = reducer; 831 var currentState = preloadedState; 832 var currentListeners = []; 833 var nextListeners = currentListeners; 834 var isDispatching = false; 835 /** 836 * This makes a shallow copy of currentListeners so we can use 837 * nextListeners as a temporary list while dispatching. 838 * 839 * This prevents any bugs around consumers calling 840 * subscribe/unsubscribe in the middle of a dispatch. 841 */ 842 843 function ensureCanMutateNextListeners() { 844 if (nextListeners === currentListeners) { 845 nextListeners = currentListeners.slice(); 846 } 847 } 848 /** 849 * Reads the state tree managed by the store. 850 * 851 * @returns {any} The current state tree of your application. 852 */ 853 854 855 function getState() { 856 if (isDispatching) { 857 throw new Error( true ? formatProdErrorMessage(3) : 0); 858 } 859 860 return currentState; 861 } 862 /** 863 * Adds a change listener. It will be called any time an action is dispatched, 864 * and some part of the state tree may potentially have changed. You may then 865 * call `getState()` to read the current state tree inside the callback. 866 * 867 * You may call `dispatch()` from a change listener, with the following 868 * caveats: 869 * 870 * 1. The subscriptions are snapshotted just before every `dispatch()` call. 871 * If you subscribe or unsubscribe while the listeners are being invoked, this 872 * will not have any effect on the `dispatch()` that is currently in progress. 873 * However, the next `dispatch()` call, whether nested or not, will use a more 874 * recent snapshot of the subscription list. 875 * 876 * 2. The listener should not expect to see all state changes, as the state 877 * might have been updated multiple times during a nested `dispatch()` before 878 * the listener is called. It is, however, guaranteed that all subscribers 879 * registered before the `dispatch()` started will be called with the latest 880 * state by the time it exits. 881 * 882 * @param {Function} listener A callback to be invoked on every dispatch. 883 * @returns {Function} A function to remove this change listener. 884 */ 885 886 887 function subscribe(listener) { 888 if (typeof listener !== 'function') { 889 throw new Error( true ? formatProdErrorMessage(4) : 0); 890 } 891 892 if (isDispatching) { 893 throw new Error( true ? formatProdErrorMessage(5) : 0); 894 } 895 896 var isSubscribed = true; 897 ensureCanMutateNextListeners(); 898 nextListeners.push(listener); 899 return function unsubscribe() { 900 if (!isSubscribed) { 901 return; 902 } 903 904 if (isDispatching) { 905 throw new Error( true ? formatProdErrorMessage(6) : 0); 906 } 907 908 isSubscribed = false; 909 ensureCanMutateNextListeners(); 910 var index = nextListeners.indexOf(listener); 911 nextListeners.splice(index, 1); 912 currentListeners = null; 913 }; 914 } 915 /** 916 * Dispatches an action. It is the only way to trigger a state change. 917 * 918 * The `reducer` function, used to create the store, will be called with the 919 * current state tree and the given `action`. Its return value will 920 * be considered the **next** state of the tree, and the change listeners 921 * will be notified. 922 * 923 * The base implementation only supports plain object actions. If you want to 924 * dispatch a Promise, an Observable, a thunk, or something else, you need to 925 * wrap your store creating function into the corresponding middleware. For 926 * example, see the documentation for the `redux-thunk` package. Even the 927 * middleware will eventually dispatch plain object actions using this method. 928 * 929 * @param {Object} action A plain object representing “what changed”. It is 930 * a good idea to keep actions serializable so you can record and replay user 931 * sessions, or use the time travelling `redux-devtools`. An action must have 932 * a `type` property which may not be `undefined`. It is a good idea to use 933 * string constants for action types. 934 * 935 * @returns {Object} For convenience, the same action object you dispatched. 936 * 937 * Note that, if you use a custom middleware, it may wrap `dispatch()` to 938 * return something else (for example, a Promise you can await). 939 */ 940 941 942 function dispatch(action) { 943 if (!isPlainObject(action)) { 944 throw new Error( true ? formatProdErrorMessage(7) : 0); 945 } 946 947 if (typeof action.type === 'undefined') { 948 throw new Error( true ? formatProdErrorMessage(8) : 0); 949 } 950 951 if (isDispatching) { 952 throw new Error( true ? formatProdErrorMessage(9) : 0); 953 } 954 955 try { 956 isDispatching = true; 957 currentState = currentReducer(currentState, action); 958 } finally { 959 isDispatching = false; 960 } 961 962 var listeners = currentListeners = nextListeners; 963 964 for (var i = 0; i < listeners.length; i++) { 965 var listener = listeners[i]; 966 listener(); 967 } 968 969 return action; 970 } 971 /** 972 * Replaces the reducer currently used by the store to calculate the state. 973 * 974 * You might need this if your app implements code splitting and you want to 975 * load some of the reducers dynamically. You might also need this if you 976 * implement a hot reloading mechanism for Redux. 977 * 978 * @param {Function} nextReducer The reducer for the store to use instead. 979 * @returns {void} 980 */ 981 982 983 function replaceReducer(nextReducer) { 984 if (typeof nextReducer !== 'function') { 985 throw new Error( true ? formatProdErrorMessage(10) : 0); 986 } 987 988 currentReducer = nextReducer; // This action has a similiar effect to ActionTypes.INIT. 989 // Any reducers that existed in both the new and old rootReducer 990 // will receive the previous state. This effectively populates 991 // the new state tree with any relevant data from the old one. 992 993 dispatch({ 994 type: ActionTypes.REPLACE 995 }); 996 } 997 /** 998 * Interoperability point for observable/reactive libraries. 999 * @returns {observable} A minimal observable of state changes. 1000 * For more information, see the observable proposal: 1001 * https://github.com/tc39/proposal-observable 1002 */ 1003 1004 1005 function observable() { 1006 var _ref; 1007 1008 var outerSubscribe = subscribe; 1009 return _ref = { 1010 /** 1011 * The minimal observable subscription method. 1012 * @param {Object} observer Any object that can be used as an observer. 1013 * The observer object should have a `next` method. 1014 * @returns {subscription} An object with an `unsubscribe` method that can 1015 * be used to unsubscribe the observable from the store, and prevent further 1016 * emission of values from the observable. 1017 */ 1018 subscribe: function subscribe(observer) { 1019 if (typeof observer !== 'object' || observer === null) { 1020 throw new Error( true ? formatProdErrorMessage(11) : 0); 1021 } 1022 1023 function observeState() { 1024 if (observer.next) { 1025 observer.next(getState()); 1026 } 1027 } 1028 1029 observeState(); 1030 var unsubscribe = outerSubscribe(observeState); 1031 return { 1032 unsubscribe: unsubscribe 1033 }; 1034 } 1035 }, _ref[$$observable] = function () { 1036 return this; 1037 }, _ref; 1038 } // When a store is created, an "INIT" action is dispatched so that every 1039 // reducer returns their initial state. This effectively populates 1040 // the initial state tree. 1041 1042 1043 dispatch({ 1044 type: ActionTypes.INIT 1045 }); 1046 return _ref2 = { 1047 dispatch: dispatch, 1048 subscribe: subscribe, 1049 getState: getState, 1050 replaceReducer: replaceReducer 1051 }, _ref2[$$observable] = observable, _ref2; 1052 } 1053 /** 1054 * Creates a Redux store that holds the state tree. 1055 * 1056 * **We recommend using `configureStore` from the 1057 * `@reduxjs/toolkit` package**, which replaces `createStore`: 1058 * **https://redux.js.org/introduction/why-rtk-is-redux-today** 1059 * 1060 * The only way to change the data in the store is to call `dispatch()` on it. 1061 * 1062 * There should only be a single store in your app. To specify how different 1063 * parts of the state tree respond to actions, you may combine several reducers 1064 * into a single reducer function by using `combineReducers`. 1065 * 1066 * @param {Function} reducer A function that returns the next state tree, given 1067 * the current state tree and the action to handle. 1068 * 1069 * @param {any} [preloadedState] The initial state. You may optionally specify it 1070 * to hydrate the state from the server in universal apps, or to restore a 1071 * previously serialized user session. 1072 * If you use `combineReducers` to produce the root reducer function, this must be 1073 * an object with the same shape as `combineReducers` keys. 1074 * 1075 * @param {Function} [enhancer] The store enhancer. You may optionally specify it 1076 * to enhance the store with third-party capabilities such as middleware, 1077 * time travel, persistence, etc. The only store enhancer that ships with Redux 1078 * is `applyMiddleware()`. 1079 * 1080 * @returns {Store} A Redux store that lets you read the state, dispatch actions 1081 * and subscribe to changes. 1082 */ 1083 1084 var legacy_createStore = (/* unused pure expression or super */ null && (createStore)); 1085 1086 /** 1087 * Prints a warning in the console if it exists. 1088 * 1089 * @param {String} message The warning message. 1090 * @returns {void} 1091 */ 1092 function warning(message) { 1093 /* eslint-disable no-console */ 1094 if (typeof console !== 'undefined' && typeof console.error === 'function') { 1095 console.error(message); 1096 } 1097 /* eslint-enable no-console */ 1098 1099 1100 try { 1101 // This error was thrown as a convenience so that if you enable 1102 // "break on all exceptions" in your console, 1103 // it would pause the execution at this line. 1104 throw new Error(message); 1105 } catch (e) {} // eslint-disable-line no-empty 1106 1107 } 1108 1109 function getUnexpectedStateShapeWarningMessage(inputState, reducers, action, unexpectedKeyCache) { 1110 var reducerKeys = Object.keys(reducers); 1111 var argumentName = action && action.type === ActionTypes.INIT ? 'preloadedState argument passed to createStore' : 'previous state received by the reducer'; 1112 1113 if (reducerKeys.length === 0) { 1114 return 'Store does not have a valid reducer. Make sure the argument passed ' + 'to combineReducers is an object whose values are reducers.'; 1115 } 1116 1117 if (!isPlainObject(inputState)) { 1118 return "The " + argumentName + " has unexpected type of \"" + kindOf(inputState) + "\". Expected argument to be an object with the following " + ("keys: \"" + reducerKeys.join('", "') + "\""); 1119 } 1120 1121 var unexpectedKeys = Object.keys(inputState).filter(function (key) { 1122 return !reducers.hasOwnProperty(key) && !unexpectedKeyCache[key]; 1123 }); 1124 unexpectedKeys.forEach(function (key) { 1125 unexpectedKeyCache[key] = true; 1126 }); 1127 if (action && action.type === ActionTypes.REPLACE) return; 1128 1129 if (unexpectedKeys.length > 0) { 1130 return "Unexpected " + (unexpectedKeys.length > 1 ? 'keys' : 'key') + " " + ("\"" + unexpectedKeys.join('", "') + "\" found in " + argumentName + ". ") + "Expected to find one of the known reducer keys instead: " + ("\"" + reducerKeys.join('", "') + "\". Unexpected keys will be ignored."); 1131 } 1132 } 1133 1134 function assertReducerShape(reducers) { 1135 Object.keys(reducers).forEach(function (key) { 1136 var reducer = reducers[key]; 1137 var initialState = reducer(undefined, { 1138 type: ActionTypes.INIT 1139 }); 1140 1141 if (typeof initialState === 'undefined') { 1142 throw new Error( true ? formatProdErrorMessage(12) : 0); 1143 } 1144 1145 if (typeof reducer(undefined, { 1146 type: ActionTypes.PROBE_UNKNOWN_ACTION() 1147 }) === 'undefined') { 1148 throw new Error( true ? formatProdErrorMessage(13) : 0); 1149 } 1150 }); 1151 } 1152 /** 1153 * Turns an object whose values are different reducer functions, into a single 1154 * reducer function. It will call every child reducer, and gather their results 1155 * into a single state object, whose keys correspond to the keys of the passed 1156 * reducer functions. 1157 * 1158 * @param {Object} reducers An object whose values correspond to different 1159 * reducer functions that need to be combined into one. One handy way to obtain 1160 * it is to use ES6 `import * as reducers` syntax. The reducers may never return 1161 * undefined for any action. Instead, they should return their initial state 1162 * if the state passed to them was undefined, and the current state for any 1163 * unrecognized action. 1164 * 1165 * @returns {Function} A reducer function that invokes every reducer inside the 1166 * passed object, and builds a state object with the same shape. 1167 */ 1168 1169 1170 function combineReducers(reducers) { 1171 var reducerKeys = Object.keys(reducers); 1172 var finalReducers = {}; 1173 1174 for (var i = 0; i < reducerKeys.length; i++) { 1175 var key = reducerKeys[i]; 1176 1177 if (false) {} 1178 1179 if (typeof reducers[key] === 'function') { 1180 finalReducers[key] = reducers[key]; 1181 } 1182 } 1183 1184 var finalReducerKeys = Object.keys(finalReducers); // This is used to make sure we don't warn about the same 1185 // keys multiple times. 1186 1187 var unexpectedKeyCache; 1188 1189 if (false) {} 1190 1191 var shapeAssertionError; 1192 1193 try { 1194 assertReducerShape(finalReducers); 1195 } catch (e) { 1196 shapeAssertionError = e; 1197 } 1198 1199 return function combination(state, action) { 1200 if (state === void 0) { 1201 state = {}; 1202 } 1203 1204 if (shapeAssertionError) { 1205 throw shapeAssertionError; 1206 } 1207 1208 if (false) { var warningMessage; } 1209 1210 var hasChanged = false; 1211 var nextState = {}; 1212 1213 for (var _i = 0; _i < finalReducerKeys.length; _i++) { 1214 var _key = finalReducerKeys[_i]; 1215 var reducer = finalReducers[_key]; 1216 var previousStateForKey = state[_key]; 1217 var nextStateForKey = reducer(previousStateForKey, action); 1218 1219 if (typeof nextStateForKey === 'undefined') { 1220 var actionType = action && action.type; 1221 throw new Error( true ? formatProdErrorMessage(14) : 0); 1222 } 1223 1224 nextState[_key] = nextStateForKey; 1225 hasChanged = hasChanged || nextStateForKey !== previousStateForKey; 1226 } 1227 1228 hasChanged = hasChanged || finalReducerKeys.length !== Object.keys(state).length; 1229 return hasChanged ? nextState : state; 1230 }; 1231 } 1232 1233 function bindActionCreator(actionCreator, dispatch) { 1234 return function () { 1235 return dispatch(actionCreator.apply(this, arguments)); 1236 }; 1237 } 1238 /** 1239 * Turns an object whose values are action creators, into an object with the 1240 * same keys, but with every function wrapped into a `dispatch` call so they 1241 * may be invoked directly. This is just a convenience method, as you can call 1242 * `store.dispatch(MyActionCreators.doSomething())` yourself just fine. 1243 * 1244 * For convenience, you can also pass an action creator as the first argument, 1245 * and get a dispatch wrapped function in return. 1246 * 1247 * @param {Function|Object} actionCreators An object whose values are action 1248 * creator functions. One handy way to obtain it is to use ES6 `import * as` 1249 * syntax. You may also pass a single function. 1250 * 1251 * @param {Function} dispatch The `dispatch` function available on your Redux 1252 * store. 1253 * 1254 * @returns {Function|Object} The object mimicking the original object, but with 1255 * every action creator wrapped into the `dispatch` call. If you passed a 1256 * function as `actionCreators`, the return value will also be a single 1257 * function. 1258 */ 1259 1260 1261 function bindActionCreators(actionCreators, dispatch) { 1262 if (typeof actionCreators === 'function') { 1263 return bindActionCreator(actionCreators, dispatch); 1264 } 1265 1266 if (typeof actionCreators !== 'object' || actionCreators === null) { 1267 throw new Error( true ? formatProdErrorMessage(16) : 0); 1268 } 1269 1270 var boundActionCreators = {}; 1271 1272 for (var key in actionCreators) { 1273 var actionCreator = actionCreators[key]; 1274 1275 if (typeof actionCreator === 'function') { 1276 boundActionCreators[key] = bindActionCreator(actionCreator, dispatch); 1277 } 1278 } 1279 1280 return boundActionCreators; 1281 } 1282 1283 /** 1284 * Composes single-argument functions from right to left. The rightmost 1285 * function can take multiple arguments as it provides the signature for 1286 * the resulting composite function. 1287 * 1288 * @param {...Function} funcs The functions to compose. 1289 * @returns {Function} A function obtained by composing the argument functions 1290 * from right to left. For example, compose(f, g, h) is identical to doing 1291 * (...args) => f(g(h(...args))). 1292 */ 1293 function compose() { 1294 for (var _len = arguments.length, funcs = new Array(_len), _key = 0; _key < _len; _key++) { 1295 funcs[_key] = arguments[_key]; 1296 } 1297 1298 if (funcs.length === 0) { 1299 return function (arg) { 1300 return arg; 1301 }; 1302 } 1303 1304 if (funcs.length === 1) { 1305 return funcs[0]; 1306 } 1307 1308 return funcs.reduce(function (a, b) { 1309 return function () { 1310 return a(b.apply(void 0, arguments)); 1311 }; 1312 }); 1313 } 1314 1315 /** 1316 * Creates a store enhancer that applies middleware to the dispatch method 1317 * of the Redux store. This is handy for a variety of tasks, such as expressing 1318 * asynchronous actions in a concise manner, or logging every action payload. 1319 * 1320 * See `redux-thunk` package as an example of the Redux middleware. 1321 * 1322 * Because middleware is potentially asynchronous, this should be the first 1323 * store enhancer in the composition chain. 1324 * 1325 * Note that each middleware will be given the `dispatch` and `getState` functions 1326 * as named arguments. 1327 * 1328 * @param {...Function} middlewares The middleware chain to be applied. 1329 * @returns {Function} A store enhancer applying the middleware. 1330 */ 1331 1332 function applyMiddleware() { 1333 for (var _len = arguments.length, middlewares = new Array(_len), _key = 0; _key < _len; _key++) { 1334 middlewares[_key] = arguments[_key]; 1335 } 1336 1337 return function (createStore) { 1338 return function () { 1339 var store = createStore.apply(void 0, arguments); 1340 1341 var _dispatch = function dispatch() { 1342 throw new Error( true ? formatProdErrorMessage(15) : 0); 1343 }; 1344 1345 var middlewareAPI = { 1346 getState: store.getState, 1347 dispatch: function dispatch() { 1348 return _dispatch.apply(void 0, arguments); 1349 } 1350 }; 1351 var chain = middlewares.map(function (middleware) { 1352 return middleware(middlewareAPI); 1353 }); 1354 _dispatch = compose.apply(void 0, chain)(store.dispatch); 1355 return _objectSpread2(_objectSpread2({}, store), {}, { 1356 dispatch: _dispatch 1357 }); 1358 }; 1359 }; 1360 } 1361 1362 1363 1364 // EXTERNAL MODULE: ./node_modules/equivalent-key-map/equivalent-key-map.js 1365 var equivalent_key_map = __webpack_require__(3249); 1366 var equivalent_key_map_default = /*#__PURE__*/__webpack_require__.n(equivalent_key_map); 1367 ;// external ["wp","reduxRoutine"] 1368 const external_wp_reduxRoutine_namespaceObject = window["wp"]["reduxRoutine"]; 1369 var external_wp_reduxRoutine_default = /*#__PURE__*/__webpack_require__.n(external_wp_reduxRoutine_namespaceObject); 1370 ;// external ["wp","compose"] 1371 const external_wp_compose_namespaceObject = window["wp"]["compose"]; 1372 ;// ./node_modules/@wordpress/data/build-module/redux-store/combine-reducers.js 1373 function combine_reducers_combineReducers(reducers) { 1374 const keys = Object.keys(reducers); 1375 return function combinedReducer(state = {}, action) { 1376 const nextState = {}; 1377 let hasChanged = false; 1378 for (const key of keys) { 1379 const reducer = reducers[key]; 1380 const prevStateForKey = state[key]; 1381 const nextStateForKey = reducer(prevStateForKey, action); 1382 nextState[key] = nextStateForKey; 1383 hasChanged = hasChanged || nextStateForKey !== prevStateForKey; 1384 } 1385 return hasChanged ? nextState : state; 1386 }; 1387 } 1388 1389 ;// ./node_modules/@wordpress/data/build-module/factory.js 1390 /** 1391 * Creates a selector function that takes additional curried argument with the 1392 * registry `select` function. While a regular selector has signature 1393 * ```js 1394 * ( state, ...selectorArgs ) => ( result ) 1395 * ``` 1396 * that allows to select data from the store's `state`, a registry selector 1397 * has signature: 1398 * ```js 1399 * ( select ) => ( state, ...selectorArgs ) => ( result ) 1400 * ``` 1401 * that supports also selecting from other registered stores. 1402 * 1403 * @example 1404 * ```js 1405 * import { store as coreStore } from '@wordpress/core-data'; 1406 * import { store as editorStore } from '@wordpress/editor'; 1407 * 1408 * const getCurrentPostId = createRegistrySelector( ( select ) => ( state ) => { 1409 * return select( editorStore ).getCurrentPostId(); 1410 * } ); 1411 * 1412 * const getPostEdits = createRegistrySelector( ( select ) => ( state ) => { 1413 * // calling another registry selector just like any other function 1414 * const postType = getCurrentPostType( state ); 1415 * const postId = getCurrentPostId( state ); 1416 * return select( coreStore ).getEntityRecordEdits( 'postType', postType, postId ); 1417 * } ); 1418 * ``` 1419 * 1420 * Note how the `getCurrentPostId` selector can be called just like any other function, 1421 * (it works even inside a regular non-registry selector) and we don't need to pass the 1422 * registry as argument. The registry binding happens automatically when registering the selector 1423 * with a store. 1424 * 1425 * @param {Function} registrySelector Function receiving a registry `select` 1426 * function and returning a state selector. 1427 * 1428 * @return {Function} Registry selector that can be registered with a store. 1429 */ 1430 function createRegistrySelector(registrySelector) { 1431 const selectorsByRegistry = new WeakMap(); 1432 // Create a selector function that is bound to the registry referenced by `selector.registry` 1433 // and that has the same API as a regular selector. Binding it in such a way makes it 1434 // possible to call the selector directly from another selector. 1435 const wrappedSelector = (...args) => { 1436 let selector = selectorsByRegistry.get(wrappedSelector.registry); 1437 // We want to make sure the cache persists even when new registry 1438 // instances are created. For example patterns create their own editors 1439 // with their own core/block-editor stores, so we should keep track of 1440 // the cache for each registry instance. 1441 if (!selector) { 1442 selector = registrySelector(wrappedSelector.registry.select); 1443 selectorsByRegistry.set(wrappedSelector.registry, selector); 1444 } 1445 return selector(...args); 1446 }; 1447 1448 /** 1449 * Flag indicating that the selector is a registry selector that needs the correct registry 1450 * reference to be assigned to `selector.registry` to make it work correctly. 1451 * be mapped as a registry selector. 1452 * 1453 * @type {boolean} 1454 */ 1455 wrappedSelector.isRegistrySelector = true; 1456 return wrappedSelector; 1457 } 1458 1459 /** 1460 * Creates a control function that takes additional curried argument with the `registry` object. 1461 * While a regular control has signature 1462 * ```js 1463 * ( action ) => ( iteratorOrPromise ) 1464 * ``` 1465 * where the control works with the `action` that it's bound to, a registry control has signature: 1466 * ```js 1467 * ( registry ) => ( action ) => ( iteratorOrPromise ) 1468 * ``` 1469 * A registry control is typically used to select data or dispatch an action to a registered 1470 * store. 1471 * 1472 * When registering a control created with `createRegistryControl` with a store, the store 1473 * knows which calling convention to use when executing the control. 1474 * 1475 * @param {Function} registryControl Function receiving a registry object and returning a control. 1476 * 1477 * @return {Function} Registry control that can be registered with a store. 1478 */ 1479 function createRegistryControl(registryControl) { 1480 registryControl.isRegistryControl = true; 1481 return registryControl; 1482 } 1483 1484 ;// ./node_modules/@wordpress/data/build-module/controls.js 1485 /** 1486 * Internal dependencies 1487 */ 1488 1489 1490 /** @typedef {import('./types').StoreDescriptor} StoreDescriptor */ 1491 1492 const SELECT = '@@data/SELECT'; 1493 const RESOLVE_SELECT = '@@data/RESOLVE_SELECT'; 1494 const DISPATCH = '@@data/DISPATCH'; 1495 function isObject(object) { 1496 return object !== null && typeof object === 'object'; 1497 } 1498 1499 /** 1500 * Dispatches a control action for triggering a synchronous registry select. 1501 * 1502 * Note: This control synchronously returns the current selector value, triggering the 1503 * resolution, but not waiting for it. 1504 * 1505 * @param {string|StoreDescriptor} storeNameOrDescriptor Unique namespace identifier for the store 1506 * @param {string} selectorName The name of the selector. 1507 * @param {Array} args Arguments for the selector. 1508 * 1509 * @example 1510 * ```js 1511 * import { controls } from '@wordpress/data'; 1512 * 1513 * // Action generator using `select`. 1514 * export function* myAction() { 1515 * const isEditorSideBarOpened = yield controls.select( 'core/edit-post', 'isEditorSideBarOpened' ); 1516 * // Do stuff with the result from the `select`. 1517 * } 1518 * ``` 1519 * 1520 * @return {Object} The control descriptor. 1521 */ 1522 function controls_select(storeNameOrDescriptor, selectorName, ...args) { 1523 return { 1524 type: SELECT, 1525 storeKey: isObject(storeNameOrDescriptor) ? storeNameOrDescriptor.name : storeNameOrDescriptor, 1526 selectorName, 1527 args 1528 }; 1529 } 1530 1531 /** 1532 * Dispatches a control action for triggering and resolving a registry select. 1533 * 1534 * Note: when this control action is handled, it automatically considers 1535 * selectors that may have a resolver. In such case, it will return a `Promise` that resolves 1536 * after the selector finishes resolving, with the final result value. 1537 * 1538 * @param {string|StoreDescriptor} storeNameOrDescriptor Unique namespace identifier for the store 1539 * @param {string} selectorName The name of the selector 1540 * @param {Array} args Arguments for the selector. 1541 * 1542 * @example 1543 * ```js 1544 * import { controls } from '@wordpress/data'; 1545 * 1546 * // Action generator using resolveSelect 1547 * export function* myAction() { 1548 * const isSidebarOpened = yield controls.resolveSelect( 'core/edit-post', 'isEditorSideBarOpened' ); 1549 * // do stuff with the result from the select. 1550 * } 1551 * ``` 1552 * 1553 * @return {Object} The control descriptor. 1554 */ 1555 function resolveSelect(storeNameOrDescriptor, selectorName, ...args) { 1556 return { 1557 type: RESOLVE_SELECT, 1558 storeKey: isObject(storeNameOrDescriptor) ? storeNameOrDescriptor.name : storeNameOrDescriptor, 1559 selectorName, 1560 args 1561 }; 1562 } 1563 1564 /** 1565 * Dispatches a control action for triggering a registry dispatch. 1566 * 1567 * @param {string|StoreDescriptor} storeNameOrDescriptor Unique namespace identifier for the store 1568 * @param {string} actionName The name of the action to dispatch 1569 * @param {Array} args Arguments for the dispatch action. 1570 * 1571 * @example 1572 * ```js 1573 * import { controls } from '@wordpress/data-controls'; 1574 * 1575 * // Action generator using dispatch 1576 * export function* myAction() { 1577 * yield controls.dispatch( 'core/editor', 'togglePublishSidebar' ); 1578 * // do some other things. 1579 * } 1580 * ``` 1581 * 1582 * @return {Object} The control descriptor. 1583 */ 1584 function dispatch(storeNameOrDescriptor, actionName, ...args) { 1585 return { 1586 type: DISPATCH, 1587 storeKey: isObject(storeNameOrDescriptor) ? storeNameOrDescriptor.name : storeNameOrDescriptor, 1588 actionName, 1589 args 1590 }; 1591 } 1592 const controls = { 1593 select: controls_select, 1594 resolveSelect, 1595 dispatch 1596 }; 1597 const builtinControls = { 1598 [SELECT]: createRegistryControl(registry => ({ 1599 storeKey, 1600 selectorName, 1601 args 1602 }) => registry.select(storeKey)[selectorName](...args)), 1603 [RESOLVE_SELECT]: createRegistryControl(registry => ({ 1604 storeKey, 1605 selectorName, 1606 args 1607 }) => { 1608 const method = registry.select(storeKey)[selectorName].hasResolver ? 'resolveSelect' : 'select'; 1609 return registry[method](storeKey)[selectorName](...args); 1610 }), 1611 [DISPATCH]: createRegistryControl(registry => ({ 1612 storeKey, 1613 actionName, 1614 args 1615 }) => registry.dispatch(storeKey)[actionName](...args)) 1616 }; 1617 1618 ;// external ["wp","privateApis"] 1619 const external_wp_privateApis_namespaceObject = window["wp"]["privateApis"]; 1620 ;// ./node_modules/@wordpress/data/build-module/lock-unlock.js 1621 /** 1622 * WordPress dependencies 1623 */ 1624 1625 const { 1626 lock, 1627 unlock 1628 } = (0,external_wp_privateApis_namespaceObject.__dangerousOptInToUnstableAPIsOnlyForCoreModules)('I acknowledge private features are not for use in themes or plugins and doing so will break in the next version of WordPress.', '@wordpress/data'); 1629 1630 ;// ./node_modules/is-promise/index.mjs 1631 function isPromise(obj) { 1632 return !!obj && (typeof obj === 'object' || typeof obj === 'function') && typeof obj.then === 'function'; 1633 } 1634 1635 ;// ./node_modules/@wordpress/data/build-module/promise-middleware.js 1636 /** 1637 * External dependencies 1638 */ 1639 1640 1641 /** 1642 * Simplest possible promise redux middleware. 1643 * 1644 * @type {import('redux').Middleware} 1645 */ 1646 const promiseMiddleware = () => next => action => { 1647 if (isPromise(action)) { 1648 return action.then(resolvedAction => { 1649 if (resolvedAction) { 1650 return next(resolvedAction); 1651 } 1652 }); 1653 } 1654 return next(action); 1655 }; 1656 /* harmony default export */ const promise_middleware = (promiseMiddleware); 1657 1658 ;// ./node_modules/@wordpress/data/build-module/resolvers-cache-middleware.js 1659 /** @typedef {import('./registry').WPDataRegistry} WPDataRegistry */ 1660 1661 /** 1662 * Creates a middleware handling resolvers cache invalidation. 1663 * 1664 * @param {WPDataRegistry} registry Registry for which to create the middleware. 1665 * @param {string} storeName Name of the store for which to create the middleware. 1666 * 1667 * @return {Function} Middleware function. 1668 */ 1669 const createResolversCacheMiddleware = (registry, storeName) => () => next => action => { 1670 const resolvers = registry.select(storeName).getCachedResolvers(); 1671 const resolverEntries = Object.entries(resolvers); 1672 resolverEntries.forEach(([selectorName, resolversByArgs]) => { 1673 const resolver = registry.stores[storeName]?.resolvers?.[selectorName]; 1674 if (!resolver || !resolver.shouldInvalidate) { 1675 return; 1676 } 1677 resolversByArgs.forEach((value, args) => { 1678 // Works around a bug in `EquivalentKeyMap` where `map.delete` merely sets an entry value 1679 // to `undefined` and `map.forEach` then iterates also over these orphaned entries. 1680 if (value === undefined) { 1681 return; 1682 } 1683 1684 // resolversByArgs is the map Map([ args ] => boolean) storing the cache resolution status for a given selector. 1685 // If the value is "finished" or "error" it means this resolver has finished its resolution which means we need 1686 // to invalidate it, if it's true it means it's inflight and the invalidation is not necessary. 1687 if (value.status !== 'finished' && value.status !== 'error') { 1688 return; 1689 } 1690 if (!resolver.shouldInvalidate(action, ...args)) { 1691 return; 1692 } 1693 1694 // Trigger cache invalidation 1695 registry.dispatch(storeName).invalidateResolution(selectorName, args); 1696 }); 1697 }); 1698 return next(action); 1699 }; 1700 /* harmony default export */ const resolvers_cache_middleware = (createResolversCacheMiddleware); 1701 1702 ;// ./node_modules/@wordpress/data/build-module/redux-store/thunk-middleware.js 1703 function createThunkMiddleware(args) { 1704 return () => next => action => { 1705 if (typeof action === 'function') { 1706 return action(args); 1707 } 1708 return next(action); 1709 }; 1710 } 1711 1712 ;// ./node_modules/@wordpress/data/build-module/redux-store/metadata/utils.js 1713 /** 1714 * External dependencies 1715 */ 1716 1717 /** 1718 * Higher-order reducer creator which creates a combined reducer object, keyed 1719 * by a property on the action object. 1720 * 1721 * @param actionProperty Action property by which to key object. 1722 * @return Higher-order reducer. 1723 */ 1724 const onSubKey = actionProperty => reducer => (state = {}, action) => { 1725 // Retrieve subkey from action. Do not track if undefined; useful for cases 1726 // where reducer is scoped by action shape. 1727 const key = action[actionProperty]; 1728 if (key === undefined) { 1729 return state; 1730 } 1731 1732 // Avoid updating state if unchanged. Note that this also accounts for a 1733 // reducer which returns undefined on a key which is not yet tracked. 1734 const nextKeyState = reducer(state[key], action); 1735 if (nextKeyState === state[key]) { 1736 return state; 1737 } 1738 return { 1739 ...state, 1740 [key]: nextKeyState 1741 }; 1742 }; 1743 1744 /** 1745 * Normalize selector argument array by defaulting `undefined` value to an empty array 1746 * and removing trailing `undefined` values. 1747 * 1748 * @param args Selector argument array 1749 * @return Normalized state key array 1750 */ 1751 function selectorArgsToStateKey(args) { 1752 if (args === undefined || args === null) { 1753 return []; 1754 } 1755 const len = args.length; 1756 let idx = len; 1757 while (idx > 0 && args[idx - 1] === undefined) { 1758 idx--; 1759 } 1760 return idx === len ? args : args.slice(0, idx); 1761 } 1762 1763 ;// ./node_modules/@wordpress/data/build-module/redux-store/metadata/reducer.js 1764 /** 1765 * External dependencies 1766 */ 1767 1768 /** 1769 * Internal dependencies 1770 */ 1771 1772 /** 1773 * Reducer function returning next state for selector resolution of 1774 * subkeys, object form: 1775 * 1776 * selectorName -> EquivalentKeyMap<Array,boolean> 1777 */ 1778 const subKeysIsResolved = onSubKey('selectorName')((state = new (equivalent_key_map_default())(), action) => { 1779 switch (action.type) { 1780 case 'START_RESOLUTION': 1781 { 1782 const nextState = new (equivalent_key_map_default())(state); 1783 nextState.set(selectorArgsToStateKey(action.args), { 1784 status: 'resolving' 1785 }); 1786 return nextState; 1787 } 1788 case 'FINISH_RESOLUTION': 1789 { 1790 const nextState = new (equivalent_key_map_default())(state); 1791 nextState.set(selectorArgsToStateKey(action.args), { 1792 status: 'finished' 1793 }); 1794 return nextState; 1795 } 1796 case 'FAIL_RESOLUTION': 1797 { 1798 const nextState = new (equivalent_key_map_default())(state); 1799 nextState.set(selectorArgsToStateKey(action.args), { 1800 status: 'error', 1801 error: action.error 1802 }); 1803 return nextState; 1804 } 1805 case 'START_RESOLUTIONS': 1806 { 1807 const nextState = new (equivalent_key_map_default())(state); 1808 for (const resolutionArgs of action.args) { 1809 nextState.set(selectorArgsToStateKey(resolutionArgs), { 1810 status: 'resolving' 1811 }); 1812 } 1813 return nextState; 1814 } 1815 case 'FINISH_RESOLUTIONS': 1816 { 1817 const nextState = new (equivalent_key_map_default())(state); 1818 for (const resolutionArgs of action.args) { 1819 nextState.set(selectorArgsToStateKey(resolutionArgs), { 1820 status: 'finished' 1821 }); 1822 } 1823 return nextState; 1824 } 1825 case 'FAIL_RESOLUTIONS': 1826 { 1827 const nextState = new (equivalent_key_map_default())(state); 1828 action.args.forEach((resolutionArgs, idx) => { 1829 const resolutionState = { 1830 status: 'error', 1831 error: undefined 1832 }; 1833 const error = action.errors[idx]; 1834 if (error) { 1835 resolutionState.error = error; 1836 } 1837 nextState.set(selectorArgsToStateKey(resolutionArgs), resolutionState); 1838 }); 1839 return nextState; 1840 } 1841 case 'INVALIDATE_RESOLUTION': 1842 { 1843 const nextState = new (equivalent_key_map_default())(state); 1844 nextState.delete(selectorArgsToStateKey(action.args)); 1845 return nextState; 1846 } 1847 } 1848 return state; 1849 }); 1850 1851 /** 1852 * Reducer function returning next state for selector resolution, object form: 1853 * 1854 * selectorName -> EquivalentKeyMap<Array, boolean> 1855 * 1856 * @param state Current state. 1857 * @param action Dispatched action. 1858 * 1859 * @return Next state. 1860 */ 1861 const isResolved = (state = {}, action) => { 1862 switch (action.type) { 1863 case 'INVALIDATE_RESOLUTION_FOR_STORE': 1864 return {}; 1865 case 'INVALIDATE_RESOLUTION_FOR_STORE_SELECTOR': 1866 { 1867 if (action.selectorName in state) { 1868 const { 1869 [action.selectorName]: removedSelector, 1870 ...restState 1871 } = state; 1872 return restState; 1873 } 1874 return state; 1875 } 1876 case 'START_RESOLUTION': 1877 case 'FINISH_RESOLUTION': 1878 case 'FAIL_RESOLUTION': 1879 case 'START_RESOLUTIONS': 1880 case 'FINISH_RESOLUTIONS': 1881 case 'FAIL_RESOLUTIONS': 1882 case 'INVALIDATE_RESOLUTION': 1883 return subKeysIsResolved(state, action); 1884 } 1885 return state; 1886 }; 1887 /* harmony default export */ const metadata_reducer = (isResolved); 1888 1889 ;// ./node_modules/rememo/rememo.js 1890 1891 1892 /** @typedef {(...args: any[]) => *[]} GetDependants */ 1893 1894 /** @typedef {() => void} Clear */ 1895 1896 /** 1897 * @typedef {{ 1898 * getDependants: GetDependants, 1899 * clear: Clear 1900 * }} EnhancedSelector 1901 */ 1902 1903 /** 1904 * Internal cache entry. 1905 * 1906 * @typedef CacheNode 1907 * 1908 * @property {?CacheNode|undefined} [prev] Previous node. 1909 * @property {?CacheNode|undefined} [next] Next node. 1910 * @property {*[]} args Function arguments for cache entry. 1911 * @property {*} val Function result. 1912 */ 1913 1914 /** 1915 * @typedef Cache 1916 * 1917 * @property {Clear} clear Function to clear cache. 1918 * @property {boolean} [isUniqueByDependants] Whether dependants are valid in 1919 * considering cache uniqueness. A cache is unique if dependents are all arrays 1920 * or objects. 1921 * @property {CacheNode?} [head] Cache head. 1922 * @property {*[]} [lastDependants] Dependants from previous invocation. 1923 */ 1924 1925 /** 1926 * Arbitrary value used as key for referencing cache object in WeakMap tree. 1927 * 1928 * @type {{}} 1929 */ 1930 var LEAF_KEY = {}; 1931 1932 /** 1933 * Returns the first argument as the sole entry in an array. 1934 * 1935 * @template T 1936 * 1937 * @param {T} value Value to return. 1938 * 1939 * @return {[T]} Value returned as entry in array. 1940 */ 1941 function arrayOf(value) { 1942 return [value]; 1943 } 1944 1945 /** 1946 * Returns true if the value passed is object-like, or false otherwise. A value 1947 * is object-like if it can support property assignment, e.g. object or array. 1948 * 1949 * @param {*} value Value to test. 1950 * 1951 * @return {boolean} Whether value is object-like. 1952 */ 1953 function isObjectLike(value) { 1954 return !!value && 'object' === typeof value; 1955 } 1956 1957 /** 1958 * Creates and returns a new cache object. 1959 * 1960 * @return {Cache} Cache object. 1961 */ 1962 function createCache() { 1963 /** @type {Cache} */ 1964 var cache = { 1965 clear: function () { 1966 cache.head = null; 1967 }, 1968 }; 1969 1970 return cache; 1971 } 1972 1973 /** 1974 * Returns true if entries within the two arrays are strictly equal by 1975 * reference from a starting index. 1976 * 1977 * @param {*[]} a First array. 1978 * @param {*[]} b Second array. 1979 * @param {number} fromIndex Index from which to start comparison. 1980 * 1981 * @return {boolean} Whether arrays are shallowly equal. 1982 */ 1983 function isShallowEqual(a, b, fromIndex) { 1984 var i; 1985 1986 if (a.length !== b.length) { 1987 return false; 1988 } 1989 1990 for (i = fromIndex; i < a.length; i++) { 1991 if (a[i] !== b[i]) { 1992 return false; 1993 } 1994 } 1995 1996 return true; 1997 } 1998 1999 /** 2000 * Returns a memoized selector function. The getDependants function argument is 2001 * called before the memoized selector and is expected to return an immutable 2002 * reference or array of references on which the selector depends for computing 2003 * its own return value. The memoize cache is preserved only as long as those 2004 * dependant references remain the same. If getDependants returns a different 2005 * reference(s), the cache is cleared and the selector value regenerated. 2006 * 2007 * @template {(...args: *[]) => *} S 2008 * 2009 * @param {S} selector Selector function. 2010 * @param {GetDependants=} getDependants Dependant getter returning an array of 2011 * references used in cache bust consideration. 2012 */ 2013 /* harmony default export */ function rememo(selector, getDependants) { 2014 /** @type {WeakMap<*,*>} */ 2015 var rootCache; 2016 2017 /** @type {GetDependants} */ 2018 var normalizedGetDependants = getDependants ? getDependants : arrayOf; 2019 2020 /** 2021 * Returns the cache for a given dependants array. When possible, a WeakMap 2022 * will be used to create a unique cache for each set of dependants. This 2023 * is feasible due to the nature of WeakMap in allowing garbage collection 2024 * to occur on entries where the key object is no longer referenced. Since 2025 * WeakMap requires the key to be an object, this is only possible when the 2026 * dependant is object-like. The root cache is created as a hierarchy where 2027 * each top-level key is the first entry in a dependants set, the value a 2028 * WeakMap where each key is the next dependant, and so on. This continues 2029 * so long as the dependants are object-like. If no dependants are object- 2030 * like, then the cache is shared across all invocations. 2031 * 2032 * @see isObjectLike 2033 * 2034 * @param {*[]} dependants Selector dependants. 2035 * 2036 * @return {Cache} Cache object. 2037 */ 2038 function getCache(dependants) { 2039 var caches = rootCache, 2040 isUniqueByDependants = true, 2041 i, 2042 dependant, 2043 map, 2044 cache; 2045 2046 for (i = 0; i < dependants.length; i++) { 2047 dependant = dependants[i]; 2048 2049 // Can only compose WeakMap from object-like key. 2050 if (!isObjectLike(dependant)) { 2051 isUniqueByDependants = false; 2052 break; 2053 } 2054 2055 // Does current segment of cache already have a WeakMap? 2056 if (caches.has(dependant)) { 2057 // Traverse into nested WeakMap. 2058 caches = caches.get(dependant); 2059 } else { 2060 // Create, set, and traverse into a new one. 2061 map = new WeakMap(); 2062 caches.set(dependant, map); 2063 caches = map; 2064 } 2065 } 2066 2067 // We use an arbitrary (but consistent) object as key for the last item 2068 // in the WeakMap to serve as our running cache. 2069 if (!caches.has(LEAF_KEY)) { 2070 cache = createCache(); 2071 cache.isUniqueByDependants = isUniqueByDependants; 2072 caches.set(LEAF_KEY, cache); 2073 } 2074 2075 return caches.get(LEAF_KEY); 2076 } 2077 2078 /** 2079 * Resets root memoization cache. 2080 */ 2081 function clear() { 2082 rootCache = new WeakMap(); 2083 } 2084 2085 /* eslint-disable jsdoc/check-param-names */ 2086 /** 2087 * The augmented selector call, considering first whether dependants have 2088 * changed before passing it to underlying memoize function. 2089 * 2090 * @param {*} source Source object for derivation. 2091 * @param {...*} extraArgs Additional arguments to pass to selector. 2092 * 2093 * @return {*} Selector result. 2094 */ 2095 /* eslint-enable jsdoc/check-param-names */ 2096 function callSelector(/* source, ...extraArgs */) { 2097 var len = arguments.length, 2098 cache, 2099 node, 2100 i, 2101 args, 2102 dependants; 2103 2104 // Create copy of arguments (avoid leaking deoptimization). 2105 args = new Array(len); 2106 for (i = 0; i < len; i++) { 2107 args[i] = arguments[i]; 2108 } 2109 2110 dependants = normalizedGetDependants.apply(null, args); 2111 cache = getCache(dependants); 2112 2113 // If not guaranteed uniqueness by dependants (primitive type), shallow 2114 // compare against last dependants and, if references have changed, 2115 // destroy cache to recalculate result. 2116 if (!cache.isUniqueByDependants) { 2117 if ( 2118 cache.lastDependants && 2119 !isShallowEqual(dependants, cache.lastDependants, 0) 2120 ) { 2121 cache.clear(); 2122 } 2123 2124 cache.lastDependants = dependants; 2125 } 2126 2127 node = cache.head; 2128 while (node) { 2129 // Check whether node arguments match arguments 2130 if (!isShallowEqual(node.args, args, 1)) { 2131 node = node.next; 2132 continue; 2133 } 2134 2135 // At this point we can assume we've found a match 2136 2137 // Surface matched node to head if not already 2138 if (node !== cache.head) { 2139 // Adjust siblings to point to each other. 2140 /** @type {CacheNode} */ (node.prev).next = node.next; 2141 if (node.next) { 2142 node.next.prev = node.prev; 2143 } 2144 2145 node.next = cache.head; 2146 node.prev = null; 2147 /** @type {CacheNode} */ (cache.head).prev = node; 2148 cache.head = node; 2149 } 2150 2151 // Return immediately 2152 return node.val; 2153 } 2154 2155 // No cached value found. Continue to insertion phase: 2156 2157 node = /** @type {CacheNode} */ ({ 2158 // Generate the result from original function 2159 val: selector.apply(null, args), 2160 }); 2161 2162 // Avoid including the source object in the cache. 2163 args[0] = null; 2164 node.args = args; 2165 2166 // Don't need to check whether node is already head, since it would 2167 // have been returned above already if it was 2168 2169 // Shift existing head down list 2170 if (cache.head) { 2171 cache.head.prev = node; 2172 node.next = cache.head; 2173 } 2174 2175 cache.head = node; 2176 2177 return node.val; 2178 } 2179 2180 callSelector.getDependants = normalizedGetDependants; 2181 callSelector.clear = clear; 2182 clear(); 2183 2184 return /** @type {S & EnhancedSelector} */ (callSelector); 2185 } 2186 2187 ;// ./node_modules/@wordpress/data/build-module/redux-store/metadata/selectors.js 2188 /** 2189 * WordPress dependencies 2190 */ 2191 2192 2193 /** 2194 * Internal dependencies 2195 */ 2196 2197 2198 2199 /** @typedef {Record<string, import('./reducer').State>} State */ 2200 /** @typedef {import('./reducer').StateValue} StateValue */ 2201 /** @typedef {import('./reducer').Status} Status */ 2202 2203 /** 2204 * Returns the raw resolution state value for a given selector name, 2205 * and arguments set. May be undefined if the selector has never been resolved 2206 * or not resolved for the given set of arguments, otherwise true or false for 2207 * resolution started and completed respectively. 2208 * 2209 * @param {State} state Data state. 2210 * @param {string} selectorName Selector name. 2211 * @param {unknown[]?} args Arguments passed to selector. 2212 * 2213 * @return {StateValue|undefined} isResolving value. 2214 */ 2215 function getResolutionState(state, selectorName, args) { 2216 const map = state[selectorName]; 2217 if (!map) { 2218 return; 2219 } 2220 return map.get(selectorArgsToStateKey(args)); 2221 } 2222 2223 /** 2224 * Returns an `isResolving`-like value for a given selector name and arguments set. 2225 * Its value is either `undefined` if the selector has never been resolved or has been 2226 * invalidated, or a `true`/`false` boolean value if the resolution is in progress or 2227 * has finished, respectively. 2228 * 2229 * This is a legacy selector that was implemented when the "raw" internal data had 2230 * this `undefined | boolean` format. Nowadays the internal value is an object that 2231 * can be retrieved with `getResolutionState`. 2232 * 2233 * @deprecated 2234 * 2235 * @param {State} state Data state. 2236 * @param {string} selectorName Selector name. 2237 * @param {unknown[]?} args Arguments passed to selector. 2238 * 2239 * @return {boolean | undefined} isResolving value. 2240 */ 2241 function getIsResolving(state, selectorName, args) { 2242 external_wp_deprecated_default()('wp.data.select( store ).getIsResolving', { 2243 since: '6.6', 2244 version: '6.8', 2245 alternative: 'wp.data.select( store ).getResolutionState' 2246 }); 2247 const resolutionState = getResolutionState(state, selectorName, args); 2248 return resolutionState && resolutionState.status === 'resolving'; 2249 } 2250 2251 /** 2252 * Returns true if resolution has already been triggered for a given 2253 * selector name, and arguments set. 2254 * 2255 * @param {State} state Data state. 2256 * @param {string} selectorName Selector name. 2257 * @param {unknown[]?} args Arguments passed to selector. 2258 * 2259 * @return {boolean} Whether resolution has been triggered. 2260 */ 2261 function hasStartedResolution(state, selectorName, args) { 2262 return getResolutionState(state, selectorName, args) !== undefined; 2263 } 2264 2265 /** 2266 * Returns true if resolution has completed for a given selector 2267 * name, and arguments set. 2268 * 2269 * @param {State} state Data state. 2270 * @param {string} selectorName Selector name. 2271 * @param {unknown[]?} args Arguments passed to selector. 2272 * 2273 * @return {boolean} Whether resolution has completed. 2274 */ 2275 function hasFinishedResolution(state, selectorName, args) { 2276 const status = getResolutionState(state, selectorName, args)?.status; 2277 return status === 'finished' || status === 'error'; 2278 } 2279 2280 /** 2281 * Returns true if resolution has failed for a given selector 2282 * name, and arguments set. 2283 * 2284 * @param {State} state Data state. 2285 * @param {string} selectorName Selector name. 2286 * @param {unknown[]?} args Arguments passed to selector. 2287 * 2288 * @return {boolean} Has resolution failed 2289 */ 2290 function hasResolutionFailed(state, selectorName, args) { 2291 return getResolutionState(state, selectorName, args)?.status === 'error'; 2292 } 2293 2294 /** 2295 * Returns the resolution error for a given selector name, and arguments set. 2296 * Note it may be of an Error type, but may also be null, undefined, or anything else 2297 * that can be `throw`-n. 2298 * 2299 * @param {State} state Data state. 2300 * @param {string} selectorName Selector name. 2301 * @param {unknown[]?} args Arguments passed to selector. 2302 * 2303 * @return {Error|unknown} Last resolution error 2304 */ 2305 function getResolutionError(state, selectorName, args) { 2306 const resolutionState = getResolutionState(state, selectorName, args); 2307 return resolutionState?.status === 'error' ? resolutionState.error : null; 2308 } 2309 2310 /** 2311 * Returns true if resolution has been triggered but has not yet completed for 2312 * a given selector name, and arguments set. 2313 * 2314 * @param {State} state Data state. 2315 * @param {string} selectorName Selector name. 2316 * @param {unknown[]?} args Arguments passed to selector. 2317 * 2318 * @return {boolean} Whether resolution is in progress. 2319 */ 2320 function isResolving(state, selectorName, args) { 2321 return getResolutionState(state, selectorName, args)?.status === 'resolving'; 2322 } 2323 2324 /** 2325 * Returns the list of the cached resolvers. 2326 * 2327 * @param {State} state Data state. 2328 * 2329 * @return {State} Resolvers mapped by args and selectorName. 2330 */ 2331 function getCachedResolvers(state) { 2332 return state; 2333 } 2334 2335 /** 2336 * Whether the store has any currently resolving selectors. 2337 * 2338 * @param {State} state Data state. 2339 * 2340 * @return {boolean} True if one or more selectors are resolving, false otherwise. 2341 */ 2342 function hasResolvingSelectors(state) { 2343 return Object.values(state).some(selectorState => 2344 /** 2345 * This uses the internal `_map` property of `EquivalentKeyMap` for 2346 * optimization purposes, since the `EquivalentKeyMap` implementation 2347 * does not support a `.values()` implementation. 2348 * 2349 * @see https://github.com/aduth/equivalent-key-map 2350 */ 2351 Array.from(selectorState._map.values()).some(resolution => resolution[1]?.status === 'resolving')); 2352 } 2353 2354 /** 2355 * Retrieves the total number of selectors, grouped per status. 2356 * 2357 * @param {State} state Data state. 2358 * 2359 * @return {Object} Object, containing selector totals by status. 2360 */ 2361 const countSelectorsByStatus = rememo(state => { 2362 const selectorsByStatus = {}; 2363 Object.values(state).forEach(selectorState => 2364 /** 2365 * This uses the internal `_map` property of `EquivalentKeyMap` for 2366 * optimization purposes, since the `EquivalentKeyMap` implementation 2367 * does not support a `.values()` implementation. 2368 * 2369 * @see https://github.com/aduth/equivalent-key-map 2370 */ 2371 Array.from(selectorState._map.values()).forEach(resolution => { 2372 var _resolution$1$status; 2373 const currentStatus = (_resolution$1$status = resolution[1]?.status) !== null && _resolution$1$status !== void 0 ? _resolution$1$status : 'error'; 2374 if (!selectorsByStatus[currentStatus]) { 2375 selectorsByStatus[currentStatus] = 0; 2376 } 2377 selectorsByStatus[currentStatus]++; 2378 })); 2379 return selectorsByStatus; 2380 }, state => [state]); 2381 2382 ;// ./node_modules/@wordpress/data/build-module/redux-store/metadata/actions.js 2383 /** 2384 * Returns an action object used in signalling that selector resolution has 2385 * started. 2386 * 2387 * @param {string} selectorName Name of selector for which resolver triggered. 2388 * @param {unknown[]} args Arguments to associate for uniqueness. 2389 * 2390 * @return {{ type: 'START_RESOLUTION', selectorName: string, args: unknown[] }} Action object. 2391 */ 2392 function startResolution(selectorName, args) { 2393 return { 2394 type: 'START_RESOLUTION', 2395 selectorName, 2396 args 2397 }; 2398 } 2399 2400 /** 2401 * Returns an action object used in signalling that selector resolution has 2402 * completed. 2403 * 2404 * @param {string} selectorName Name of selector for which resolver triggered. 2405 * @param {unknown[]} args Arguments to associate for uniqueness. 2406 * 2407 * @return {{ type: 'FINISH_RESOLUTION', selectorName: string, args: unknown[] }} Action object. 2408 */ 2409 function finishResolution(selectorName, args) { 2410 return { 2411 type: 'FINISH_RESOLUTION', 2412 selectorName, 2413 args 2414 }; 2415 } 2416 2417 /** 2418 * Returns an action object used in signalling that selector resolution has 2419 * failed. 2420 * 2421 * @param {string} selectorName Name of selector for which resolver triggered. 2422 * @param {unknown[]} args Arguments to associate for uniqueness. 2423 * @param {Error|unknown} error The error that caused the failure. 2424 * 2425 * @return {{ type: 'FAIL_RESOLUTION', selectorName: string, args: unknown[], error: Error|unknown }} Action object. 2426 */ 2427 function failResolution(selectorName, args, error) { 2428 return { 2429 type: 'FAIL_RESOLUTION', 2430 selectorName, 2431 args, 2432 error 2433 }; 2434 } 2435 2436 /** 2437 * Returns an action object used in signalling that a batch of selector resolutions has 2438 * started. 2439 * 2440 * @param {string} selectorName Name of selector for which resolver triggered. 2441 * @param {unknown[][]} args Array of arguments to associate for uniqueness, each item 2442 * is associated to a resolution. 2443 * 2444 * @return {{ type: 'START_RESOLUTIONS', selectorName: string, args: unknown[][] }} Action object. 2445 */ 2446 function startResolutions(selectorName, args) { 2447 return { 2448 type: 'START_RESOLUTIONS', 2449 selectorName, 2450 args 2451 }; 2452 } 2453 2454 /** 2455 * Returns an action object used in signalling that a batch of selector resolutions has 2456 * completed. 2457 * 2458 * @param {string} selectorName Name of selector for which resolver triggered. 2459 * @param {unknown[][]} args Array of arguments to associate for uniqueness, each item 2460 * is associated to a resolution. 2461 * 2462 * @return {{ type: 'FINISH_RESOLUTIONS', selectorName: string, args: unknown[][] }} Action object. 2463 */ 2464 function finishResolutions(selectorName, args) { 2465 return { 2466 type: 'FINISH_RESOLUTIONS', 2467 selectorName, 2468 args 2469 }; 2470 } 2471 2472 /** 2473 * Returns an action object used in signalling that a batch of selector resolutions has 2474 * completed and at least one of them has failed. 2475 * 2476 * @param {string} selectorName Name of selector for which resolver triggered. 2477 * @param {unknown[]} args Array of arguments to associate for uniqueness, each item 2478 * is associated to a resolution. 2479 * @param {(Error|unknown)[]} errors Array of errors to associate for uniqueness, each item 2480 * is associated to a resolution. 2481 * @return {{ type: 'FAIL_RESOLUTIONS', selectorName: string, args: unknown[], errors: Array<Error|unknown> }} Action object. 2482 */ 2483 function failResolutions(selectorName, args, errors) { 2484 return { 2485 type: 'FAIL_RESOLUTIONS', 2486 selectorName, 2487 args, 2488 errors 2489 }; 2490 } 2491 2492 /** 2493 * Returns an action object used in signalling that we should invalidate the resolution cache. 2494 * 2495 * @param {string} selectorName Name of selector for which resolver should be invalidated. 2496 * @param {unknown[]} args Arguments to associate for uniqueness. 2497 * 2498 * @return {{ type: 'INVALIDATE_RESOLUTION', selectorName: string, args: any[] }} Action object. 2499 */ 2500 function invalidateResolution(selectorName, args) { 2501 return { 2502 type: 'INVALIDATE_RESOLUTION', 2503 selectorName, 2504 args 2505 }; 2506 } 2507 2508 /** 2509 * Returns an action object used in signalling that the resolution 2510 * should be invalidated. 2511 * 2512 * @return {{ type: 'INVALIDATE_RESOLUTION_FOR_STORE' }} Action object. 2513 */ 2514 function invalidateResolutionForStore() { 2515 return { 2516 type: 'INVALIDATE_RESOLUTION_FOR_STORE' 2517 }; 2518 } 2519 2520 /** 2521 * Returns an action object used in signalling that the resolution cache for a 2522 * given selectorName should be invalidated. 2523 * 2524 * @param {string} selectorName Name of selector for which all resolvers should 2525 * be invalidated. 2526 * 2527 * @return {{ type: 'INVALIDATE_RESOLUTION_FOR_STORE_SELECTOR', selectorName: string }} Action object. 2528 */ 2529 function invalidateResolutionForStoreSelector(selectorName) { 2530 return { 2531 type: 'INVALIDATE_RESOLUTION_FOR_STORE_SELECTOR', 2532 selectorName 2533 }; 2534 } 2535 2536 ;// ./node_modules/@wordpress/data/build-module/redux-store/index.js 2537 /** 2538 * External dependencies 2539 */ 2540 2541 2542 2543 /** 2544 * WordPress dependencies 2545 */ 2546 2547 2548 2549 /** 2550 * Internal dependencies 2551 */ 2552 2553 2554 2555 2556 2557 2558 2559 2560 2561 2562 2563 /** @typedef {import('../types').DataRegistry} DataRegistry */ 2564 /** @typedef {import('../types').ListenerFunction} ListenerFunction */ 2565 /** 2566 * @typedef {import('../types').StoreDescriptor<C>} StoreDescriptor 2567 * @template {import('../types').AnyConfig} C 2568 */ 2569 /** 2570 * @typedef {import('../types').ReduxStoreConfig<State,Actions,Selectors>} ReduxStoreConfig 2571 * @template State 2572 * @template {Record<string,import('../types').ActionCreator>} Actions 2573 * @template Selectors 2574 */ 2575 2576 const trimUndefinedValues = array => { 2577 const result = [...array]; 2578 for (let i = result.length - 1; i >= 0; i--) { 2579 if (result[i] === undefined) { 2580 result.splice(i, 1); 2581 } 2582 } 2583 return result; 2584 }; 2585 2586 /** 2587 * Creates a new object with the same keys, but with `callback()` called as 2588 * a transformer function on each of the values. 2589 * 2590 * @param {Object} obj The object to transform. 2591 * @param {Function} callback The function to transform each object value. 2592 * @return {Array} Transformed object. 2593 */ 2594 const mapValues = (obj, callback) => Object.fromEntries(Object.entries(obj !== null && obj !== void 0 ? obj : {}).map(([key, value]) => [key, callback(value, key)])); 2595 2596 // Convert non serializable types to plain objects 2597 const devToolsReplacer = (key, state) => { 2598 if (state instanceof Map) { 2599 return Object.fromEntries(state); 2600 } 2601 if (state instanceof window.HTMLElement) { 2602 return null; 2603 } 2604 return state; 2605 }; 2606 2607 /** 2608 * Create a cache to track whether resolvers started running or not. 2609 * 2610 * @return {Object} Resolvers Cache. 2611 */ 2612 function createResolversCache() { 2613 const cache = {}; 2614 return { 2615 isRunning(selectorName, args) { 2616 return cache[selectorName] && cache[selectorName].get(trimUndefinedValues(args)); 2617 }, 2618 clear(selectorName, args) { 2619 if (cache[selectorName]) { 2620 cache[selectorName].delete(trimUndefinedValues(args)); 2621 } 2622 }, 2623 markAsRunning(selectorName, args) { 2624 if (!cache[selectorName]) { 2625 cache[selectorName] = new (equivalent_key_map_default())(); 2626 } 2627 cache[selectorName].set(trimUndefinedValues(args), true); 2628 } 2629 }; 2630 } 2631 function createBindingCache(bind) { 2632 const cache = new WeakMap(); 2633 return { 2634 get(item, itemName) { 2635 let boundItem = cache.get(item); 2636 if (!boundItem) { 2637 boundItem = bind(item, itemName); 2638 cache.set(item, boundItem); 2639 } 2640 return boundItem; 2641 } 2642 }; 2643 } 2644 2645 /** 2646 * Creates a data store descriptor for the provided Redux store configuration containing 2647 * properties describing reducer, actions, selectors, controls and resolvers. 2648 * 2649 * @example 2650 * ```js 2651 * import { createReduxStore } from '@wordpress/data'; 2652 * 2653 * const store = createReduxStore( 'demo', { 2654 * reducer: ( state = 'OK' ) => state, 2655 * selectors: { 2656 * getValue: ( state ) => state, 2657 * }, 2658 * } ); 2659 * ``` 2660 * 2661 * @template State 2662 * @template {Record<string,import('../types').ActionCreator>} Actions 2663 * @template Selectors 2664 * @param {string} key Unique namespace identifier. 2665 * @param {ReduxStoreConfig<State,Actions,Selectors>} options Registered store options, with properties 2666 * describing reducer, actions, selectors, 2667 * and resolvers. 2668 * 2669 * @return {StoreDescriptor<ReduxStoreConfig<State,Actions,Selectors>>} Store Object. 2670 */ 2671 function createReduxStore(key, options) { 2672 const privateActions = {}; 2673 const privateSelectors = {}; 2674 const privateRegistrationFunctions = { 2675 privateActions, 2676 registerPrivateActions: actions => { 2677 Object.assign(privateActions, actions); 2678 }, 2679 privateSelectors, 2680 registerPrivateSelectors: selectors => { 2681 Object.assign(privateSelectors, selectors); 2682 } 2683 }; 2684 const storeDescriptor = { 2685 name: key, 2686 instantiate: registry => { 2687 /** 2688 * Stores listener functions registered with `subscribe()`. 2689 * 2690 * When functions register to listen to store changes with 2691 * `subscribe()` they get added here. Although Redux offers 2692 * its own `subscribe()` function directly, by wrapping the 2693 * subscription in this store instance it's possible to 2694 * optimize checking if the state has changed before calling 2695 * each listener. 2696 * 2697 * @type {Set<ListenerFunction>} 2698 */ 2699 const listeners = new Set(); 2700 const reducer = options.reducer; 2701 const thunkArgs = { 2702 registry, 2703 get dispatch() { 2704 return thunkActions; 2705 }, 2706 get select() { 2707 return thunkSelectors; 2708 }, 2709 get resolveSelect() { 2710 return getResolveSelectors(); 2711 } 2712 }; 2713 const store = instantiateReduxStore(key, options, registry, thunkArgs); 2714 // Expose the private registration functions on the store 2715 // so they can be copied to a sub registry in registry.js. 2716 lock(store, privateRegistrationFunctions); 2717 const resolversCache = createResolversCache(); 2718 function bindAction(action) { 2719 return (...args) => Promise.resolve(store.dispatch(action(...args))); 2720 } 2721 const actions = { 2722 ...mapValues(actions_namespaceObject, bindAction), 2723 ...mapValues(options.actions, bindAction) 2724 }; 2725 const boundPrivateActions = createBindingCache(bindAction); 2726 const allActions = new Proxy(() => {}, { 2727 get: (target, prop) => { 2728 const privateAction = privateActions[prop]; 2729 return privateAction ? boundPrivateActions.get(privateAction, prop) : actions[prop]; 2730 } 2731 }); 2732 const thunkActions = new Proxy(allActions, { 2733 apply: (target, thisArg, [action]) => store.dispatch(action) 2734 }); 2735 lock(actions, allActions); 2736 const resolvers = options.resolvers ? mapResolvers(options.resolvers) : {}; 2737 function bindSelector(selector, selectorName) { 2738 if (selector.isRegistrySelector) { 2739 selector.registry = registry; 2740 } 2741 const boundSelector = (...args) => { 2742 args = normalize(selector, args); 2743 const state = store.__unstableOriginalGetState(); 2744 // Before calling the selector, switch to the correct 2745 // registry. 2746 if (selector.isRegistrySelector) { 2747 selector.registry = registry; 2748 } 2749 return selector(state.root, ...args); 2750 }; 2751 2752 // Expose normalization method on the bound selector 2753 // in order that it can be called when fullfilling 2754 // the resolver. 2755 boundSelector.__unstableNormalizeArgs = selector.__unstableNormalizeArgs; 2756 const resolver = resolvers[selectorName]; 2757 if (!resolver) { 2758 boundSelector.hasResolver = false; 2759 return boundSelector; 2760 } 2761 return mapSelectorWithResolver(boundSelector, selectorName, resolver, store, resolversCache); 2762 } 2763 function bindMetadataSelector(metaDataSelector) { 2764 const boundSelector = (...args) => { 2765 const state = store.__unstableOriginalGetState(); 2766 const originalSelectorName = args && args[0]; 2767 const originalSelectorArgs = args && args[1]; 2768 const targetSelector = options?.selectors?.[originalSelectorName]; 2769 2770 // Normalize the arguments passed to the target selector. 2771 if (originalSelectorName && targetSelector) { 2772 args[1] = normalize(targetSelector, originalSelectorArgs); 2773 } 2774 return metaDataSelector(state.metadata, ...args); 2775 }; 2776 boundSelector.hasResolver = false; 2777 return boundSelector; 2778 } 2779 const selectors = { 2780 ...mapValues(selectors_namespaceObject, bindMetadataSelector), 2781 ...mapValues(options.selectors, bindSelector) 2782 }; 2783 const boundPrivateSelectors = createBindingCache(bindSelector); 2784 2785 // Pre-bind the private selectors that have been registered by the time of 2786 // instantiation, so that registry selectors are bound to the registry. 2787 for (const [selectorName, selector] of Object.entries(privateSelectors)) { 2788 boundPrivateSelectors.get(selector, selectorName); 2789 } 2790 const allSelectors = new Proxy(() => {}, { 2791 get: (target, prop) => { 2792 const privateSelector = privateSelectors[prop]; 2793 return privateSelector ? boundPrivateSelectors.get(privateSelector, prop) : selectors[prop]; 2794 } 2795 }); 2796 const thunkSelectors = new Proxy(allSelectors, { 2797 apply: (target, thisArg, [selector]) => selector(store.__unstableOriginalGetState()) 2798 }); 2799 lock(selectors, allSelectors); 2800 const resolveSelectors = mapResolveSelectors(selectors, store); 2801 const suspendSelectors = mapSuspendSelectors(selectors, store); 2802 const getSelectors = () => selectors; 2803 const getActions = () => actions; 2804 const getResolveSelectors = () => resolveSelectors; 2805 const getSuspendSelectors = () => suspendSelectors; 2806 2807 // We have some modules monkey-patching the store object 2808 // It's wrong to do so but until we refactor all of our effects to controls 2809 // We need to keep the same "store" instance here. 2810 store.__unstableOriginalGetState = store.getState; 2811 store.getState = () => store.__unstableOriginalGetState().root; 2812 2813 // Customize subscribe behavior to call listeners only on effective change, 2814 // not on every dispatch. 2815 const subscribe = store && (listener => { 2816 listeners.add(listener); 2817 return () => listeners.delete(listener); 2818 }); 2819 let lastState = store.__unstableOriginalGetState(); 2820 store.subscribe(() => { 2821 const state = store.__unstableOriginalGetState(); 2822 const hasChanged = state !== lastState; 2823 lastState = state; 2824 if (hasChanged) { 2825 for (const listener of listeners) { 2826 listener(); 2827 } 2828 } 2829 }); 2830 2831 // This can be simplified to just { subscribe, getSelectors, getActions } 2832 // Once we remove the use function. 2833 return { 2834 reducer, 2835 store, 2836 actions, 2837 selectors, 2838 resolvers, 2839 getSelectors, 2840 getResolveSelectors, 2841 getSuspendSelectors, 2842 getActions, 2843 subscribe 2844 }; 2845 } 2846 }; 2847 2848 // Expose the private registration functions on the store 2849 // descriptor. That's a natural choice since that's where the 2850 // public actions and selectors are stored . 2851 lock(storeDescriptor, privateRegistrationFunctions); 2852 return storeDescriptor; 2853 } 2854 2855 /** 2856 * Creates a redux store for a namespace. 2857 * 2858 * @param {string} key Unique namespace identifier. 2859 * @param {Object} options Registered store options, with properties 2860 * describing reducer, actions, selectors, 2861 * and resolvers. 2862 * @param {DataRegistry} registry Registry reference. 2863 * @param {Object} thunkArgs Argument object for the thunk middleware. 2864 * @return {Object} Newly created redux store. 2865 */ 2866 function instantiateReduxStore(key, options, registry, thunkArgs) { 2867 const controls = { 2868 ...options.controls, 2869 ...builtinControls 2870 }; 2871 const normalizedControls = mapValues(controls, control => control.isRegistryControl ? control(registry) : control); 2872 const middlewares = [resolvers_cache_middleware(registry, key), promise_middleware, external_wp_reduxRoutine_default()(normalizedControls), createThunkMiddleware(thunkArgs)]; 2873 const enhancers = [applyMiddleware(...middlewares)]; 2874 if (typeof window !== 'undefined' && window.__REDUX_DEVTOOLS_EXTENSION__) { 2875 enhancers.push(window.__REDUX_DEVTOOLS_EXTENSION__({ 2876 name: key, 2877 instanceId: key, 2878 serialize: { 2879 replacer: devToolsReplacer 2880 } 2881 })); 2882 } 2883 const { 2884 reducer, 2885 initialState 2886 } = options; 2887 const enhancedReducer = combine_reducers_combineReducers({ 2888 metadata: metadata_reducer, 2889 root: reducer 2890 }); 2891 return createStore(enhancedReducer, { 2892 root: initialState 2893 }, (0,external_wp_compose_namespaceObject.compose)(enhancers)); 2894 } 2895 2896 /** 2897 * Maps selectors to functions that return a resolution promise for them 2898 * 2899 * @param {Object} selectors Selectors to map. 2900 * @param {Object} store The redux store the selectors select from. 2901 * 2902 * @return {Object} Selectors mapped to their resolution functions. 2903 */ 2904 function mapResolveSelectors(selectors, store) { 2905 const { 2906 getIsResolving, 2907 hasStartedResolution, 2908 hasFinishedResolution, 2909 hasResolutionFailed, 2910 isResolving, 2911 getCachedResolvers, 2912 getResolutionState, 2913 getResolutionError, 2914 hasResolvingSelectors, 2915 countSelectorsByStatus, 2916 ...storeSelectors 2917 } = selectors; 2918 return mapValues(storeSelectors, (selector, selectorName) => { 2919 // If the selector doesn't have a resolver, just convert the return value 2920 // (including exceptions) to a Promise, no additional extra behavior is needed. 2921 if (!selector.hasResolver) { 2922 return async (...args) => selector.apply(null, args); 2923 } 2924 return (...args) => { 2925 return new Promise((resolve, reject) => { 2926 const hasFinished = () => selectors.hasFinishedResolution(selectorName, args); 2927 const finalize = result => { 2928 const hasFailed = selectors.hasResolutionFailed(selectorName, args); 2929 if (hasFailed) { 2930 const error = selectors.getResolutionError(selectorName, args); 2931 reject(error); 2932 } else { 2933 resolve(result); 2934 } 2935 }; 2936 const getResult = () => selector.apply(null, args); 2937 // Trigger the selector (to trigger the resolver) 2938 const result = getResult(); 2939 if (hasFinished()) { 2940 return finalize(result); 2941 } 2942 const unsubscribe = store.subscribe(() => { 2943 if (hasFinished()) { 2944 unsubscribe(); 2945 finalize(getResult()); 2946 } 2947 }); 2948 }); 2949 }; 2950 }); 2951 } 2952 2953 /** 2954 * Maps selectors to functions that throw a suspense promise if not yet resolved. 2955 * 2956 * @param {Object} selectors Selectors to map. 2957 * @param {Object} store The redux store the selectors select from. 2958 * 2959 * @return {Object} Selectors mapped to their suspense functions. 2960 */ 2961 function mapSuspendSelectors(selectors, store) { 2962 return mapValues(selectors, (selector, selectorName) => { 2963 // Selector without a resolver doesn't have any extra suspense behavior. 2964 if (!selector.hasResolver) { 2965 return selector; 2966 } 2967 return (...args) => { 2968 const result = selector.apply(null, args); 2969 if (selectors.hasFinishedResolution(selectorName, args)) { 2970 if (selectors.hasResolutionFailed(selectorName, args)) { 2971 throw selectors.getResolutionError(selectorName, args); 2972 } 2973 return result; 2974 } 2975 throw new Promise(resolve => { 2976 const unsubscribe = store.subscribe(() => { 2977 if (selectors.hasFinishedResolution(selectorName, args)) { 2978 resolve(); 2979 unsubscribe(); 2980 } 2981 }); 2982 }); 2983 }; 2984 }); 2985 } 2986 2987 /** 2988 * Convert resolvers to a normalized form, an object with `fulfill` method and 2989 * optional methods like `isFulfilled`. 2990 * 2991 * @param {Object} resolvers Resolver to convert 2992 */ 2993 function mapResolvers(resolvers) { 2994 return mapValues(resolvers, resolver => { 2995 if (resolver.fulfill) { 2996 return resolver; 2997 } 2998 return { 2999 ...resolver, 3000 // Copy the enumerable properties of the resolver function. 3001 fulfill: resolver // Add the fulfill method. 3002 }; 3003 }); 3004 } 3005 3006 /** 3007 * Returns a selector with a matched resolver. 3008 * Resolvers are side effects invoked once per argument set of a given selector call, 3009 * used in ensuring that the data needs for the selector are satisfied. 3010 * 3011 * @param {Object} selector The selector function to be bound. 3012 * @param {string} selectorName The selector name. 3013 * @param {Object} resolver Resolver to call. 3014 * @param {Object} store The redux store to which the resolvers should be mapped. 3015 * @param {Object} resolversCache Resolvers Cache. 3016 */ 3017 function mapSelectorWithResolver(selector, selectorName, resolver, store, resolversCache) { 3018 function fulfillSelector(args) { 3019 const state = store.getState(); 3020 if (resolversCache.isRunning(selectorName, args) || typeof resolver.isFulfilled === 'function' && resolver.isFulfilled(state, ...args)) { 3021 return; 3022 } 3023 const { 3024 metadata 3025 } = store.__unstableOriginalGetState(); 3026 if (hasStartedResolution(metadata, selectorName, args)) { 3027 return; 3028 } 3029 resolversCache.markAsRunning(selectorName, args); 3030 setTimeout(async () => { 3031 resolversCache.clear(selectorName, args); 3032 store.dispatch(startResolution(selectorName, args)); 3033 try { 3034 const action = resolver.fulfill(...args); 3035 if (action) { 3036 await store.dispatch(action); 3037 } 3038 store.dispatch(finishResolution(selectorName, args)); 3039 } catch (error) { 3040 store.dispatch(failResolution(selectorName, args, error)); 3041 } 3042 }, 0); 3043 } 3044 const selectorResolver = (...args) => { 3045 args = normalize(selector, args); 3046 fulfillSelector(args); 3047 return selector(...args); 3048 }; 3049 selectorResolver.hasResolver = true; 3050 return selectorResolver; 3051 } 3052 3053 /** 3054 * Applies selector's normalization function to the given arguments 3055 * if it exists. 3056 * 3057 * @param {Object} selector The selector potentially with a normalization method property. 3058 * @param {Array} args selector arguments to normalize. 3059 * @return {Array} Potentially normalized arguments. 3060 */ 3061 function normalize(selector, args) { 3062 if (selector.__unstableNormalizeArgs && typeof selector.__unstableNormalizeArgs === 'function' && args?.length) { 3063 return selector.__unstableNormalizeArgs(args); 3064 } 3065 return args; 3066 } 3067 3068 ;// ./node_modules/@wordpress/data/build-module/store/index.js 3069 const coreDataStore = { 3070 name: 'core/data', 3071 instantiate(registry) { 3072 const getCoreDataSelector = selectorName => (key, ...args) => { 3073 return registry.select(key)[selectorName](...args); 3074 }; 3075 const getCoreDataAction = actionName => (key, ...args) => { 3076 return registry.dispatch(key)[actionName](...args); 3077 }; 3078 return { 3079 getSelectors() { 3080 return Object.fromEntries(['getIsResolving', 'hasStartedResolution', 'hasFinishedResolution', 'isResolving', 'getCachedResolvers'].map(selectorName => [selectorName, getCoreDataSelector(selectorName)])); 3081 }, 3082 getActions() { 3083 return Object.fromEntries(['startResolution', 'finishResolution', 'invalidateResolution', 'invalidateResolutionForStore', 'invalidateResolutionForStoreSelector'].map(actionName => [actionName, getCoreDataAction(actionName)])); 3084 }, 3085 subscribe() { 3086 // There's no reasons to trigger any listener when we subscribe to this store 3087 // because there's no state stored in this store that need to retrigger selectors 3088 // if a change happens, the corresponding store where the tracking stated live 3089 // would have already triggered a "subscribe" call. 3090 return () => () => {}; 3091 } 3092 }; 3093 } 3094 }; 3095 /* harmony default export */ const store = (coreDataStore); 3096 3097 ;// ./node_modules/@wordpress/data/build-module/utils/emitter.js 3098 /** 3099 * Create an event emitter. 3100 * 3101 * @return {import("../types").DataEmitter} Emitter. 3102 */ 3103 function createEmitter() { 3104 let isPaused = false; 3105 let isPending = false; 3106 const listeners = new Set(); 3107 const notifyListeners = () => 3108 // We use Array.from to clone the listeners Set 3109 // This ensures that we don't run a listener 3110 // that was added as a response to another listener. 3111 Array.from(listeners).forEach(listener => listener()); 3112 return { 3113 get isPaused() { 3114 return isPaused; 3115 }, 3116 subscribe(listener) { 3117 listeners.add(listener); 3118 return () => listeners.delete(listener); 3119 }, 3120 pause() { 3121 isPaused = true; 3122 }, 3123 resume() { 3124 isPaused = false; 3125 if (isPending) { 3126 isPending = false; 3127 notifyListeners(); 3128 } 3129 }, 3130 emit() { 3131 if (isPaused) { 3132 isPending = true; 3133 return; 3134 } 3135 notifyListeners(); 3136 } 3137 }; 3138 } 3139 3140 ;// ./node_modules/@wordpress/data/build-module/registry.js 3141 /** 3142 * WordPress dependencies 3143 */ 3144 3145 3146 /** 3147 * Internal dependencies 3148 */ 3149 3150 3151 3152 3153 3154 /** @typedef {import('./types').StoreDescriptor} StoreDescriptor */ 3155 3156 /** 3157 * @typedef {Object} WPDataRegistry An isolated orchestrator of store registrations. 3158 * 3159 * @property {Function} registerGenericStore Given a namespace key and settings 3160 * object, registers a new generic 3161 * store. 3162 * @property {Function} registerStore Given a namespace key and settings 3163 * object, registers a new namespace 3164 * store. 3165 * @property {Function} subscribe Given a function callback, invokes 3166 * the callback on any change to state 3167 * within any registered store. 3168 * @property {Function} select Given a namespace key, returns an 3169 * object of the store's registered 3170 * selectors. 3171 * @property {Function} dispatch Given a namespace key, returns an 3172 * object of the store's registered 3173 * action dispatchers. 3174 */ 3175 3176 /** 3177 * @typedef {Object} WPDataPlugin An object of registry function overrides. 3178 * 3179 * @property {Function} registerStore registers store. 3180 */ 3181 3182 function getStoreName(storeNameOrDescriptor) { 3183 return typeof storeNameOrDescriptor === 'string' ? storeNameOrDescriptor : storeNameOrDescriptor.name; 3184 } 3185 /** 3186 * Creates a new store registry, given an optional object of initial store 3187 * configurations. 3188 * 3189 * @param {Object} storeConfigs Initial store configurations. 3190 * @param {Object?} parent Parent registry. 3191 * 3192 * @return {WPDataRegistry} Data registry. 3193 */ 3194 function createRegistry(storeConfigs = {}, parent = null) { 3195 const stores = {}; 3196 const emitter = createEmitter(); 3197 let listeningStores = null; 3198 3199 /** 3200 * Global listener called for each store's update. 3201 */ 3202 function globalListener() { 3203 emitter.emit(); 3204 } 3205 3206 /** 3207 * Subscribe to changes to any data, either in all stores in registry, or 3208 * in one specific store. 3209 * 3210 * @param {Function} listener Listener function. 3211 * @param {string|StoreDescriptor?} storeNameOrDescriptor Optional store name. 3212 * 3213 * @return {Function} Unsubscribe function. 3214 */ 3215 const subscribe = (listener, storeNameOrDescriptor) => { 3216 // subscribe to all stores 3217 if (!storeNameOrDescriptor) { 3218 return emitter.subscribe(listener); 3219 } 3220 3221 // subscribe to one store 3222 const storeName = getStoreName(storeNameOrDescriptor); 3223 const store = stores[storeName]; 3224 if (store) { 3225 return store.subscribe(listener); 3226 } 3227 3228 // Trying to access a store that hasn't been registered, 3229 // this is a pattern rarely used but seen in some places. 3230 // We fallback to global `subscribe` here for backward-compatibility for now. 3231 // See https://github.com/WordPress/gutenberg/pull/27466 for more info. 3232 if (!parent) { 3233 return emitter.subscribe(listener); 3234 } 3235 return parent.subscribe(listener, storeNameOrDescriptor); 3236 }; 3237 3238 /** 3239 * Calls a selector given the current state and extra arguments. 3240 * 3241 * @param {string|StoreDescriptor} storeNameOrDescriptor Unique namespace identifier for the store 3242 * or the store descriptor. 3243 * 3244 * @return {*} The selector's returned value. 3245 */ 3246 function select(storeNameOrDescriptor) { 3247 const storeName = getStoreName(storeNameOrDescriptor); 3248 listeningStores?.add(storeName); 3249 const store = stores[storeName]; 3250 if (store) { 3251 return store.getSelectors(); 3252 } 3253 return parent?.select(storeName); 3254 } 3255 function __unstableMarkListeningStores(callback, ref) { 3256 listeningStores = new Set(); 3257 try { 3258 return callback.call(this); 3259 } finally { 3260 ref.current = Array.from(listeningStores); 3261 listeningStores = null; 3262 } 3263 } 3264 3265 /** 3266 * Given a store descriptor, returns an object containing the store's selectors pre-bound to 3267 * state so that you only need to supply additional arguments, and modified so that they return 3268 * promises that resolve to their eventual values, after any resolvers have ran. 3269 * 3270 * @param {StoreDescriptor|string} storeNameOrDescriptor The store descriptor. The legacy calling 3271 * convention of passing the store name is 3272 * also supported. 3273 * 3274 * @return {Object} Each key of the object matches the name of a selector. 3275 */ 3276 function resolveSelect(storeNameOrDescriptor) { 3277 const storeName = getStoreName(storeNameOrDescriptor); 3278 listeningStores?.add(storeName); 3279 const store = stores[storeName]; 3280 if (store) { 3281 return store.getResolveSelectors(); 3282 } 3283 return parent && parent.resolveSelect(storeName); 3284 } 3285 3286 /** 3287 * Given a store descriptor, returns an object containing the store's selectors pre-bound to 3288 * state so that you only need to supply additional arguments, and modified so that they throw 3289 * promises in case the selector is not resolved yet. 3290 * 3291 * @param {StoreDescriptor|string} storeNameOrDescriptor The store descriptor. The legacy calling 3292 * convention of passing the store name is 3293 * also supported. 3294 * 3295 * @return {Object} Object containing the store's suspense-wrapped selectors. 3296 */ 3297 function suspendSelect(storeNameOrDescriptor) { 3298 const storeName = getStoreName(storeNameOrDescriptor); 3299 listeningStores?.add(storeName); 3300 const store = stores[storeName]; 3301 if (store) { 3302 return store.getSuspendSelectors(); 3303 } 3304 return parent && parent.suspendSelect(storeName); 3305 } 3306 3307 /** 3308 * Returns the available actions for a part of the state. 3309 * 3310 * @param {string|StoreDescriptor} storeNameOrDescriptor Unique namespace identifier for the store 3311 * or the store descriptor. 3312 * 3313 * @return {*} The action's returned value. 3314 */ 3315 function dispatch(storeNameOrDescriptor) { 3316 const storeName = getStoreName(storeNameOrDescriptor); 3317 const store = stores[storeName]; 3318 if (store) { 3319 return store.getActions(); 3320 } 3321 return parent && parent.dispatch(storeName); 3322 } 3323 3324 // 3325 // Deprecated 3326 // TODO: Remove this after `use()` is removed. 3327 function withPlugins(attributes) { 3328 return Object.fromEntries(Object.entries(attributes).map(([key, attribute]) => { 3329 if (typeof attribute !== 'function') { 3330 return [key, attribute]; 3331 } 3332 return [key, function () { 3333 return registry[key].apply(null, arguments); 3334 }]; 3335 })); 3336 } 3337 3338 /** 3339 * Registers a store instance. 3340 * 3341 * @param {string} name Store registry name. 3342 * @param {Function} createStore Function that creates a store object (getSelectors, getActions, subscribe). 3343 */ 3344 function registerStoreInstance(name, createStore) { 3345 if (stores[name]) { 3346 // eslint-disable-next-line no-console 3347 console.error('Store "' + name + '" is already registered.'); 3348 return stores[name]; 3349 } 3350 const store = createStore(); 3351 if (typeof store.getSelectors !== 'function') { 3352 throw new TypeError('store.getSelectors must be a function'); 3353 } 3354 if (typeof store.getActions !== 'function') { 3355 throw new TypeError('store.getActions must be a function'); 3356 } 3357 if (typeof store.subscribe !== 'function') { 3358 throw new TypeError('store.subscribe must be a function'); 3359 } 3360 // The emitter is used to keep track of active listeners when the registry 3361 // get paused, that way, when resumed we should be able to call all these 3362 // pending listeners. 3363 store.emitter = createEmitter(); 3364 const currentSubscribe = store.subscribe; 3365 store.subscribe = listener => { 3366 const unsubscribeFromEmitter = store.emitter.subscribe(listener); 3367 const unsubscribeFromStore = currentSubscribe(() => { 3368 if (store.emitter.isPaused) { 3369 store.emitter.emit(); 3370 return; 3371 } 3372 listener(); 3373 }); 3374 return () => { 3375 unsubscribeFromStore?.(); 3376 unsubscribeFromEmitter?.(); 3377 }; 3378 }; 3379 stores[name] = store; 3380 store.subscribe(globalListener); 3381 3382 // Copy private actions and selectors from the parent store. 3383 if (parent) { 3384 try { 3385 unlock(store.store).registerPrivateActions(unlock(parent).privateActionsOf(name)); 3386 unlock(store.store).registerPrivateSelectors(unlock(parent).privateSelectorsOf(name)); 3387 } catch (e) { 3388 // unlock() throws if store.store was not locked. 3389 // The error indicates there's nothing to do here so let's 3390 // ignore it. 3391 } 3392 } 3393 return store; 3394 } 3395 3396 /** 3397 * Registers a new store given a store descriptor. 3398 * 3399 * @param {StoreDescriptor} store Store descriptor. 3400 */ 3401 function register(store) { 3402 registerStoreInstance(store.name, () => store.instantiate(registry)); 3403 } 3404 function registerGenericStore(name, store) { 3405 external_wp_deprecated_default()('wp.data.registerGenericStore', { 3406 since: '5.9', 3407 alternative: 'wp.data.register( storeDescriptor )' 3408 }); 3409 registerStoreInstance(name, () => store); 3410 } 3411 3412 /** 3413 * Registers a standard `@wordpress/data` store. 3414 * 3415 * @param {string} storeName Unique namespace identifier. 3416 * @param {Object} options Store description (reducer, actions, selectors, resolvers). 3417 * 3418 * @return {Object} Registered store object. 3419 */ 3420 function registerStore(storeName, options) { 3421 if (!options.reducer) { 3422 throw new TypeError('Must specify store reducer'); 3423 } 3424 const store = registerStoreInstance(storeName, () => createReduxStore(storeName, options).instantiate(registry)); 3425 return store.store; 3426 } 3427 function batch(callback) { 3428 // If we're already batching, just call the callback. 3429 if (emitter.isPaused) { 3430 callback(); 3431 return; 3432 } 3433 emitter.pause(); 3434 Object.values(stores).forEach(store => store.emitter.pause()); 3435 try { 3436 callback(); 3437 } finally { 3438 emitter.resume(); 3439 Object.values(stores).forEach(store => store.emitter.resume()); 3440 } 3441 } 3442 let registry = { 3443 batch, 3444 stores, 3445 namespaces: stores, 3446 // TODO: Deprecate/remove this. 3447 subscribe, 3448 select, 3449 resolveSelect, 3450 suspendSelect, 3451 dispatch, 3452 use, 3453 register, 3454 registerGenericStore, 3455 registerStore, 3456 __unstableMarkListeningStores 3457 }; 3458 3459 // 3460 // TODO: 3461 // This function will be deprecated as soon as it is no longer internally referenced. 3462 function use(plugin, options) { 3463 if (!plugin) { 3464 return; 3465 } 3466 registry = { 3467 ...registry, 3468 ...plugin(registry, options) 3469 }; 3470 return registry; 3471 } 3472 registry.register(store); 3473 for (const [name, config] of Object.entries(storeConfigs)) { 3474 registry.register(createReduxStore(name, config)); 3475 } 3476 if (parent) { 3477 parent.subscribe(globalListener); 3478 } 3479 const registryWithPlugins = withPlugins(registry); 3480 lock(registryWithPlugins, { 3481 privateActionsOf: name => { 3482 try { 3483 return unlock(stores[name].store).privateActions; 3484 } catch (e) { 3485 // unlock() throws an error the store was not locked – this means 3486 // there no private actions are available 3487 return {}; 3488 } 3489 }, 3490 privateSelectorsOf: name => { 3491 try { 3492 return unlock(stores[name].store).privateSelectors; 3493 } catch (e) { 3494 return {}; 3495 } 3496 } 3497 }); 3498 return registryWithPlugins; 3499 } 3500 3501 ;// ./node_modules/@wordpress/data/build-module/default-registry.js 3502 /** 3503 * Internal dependencies 3504 */ 3505 3506 /* harmony default export */ const default_registry = (createRegistry()); 3507 3508 ;// ./node_modules/is-plain-object/dist/is-plain-object.mjs 3509 /*! 3510 * is-plain-object <https://github.com/jonschlinkert/is-plain-object> 3511 * 3512 * Copyright (c) 2014-2017, Jon Schlinkert. 3513 * Released under the MIT License. 3514 */ 3515 3516 function is_plain_object_isObject(o) { 3517 return Object.prototype.toString.call(o) === '[object Object]'; 3518 } 3519 3520 function is_plain_object_isPlainObject(o) { 3521 var ctor,prot; 3522 3523 if (is_plain_object_isObject(o) === false) return false; 3524 3525 // If has modified constructor 3526 ctor = o.constructor; 3527 if (ctor === undefined) return true; 3528 3529 // If has modified prototype 3530 prot = ctor.prototype; 3531 if (is_plain_object_isObject(prot) === false) return false; 3532 3533 // If constructor does not have an Object-specific method 3534 if (prot.hasOwnProperty('isPrototypeOf') === false) { 3535 return false; 3536 } 3537 3538 // Most likely a plain Object 3539 return true; 3540 } 3541 3542 3543 3544 // EXTERNAL MODULE: ./node_modules/deepmerge/dist/cjs.js 3545 var cjs = __webpack_require__(66); 3546 var cjs_default = /*#__PURE__*/__webpack_require__.n(cjs); 3547 ;// ./node_modules/@wordpress/data/build-module/plugins/persistence/storage/object.js 3548 let objectStorage; 3549 const storage = { 3550 getItem(key) { 3551 if (!objectStorage || !objectStorage[key]) { 3552 return null; 3553 } 3554 return objectStorage[key]; 3555 }, 3556 setItem(key, value) { 3557 if (!objectStorage) { 3558 storage.clear(); 3559 } 3560 objectStorage[key] = String(value); 3561 }, 3562 clear() { 3563 objectStorage = Object.create(null); 3564 } 3565 }; 3566 /* harmony default export */ const object = (storage); 3567 3568 ;// ./node_modules/@wordpress/data/build-module/plugins/persistence/storage/default.js 3569 /** 3570 * Internal dependencies 3571 */ 3572 3573 let default_storage; 3574 try { 3575 // Private Browsing in Safari 10 and earlier will throw an error when 3576 // attempting to set into localStorage. The test here is intentional in 3577 // causing a thrown error as condition for using fallback object storage. 3578 default_storage = window.localStorage; 3579 default_storage.setItem('__wpDataTestLocalStorage', ''); 3580 default_storage.removeItem('__wpDataTestLocalStorage'); 3581 } catch (error) { 3582 default_storage = object; 3583 } 3584 /* harmony default export */ const storage_default = (default_storage); 3585 3586 ;// ./node_modules/@wordpress/data/build-module/plugins/persistence/index.js 3587 /** 3588 * External dependencies 3589 */ 3590 3591 3592 3593 /** 3594 * Internal dependencies 3595 */ 3596 3597 3598 3599 /** @typedef {import('../../registry').WPDataRegistry} WPDataRegistry */ 3600 3601 /** @typedef {import('../../registry').WPDataPlugin} WPDataPlugin */ 3602 3603 /** 3604 * @typedef {Object} WPDataPersistencePluginOptions Persistence plugin options. 3605 * 3606 * @property {Storage} storage Persistent storage implementation. This must 3607 * at least implement `getItem` and `setItem` of 3608 * the Web Storage API. 3609 * @property {string} storageKey Key on which to set in persistent storage. 3610 */ 3611 3612 /** 3613 * Default plugin storage. 3614 * 3615 * @type {Storage} 3616 */ 3617 const DEFAULT_STORAGE = storage_default; 3618 3619 /** 3620 * Default plugin storage key. 3621 * 3622 * @type {string} 3623 */ 3624 const DEFAULT_STORAGE_KEY = 'WP_DATA'; 3625 3626 /** 3627 * Higher-order reducer which invokes the original reducer only if state is 3628 * inequal from that of the action's `nextState` property, otherwise returning 3629 * the original state reference. 3630 * 3631 * @param {Function} reducer Original reducer. 3632 * 3633 * @return {Function} Enhanced reducer. 3634 */ 3635 const withLazySameState = reducer => (state, action) => { 3636 if (action.nextState === state) { 3637 return state; 3638 } 3639 return reducer(state, action); 3640 }; 3641 3642 /** 3643 * Creates a persistence interface, exposing getter and setter methods (`get` 3644 * and `set` respectively). 3645 * 3646 * @param {WPDataPersistencePluginOptions} options Plugin options. 3647 * 3648 * @return {Object} Persistence interface. 3649 */ 3650 function createPersistenceInterface(options) { 3651 const { 3652 storage = DEFAULT_STORAGE, 3653 storageKey = DEFAULT_STORAGE_KEY 3654 } = options; 3655 let data; 3656 3657 /** 3658 * Returns the persisted data as an object, defaulting to an empty object. 3659 * 3660 * @return {Object} Persisted data. 3661 */ 3662 function getData() { 3663 if (data === undefined) { 3664 // If unset, getItem is expected to return null. Fall back to 3665 // empty object. 3666 const persisted = storage.getItem(storageKey); 3667 if (persisted === null) { 3668 data = {}; 3669 } else { 3670 try { 3671 data = JSON.parse(persisted); 3672 } catch (error) { 3673 // Similarly, should any error be thrown during parse of 3674 // the string (malformed JSON), fall back to empty object. 3675 data = {}; 3676 } 3677 } 3678 } 3679 return data; 3680 } 3681 3682 /** 3683 * Merges an updated reducer state into the persisted data. 3684 * 3685 * @param {string} key Key to update. 3686 * @param {*} value Updated value. 3687 */ 3688 function setData(key, value) { 3689 data = { 3690 ...data, 3691 [key]: value 3692 }; 3693 storage.setItem(storageKey, JSON.stringify(data)); 3694 } 3695 return { 3696 get: getData, 3697 set: setData 3698 }; 3699 } 3700 3701 /** 3702 * Data plugin to persist store state into a single storage key. 3703 * 3704 * @param {WPDataRegistry} registry Data registry. 3705 * @param {?WPDataPersistencePluginOptions} pluginOptions Plugin options. 3706 * 3707 * @return {WPDataPlugin} Data plugin. 3708 */ 3709 function persistencePlugin(registry, pluginOptions) { 3710 const persistence = createPersistenceInterface(pluginOptions); 3711 3712 /** 3713 * Creates an enhanced store dispatch function, triggering the state of the 3714 * given store name to be persisted when changed. 3715 * 3716 * @param {Function} getState Function which returns current state. 3717 * @param {string} storeName Store name. 3718 * @param {?Array<string>} keys Optional subset of keys to save. 3719 * 3720 * @return {Function} Enhanced dispatch function. 3721 */ 3722 function createPersistOnChange(getState, storeName, keys) { 3723 let getPersistedState; 3724 if (Array.isArray(keys)) { 3725 // Given keys, the persisted state should by produced as an object 3726 // of the subset of keys. This implementation uses combineReducers 3727 // to leverage its behavior of returning the same object when none 3728 // of the property values changes. This allows a strict reference 3729 // equality to bypass a persistence set on an unchanging state. 3730 const reducers = keys.reduce((accumulator, key) => Object.assign(accumulator, { 3731 [key]: (state, action) => action.nextState[key] 3732 }), {}); 3733 getPersistedState = withLazySameState(build_module_combineReducers(reducers)); 3734 } else { 3735 getPersistedState = (state, action) => action.nextState; 3736 } 3737 let lastState = getPersistedState(undefined, { 3738 nextState: getState() 3739 }); 3740 return () => { 3741 const state = getPersistedState(lastState, { 3742 nextState: getState() 3743 }); 3744 if (state !== lastState) { 3745 persistence.set(storeName, state); 3746 lastState = state; 3747 } 3748 }; 3749 } 3750 return { 3751 registerStore(storeName, options) { 3752 if (!options.persist) { 3753 return registry.registerStore(storeName, options); 3754 } 3755 3756 // Load from persistence to use as initial state. 3757 const persistedState = persistence.get()[storeName]; 3758 if (persistedState !== undefined) { 3759 let initialState = options.reducer(options.initialState, { 3760 type: '@@WP/PERSISTENCE_RESTORE' 3761 }); 3762 if (is_plain_object_isPlainObject(initialState) && is_plain_object_isPlainObject(persistedState)) { 3763 // If state is an object, ensure that: 3764 // - Other keys are left intact when persisting only a 3765 // subset of keys. 3766 // - New keys in what would otherwise be used as initial 3767 // state are deeply merged as base for persisted value. 3768 initialState = cjs_default()(initialState, persistedState, { 3769 isMergeableObject: is_plain_object_isPlainObject 3770 }); 3771 } else { 3772 // If there is a mismatch in object-likeness of default 3773 // initial or persisted state, defer to persisted value. 3774 initialState = persistedState; 3775 } 3776 options = { 3777 ...options, 3778 initialState 3779 }; 3780 } 3781 const store = registry.registerStore(storeName, options); 3782 store.subscribe(createPersistOnChange(store.getState, storeName, options.persist)); 3783 return store; 3784 } 3785 }; 3786 } 3787 persistencePlugin.__unstableMigrate = () => {}; 3788 /* harmony default export */ const persistence = (persistencePlugin); 3789 3790 ;// ./node_modules/@wordpress/data/build-module/plugins/index.js 3791 3792 3793 ;// external ["wp","priorityQueue"] 3794 const external_wp_priorityQueue_namespaceObject = window["wp"]["priorityQueue"]; 3795 ;// external ["wp","element"] 3796 const external_wp_element_namespaceObject = window["wp"]["element"]; 3797 ;// external ["wp","isShallowEqual"] 3798 const external_wp_isShallowEqual_namespaceObject = window["wp"]["isShallowEqual"]; 3799 var external_wp_isShallowEqual_default = /*#__PURE__*/__webpack_require__.n(external_wp_isShallowEqual_namespaceObject); 3800 ;// ./node_modules/@wordpress/data/build-module/components/registry-provider/context.js 3801 /** 3802 * WordPress dependencies 3803 */ 3804 3805 3806 /** 3807 * Internal dependencies 3808 */ 3809 3810 const Context = (0,external_wp_element_namespaceObject.createContext)(default_registry); 3811 const { 3812 Consumer, 3813 Provider 3814 } = Context; 3815 3816 /** 3817 * A custom react Context consumer exposing the provided `registry` to 3818 * children components. Used along with the RegistryProvider. 3819 * 3820 * You can read more about the react context api here: 3821 * https://react.dev/learn/passing-data-deeply-with-context#step-3-provide-the-context 3822 * 3823 * @example 3824 * ```js 3825 * import { 3826 * RegistryProvider, 3827 * RegistryConsumer, 3828 * createRegistry 3829 * } from '@wordpress/data'; 3830 * 3831 * const registry = createRegistry( {} ); 3832 * 3833 * const App = ( { props } ) => { 3834 * return <RegistryProvider value={ registry }> 3835 * <div>Hello There</div> 3836 * <RegistryConsumer> 3837 * { ( registry ) => ( 3838 * <ComponentUsingRegistry 3839 * { ...props } 3840 * registry={ registry } 3841 * ) } 3842 * </RegistryConsumer> 3843 * </RegistryProvider> 3844 * } 3845 * ``` 3846 */ 3847 const RegistryConsumer = Consumer; 3848 3849 /** 3850 * A custom Context provider for exposing the provided `registry` to children 3851 * components via a consumer. 3852 * 3853 * See <a name="#RegistryConsumer">RegistryConsumer</a> documentation for 3854 * example. 3855 */ 3856 /* harmony default export */ const context = (Provider); 3857 3858 ;// ./node_modules/@wordpress/data/build-module/components/registry-provider/use-registry.js 3859 /** 3860 * WordPress dependencies 3861 */ 3862 3863 3864 /** 3865 * Internal dependencies 3866 */ 3867 3868 3869 /** 3870 * A custom react hook exposing the registry context for use. 3871 * 3872 * This exposes the `registry` value provided via the 3873 * <a href="#RegistryProvider">Registry Provider</a> to a component implementing 3874 * this hook. 3875 * 3876 * It acts similarly to the `useContext` react hook. 3877 * 3878 * Note: Generally speaking, `useRegistry` is a low level hook that in most cases 3879 * won't be needed for implementation. Most interactions with the `@wordpress/data` 3880 * API can be performed via the `useSelect` hook, or the `withSelect` and 3881 * `withDispatch` higher order components. 3882 * 3883 * @example 3884 * ```js 3885 * import { 3886 * RegistryProvider, 3887 * createRegistry, 3888 * useRegistry, 3889 * } from '@wordpress/data'; 3890 * 3891 * const registry = createRegistry( {} ); 3892 * 3893 * const SomeChildUsingRegistry = ( props ) => { 3894 * const registry = useRegistry(); 3895 * // ...logic implementing the registry in other react hooks. 3896 * }; 3897 * 3898 * 3899 * const ParentProvidingRegistry = ( props ) => { 3900 * return <RegistryProvider value={ registry }> 3901 * <SomeChildUsingRegistry { ...props } /> 3902 * </RegistryProvider> 3903 * }; 3904 * ``` 3905 * 3906 * @return {Function} A custom react hook exposing the registry context value. 3907 */ 3908 function useRegistry() { 3909 return (0,external_wp_element_namespaceObject.useContext)(Context); 3910 } 3911 3912 ;// ./node_modules/@wordpress/data/build-module/components/async-mode-provider/context.js 3913 /** 3914 * WordPress dependencies 3915 */ 3916 3917 const context_Context = (0,external_wp_element_namespaceObject.createContext)(false); 3918 const { 3919 Consumer: context_Consumer, 3920 Provider: context_Provider 3921 } = context_Context; 3922 const AsyncModeConsumer = (/* unused pure expression or super */ null && (context_Consumer)); 3923 3924 /** 3925 * Context Provider Component used to switch the data module component rerendering 3926 * between Sync and Async modes. 3927 * 3928 * @example 3929 * 3930 * ```js 3931 * import { useSelect, AsyncModeProvider } from '@wordpress/data'; 3932 * import { store as blockEditorStore } from '@wordpress/block-editor'; 3933 * 3934 * function BlockCount() { 3935 * const count = useSelect( ( select ) => { 3936 * return select( blockEditorStore ).getBlockCount() 3937 * }, [] ); 3938 * 3939 * return count; 3940 * } 3941 * 3942 * function App() { 3943 * return ( 3944 * <AsyncModeProvider value={ true }> 3945 * <BlockCount /> 3946 * </AsyncModeProvider> 3947 * ); 3948 * } 3949 * ``` 3950 * 3951 * In this example, the BlockCount component is rerendered asynchronously. 3952 * It means if a more critical task is being performed (like typing in an input), 3953 * the rerendering is delayed until the browser becomes IDLE. 3954 * It is possible to nest multiple levels of AsyncModeProvider to fine-tune the rendering behavior. 3955 * 3956 * @param {boolean} props.value Enable Async Mode. 3957 * @return {Component} The component to be rendered. 3958 */ 3959 /* harmony default export */ const async_mode_provider_context = (context_Provider); 3960 3961 ;// ./node_modules/@wordpress/data/build-module/components/async-mode-provider/use-async-mode.js 3962 /** 3963 * WordPress dependencies 3964 */ 3965 3966 3967 /** 3968 * Internal dependencies 3969 */ 3970 3971 function useAsyncMode() { 3972 return (0,external_wp_element_namespaceObject.useContext)(context_Context); 3973 } 3974 3975 ;// ./node_modules/@wordpress/data/build-module/components/use-select/index.js 3976 /** 3977 * WordPress dependencies 3978 */ 3979 3980 3981 3982 3983 /** 3984 * Internal dependencies 3985 */ 3986 3987 3988 const renderQueue = (0,external_wp_priorityQueue_namespaceObject.createQueue)(); 3989 3990 /** 3991 * @typedef {import('../../types').StoreDescriptor<C>} StoreDescriptor 3992 * @template {import('../../types').AnyConfig} C 3993 */ 3994 /** 3995 * @typedef {import('../../types').ReduxStoreConfig<State,Actions,Selectors>} ReduxStoreConfig 3996 * @template State 3997 * @template {Record<string,import('../../types').ActionCreator>} Actions 3998 * @template Selectors 3999 */ 4000 /** @typedef {import('../../types').MapSelect} MapSelect */ 4001 /** 4002 * @typedef {import('../../types').UseSelectReturn<T>} UseSelectReturn 4003 * @template {MapSelect|StoreDescriptor<any>} T 4004 */ 4005 4006 function Store(registry, suspense) { 4007 const select = suspense ? registry.suspendSelect : registry.select; 4008 const queueContext = {}; 4009 let lastMapSelect; 4010 let lastMapResult; 4011 let lastMapResultValid = false; 4012 let lastIsAsync; 4013 let subscriber; 4014 let didWarnUnstableReference; 4015 const storeStatesOnMount = new Map(); 4016 function getStoreState(name) { 4017 var _registry$stores$name; 4018 // If there's no store property (custom generic store), return an empty 4019 // object. When comparing the state, the empty objects will cause the 4020 // equality check to fail, setting `lastMapResultValid` to false. 4021 return (_registry$stores$name = registry.stores[name]?.store?.getState?.()) !== null && _registry$stores$name !== void 0 ? _registry$stores$name : {}; 4022 } 4023 const createSubscriber = stores => { 4024 // The set of stores the `subscribe` function is supposed to subscribe to. Here it is 4025 // initialized, and then the `updateStores` function can add new stores to it. 4026 const activeStores = [...stores]; 4027 4028 // The `subscribe` function, which is passed to the `useSyncExternalStore` hook, could 4029 // be called multiple times to establish multiple subscriptions. That's why we need to 4030 // keep a set of active subscriptions; 4031 const activeSubscriptions = new Set(); 4032 function subscribe(listener) { 4033 // Maybe invalidate the value right after subscription was created. 4034 // React will call `getValue` after subscribing, to detect store 4035 // updates that happened in the interval between the `getValue` call 4036 // during render and creating the subscription, which is slightly 4037 // delayed. We need to ensure that this second `getValue` call will 4038 // compute a fresh value only if any of the store states have 4039 // changed in the meantime. 4040 if (lastMapResultValid) { 4041 for (const name of activeStores) { 4042 if (storeStatesOnMount.get(name) !== getStoreState(name)) { 4043 lastMapResultValid = false; 4044 } 4045 } 4046 } 4047 storeStatesOnMount.clear(); 4048 const onStoreChange = () => { 4049 // Invalidate the value on store update, so that a fresh value is computed. 4050 lastMapResultValid = false; 4051 listener(); 4052 }; 4053 const onChange = () => { 4054 if (lastIsAsync) { 4055 renderQueue.add(queueContext, onStoreChange); 4056 } else { 4057 onStoreChange(); 4058 } 4059 }; 4060 const unsubs = []; 4061 function subscribeStore(storeName) { 4062 unsubs.push(registry.subscribe(onChange, storeName)); 4063 } 4064 for (const storeName of activeStores) { 4065 subscribeStore(storeName); 4066 } 4067 activeSubscriptions.add(subscribeStore); 4068 return () => { 4069 activeSubscriptions.delete(subscribeStore); 4070 for (const unsub of unsubs.values()) { 4071 // The return value of the subscribe function could be undefined if the store is a custom generic store. 4072 unsub?.(); 4073 } 4074 // Cancel existing store updates that were already scheduled. 4075 renderQueue.cancel(queueContext); 4076 }; 4077 } 4078 4079 // Check if `newStores` contains some stores we're not subscribed to yet, and add them. 4080 function updateStores(newStores) { 4081 for (const newStore of newStores) { 4082 if (activeStores.includes(newStore)) { 4083 continue; 4084 } 4085 4086 // New `subscribe` calls will subscribe to `newStore`, too. 4087 activeStores.push(newStore); 4088 4089 // Add `newStore` to existing subscriptions. 4090 for (const subscription of activeSubscriptions) { 4091 subscription(newStore); 4092 } 4093 } 4094 } 4095 return { 4096 subscribe, 4097 updateStores 4098 }; 4099 }; 4100 return (mapSelect, isAsync) => { 4101 function updateValue() { 4102 // If the last value is valid, and the `mapSelect` callback hasn't changed, 4103 // then we can safely return the cached value. The value can change only on 4104 // store update, and in that case value will be invalidated by the listener. 4105 if (lastMapResultValid && mapSelect === lastMapSelect) { 4106 return lastMapResult; 4107 } 4108 const listeningStores = { 4109 current: null 4110 }; 4111 const mapResult = registry.__unstableMarkListeningStores(() => mapSelect(select, registry), listeningStores); 4112 if (false) {} 4113 if (!subscriber) { 4114 for (const name of listeningStores.current) { 4115 storeStatesOnMount.set(name, getStoreState(name)); 4116 } 4117 subscriber = createSubscriber(listeningStores.current); 4118 } else { 4119 subscriber.updateStores(listeningStores.current); 4120 } 4121 4122 // If the new value is shallow-equal to the old one, keep the old one so 4123 // that we don't trigger unwanted updates that do a `===` check. 4124 if (!external_wp_isShallowEqual_default()(lastMapResult, mapResult)) { 4125 lastMapResult = mapResult; 4126 } 4127 lastMapSelect = mapSelect; 4128 lastMapResultValid = true; 4129 } 4130 function getValue() { 4131 // Update the value in case it's been invalidated or `mapSelect` has changed. 4132 updateValue(); 4133 return lastMapResult; 4134 } 4135 4136 // When transitioning from async to sync mode, cancel existing store updates 4137 // that have been scheduled, and invalidate the value so that it's freshly 4138 // computed. It might have been changed by the update we just cancelled. 4139 if (lastIsAsync && !isAsync) { 4140 lastMapResultValid = false; 4141 renderQueue.cancel(queueContext); 4142 } 4143 updateValue(); 4144 lastIsAsync = isAsync; 4145 4146 // Return a pair of functions that can be passed to `useSyncExternalStore`. 4147 return { 4148 subscribe: subscriber.subscribe, 4149 getValue 4150 }; 4151 }; 4152 } 4153 function useStaticSelect(storeName) { 4154 return useRegistry().select(storeName); 4155 } 4156 function useMappingSelect(suspense, mapSelect, deps) { 4157 const registry = useRegistry(); 4158 const isAsync = useAsyncMode(); 4159 const store = (0,external_wp_element_namespaceObject.useMemo)(() => Store(registry, suspense), [registry, suspense]); 4160 4161 // These are "pass-through" dependencies from the parent hook, 4162 // and the parent should catch any hook rule violations. 4163 // eslint-disable-next-line react-hooks/exhaustive-deps 4164 const selector = (0,external_wp_element_namespaceObject.useCallback)(mapSelect, deps); 4165 const { 4166 subscribe, 4167 getValue 4168 } = store(selector, isAsync); 4169 const result = (0,external_wp_element_namespaceObject.useSyncExternalStore)(subscribe, getValue, getValue); 4170 (0,external_wp_element_namespaceObject.useDebugValue)(result); 4171 return result; 4172 } 4173 4174 /** 4175 * Custom react hook for retrieving props from registered selectors. 4176 * 4177 * In general, this custom React hook follows the 4178 * [rules of hooks](https://react.dev/reference/rules/rules-of-hooks). 4179 * 4180 * @template {MapSelect | StoreDescriptor<any>} T 4181 * @param {T} mapSelect Function called on every state change. The returned value is 4182 * exposed to the component implementing this hook. The function 4183 * receives the `registry.select` method on the first argument 4184 * and the `registry` on the second argument. 4185 * When a store key is passed, all selectors for the store will be 4186 * returned. This is only meant for usage of these selectors in event 4187 * callbacks, not for data needed to create the element tree. 4188 * @param {unknown[]} deps If provided, this memoizes the mapSelect so the same `mapSelect` is 4189 * invoked on every state change unless the dependencies change. 4190 * 4191 * @example 4192 * ```js 4193 * import { useSelect } from '@wordpress/data'; 4194 * import { store as myCustomStore } from 'my-custom-store'; 4195 * 4196 * function HammerPriceDisplay( { currency } ) { 4197 * const price = useSelect( ( select ) => { 4198 * return select( myCustomStore ).getPrice( 'hammer', currency ); 4199 * }, [ currency ] ); 4200 * return new Intl.NumberFormat( 'en-US', { 4201 * style: 'currency', 4202 * currency, 4203 * } ).format( price ); 4204 * } 4205 * 4206 * // Rendered in the application: 4207 * // <HammerPriceDisplay currency="USD" /> 4208 * ``` 4209 * 4210 * In the above example, when `HammerPriceDisplay` is rendered into an 4211 * application, the price will be retrieved from the store state using the 4212 * `mapSelect` callback on `useSelect`. If the currency prop changes then 4213 * any price in the state for that currency is retrieved. If the currency prop 4214 * doesn't change and other props are passed in that do change, the price will 4215 * not change because the dependency is just the currency. 4216 * 4217 * When data is only used in an event callback, the data should not be retrieved 4218 * on render, so it may be useful to get the selectors function instead. 4219 * 4220 * **Don't use `useSelect` this way when calling the selectors in the render 4221 * function because your component won't re-render on a data change.** 4222 * 4223 * ```js 4224 * import { useSelect } from '@wordpress/data'; 4225 * import { store as myCustomStore } from 'my-custom-store'; 4226 * 4227 * function Paste( { children } ) { 4228 * const { getSettings } = useSelect( myCustomStore ); 4229 * function onPaste() { 4230 * // Do something with the settings. 4231 * const settings = getSettings(); 4232 * } 4233 * return <div onPaste={ onPaste }>{ children }</div>; 4234 * } 4235 * ``` 4236 * @return {UseSelectReturn<T>} A custom react hook. 4237 */ 4238 function useSelect(mapSelect, deps) { 4239 // On initial call, on mount, determine the mode of this `useSelect` call 4240 // and then never allow it to change on subsequent updates. 4241 const staticSelectMode = typeof mapSelect !== 'function'; 4242 const staticSelectModeRef = (0,external_wp_element_namespaceObject.useRef)(staticSelectMode); 4243 if (staticSelectMode !== staticSelectModeRef.current) { 4244 const prevMode = staticSelectModeRef.current ? 'static' : 'mapping'; 4245 const nextMode = staticSelectMode ? 'static' : 'mapping'; 4246 throw new Error(`Switching useSelect from $prevMode} to $nextMode} is not allowed`); 4247 } 4248 4249 /* eslint-disable react-hooks/rules-of-hooks */ 4250 // `staticSelectMode` is not allowed to change during the hook instance's, 4251 // lifetime, so the rules of hooks are not really violated. 4252 return staticSelectMode ? useStaticSelect(mapSelect) : useMappingSelect(false, mapSelect, deps); 4253 /* eslint-enable react-hooks/rules-of-hooks */ 4254 } 4255 4256 /** 4257 * A variant of the `useSelect` hook that has the same API, but is a compatible 4258 * Suspense-enabled data source. 4259 * 4260 * @template {MapSelect} T 4261 * @param {T} mapSelect Function called on every state change. The 4262 * returned value is exposed to the component 4263 * using this hook. The function receives the 4264 * `registry.suspendSelect` method as the first 4265 * argument and the `registry` as the second one. 4266 * @param {Array} deps A dependency array used to memoize the `mapSelect` 4267 * so that the same `mapSelect` is invoked on every 4268 * state change unless the dependencies change. 4269 * 4270 * @throws {Promise} A suspense Promise that is thrown if any of the called 4271 * selectors is in an unresolved state. 4272 * 4273 * @return {ReturnType<T>} Data object returned by the `mapSelect` function. 4274 */ 4275 function useSuspenseSelect(mapSelect, deps) { 4276 return useMappingSelect(true, mapSelect, deps); 4277 } 4278 4279 ;// external "ReactJSXRuntime" 4280 const external_ReactJSXRuntime_namespaceObject = window["ReactJSXRuntime"]; 4281 ;// ./node_modules/@wordpress/data/build-module/components/with-select/index.js 4282 /** 4283 * WordPress dependencies 4284 */ 4285 4286 4287 /** 4288 * Internal dependencies 4289 */ 4290 4291 4292 /** @typedef {import('react').ComponentType} ComponentType */ 4293 4294 /** 4295 * Higher-order component used to inject state-derived props using registered 4296 * selectors. 4297 * 4298 * @param {Function} mapSelectToProps Function called on every state change, 4299 * expected to return object of props to 4300 * merge with the component's own props. 4301 * 4302 * @example 4303 * ```js 4304 * import { withSelect } from '@wordpress/data'; 4305 * import { store as myCustomStore } from 'my-custom-store'; 4306 * 4307 * function PriceDisplay( { price, currency } ) { 4308 * return new Intl.NumberFormat( 'en-US', { 4309 * style: 'currency', 4310 * currency, 4311 * } ).format( price ); 4312 * } 4313 * 4314 * const HammerPriceDisplay = withSelect( ( select, ownProps ) => { 4315 * const { getPrice } = select( myCustomStore ); 4316 * const { currency } = ownProps; 4317 * 4318 * return { 4319 * price: getPrice( 'hammer', currency ), 4320 * }; 4321 * } )( PriceDisplay ); 4322 * 4323 * // Rendered in the application: 4324 * // 4325 * // <HammerPriceDisplay currency="USD" /> 4326 * ``` 4327 * In the above example, when `HammerPriceDisplay` is rendered into an 4328 * application, it will pass the price into the underlying `PriceDisplay` 4329 * component and update automatically if the price of a hammer ever changes in 4330 * the store. 4331 * 4332 * @return {ComponentType} Enhanced component with merged state data props. 4333 */ 4334 4335 const withSelect = mapSelectToProps => (0,external_wp_compose_namespaceObject.createHigherOrderComponent)(WrappedComponent => (0,external_wp_compose_namespaceObject.pure)(ownProps => { 4336 const mapSelect = (select, registry) => mapSelectToProps(select, ownProps, registry); 4337 const mergeProps = useSelect(mapSelect); 4338 return /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(WrappedComponent, { 4339 ...ownProps, 4340 ...mergeProps 4341 }); 4342 }), 'withSelect'); 4343 /* harmony default export */ const with_select = (withSelect); 4344 4345 ;// ./node_modules/@wordpress/data/build-module/components/use-dispatch/use-dispatch-with-map.js 4346 /** 4347 * WordPress dependencies 4348 */ 4349 4350 4351 4352 /** 4353 * Internal dependencies 4354 */ 4355 4356 4357 /** 4358 * Custom react hook for returning aggregate dispatch actions using the provided 4359 * dispatchMap. 4360 * 4361 * Currently this is an internal api only and is implemented by `withDispatch` 4362 * 4363 * @param {Function} dispatchMap Receives the `registry.dispatch` function as 4364 * the first argument and the `registry` object 4365 * as the second argument. Should return an 4366 * object mapping props to functions. 4367 * @param {Array} deps An array of dependencies for the hook. 4368 * @return {Object} An object mapping props to functions created by the passed 4369 * in dispatchMap. 4370 */ 4371 const useDispatchWithMap = (dispatchMap, deps) => { 4372 const registry = useRegistry(); 4373 const currentDispatchMapRef = (0,external_wp_element_namespaceObject.useRef)(dispatchMap); 4374 (0,external_wp_compose_namespaceObject.useIsomorphicLayoutEffect)(() => { 4375 currentDispatchMapRef.current = dispatchMap; 4376 }); 4377 return (0,external_wp_element_namespaceObject.useMemo)(() => { 4378 const currentDispatchProps = currentDispatchMapRef.current(registry.dispatch, registry); 4379 return Object.fromEntries(Object.entries(currentDispatchProps).map(([propName, dispatcher]) => { 4380 if (typeof dispatcher !== 'function') { 4381 // eslint-disable-next-line no-console 4382 console.warn(`Property $propName} returned from dispatchMap in useDispatchWithMap must be a function.`); 4383 } 4384 return [propName, (...args) => currentDispatchMapRef.current(registry.dispatch, registry)[propName](...args)]; 4385 })); 4386 }, [registry, ...deps]); 4387 }; 4388 /* harmony default export */ const use_dispatch_with_map = (useDispatchWithMap); 4389 4390 ;// ./node_modules/@wordpress/data/build-module/components/with-dispatch/index.js 4391 /** 4392 * WordPress dependencies 4393 */ 4394 4395 4396 /** 4397 * Internal dependencies 4398 */ 4399 4400 4401 /** @typedef {import('react').ComponentType} ComponentType */ 4402 4403 /** 4404 * Higher-order component used to add dispatch props using registered action 4405 * creators. 4406 * 4407 * @param {Function} mapDispatchToProps A function of returning an object of 4408 * prop names where value is a 4409 * dispatch-bound action creator, or a 4410 * function to be called with the 4411 * component's props and returning an 4412 * action creator. 4413 * 4414 * @example 4415 * ```jsx 4416 * function Button( { onClick, children } ) { 4417 * return <button type="button" onClick={ onClick }>{ children }</button>; 4418 * } 4419 * 4420 * import { withDispatch } from '@wordpress/data'; 4421 * import { store as myCustomStore } from 'my-custom-store'; 4422 * 4423 * const SaleButton = withDispatch( ( dispatch, ownProps ) => { 4424 * const { startSale } = dispatch( myCustomStore ); 4425 * const { discountPercent } = ownProps; 4426 * 4427 * return { 4428 * onClick() { 4429 * startSale( discountPercent ); 4430 * }, 4431 * }; 4432 * } )( Button ); 4433 * 4434 * // Rendered in the application: 4435 * // 4436 * // <SaleButton discountPercent="20">Start Sale!</SaleButton> 4437 * ``` 4438 * 4439 * @example 4440 * In the majority of cases, it will be sufficient to use only two first params 4441 * passed to `mapDispatchToProps` as illustrated in the previous example. 4442 * However, there might be some very advanced use cases where using the 4443 * `registry` object might be used as a tool to optimize the performance of 4444 * your component. Using `select` function from the registry might be useful 4445 * when you need to fetch some dynamic data from the store at the time when the 4446 * event is fired, but at the same time, you never use it to render your 4447 * component. In such scenario, you can avoid using the `withSelect` higher 4448 * order component to compute such prop, which might lead to unnecessary 4449 * re-renders of your component caused by its frequent value change. 4450 * Keep in mind, that `mapDispatchToProps` must return an object with functions 4451 * only. 4452 * 4453 * ```jsx 4454 * function Button( { onClick, children } ) { 4455 * return <button type="button" onClick={ onClick }>{ children }</button>; 4456 * } 4457 * 4458 * import { withDispatch } from '@wordpress/data'; 4459 * import { store as myCustomStore } from 'my-custom-store'; 4460 * 4461 * const SaleButton = withDispatch( ( dispatch, ownProps, { select } ) => { 4462 * // Stock number changes frequently. 4463 * const { getStockNumber } = select( myCustomStore ); 4464 * const { startSale } = dispatch( myCustomStore ); 4465 * return { 4466 * onClick() { 4467 * const discountPercent = getStockNumber() > 50 ? 10 : 20; 4468 * startSale( discountPercent ); 4469 * }, 4470 * }; 4471 * } )( Button ); 4472 * 4473 * // Rendered in the application: 4474 * // 4475 * // <SaleButton>Start Sale!</SaleButton> 4476 * ``` 4477 * 4478 * _Note:_ It is important that the `mapDispatchToProps` function always 4479 * returns an object with the same keys. For example, it should not contain 4480 * conditions under which a different value would be returned. 4481 * 4482 * @return {ComponentType} Enhanced component with merged dispatcher props. 4483 */ 4484 4485 const withDispatch = mapDispatchToProps => (0,external_wp_compose_namespaceObject.createHigherOrderComponent)(WrappedComponent => ownProps => { 4486 const mapDispatch = (dispatch, registry) => mapDispatchToProps(dispatch, ownProps, registry); 4487 const dispatchProps = use_dispatch_with_map(mapDispatch, []); 4488 return /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(WrappedComponent, { 4489 ...ownProps, 4490 ...dispatchProps 4491 }); 4492 }, 'withDispatch'); 4493 /* harmony default export */ const with_dispatch = (withDispatch); 4494 4495 ;// ./node_modules/@wordpress/data/build-module/components/with-registry/index.js 4496 /** 4497 * WordPress dependencies 4498 */ 4499 4500 4501 /** 4502 * Internal dependencies 4503 */ 4504 4505 4506 /** 4507 * Higher-order component which renders the original component with the current 4508 * registry context passed as its `registry` prop. 4509 * 4510 * @param {Component} OriginalComponent Original component. 4511 * 4512 * @return {Component} Enhanced component. 4513 */ 4514 4515 const withRegistry = (0,external_wp_compose_namespaceObject.createHigherOrderComponent)(OriginalComponent => props => /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(RegistryConsumer, { 4516 children: registry => /*#__PURE__*/(0,external_ReactJSXRuntime_namespaceObject.jsx)(OriginalComponent, { 4517 ...props, 4518 registry: registry 4519 }) 4520 }), 'withRegistry'); 4521 /* harmony default export */ const with_registry = (withRegistry); 4522 4523 ;// ./node_modules/@wordpress/data/build-module/components/use-dispatch/use-dispatch.js 4524 /** 4525 * Internal dependencies 4526 */ 4527 4528 4529 /** 4530 * @typedef {import('../../types').StoreDescriptor<StoreConfig>} StoreDescriptor 4531 * @template {import('../../types').AnyConfig} StoreConfig 4532 */ 4533 /** 4534 * @typedef {import('../../types').UseDispatchReturn<StoreNameOrDescriptor>} UseDispatchReturn 4535 * @template StoreNameOrDescriptor 4536 */ 4537 4538 /** 4539 * A custom react hook returning the current registry dispatch actions creators. 4540 * 4541 * Note: The component using this hook must be within the context of a 4542 * RegistryProvider. 4543 * 4544 * @template {undefined | string | StoreDescriptor<any>} StoreNameOrDescriptor 4545 * @param {StoreNameOrDescriptor} [storeNameOrDescriptor] Optionally provide the name of the 4546 * store or its descriptor from which to 4547 * retrieve action creators. If not 4548 * provided, the registry.dispatch 4549 * function is returned instead. 4550 * 4551 * @example 4552 * This illustrates a pattern where you may need to retrieve dynamic data from 4553 * the server via the `useSelect` hook to use in combination with the dispatch 4554 * action. 4555 * 4556 * ```jsx 4557 * import { useCallback } from 'react'; 4558 * import { useDispatch, useSelect } from '@wordpress/data'; 4559 * import { store as myCustomStore } from 'my-custom-store'; 4560 * 4561 * function Button( { onClick, children } ) { 4562 * return <button type="button" onClick={ onClick }>{ children }</button> 4563 * } 4564 * 4565 * const SaleButton = ( { children } ) => { 4566 * const { stockNumber } = useSelect( 4567 * ( select ) => select( myCustomStore ).getStockNumber(), 4568 * [] 4569 * ); 4570 * const { startSale } = useDispatch( myCustomStore ); 4571 * const onClick = useCallback( () => { 4572 * const discountPercent = stockNumber > 50 ? 10: 20; 4573 * startSale( discountPercent ); 4574 * }, [ stockNumber ] ); 4575 * return <Button onClick={ onClick }>{ children }</Button> 4576 * } 4577 * 4578 * // Rendered somewhere in the application: 4579 * // 4580 * // <SaleButton>Start Sale!</SaleButton> 4581 * ``` 4582 * @return {UseDispatchReturn<StoreNameOrDescriptor>} A custom react hook. 4583 */ 4584 const useDispatch = storeNameOrDescriptor => { 4585 const { 4586 dispatch 4587 } = useRegistry(); 4588 return storeNameOrDescriptor === void 0 ? dispatch : dispatch(storeNameOrDescriptor); 4589 }; 4590 /* harmony default export */ const use_dispatch = (useDispatch); 4591 4592 ;// ./node_modules/@wordpress/data/build-module/dispatch.js 4593 /** 4594 * Internal dependencies 4595 */ 4596 4597 4598 4599 /** 4600 * Given a store descriptor, returns an object of the store's action creators. 4601 * Calling an action creator will cause it to be dispatched, updating the state value accordingly. 4602 * 4603 * Note: Action creators returned by the dispatch will return a promise when 4604 * they are called. 4605 * 4606 * @param storeNameOrDescriptor The store descriptor. The legacy calling convention of passing 4607 * the store name is also supported. 4608 * 4609 * @example 4610 * ```js 4611 * import { dispatch } from '@wordpress/data'; 4612 * import { store as myCustomStore } from 'my-custom-store'; 4613 * 4614 * dispatch( myCustomStore ).setPrice( 'hammer', 9.75 ); 4615 * ``` 4616 * @return Object containing the action creators. 4617 */ 4618 function dispatch_dispatch(storeNameOrDescriptor) { 4619 return default_registry.dispatch(storeNameOrDescriptor); 4620 } 4621 4622 ;// ./node_modules/@wordpress/data/build-module/select.js 4623 /** 4624 * Internal dependencies 4625 */ 4626 4627 4628 4629 /** 4630 * Given a store descriptor, returns an object of the store's selectors. 4631 * The selector functions are been pre-bound to pass the current state automatically. 4632 * As a consumer, you need only pass arguments of the selector, if applicable. 4633 * 4634 * 4635 * @param storeNameOrDescriptor The store descriptor. The legacy calling convention 4636 * of passing the store name is also supported. 4637 * 4638 * @example 4639 * ```js 4640 * import { select } from '@wordpress/data'; 4641 * import { store as myCustomStore } from 'my-custom-store'; 4642 * 4643 * select( myCustomStore ).getPrice( 'hammer' ); 4644 * ``` 4645 * 4646 * @return Object containing the store's selectors. 4647 */ 4648 function select_select(storeNameOrDescriptor) { 4649 return default_registry.select(storeNameOrDescriptor); 4650 } 4651 4652 ;// ./node_modules/@wordpress/data/build-module/index.js 4653 /** 4654 * Internal dependencies 4655 */ 4656 4657 4658 4659 4660 /** @typedef {import('./types').StoreDescriptor} StoreDescriptor */ 4661 4662 4663 4664 4665 4666 4667 4668 4669 4670 4671 4672 4673 4674 4675 4676 4677 /** 4678 * Object of available plugins to use with a registry. 4679 * 4680 * @see [use](#use) 4681 * 4682 * @type {Object} 4683 */ 4684 4685 4686 /** 4687 * The combineReducers helper function turns an object whose values are different 4688 * reducing functions into a single reducing function you can pass to registerReducer. 4689 * 4690 * @type {import('./types').combineReducers} 4691 * @param {Object} reducers An object whose values correspond to different reducing 4692 * functions that need to be combined into one. 4693 * 4694 * @example 4695 * ```js 4696 * import { combineReducers, createReduxStore, register } from '@wordpress/data'; 4697 * 4698 * const prices = ( state = {}, action ) => { 4699 * return action.type === 'SET_PRICE' ? 4700 * { 4701 * ...state, 4702 * [ action.item ]: action.price, 4703 * } : 4704 * state; 4705 * }; 4706 * 4707 * const discountPercent = ( state = 0, action ) => { 4708 * return action.type === 'START_SALE' ? 4709 * action.discountPercent : 4710 * state; 4711 * }; 4712 * 4713 * const store = createReduxStore( 'my-shop', { 4714 * reducer: combineReducers( { 4715 * prices, 4716 * discountPercent, 4717 * } ), 4718 * } ); 4719 * register( store ); 4720 * ``` 4721 * 4722 * @return {Function} A reducer that invokes every reducer inside the reducers 4723 * object, and constructs a state object with the same shape. 4724 */ 4725 const build_module_combineReducers = combine_reducers_combineReducers; 4726 4727 /** 4728 * Given a store descriptor, returns an object containing the store's selectors pre-bound to state 4729 * so that you only need to supply additional arguments, and modified so that they return promises 4730 * that resolve to their eventual values, after any resolvers have ran. 4731 * 4732 * @param {StoreDescriptor|string} storeNameOrDescriptor The store descriptor. The legacy calling 4733 * convention of passing the store name is 4734 * also supported. 4735 * 4736 * @example 4737 * ```js 4738 * import { resolveSelect } from '@wordpress/data'; 4739 * import { store as myCustomStore } from 'my-custom-store'; 4740 * 4741 * resolveSelect( myCustomStore ).getPrice( 'hammer' ).then(console.log) 4742 * ``` 4743 * 4744 * @return {Object} Object containing the store's promise-wrapped selectors. 4745 */ 4746 const build_module_resolveSelect = default_registry.resolveSelect; 4747 4748 /** 4749 * Given a store descriptor, returns an object containing the store's selectors pre-bound to state 4750 * so that you only need to supply additional arguments, and modified so that they throw promises 4751 * in case the selector is not resolved yet. 4752 * 4753 * @param {StoreDescriptor|string} storeNameOrDescriptor The store descriptor. The legacy calling 4754 * convention of passing the store name is 4755 * also supported. 4756 * 4757 * @return {Object} Object containing the store's suspense-wrapped selectors. 4758 */ 4759 const suspendSelect = default_registry.suspendSelect; 4760 4761 /** 4762 * Given a listener function, the function will be called any time the state value 4763 * of one of the registered stores has changed. If you specify the optional 4764 * `storeNameOrDescriptor` parameter, the listener function will be called only 4765 * on updates on that one specific registered store. 4766 * 4767 * This function returns an `unsubscribe` function used to stop the subscription. 4768 * 4769 * @param {Function} listener Callback function. 4770 * @param {string|StoreDescriptor?} storeNameOrDescriptor Optional store name. 4771 * 4772 * @example 4773 * ```js 4774 * import { subscribe } from '@wordpress/data'; 4775 * 4776 * const unsubscribe = subscribe( () => { 4777 * // You could use this opportunity to test whether the derived result of a 4778 * // selector has subsequently changed as the result of a state update. 4779 * } ); 4780 * 4781 * // Later, if necessary... 4782 * unsubscribe(); 4783 * ``` 4784 */ 4785 const subscribe = default_registry.subscribe; 4786 4787 /** 4788 * Registers a generic store instance. 4789 * 4790 * @deprecated Use `register( storeDescriptor )` instead. 4791 * 4792 * @param {string} name Store registry name. 4793 * @param {Object} store Store instance (`{ getSelectors, getActions, subscribe }`). 4794 */ 4795 const registerGenericStore = default_registry.registerGenericStore; 4796 4797 /** 4798 * Registers a standard `@wordpress/data` store. 4799 * 4800 * @deprecated Use `register` instead. 4801 * 4802 * @param {string} storeName Unique namespace identifier for the store. 4803 * @param {Object} options Store description (reducer, actions, selectors, resolvers). 4804 * 4805 * @return {Object} Registered store object. 4806 */ 4807 const registerStore = default_registry.registerStore; 4808 4809 /** 4810 * Extends a registry to inherit functionality provided by a given plugin. A 4811 * plugin is an object with properties aligning to that of a registry, merged 4812 * to extend the default registry behavior. 4813 * 4814 * @param {Object} plugin Plugin object. 4815 */ 4816 const use = default_registry.use; 4817 4818 /** 4819 * Registers a standard `@wordpress/data` store descriptor. 4820 * 4821 * @example 4822 * ```js 4823 * import { createReduxStore, register } from '@wordpress/data'; 4824 * 4825 * const store = createReduxStore( 'demo', { 4826 * reducer: ( state = 'OK' ) => state, 4827 * selectors: { 4828 * getValue: ( state ) => state, 4829 * }, 4830 * } ); 4831 * register( store ); 4832 * ``` 4833 * 4834 * @param {StoreDescriptor} store Store descriptor. 4835 */ 4836 const register = default_registry.register; 4837 4838 (window.wp = window.wp || {}).data = __webpack_exports__; 4839 /******/ })() 4840 ;
title
Description
Body
title
Description
Body
title
Description
Body
title
Body
Generated : Tue Jan 21 08:20:01 2025 | Cross-referenced by PHPXref |