[ Index ]

PHP Cross Reference of WordPress

title

Body

[close]

/wp-includes/js/dist/ -> plugins.js (source)

   1  /******/ (function() { // webpackBootstrap
   2  /******/     var __webpack_modules__ = ({
   3  
   4  /***/ 9756:
   5  /***/ (function(module) {
   6  
   7  /**
   8   * Memize options object.
   9   *
  10   * @typedef MemizeOptions
  11   *
  12   * @property {number} [maxSize] Maximum size of the cache.
  13   */
  14  
  15  /**
  16   * Internal cache entry.
  17   *
  18   * @typedef MemizeCacheNode
  19   *
  20   * @property {?MemizeCacheNode|undefined} [prev] Previous node.
  21   * @property {?MemizeCacheNode|undefined} [next] Next node.
  22   * @property {Array<*>}                   args   Function arguments for cache
  23   *                                               entry.
  24   * @property {*}                          val    Function result.
  25   */
  26  
  27  /**
  28   * Properties of the enhanced function for controlling cache.
  29   *
  30   * @typedef MemizeMemoizedFunction
  31   *
  32   * @property {()=>void} clear Clear the cache.
  33   */
  34  
  35  /**
  36   * Accepts a function to be memoized, and returns a new memoized function, with
  37   * optional options.
  38   *
  39   * @template {Function} F
  40   *
  41   * @param {F}             fn        Function to memoize.
  42   * @param {MemizeOptions} [options] Options object.
  43   *
  44   * @return {F & MemizeMemoizedFunction} Memoized function.
  45   */
  46  function memize( fn, options ) {
  47      var size = 0;
  48  
  49      /** @type {?MemizeCacheNode|undefined} */
  50      var head;
  51  
  52      /** @type {?MemizeCacheNode|undefined} */
  53      var tail;
  54  
  55      options = options || {};
  56  
  57  	function memoized( /* ...args */ ) {
  58          var node = head,
  59              len = arguments.length,
  60              args, i;
  61  
  62          searchCache: while ( node ) {
  63              // Perform a shallow equality test to confirm that whether the node
  64              // under test is a candidate for the arguments passed. Two arrays
  65              // are shallowly equal if their length matches and each entry is
  66              // strictly equal between the two sets. Avoid abstracting to a
  67              // function which could incur an arguments leaking deoptimization.
  68  
  69              // Check whether node arguments match arguments length
  70              if ( node.args.length !== arguments.length ) {
  71                  node = node.next;
  72                  continue;
  73              }
  74  
  75              // Check whether node arguments match arguments values
  76              for ( i = 0; i < len; i++ ) {
  77                  if ( node.args[ i ] !== arguments[ i ] ) {
  78                      node = node.next;
  79                      continue searchCache;
  80                  }
  81              }
  82  
  83              // At this point we can assume we've found a match
  84  
  85              // Surface matched node to head if not already
  86              if ( node !== head ) {
  87                  // As tail, shift to previous. Must only shift if not also
  88                  // head, since if both head and tail, there is no previous.
  89                  if ( node === tail ) {
  90                      tail = node.prev;
  91                  }
  92  
  93                  // Adjust siblings to point to each other. If node was tail,
  94                  // this also handles new tail's empty `next` assignment.
  95                  /** @type {MemizeCacheNode} */ ( node.prev ).next = node.next;
  96                  if ( node.next ) {
  97                      node.next.prev = node.prev;
  98                  }
  99  
 100                  node.next = head;
 101                  node.prev = null;
 102                  /** @type {MemizeCacheNode} */ ( head ).prev = node;
 103                  head = node;
 104              }
 105  
 106              // Return immediately
 107              return node.val;
 108          }
 109  
 110          // No cached value found. Continue to insertion phase:
 111  
 112          // Create a copy of arguments (avoid leaking deoptimization)
 113          args = new Array( len );
 114          for ( i = 0; i < len; i++ ) {
 115              args[ i ] = arguments[ i ];
 116          }
 117  
 118          node = {
 119              args: args,
 120  
 121              // Generate the result from original function
 122              val: fn.apply( null, args ),
 123          };
 124  
 125          // Don't need to check whether node is already head, since it would
 126          // have been returned above already if it was
 127  
 128          // Shift existing head down list
 129          if ( head ) {
 130              head.prev = node;
 131              node.next = head;
 132          } else {
 133              // If no head, follows that there's no tail (at initial or reset)
 134              tail = node;
 135          }
 136  
 137          // Trim tail if we're reached max size and are pending cache insertion
 138          if ( size === /** @type {MemizeOptions} */ ( options ).maxSize ) {
 139              tail = /** @type {MemizeCacheNode} */ ( tail ).prev;
 140              /** @type {MemizeCacheNode} */ ( tail ).next = null;
 141          } else {
 142              size++;
 143          }
 144  
 145          head = node;
 146  
 147          return node.val;
 148      }
 149  
 150      memoized.clear = function() {
 151          head = null;
 152          tail = null;
 153          size = 0;
 154      };
 155  
 156      if ( false ) {}
 157  
 158      // Ignore reason: There's not a clear solution to create an intersection of
 159      // the function with additional properties, where the goal is to retain the
 160      // function signature of the incoming argument and add control properties
 161      // on the return value.
 162  
 163      // @ts-ignore
 164      return memoized;
 165  }
 166  
 167  module.exports = memize;
 168  
 169  
 170  /***/ })
 171  
 172  /******/     });
 173  /************************************************************************/
 174  /******/     // The module cache
 175  /******/     var __webpack_module_cache__ = {};
 176  /******/     
 177  /******/     // The require function
 178  /******/ 	function __webpack_require__(moduleId) {
 179  /******/         // Check if module is in cache
 180  /******/         var cachedModule = __webpack_module_cache__[moduleId];
 181  /******/         if (cachedModule !== undefined) {
 182  /******/             return cachedModule.exports;
 183  /******/         }
 184  /******/         // Create a new module (and put it into the cache)
 185  /******/         var module = __webpack_module_cache__[moduleId] = {
 186  /******/             // no module.id needed
 187  /******/             // no module.loaded needed
 188  /******/             exports: {}
 189  /******/         };
 190  /******/     
 191  /******/         // Execute the module function
 192  /******/         __webpack_modules__[moduleId](module, module.exports, __webpack_require__);
 193  /******/     
 194  /******/         // Return the exports of the module
 195  /******/         return module.exports;
 196  /******/     }
 197  /******/     
 198  /************************************************************************/
 199  /******/     /* webpack/runtime/compat get default export */
 200  /******/     !function() {
 201  /******/         // getDefaultExport function for compatibility with non-harmony modules
 202  /******/         __webpack_require__.n = function(module) {
 203  /******/             var getter = module && module.__esModule ?
 204  /******/                 function() { return module['default']; } :
 205  /******/                 function() { return module; };
 206  /******/             __webpack_require__.d(getter, { a: getter });
 207  /******/             return getter;
 208  /******/         };
 209  /******/     }();
 210  /******/     
 211  /******/     /* webpack/runtime/define property getters */
 212  /******/     !function() {
 213  /******/         // define getter functions for harmony exports
 214  /******/         __webpack_require__.d = function(exports, definition) {
 215  /******/             for(var key in definition) {
 216  /******/                 if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {
 217  /******/                     Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });
 218  /******/                 }
 219  /******/             }
 220  /******/         };
 221  /******/     }();
 222  /******/     
 223  /******/     /* webpack/runtime/hasOwnProperty shorthand */
 224  /******/     !function() {
 225  /******/         __webpack_require__.o = function(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); }
 226  /******/     }();
 227  /******/     
 228  /******/     /* webpack/runtime/make namespace object */
 229  /******/     !function() {
 230  /******/         // define __esModule on exports
 231  /******/         __webpack_require__.r = function(exports) {
 232  /******/             if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
 233  /******/                 Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
 234  /******/             }
 235  /******/             Object.defineProperty(exports, '__esModule', { value: true });
 236  /******/         };
 237  /******/     }();
 238  /******/     
 239  /************************************************************************/
 240  var __webpack_exports__ = {};
 241  // This entry need to be wrapped in an IIFE because it need to be in strict mode.
 242  !function() {
 243  "use strict";
 244  // ESM COMPAT FLAG
 245  __webpack_require__.r(__webpack_exports__);
 246  
 247  // EXPORTS
 248  __webpack_require__.d(__webpack_exports__, {
 249    "PluginArea": function() { return /* reexport */ plugin_area; },
 250    "getPlugin": function() { return /* reexport */ getPlugin; },
 251    "getPlugins": function() { return /* reexport */ getPlugins; },
 252    "registerPlugin": function() { return /* reexport */ registerPlugin; },
 253    "unregisterPlugin": function() { return /* reexport */ unregisterPlugin; },
 254    "withPluginContext": function() { return /* reexport */ withPluginContext; }
 255  });
 256  
 257  ;// CONCATENATED MODULE: external ["wp","element"]
 258  var external_wp_element_namespaceObject = window["wp"]["element"];
 259  ;// CONCATENATED MODULE: external "lodash"
 260  var external_lodash_namespaceObject = window["lodash"];
 261  // EXTERNAL MODULE: ./node_modules/memize/index.js
 262  var memize = __webpack_require__(9756);
 263  var memize_default = /*#__PURE__*/__webpack_require__.n(memize);
 264  ;// CONCATENATED MODULE: external ["wp","hooks"]
 265  var external_wp_hooks_namespaceObject = window["wp"]["hooks"];
 266  ;// CONCATENATED MODULE: ./node_modules/@babel/runtime/helpers/esm/extends.js
 267  function _extends() {
 268    _extends = Object.assign || function (target) {
 269      for (var i = 1; i < arguments.length; i++) {
 270        var source = arguments[i];
 271  
 272        for (var key in source) {
 273          if (Object.prototype.hasOwnProperty.call(source, key)) {
 274            target[key] = source[key];
 275          }
 276        }
 277      }
 278  
 279      return target;
 280    };
 281  
 282    return _extends.apply(this, arguments);
 283  }
 284  ;// CONCATENATED MODULE: external ["wp","compose"]
 285  var external_wp_compose_namespaceObject = window["wp"]["compose"];
 286  ;// CONCATENATED MODULE: ./node_modules/@wordpress/plugins/build-module/components/plugin-context/index.js
 287  
 288  
 289  
 290  /**
 291   * WordPress dependencies
 292   */
 293  
 294  
 295  const {
 296    Consumer,
 297    Provider
 298  } = (0,external_wp_element_namespaceObject.createContext)({
 299    name: null,
 300    icon: null
 301  });
 302  
 303  /**
 304   * A Higher Order Component used to inject Plugin context to the
 305   * wrapped component.
 306   *
 307   * @param {Function} mapContextToProps Function called on every context change,
 308   *                                     expected to return object of props to
 309   *                                     merge with the component's own props.
 310   *
 311   * @return {WPComponent} Enhanced component with injected context as props.
 312   */
 313  
 314  const withPluginContext = mapContextToProps => (0,external_wp_compose_namespaceObject.createHigherOrderComponent)(OriginalComponent => {
 315    return props => (0,external_wp_element_namespaceObject.createElement)(Consumer, null, context => (0,external_wp_element_namespaceObject.createElement)(OriginalComponent, _extends({}, props, mapContextToProps(context, props))));
 316  }, 'withPluginContext');
 317  
 318  ;// CONCATENATED MODULE: ./node_modules/@wordpress/plugins/build-module/components/plugin-error-boundary/index.js
 319  /**
 320   * WordPress dependencies
 321   */
 322  
 323  class PluginErrorBoundary extends external_wp_element_namespaceObject.Component {
 324    constructor(props) {
 325      super(props);
 326      this.state = {
 327        hasError: false
 328      };
 329    }
 330  
 331    static getDerivedStateFromError() {
 332      return {
 333        hasError: true
 334      };
 335    }
 336  
 337    componentDidCatch(error) {
 338      const {
 339        name,
 340        onError
 341      } = this.props;
 342  
 343      if (onError) {
 344        onError(name, error);
 345      }
 346    }
 347  
 348    render() {
 349      if (!this.state.hasError) {
 350        return this.props.children;
 351      }
 352  
 353      return null;
 354    }
 355  
 356  }
 357  
 358  ;// CONCATENATED MODULE: external ["wp","primitives"]
 359  var external_wp_primitives_namespaceObject = window["wp"]["primitives"];
 360  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/plugins.js
 361  
 362  
 363  /**
 364   * WordPress dependencies
 365   */
 366  
 367  const plugins = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
 368    xmlns: "http://www.w3.org/2000/svg",
 369    viewBox: "0 0 24 24"
 370  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
 371    d: "M10.5 4v4h3V4H15v4h1.5a1 1 0 011 1v4l-3 4v2a1 1 0 01-1 1h-3a1 1 0 01-1-1v-2l-3-4V9a1 1 0 011-1H9V4h1.5zm.5 12.5v2h2v-2l3-4v-3H8v3l3 4z"
 372  }));
 373  /* harmony default export */ var library_plugins = (plugins);
 374  
 375  ;// CONCATENATED MODULE: ./node_modules/@wordpress/plugins/build-module/api/index.js
 376  /* eslint no-console: [ 'error', { allow: [ 'error' ] } ] */
 377  
 378  /**
 379   * WordPress dependencies
 380   */
 381  
 382  
 383  /**
 384   * External dependencies
 385   */
 386  
 387  
 388  /**
 389   * Defined behavior of a plugin type.
 390   *
 391   * @typedef {Object} WPPlugin
 392   *
 393   * @property {string}                    name    A string identifying the plugin. Must be
 394   *                                               unique across all registered plugins.
 395   * @property {string|WPElement|Function} [icon]  An icon to be shown in the UI. It can
 396   *                                               be a slug of the Dashicon, or an element
 397   *                                               (or function returning an element) if you
 398   *                                               choose to render your own SVG.
 399   * @property {Function}                  render  A component containing the UI elements
 400   *                                               to be rendered.
 401   * @property {string}                    [scope] The optional scope to be used when rendering inside
 402   *                                               a plugin area. No scope by default.
 403   */
 404  
 405  /**
 406   * Plugin definitions keyed by plugin name.
 407   *
 408   * @type {Object.<string,WPPlugin>}
 409   */
 410  
 411  const api_plugins = {};
 412  /**
 413   * Registers a plugin to the editor.
 414   *
 415   * @param {string}   name     A string identifying the plugin.Must be
 416   *                            unique across all registered plugins.
 417   * @param {WPPlugin} settings The settings for this plugin.
 418   *
 419   * @example
 420   * ```js
 421   * // Using ES5 syntax
 422   * var el = wp.element.createElement;
 423   * var Fragment = wp.element.Fragment;
 424   * var PluginSidebar = wp.editPost.PluginSidebar;
 425   * var PluginSidebarMoreMenuItem = wp.editPost.PluginSidebarMoreMenuItem;
 426   * var registerPlugin = wp.plugins.registerPlugin;
 427   * var moreIcon = wp.element.createElement( 'svg' ); //... svg element.
 428   *
 429   * function Component() {
 430   *     return el(
 431   *         Fragment,
 432   *         {},
 433   *         el(
 434   *             PluginSidebarMoreMenuItem,
 435   *             {
 436   *                 target: 'sidebar-name',
 437   *             },
 438   *             'My Sidebar'
 439   *         ),
 440   *         el(
 441   *             PluginSidebar,
 442   *             {
 443   *                 name: 'sidebar-name',
 444   *                 title: 'My Sidebar',
 445   *             },
 446   *             'Content of the sidebar'
 447   *         )
 448   *     );
 449   * }
 450   * registerPlugin( 'plugin-name', {
 451   *     icon: moreIcon,
 452   *     render: Component,
 453   *     scope: 'my-page',
 454   * } );
 455   * ```
 456   *
 457   * @example
 458   * ```js
 459   * // Using ESNext syntax
 460   * import { PluginSidebar, PluginSidebarMoreMenuItem } from '@wordpress/edit-post';
 461   * import { registerPlugin } from '@wordpress/plugins';
 462   * import { more } from '@wordpress/icons';
 463   *
 464   * const Component = () => (
 465   *     <>
 466   *         <PluginSidebarMoreMenuItem
 467   *             target="sidebar-name"
 468   *         >
 469   *             My Sidebar
 470   *         </PluginSidebarMoreMenuItem>
 471   *         <PluginSidebar
 472   *             name="sidebar-name"
 473   *             title="My Sidebar"
 474   *         >
 475   *             Content of the sidebar
 476   *         </PluginSidebar>
 477   *     </>
 478   * );
 479   *
 480   * registerPlugin( 'plugin-name', {
 481   *     icon: more,
 482   *     render: Component,
 483   *     scope: 'my-page',
 484   * } );
 485   * ```
 486   *
 487   * @return {WPPlugin} The final plugin settings object.
 488   */
 489  
 490  function registerPlugin(name, settings) {
 491    if (typeof settings !== 'object') {
 492      console.error('No settings object provided!');
 493      return null;
 494    }
 495  
 496    if (typeof name !== 'string') {
 497      console.error('Plugin name must be string.');
 498      return null;
 499    }
 500  
 501    if (!/^[a-z][a-z0-9-]*$/.test(name)) {
 502      console.error('Plugin name must include only lowercase alphanumeric characters or dashes, and start with a letter. Example: "my-plugin".');
 503      return null;
 504    }
 505  
 506    if (api_plugins[name]) {
 507      console.error(`Plugin "$name}" is already registered.`);
 508    }
 509  
 510    settings = (0,external_wp_hooks_namespaceObject.applyFilters)('plugins.registerPlugin', settings, name);
 511    const {
 512      render,
 513      scope
 514    } = settings;
 515  
 516    if (!(0,external_lodash_namespaceObject.isFunction)(render)) {
 517      console.error('The "render" property must be specified and must be a valid function.');
 518      return null;
 519    }
 520  
 521    if (scope) {
 522      if (typeof scope !== 'string') {
 523        console.error('Plugin scope must be string.');
 524        return null;
 525      }
 526  
 527      if (!/^[a-z][a-z0-9-]*$/.test(scope)) {
 528        console.error('Plugin scope must include only lowercase alphanumeric characters or dashes, and start with a letter. Example: "my-page".');
 529        return null;
 530      }
 531    }
 532  
 533    api_plugins[name] = {
 534      name,
 535      icon: library_plugins,
 536      ...settings
 537    };
 538    (0,external_wp_hooks_namespaceObject.doAction)('plugins.pluginRegistered', settings, name);
 539    return settings;
 540  }
 541  /**
 542   * Unregisters a plugin by name.
 543   *
 544   * @param {string} name Plugin name.
 545   *
 546   * @example
 547   * ```js
 548   * // Using ES5 syntax
 549   * var unregisterPlugin = wp.plugins.unregisterPlugin;
 550   *
 551   * unregisterPlugin( 'plugin-name' );
 552   * ```
 553   *
 554   * @example
 555   * ```js
 556   * // Using ESNext syntax
 557   * import { unregisterPlugin } from '@wordpress/plugins';
 558   *
 559   * unregisterPlugin( 'plugin-name' );
 560   * ```
 561   *
 562   * @return {?WPPlugin} The previous plugin settings object, if it has been
 563   *                     successfully unregistered; otherwise `undefined`.
 564   */
 565  
 566  function unregisterPlugin(name) {
 567    if (!api_plugins[name]) {
 568      console.error('Plugin "' + name + '" is not registered.');
 569      return;
 570    }
 571  
 572    const oldPlugin = api_plugins[name];
 573    delete api_plugins[name];
 574    (0,external_wp_hooks_namespaceObject.doAction)('plugins.pluginUnregistered', oldPlugin, name);
 575    return oldPlugin;
 576  }
 577  /**
 578   * Returns a registered plugin settings.
 579   *
 580   * @param {string} name Plugin name.
 581   *
 582   * @return {?WPPlugin} Plugin setting.
 583   */
 584  
 585  function getPlugin(name) {
 586    return api_plugins[name];
 587  }
 588  /**
 589   * Returns all registered plugins without a scope or for a given scope.
 590   *
 591   * @param {string} [scope] The scope to be used when rendering inside
 592   *                         a plugin area. No scope by default.
 593   *
 594   * @return {WPPlugin[]} The list of plugins without a scope or for a given scope.
 595   */
 596  
 597  function getPlugins(scope) {
 598    return Object.values(api_plugins).filter(plugin => plugin.scope === scope);
 599  }
 600  
 601  ;// CONCATENATED MODULE: ./node_modules/@wordpress/plugins/build-module/components/plugin-area/index.js
 602  
 603  
 604  /**
 605   * External dependencies
 606   */
 607  
 608  
 609  /**
 610   * WordPress dependencies
 611   */
 612  
 613  
 614  
 615  /**
 616   * Internal dependencies
 617   */
 618  
 619  
 620  
 621  
 622  /**
 623   * A component that renders all plugin fills in a hidden div.
 624   *
 625   * @example
 626   * ```js
 627   * // Using ES5 syntax
 628   * var el = wp.element.createElement;
 629   * var PluginArea = wp.plugins.PluginArea;
 630   *
 631   * function Layout() {
 632   *     return el(
 633   *         'div',
 634   *         { scope: 'my-page' },
 635   *         'Content of the page',
 636   *         PluginArea
 637   *     );
 638   * }
 639   * ```
 640   *
 641   * @example
 642   * ```js
 643   * // Using ESNext syntax
 644   * import { PluginArea } from '@wordpress/plugins';
 645   *
 646   * const Layout = () => (
 647   *     <div>
 648   *         Content of the page
 649   *         <PluginArea scope="my-page" />
 650   *     </div>
 651   * );
 652   * ```
 653   *
 654   * @return {WPComponent} The component to be rendered.
 655   */
 656  
 657  class PluginArea extends external_wp_element_namespaceObject.Component {
 658    constructor() {
 659      super(...arguments);
 660      this.setPlugins = this.setPlugins.bind(this);
 661      this.memoizedContext = memize_default()((name, icon) => {
 662        return {
 663          name,
 664          icon
 665        };
 666      });
 667      this.state = this.getCurrentPluginsState();
 668    }
 669  
 670    getCurrentPluginsState() {
 671      return {
 672        plugins: (0,external_lodash_namespaceObject.map)(getPlugins(this.props.scope), _ref => {
 673          let {
 674            icon,
 675            name,
 676            render
 677          } = _ref;
 678          return {
 679            Plugin: render,
 680            context: this.memoizedContext(name, icon)
 681          };
 682        })
 683      };
 684    }
 685  
 686    componentDidMount() {
 687      (0,external_wp_hooks_namespaceObject.addAction)('plugins.pluginRegistered', 'core/plugins/plugin-area/plugins-registered', this.setPlugins);
 688      (0,external_wp_hooks_namespaceObject.addAction)('plugins.pluginUnregistered', 'core/plugins/plugin-area/plugins-unregistered', this.setPlugins);
 689    }
 690  
 691    componentWillUnmount() {
 692      (0,external_wp_hooks_namespaceObject.removeAction)('plugins.pluginRegistered', 'core/plugins/plugin-area/plugins-registered');
 693      (0,external_wp_hooks_namespaceObject.removeAction)('plugins.pluginUnregistered', 'core/plugins/plugin-area/plugins-unregistered');
 694    }
 695  
 696    setPlugins() {
 697      this.setState(this.getCurrentPluginsState);
 698    }
 699  
 700    render() {
 701      return (0,external_wp_element_namespaceObject.createElement)("div", {
 702        style: {
 703          display: 'none'
 704        }
 705      }, (0,external_lodash_namespaceObject.map)(this.state.plugins, _ref2 => {
 706        let {
 707          context,
 708          Plugin
 709        } = _ref2;
 710        return (0,external_wp_element_namespaceObject.createElement)(Provider, {
 711          key: context.name,
 712          value: context
 713        }, (0,external_wp_element_namespaceObject.createElement)(PluginErrorBoundary, {
 714          name: context.name,
 715          onError: this.props.onError
 716        }, (0,external_wp_element_namespaceObject.createElement)(Plugin, null)));
 717      }));
 718    }
 719  
 720  }
 721  
 722  /* harmony default export */ var plugin_area = (PluginArea);
 723  
 724  ;// CONCATENATED MODULE: ./node_modules/@wordpress/plugins/build-module/components/index.js
 725  
 726  
 727  
 728  ;// CONCATENATED MODULE: ./node_modules/@wordpress/plugins/build-module/index.js
 729  
 730  
 731  
 732  }();
 733  (window.wp = window.wp || {}).plugins = __webpack_exports__;
 734  /******/ })()
 735  ;


Generated: Mon Jan 27 01:00:02 2025 Cross-referenced by PHPXref 0.7.1