[ Index ]

PHP Cross Reference of WordPress

title

Body

[close]

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

   1  /******/ (function() { // webpackBootstrap
   2  /******/     var __webpack_modules__ = ({
   3  
   4  /***/ 6411:
   5  /***/ (function(module, exports) {
   6  
   7  var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;/*!
   8      autosize 4.0.4
   9      license: MIT
  10      http://www.jacklmoore.com/autosize
  11  */
  12  (function (global, factory) {
  13      if (true) {
  14          !(__WEBPACK_AMD_DEFINE_ARRAY__ = [module, exports], __WEBPACK_AMD_DEFINE_FACTORY__ = (factory),
  15          __WEBPACK_AMD_DEFINE_RESULT__ = (typeof __WEBPACK_AMD_DEFINE_FACTORY__ === 'function' ?
  16          (__WEBPACK_AMD_DEFINE_FACTORY__.apply(exports, __WEBPACK_AMD_DEFINE_ARRAY__)) : __WEBPACK_AMD_DEFINE_FACTORY__),
  17          __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__));
  18      } else { var mod; }
  19  })(this, function (module, exports) {
  20      'use strict';
  21  
  22      var map = typeof Map === "function" ? new Map() : function () {
  23          var keys = [];
  24          var values = [];
  25  
  26          return {
  27              has: function has(key) {
  28                  return keys.indexOf(key) > -1;
  29              },
  30              get: function get(key) {
  31                  return values[keys.indexOf(key)];
  32              },
  33              set: function set(key, value) {
  34                  if (keys.indexOf(key) === -1) {
  35                      keys.push(key);
  36                      values.push(value);
  37                  }
  38              },
  39              delete: function _delete(key) {
  40                  var index = keys.indexOf(key);
  41                  if (index > -1) {
  42                      keys.splice(index, 1);
  43                      values.splice(index, 1);
  44                  }
  45              }
  46          };
  47      }();
  48  
  49      var createEvent = function createEvent(name) {
  50          return new Event(name, { bubbles: true });
  51      };
  52      try {
  53          new Event('test');
  54      } catch (e) {
  55          // IE does not support `new Event()`
  56          createEvent = function createEvent(name) {
  57              var evt = document.createEvent('Event');
  58              evt.initEvent(name, true, false);
  59              return evt;
  60          };
  61      }
  62  
  63  	function assign(ta) {
  64          if (!ta || !ta.nodeName || ta.nodeName !== 'TEXTAREA' || map.has(ta)) return;
  65  
  66          var heightOffset = null;
  67          var clientWidth = null;
  68          var cachedHeight = null;
  69  
  70  		function init() {
  71              var style = window.getComputedStyle(ta, null);
  72  
  73              if (style.resize === 'vertical') {
  74                  ta.style.resize = 'none';
  75              } else if (style.resize === 'both') {
  76                  ta.style.resize = 'horizontal';
  77              }
  78  
  79              if (style.boxSizing === 'content-box') {
  80                  heightOffset = -(parseFloat(style.paddingTop) + parseFloat(style.paddingBottom));
  81              } else {
  82                  heightOffset = parseFloat(style.borderTopWidth) + parseFloat(style.borderBottomWidth);
  83              }
  84              // Fix when a textarea is not on document body and heightOffset is Not a Number
  85              if (isNaN(heightOffset)) {
  86                  heightOffset = 0;
  87              }
  88  
  89              update();
  90          }
  91  
  92  		function changeOverflow(value) {
  93              {
  94                  // Chrome/Safari-specific fix:
  95                  // When the textarea y-overflow is hidden, Chrome/Safari do not reflow the text to account for the space
  96                  // made available by removing the scrollbar. The following forces the necessary text reflow.
  97                  var width = ta.style.width;
  98                  ta.style.width = '0px';
  99                  // Force reflow:
 100                  /* jshint ignore:start */
 101                  ta.offsetWidth;
 102                  /* jshint ignore:end */
 103                  ta.style.width = width;
 104              }
 105  
 106              ta.style.overflowY = value;
 107          }
 108  
 109  		function getParentOverflows(el) {
 110              var arr = [];
 111  
 112              while (el && el.parentNode && el.parentNode instanceof Element) {
 113                  if (el.parentNode.scrollTop) {
 114                      arr.push({
 115                          node: el.parentNode,
 116                          scrollTop: el.parentNode.scrollTop
 117                      });
 118                  }
 119                  el = el.parentNode;
 120              }
 121  
 122              return arr;
 123          }
 124  
 125  		function resize() {
 126              if (ta.scrollHeight === 0) {
 127                  // If the scrollHeight is 0, then the element probably has display:none or is detached from the DOM.
 128                  return;
 129              }
 130  
 131              var overflows = getParentOverflows(ta);
 132              var docTop = document.documentElement && document.documentElement.scrollTop; // Needed for Mobile IE (ticket #240)
 133  
 134              ta.style.height = '';
 135              ta.style.height = ta.scrollHeight + heightOffset + 'px';
 136  
 137              // used to check if an update is actually necessary on window.resize
 138              clientWidth = ta.clientWidth;
 139  
 140              // prevents scroll-position jumping
 141              overflows.forEach(function (el) {
 142                  el.node.scrollTop = el.scrollTop;
 143              });
 144  
 145              if (docTop) {
 146                  document.documentElement.scrollTop = docTop;
 147              }
 148          }
 149  
 150  		function update() {
 151              resize();
 152  
 153              var styleHeight = Math.round(parseFloat(ta.style.height));
 154              var computed = window.getComputedStyle(ta, null);
 155  
 156              // Using offsetHeight as a replacement for computed.height in IE, because IE does not account use of border-box
 157              var actualHeight = computed.boxSizing === 'content-box' ? Math.round(parseFloat(computed.height)) : ta.offsetHeight;
 158  
 159              // The actual height not matching the style height (set via the resize method) indicates that 
 160              // the max-height has been exceeded, in which case the overflow should be allowed.
 161              if (actualHeight < styleHeight) {
 162                  if (computed.overflowY === 'hidden') {
 163                      changeOverflow('scroll');
 164                      resize();
 165                      actualHeight = computed.boxSizing === 'content-box' ? Math.round(parseFloat(window.getComputedStyle(ta, null).height)) : ta.offsetHeight;
 166                  }
 167              } else {
 168                  // Normally keep overflow set to hidden, to avoid flash of scrollbar as the textarea expands.
 169                  if (computed.overflowY !== 'hidden') {
 170                      changeOverflow('hidden');
 171                      resize();
 172                      actualHeight = computed.boxSizing === 'content-box' ? Math.round(parseFloat(window.getComputedStyle(ta, null).height)) : ta.offsetHeight;
 173                  }
 174              }
 175  
 176              if (cachedHeight !== actualHeight) {
 177                  cachedHeight = actualHeight;
 178                  var evt = createEvent('autosize:resized');
 179                  try {
 180                      ta.dispatchEvent(evt);
 181                  } catch (err) {
 182                      // Firefox will throw an error on dispatchEvent for a detached element
 183                      // https://bugzilla.mozilla.org/show_bug.cgi?id=889376
 184                  }
 185              }
 186          }
 187  
 188          var pageResize = function pageResize() {
 189              if (ta.clientWidth !== clientWidth) {
 190                  update();
 191              }
 192          };
 193  
 194          var destroy = function (style) {
 195              window.removeEventListener('resize', pageResize, false);
 196              ta.removeEventListener('input', update, false);
 197              ta.removeEventListener('keyup', update, false);
 198              ta.removeEventListener('autosize:destroy', destroy, false);
 199              ta.removeEventListener('autosize:update', update, false);
 200  
 201              Object.keys(style).forEach(function (key) {
 202                  ta.style[key] = style[key];
 203              });
 204  
 205              map.delete(ta);
 206          }.bind(ta, {
 207              height: ta.style.height,
 208              resize: ta.style.resize,
 209              overflowY: ta.style.overflowY,
 210              overflowX: ta.style.overflowX,
 211              wordWrap: ta.style.wordWrap
 212          });
 213  
 214          ta.addEventListener('autosize:destroy', destroy, false);
 215  
 216          // IE9 does not fire onpropertychange or oninput for deletions,
 217          // so binding to onkeyup to catch most of those events.
 218          // There is no way that I know of to detect something like 'cut' in IE9.
 219          if ('onpropertychange' in ta && 'oninput' in ta) {
 220              ta.addEventListener('keyup', update, false);
 221          }
 222  
 223          window.addEventListener('resize', pageResize, false);
 224          ta.addEventListener('input', update, false);
 225          ta.addEventListener('autosize:update', update, false);
 226          ta.style.overflowX = 'hidden';
 227          ta.style.wordWrap = 'break-word';
 228  
 229          map.set(ta, {
 230              destroy: destroy,
 231              update: update
 232          });
 233  
 234          init();
 235      }
 236  
 237  	function destroy(ta) {
 238          var methods = map.get(ta);
 239          if (methods) {
 240              methods.destroy();
 241          }
 242      }
 243  
 244  	function update(ta) {
 245          var methods = map.get(ta);
 246          if (methods) {
 247              methods.update();
 248          }
 249      }
 250  
 251      var autosize = null;
 252  
 253      // Do nothing in Node.js environment and IE8 (or lower)
 254      if (typeof window === 'undefined' || typeof window.getComputedStyle !== 'function') {
 255          autosize = function autosize(el) {
 256              return el;
 257          };
 258          autosize.destroy = function (el) {
 259              return el;
 260          };
 261          autosize.update = function (el) {
 262              return el;
 263          };
 264      } else {
 265          autosize = function autosize(el, options) {
 266              if (el) {
 267                  Array.prototype.forEach.call(el.length ? el : [el], function (x) {
 268                      return assign(x, options);
 269                  });
 270              }
 271              return el;
 272          };
 273          autosize.destroy = function (el) {
 274              if (el) {
 275                  Array.prototype.forEach.call(el.length ? el : [el], destroy);
 276              }
 277              return el;
 278          };
 279          autosize.update = function (el) {
 280              if (el) {
 281                  Array.prototype.forEach.call(el.length ? el : [el], update);
 282              }
 283              return el;
 284          };
 285      }
 286  
 287      exports.default = autosize;
 288      module.exports = exports['default'];
 289  });
 290  
 291  /***/ }),
 292  
 293  /***/ 4403:
 294  /***/ (function(module, exports) {
 295  
 296  var __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;/*!
 297    Copyright (c) 2018 Jed Watson.
 298    Licensed under the MIT License (MIT), see
 299    http://jedwatson.github.io/classnames
 300  */
 301  /* global define */
 302  
 303  (function () {
 304      'use strict';
 305  
 306      var hasOwn = {}.hasOwnProperty;
 307  
 308  	function classNames() {
 309          var classes = [];
 310  
 311          for (var i = 0; i < arguments.length; i++) {
 312              var arg = arguments[i];
 313              if (!arg) continue;
 314  
 315              var argType = typeof arg;
 316  
 317              if (argType === 'string' || argType === 'number') {
 318                  classes.push(arg);
 319              } else if (Array.isArray(arg)) {
 320                  if (arg.length) {
 321                      var inner = classNames.apply(null, arg);
 322                      if (inner) {
 323                          classes.push(inner);
 324                      }
 325                  }
 326              } else if (argType === 'object') {
 327                  if (arg.toString === Object.prototype.toString) {
 328                      for (var key in arg) {
 329                          if (hasOwn.call(arg, key) && arg[key]) {
 330                              classes.push(key);
 331                          }
 332                      }
 333                  } else {
 334                      classes.push(arg.toString());
 335                  }
 336              }
 337          }
 338  
 339          return classes.join(' ');
 340      }
 341  
 342      if ( true && module.exports) {
 343          classNames.default = classNames;
 344          module.exports = classNames;
 345      } else if (true) {
 346          // register as 'classnames', consistent with npm package name
 347          !(__WEBPACK_AMD_DEFINE_ARRAY__ = [], __WEBPACK_AMD_DEFINE_RESULT__ = (function () {
 348              return classNames;
 349          }).apply(exports, __WEBPACK_AMD_DEFINE_ARRAY__),
 350          __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__));
 351      } else {}
 352  }());
 353  
 354  
 355  /***/ }),
 356  
 357  /***/ 4827:
 358  /***/ (function(module) {
 359  
 360  // This code has been refactored for 140 bytes
 361  // You can see the original here: https://github.com/twolfson/computedStyle/blob/04cd1da2e30fa45844f95f5cb1ac898e9b9ef050/lib/computedStyle.js
 362  var computedStyle = function (el, prop, getComputedStyle) {
 363    getComputedStyle = window.getComputedStyle;
 364  
 365    // In one fell swoop
 366    return (
 367      // If we have getComputedStyle
 368      getComputedStyle ?
 369        // Query it
 370        // TODO: From CSS-Query notes, we might need (node, null) for FF
 371        getComputedStyle(el) :
 372  
 373      // Otherwise, we are in IE and use currentStyle
 374        el.currentStyle
 375    )[
 376      // Switch to camelCase for CSSOM
 377      // DEV: Grabbed from jQuery
 378      // https://github.com/jquery/jquery/blob/1.9-stable/src/css.js#L191-L194
 379      // https://github.com/jquery/jquery/blob/1.9-stable/src/core.js#L593-L597
 380      prop.replace(/-(\w)/gi, function (word, letter) {
 381        return letter.toUpperCase();
 382      })
 383    ];
 384  };
 385  
 386  module.exports = computedStyle;
 387  
 388  
 389  /***/ }),
 390  
 391  /***/ 9894:
 392  /***/ (function(module, __unused_webpack_exports, __webpack_require__) {
 393  
 394  // Load in dependencies
 395  var computedStyle = __webpack_require__(4827);
 396  
 397  /**
 398   * Calculate the `line-height` of a given node
 399   * @param {HTMLElement} node Element to calculate line height of. Must be in the DOM.
 400   * @returns {Number} `line-height` of the element in pixels
 401   */
 402  function lineHeight(node) {
 403    // Grab the line-height via style
 404    var lnHeightStr = computedStyle(node, 'line-height');
 405    var lnHeight = parseFloat(lnHeightStr, 10);
 406  
 407    // If the lineHeight did not contain a unit (i.e. it was numeric), convert it to ems (e.g. '2.3' === '2.3em')
 408    if (lnHeightStr === lnHeight + '') {
 409      // Save the old lineHeight style and update the em unit to the element
 410      var _lnHeightStyle = node.style.lineHeight;
 411      node.style.lineHeight = lnHeightStr + 'em';
 412  
 413      // Calculate the em based height
 414      lnHeightStr = computedStyle(node, 'line-height');
 415      lnHeight = parseFloat(lnHeightStr, 10);
 416  
 417      // Revert the lineHeight style
 418      if (_lnHeightStyle) {
 419        node.style.lineHeight = _lnHeightStyle;
 420      } else {
 421        delete node.style.lineHeight;
 422      }
 423    }
 424  
 425    // If the lineHeight is in `pt`, convert it to pixels (4px for 3pt)
 426    // DEV: `em` units are converted to `pt` in IE6
 427    // Conversion ratio from https://developer.mozilla.org/en-US/docs/Web/CSS/length
 428    if (lnHeightStr.indexOf('pt') !== -1) {
 429      lnHeight *= 4;
 430      lnHeight /= 3;
 431    // Otherwise, if the lineHeight is in `mm`, convert it to pixels (96px for 25.4mm)
 432    } else if (lnHeightStr.indexOf('mm') !== -1) {
 433      lnHeight *= 96;
 434      lnHeight /= 25.4;
 435    // Otherwise, if the lineHeight is in `cm`, convert it to pixels (96px for 2.54cm)
 436    } else if (lnHeightStr.indexOf('cm') !== -1) {
 437      lnHeight *= 96;
 438      lnHeight /= 2.54;
 439    // Otherwise, if the lineHeight is in `in`, convert it to pixels (96px for 1in)
 440    } else if (lnHeightStr.indexOf('in') !== -1) {
 441      lnHeight *= 96;
 442    // Otherwise, if the lineHeight is in `pc`, convert it to pixels (12pt for 1pc)
 443    } else if (lnHeightStr.indexOf('pc') !== -1) {
 444      lnHeight *= 16;
 445    }
 446  
 447    // Continue our computation
 448    lnHeight = Math.round(lnHeight);
 449  
 450    // If the line-height is "normal", calculate by font-size
 451    if (lnHeightStr === 'normal') {
 452      // Create a temporary node
 453      var nodeName = node.nodeName;
 454      var _node = document.createElement(nodeName);
 455      _node.innerHTML = '&nbsp;';
 456  
 457      // If we have a text area, reset it to only 1 row
 458      // https://github.com/twolfson/line-height/issues/4
 459      if (nodeName.toUpperCase() === 'TEXTAREA') {
 460        _node.setAttribute('rows', '1');
 461      }
 462  
 463      // Set the font-size of the element
 464      var fontSizeStr = computedStyle(node, 'font-size');
 465      _node.style.fontSize = fontSizeStr;
 466  
 467      // Remove default padding/border which can affect offset height
 468      // https://github.com/twolfson/line-height/issues/4
 469      // https://developer.mozilla.org/en-US/docs/Web/API/HTMLElement/offsetHeight
 470      _node.style.padding = '0px';
 471      _node.style.border = '0px';
 472  
 473      // Append it to the body
 474      var body = document.body;
 475      body.appendChild(_node);
 476  
 477      // Assume the line height of the element is the height
 478      var height = _node.offsetHeight;
 479      lnHeight = height;
 480  
 481      // Remove our child from the DOM
 482      body.removeChild(_node);
 483    }
 484  
 485    // Return the calculated height
 486    return lnHeight;
 487  }
 488  
 489  // Export lineHeight
 490  module.exports = lineHeight;
 491  
 492  
 493  /***/ }),
 494  
 495  /***/ 5372:
 496  /***/ (function(module, __unused_webpack_exports, __webpack_require__) {
 497  
 498  "use strict";
 499  /**
 500   * Copyright (c) 2013-present, Facebook, Inc.
 501   *
 502   * This source code is licensed under the MIT license found in the
 503   * LICENSE file in the root directory of this source tree.
 504   */
 505  
 506  
 507  
 508  var ReactPropTypesSecret = __webpack_require__(9567);
 509  
 510  function emptyFunction() {}
 511  function emptyFunctionWithReset() {}
 512  emptyFunctionWithReset.resetWarningCache = emptyFunction;
 513  
 514  module.exports = function() {
 515    function shim(props, propName, componentName, location, propFullName, secret) {
 516      if (secret === ReactPropTypesSecret) {
 517        // It is still safe when called from React.
 518        return;
 519      }
 520      var err = new Error(
 521        'Calling PropTypes validators directly is not supported by the `prop-types` package. ' +
 522        'Use PropTypes.checkPropTypes() to call them. ' +
 523        'Read more at http://fb.me/use-check-prop-types'
 524      );
 525      err.name = 'Invariant Violation';
 526      throw err;
 527    };
 528    shim.isRequired = shim;
 529    function getShim() {
 530      return shim;
 531    };
 532    // Important!
 533    // Keep this list in sync with production version in `./factoryWithTypeCheckers.js`.
 534    var ReactPropTypes = {
 535      array: shim,
 536      bigint: shim,
 537      bool: shim,
 538      func: shim,
 539      number: shim,
 540      object: shim,
 541      string: shim,
 542      symbol: shim,
 543  
 544      any: shim,
 545      arrayOf: getShim,
 546      element: shim,
 547      elementType: shim,
 548      instanceOf: getShim,
 549      node: shim,
 550      objectOf: getShim,
 551      oneOf: getShim,
 552      oneOfType: getShim,
 553      shape: getShim,
 554      exact: getShim,
 555  
 556      checkPropTypes: emptyFunctionWithReset,
 557      resetWarningCache: emptyFunction
 558    };
 559  
 560    ReactPropTypes.PropTypes = ReactPropTypes;
 561  
 562    return ReactPropTypes;
 563  };
 564  
 565  
 566  /***/ }),
 567  
 568  /***/ 2652:
 569  /***/ (function(module, __unused_webpack_exports, __webpack_require__) {
 570  
 571  /**
 572   * Copyright (c) 2013-present, Facebook, Inc.
 573   *
 574   * This source code is licensed under the MIT license found in the
 575   * LICENSE file in the root directory of this source tree.
 576   */
 577  
 578  if (false) { var throwOnDirectAccess, ReactIs; } else {
 579    // By explicitly using `prop-types` you are opting into new production behavior.
 580    // http://fb.me/prop-types-in-prod
 581    module.exports = __webpack_require__(5372)();
 582  }
 583  
 584  
 585  /***/ }),
 586  
 587  /***/ 9567:
 588  /***/ (function(module) {
 589  
 590  "use strict";
 591  /**
 592   * Copyright (c) 2013-present, Facebook, Inc.
 593   *
 594   * This source code is licensed under the MIT license found in the
 595   * LICENSE file in the root directory of this source tree.
 596   */
 597  
 598  
 599  
 600  var ReactPropTypesSecret = 'SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED';
 601  
 602  module.exports = ReactPropTypesSecret;
 603  
 604  
 605  /***/ }),
 606  
 607  /***/ 5438:
 608  /***/ (function(__unused_webpack_module, exports, __webpack_require__) {
 609  
 610  "use strict";
 611  
 612  var __extends = (this && this.__extends) || (function () {
 613      var extendStatics = Object.setPrototypeOf ||
 614          ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
 615          function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
 616      return function (d, b) {
 617          extendStatics(d, b);
 618          function __() { this.constructor = d; }
 619          d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
 620      };
 621  })();
 622  var __assign = (this && this.__assign) || Object.assign || function(t) {
 623      for (var s, i = 1, n = arguments.length; i < n; i++) {
 624          s = arguments[i];
 625          for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
 626              t[p] = s[p];
 627      }
 628      return t;
 629  };
 630  var __rest = (this && this.__rest) || function (s, e) {
 631      var t = {};
 632      for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
 633          t[p] = s[p];
 634      if (s != null && typeof Object.getOwnPropertySymbols === "function")
 635          for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) if (e.indexOf(p[i]) < 0)
 636              t[p[i]] = s[p[i]];
 637      return t;
 638  };
 639  exports.__esModule = true;
 640  var React = __webpack_require__(9196);
 641  var PropTypes = __webpack_require__(2652);
 642  var autosize = __webpack_require__(6411);
 643  var _getLineHeight = __webpack_require__(9894);
 644  var getLineHeight = _getLineHeight;
 645  var RESIZED = "autosize:resized";
 646  /**
 647   * A light replacement for built-in textarea component
 648   * which automaticaly adjusts its height to match the content
 649   */
 650  var TextareaAutosizeClass = /** @class */ (function (_super) {
 651      __extends(TextareaAutosizeClass, _super);
 652      function TextareaAutosizeClass() {
 653          var _this = _super !== null && _super.apply(this, arguments) || this;
 654          _this.state = {
 655              lineHeight: null
 656          };
 657          _this.textarea = null;
 658          _this.onResize = function (e) {
 659              if (_this.props.onResize) {
 660                  _this.props.onResize(e);
 661              }
 662          };
 663          _this.updateLineHeight = function () {
 664              if (_this.textarea) {
 665                  _this.setState({
 666                      lineHeight: getLineHeight(_this.textarea)
 667                  });
 668              }
 669          };
 670          _this.onChange = function (e) {
 671              var onChange = _this.props.onChange;
 672              _this.currentValue = e.currentTarget.value;
 673              onChange && onChange(e);
 674          };
 675          return _this;
 676      }
 677      TextareaAutosizeClass.prototype.componentDidMount = function () {
 678          var _this = this;
 679          var _a = this.props, maxRows = _a.maxRows, async = _a.async;
 680          if (typeof maxRows === "number") {
 681              this.updateLineHeight();
 682          }
 683          if (typeof maxRows === "number" || async) {
 684              /*
 685                the defer is needed to:
 686                  - force "autosize" to activate the scrollbar when this.props.maxRows is passed
 687                  - support StyledComponents (see #71)
 688              */
 689              setTimeout(function () { return _this.textarea && autosize(_this.textarea); });
 690          }
 691          else {
 692              this.textarea && autosize(this.textarea);
 693          }
 694          if (this.textarea) {
 695              this.textarea.addEventListener(RESIZED, this.onResize);
 696          }
 697      };
 698      TextareaAutosizeClass.prototype.componentWillUnmount = function () {
 699          if (this.textarea) {
 700              this.textarea.removeEventListener(RESIZED, this.onResize);
 701              autosize.destroy(this.textarea);
 702          }
 703      };
 704      TextareaAutosizeClass.prototype.render = function () {
 705          var _this = this;
 706          var _a = this, _b = _a.props, onResize = _b.onResize, maxRows = _b.maxRows, onChange = _b.onChange, style = _b.style, innerRef = _b.innerRef, children = _b.children, props = __rest(_b, ["onResize", "maxRows", "onChange", "style", "innerRef", "children"]), lineHeight = _a.state.lineHeight;
 707          var maxHeight = maxRows && lineHeight ? lineHeight * maxRows : null;
 708          return (React.createElement("textarea", __assign({}, props, { onChange: this.onChange, style: maxHeight ? __assign({}, style, { maxHeight: maxHeight }) : style, ref: function (element) {
 709                  _this.textarea = element;
 710                  if (typeof _this.props.innerRef === 'function') {
 711                      _this.props.innerRef(element);
 712                  }
 713                  else if (_this.props.innerRef) {
 714                      _this.props.innerRef.current = element;
 715                  }
 716              } }), children));
 717      };
 718      TextareaAutosizeClass.prototype.componentDidUpdate = function () {
 719          this.textarea && autosize.update(this.textarea);
 720      };
 721      TextareaAutosizeClass.defaultProps = {
 722          rows: 1,
 723          async: false
 724      };
 725      TextareaAutosizeClass.propTypes = {
 726          rows: PropTypes.number,
 727          maxRows: PropTypes.number,
 728          onResize: PropTypes.func,
 729          innerRef: PropTypes.any,
 730          async: PropTypes.bool
 731      };
 732      return TextareaAutosizeClass;
 733  }(React.Component));
 734  exports.TextareaAutosize = React.forwardRef(function (props, ref) {
 735      return React.createElement(TextareaAutosizeClass, __assign({}, props, { innerRef: ref }));
 736  });
 737  
 738  
 739  /***/ }),
 740  
 741  /***/ 773:
 742  /***/ (function(__unused_webpack_module, exports, __webpack_require__) {
 743  
 744  "use strict";
 745  var __webpack_unused_export__;
 746  
 747  __webpack_unused_export__ = true;
 748  var TextareaAutosize_1 = __webpack_require__(5438);
 749  exports.Z = TextareaAutosize_1.TextareaAutosize;
 750  
 751  
 752  /***/ }),
 753  
 754  /***/ 9196:
 755  /***/ (function(module) {
 756  
 757  "use strict";
 758  module.exports = window["React"];
 759  
 760  /***/ })
 761  
 762  /******/     });
 763  /************************************************************************/
 764  /******/     // The module cache
 765  /******/     var __webpack_module_cache__ = {};
 766  /******/     
 767  /******/     // The require function
 768  /******/ 	function __webpack_require__(moduleId) {
 769  /******/         // Check if module is in cache
 770  /******/         var cachedModule = __webpack_module_cache__[moduleId];
 771  /******/         if (cachedModule !== undefined) {
 772  /******/             return cachedModule.exports;
 773  /******/         }
 774  /******/         // Create a new module (and put it into the cache)
 775  /******/         var module = __webpack_module_cache__[moduleId] = {
 776  /******/             // no module.id needed
 777  /******/             // no module.loaded needed
 778  /******/             exports: {}
 779  /******/         };
 780  /******/     
 781  /******/         // Execute the module function
 782  /******/         __webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);
 783  /******/     
 784  /******/         // Return the exports of the module
 785  /******/         return module.exports;
 786  /******/     }
 787  /******/     
 788  /************************************************************************/
 789  /******/     /* webpack/runtime/compat get default export */
 790  /******/     !function() {
 791  /******/         // getDefaultExport function for compatibility with non-harmony modules
 792  /******/         __webpack_require__.n = function(module) {
 793  /******/             var getter = module && module.__esModule ?
 794  /******/                 function() { return module['default']; } :
 795  /******/                 function() { return module; };
 796  /******/             __webpack_require__.d(getter, { a: getter });
 797  /******/             return getter;
 798  /******/         };
 799  /******/     }();
 800  /******/     
 801  /******/     /* webpack/runtime/define property getters */
 802  /******/     !function() {
 803  /******/         // define getter functions for harmony exports
 804  /******/         __webpack_require__.d = function(exports, definition) {
 805  /******/             for(var key in definition) {
 806  /******/                 if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {
 807  /******/                     Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });
 808  /******/                 }
 809  /******/             }
 810  /******/         };
 811  /******/     }();
 812  /******/     
 813  /******/     /* webpack/runtime/hasOwnProperty shorthand */
 814  /******/     !function() {
 815  /******/         __webpack_require__.o = function(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); }
 816  /******/     }();
 817  /******/     
 818  /******/     /* webpack/runtime/make namespace object */
 819  /******/     !function() {
 820  /******/         // define __esModule on exports
 821  /******/         __webpack_require__.r = function(exports) {
 822  /******/             if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
 823  /******/                 Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
 824  /******/             }
 825  /******/             Object.defineProperty(exports, '__esModule', { value: true });
 826  /******/         };
 827  /******/     }();
 828  /******/     
 829  /************************************************************************/
 830  var __webpack_exports__ = {};
 831  // This entry need to be wrapped in an IIFE because it need to be in strict mode.
 832  !function() {
 833  "use strict";
 834  // ESM COMPAT FLAG
 835  __webpack_require__.r(__webpack_exports__);
 836  
 837  // EXPORTS
 838  __webpack_require__.d(__webpack_exports__, {
 839    "AlignmentToolbar": function() { return /* reexport */ AlignmentToolbar; },
 840    "Autocomplete": function() { return /* reexport */ Autocomplete; },
 841    "AutosaveMonitor": function() { return /* reexport */ autosave_monitor; },
 842    "BlockAlignmentToolbar": function() { return /* reexport */ BlockAlignmentToolbar; },
 843    "BlockControls": function() { return /* reexport */ BlockControls; },
 844    "BlockEdit": function() { return /* reexport */ BlockEdit; },
 845    "BlockEditorKeyboardShortcuts": function() { return /* reexport */ BlockEditorKeyboardShortcuts; },
 846    "BlockFormatControls": function() { return /* reexport */ BlockFormatControls; },
 847    "BlockIcon": function() { return /* reexport */ BlockIcon; },
 848    "BlockInspector": function() { return /* reexport */ BlockInspector; },
 849    "BlockList": function() { return /* reexport */ BlockList; },
 850    "BlockMover": function() { return /* reexport */ BlockMover; },
 851    "BlockNavigationDropdown": function() { return /* reexport */ BlockNavigationDropdown; },
 852    "BlockSelectionClearer": function() { return /* reexport */ BlockSelectionClearer; },
 853    "BlockSettingsMenu": function() { return /* reexport */ BlockSettingsMenu; },
 854    "BlockTitle": function() { return /* reexport */ BlockTitle; },
 855    "BlockToolbar": function() { return /* reexport */ BlockToolbar; },
 856    "ColorPalette": function() { return /* reexport */ ColorPalette; },
 857    "ContrastChecker": function() { return /* reexport */ ContrastChecker; },
 858    "CopyHandler": function() { return /* reexport */ CopyHandler; },
 859    "DefaultBlockAppender": function() { return /* reexport */ DefaultBlockAppender; },
 860    "DocumentOutline": function() { return /* reexport */ document_outline; },
 861    "DocumentOutlineCheck": function() { return /* reexport */ check; },
 862    "EditorHistoryRedo": function() { return /* reexport */ editor_history_redo; },
 863    "EditorHistoryUndo": function() { return /* reexport */ editor_history_undo; },
 864    "EditorKeyboardShortcutsRegister": function() { return /* reexport */ register_shortcuts; },
 865    "EditorNotices": function() { return /* reexport */ editor_notices; },
 866    "EditorProvider": function() { return /* reexport */ provider; },
 867    "EditorSnackbars": function() { return /* reexport */ EditorSnackbars; },
 868    "EntitiesSavedStates": function() { return /* reexport */ EntitiesSavedStates; },
 869    "ErrorBoundary": function() { return /* reexport */ error_boundary; },
 870    "FontSizePicker": function() { return /* reexport */ FontSizePicker; },
 871    "InnerBlocks": function() { return /* reexport */ InnerBlocks; },
 872    "Inserter": function() { return /* reexport */ Inserter; },
 873    "InspectorAdvancedControls": function() { return /* reexport */ InspectorAdvancedControls; },
 874    "InspectorControls": function() { return /* reexport */ InspectorControls; },
 875    "LocalAutosaveMonitor": function() { return /* reexport */ local_autosave_monitor; },
 876    "MediaPlaceholder": function() { return /* reexport */ MediaPlaceholder; },
 877    "MediaUpload": function() { return /* reexport */ MediaUpload; },
 878    "MediaUploadCheck": function() { return /* reexport */ MediaUploadCheck; },
 879    "MultiSelectScrollIntoView": function() { return /* reexport */ MultiSelectScrollIntoView; },
 880    "NavigableToolbar": function() { return /* reexport */ NavigableToolbar; },
 881    "ObserveTyping": function() { return /* reexport */ ObserveTyping; },
 882    "PageAttributesCheck": function() { return /* reexport */ page_attributes_check; },
 883    "PageAttributesOrder": function() { return /* reexport */ order; },
 884    "PageAttributesParent": function() { return /* reexport */ page_attributes_parent; },
 885    "PageTemplate": function() { return /* reexport */ post_template; },
 886    "PanelColorSettings": function() { return /* reexport */ PanelColorSettings; },
 887    "PlainText": function() { return /* reexport */ PlainText; },
 888    "PostAuthor": function() { return /* reexport */ post_author; },
 889    "PostAuthorCheck": function() { return /* reexport */ PostAuthorCheck; },
 890    "PostComments": function() { return /* reexport */ post_comments; },
 891    "PostExcerpt": function() { return /* reexport */ post_excerpt; },
 892    "PostExcerptCheck": function() { return /* reexport */ post_excerpt_check; },
 893    "PostFeaturedImage": function() { return /* reexport */ post_featured_image; },
 894    "PostFeaturedImageCheck": function() { return /* reexport */ post_featured_image_check; },
 895    "PostFormat": function() { return /* reexport */ PostFormat; },
 896    "PostFormatCheck": function() { return /* reexport */ post_format_check; },
 897    "PostLastRevision": function() { return /* reexport */ post_last_revision; },
 898    "PostLastRevisionCheck": function() { return /* reexport */ post_last_revision_check; },
 899    "PostLockedModal": function() { return /* reexport */ PostLockedModal; },
 900    "PostPendingStatus": function() { return /* reexport */ post_pending_status; },
 901    "PostPendingStatusCheck": function() { return /* reexport */ post_pending_status_check; },
 902    "PostPingbacks": function() { return /* reexport */ post_pingbacks; },
 903    "PostPreviewButton": function() { return /* reexport */ post_preview_button; },
 904    "PostPublishButton": function() { return /* reexport */ post_publish_button; },
 905    "PostPublishButtonLabel": function() { return /* reexport */ label; },
 906    "PostPublishPanel": function() { return /* reexport */ post_publish_panel; },
 907    "PostSavedState": function() { return /* reexport */ PostSavedState; },
 908    "PostSchedule": function() { return /* reexport */ PostSchedule; },
 909    "PostScheduleCheck": function() { return /* reexport */ post_schedule_check; },
 910    "PostScheduleLabel": function() { return /* reexport */ post_schedule_label; },
 911    "PostSlug": function() { return /* reexport */ post_slug; },
 912    "PostSlugCheck": function() { return /* reexport */ PostSlugCheck; },
 913    "PostSticky": function() { return /* reexport */ post_sticky; },
 914    "PostStickyCheck": function() { return /* reexport */ post_sticky_check; },
 915    "PostSwitchToDraftButton": function() { return /* reexport */ post_switch_to_draft_button; },
 916    "PostTaxonomies": function() { return /* reexport */ post_taxonomies; },
 917    "PostTaxonomiesCheck": function() { return /* reexport */ post_taxonomies_check; },
 918    "PostTaxonomiesFlatTermSelector": function() { return /* reexport */ flat_term_selector; },
 919    "PostTaxonomiesHierarchicalTermSelector": function() { return /* reexport */ hierarchical_term_selector; },
 920    "PostTextEditor": function() { return /* reexport */ PostTextEditor; },
 921    "PostTitle": function() { return /* reexport */ PostTitle; },
 922    "PostTrash": function() { return /* reexport */ PostTrash; },
 923    "PostTrashCheck": function() { return /* reexport */ post_trash_check; },
 924    "PostTypeSupportCheck": function() { return /* reexport */ post_type_support_check; },
 925    "PostVisibility": function() { return /* reexport */ post_visibility; },
 926    "PostVisibilityCheck": function() { return /* reexport */ post_visibility_check; },
 927    "PostVisibilityLabel": function() { return /* reexport */ post_visibility_label; },
 928    "RichText": function() { return /* reexport */ RichText; },
 929    "RichTextShortcut": function() { return /* reexport */ RichTextShortcut; },
 930    "RichTextToolbarButton": function() { return /* reexport */ RichTextToolbarButton; },
 931    "ServerSideRender": function() { return /* reexport */ (external_wp_serverSideRender_default()); },
 932    "SkipToSelectedBlock": function() { return /* reexport */ SkipToSelectedBlock; },
 933    "TableOfContents": function() { return /* reexport */ table_of_contents; },
 934    "TextEditorGlobalKeyboardShortcuts": function() { return /* reexport */ TextEditorGlobalKeyboardShortcuts; },
 935    "ThemeSupportCheck": function() { return /* reexport */ theme_support_check; },
 936    "URLInput": function() { return /* reexport */ URLInput; },
 937    "URLInputButton": function() { return /* reexport */ URLInputButton; },
 938    "URLPopover": function() { return /* reexport */ URLPopover; },
 939    "UnsavedChangesWarning": function() { return /* reexport */ UnsavedChangesWarning; },
 940    "VisualEditorGlobalKeyboardShortcuts": function() { return /* reexport */ visual_editor_shortcuts; },
 941    "Warning": function() { return /* reexport */ Warning; },
 942    "WordCount": function() { return /* reexport */ WordCount; },
 943    "WritingFlow": function() { return /* reexport */ WritingFlow; },
 944    "__unstableRichTextInputEvent": function() { return /* reexport */ __unstableRichTextInputEvent; },
 945    "cleanForSlug": function() { return /* reexport */ cleanForSlug; },
 946    "createCustomColorsHOC": function() { return /* reexport */ createCustomColorsHOC; },
 947    "getColorClassName": function() { return /* reexport */ getColorClassName; },
 948    "getColorObjectByAttributeValues": function() { return /* reexport */ getColorObjectByAttributeValues; },
 949    "getColorObjectByColorValue": function() { return /* reexport */ getColorObjectByColorValue; },
 950    "getFontSize": function() { return /* reexport */ getFontSize; },
 951    "getFontSizeClass": function() { return /* reexport */ getFontSizeClass; },
 952    "getTemplatePartIcon": function() { return /* reexport */ getTemplatePartIcon; },
 953    "mediaUpload": function() { return /* reexport */ mediaUpload; },
 954    "store": function() { return /* reexport */ store_store; },
 955    "storeConfig": function() { return /* reexport */ storeConfig; },
 956    "transformStyles": function() { return /* reexport */ external_wp_blockEditor_namespaceObject.transformStyles; },
 957    "userAutocompleter": function() { return /* reexport */ user; },
 958    "withColorContext": function() { return /* reexport */ withColorContext; },
 959    "withColors": function() { return /* reexport */ withColors; },
 960    "withFontSizes": function() { return /* reexport */ withFontSizes; }
 961  });
 962  
 963  // NAMESPACE OBJECT: ./node_modules/@wordpress/editor/build-module/store/selectors.js
 964  var selectors_namespaceObject = {};
 965  __webpack_require__.r(selectors_namespaceObject);
 966  __webpack_require__.d(selectors_namespaceObject, {
 967    "__experimentalGetDefaultTemplatePartAreas": function() { return __experimentalGetDefaultTemplatePartAreas; },
 968    "__experimentalGetDefaultTemplateType": function() { return __experimentalGetDefaultTemplateType; },
 969    "__experimentalGetDefaultTemplateTypes": function() { return __experimentalGetDefaultTemplateTypes; },
 970    "__experimentalGetTemplateInfo": function() { return __experimentalGetTemplateInfo; },
 971    "__unstableIsEditorReady": function() { return __unstableIsEditorReady; },
 972    "canInsertBlockType": function() { return canInsertBlockType; },
 973    "canUserUseUnfilteredHTML": function() { return canUserUseUnfilteredHTML; },
 974    "didPostSaveRequestFail": function() { return didPostSaveRequestFail; },
 975    "didPostSaveRequestSucceed": function() { return didPostSaveRequestSucceed; },
 976    "getActivePostLock": function() { return getActivePostLock; },
 977    "getAdjacentBlockClientId": function() { return getAdjacentBlockClientId; },
 978    "getAutosaveAttribute": function() { return getAutosaveAttribute; },
 979    "getBlock": function() { return getBlock; },
 980    "getBlockAttributes": function() { return getBlockAttributes; },
 981    "getBlockCount": function() { return getBlockCount; },
 982    "getBlockHierarchyRootClientId": function() { return getBlockHierarchyRootClientId; },
 983    "getBlockIndex": function() { return getBlockIndex; },
 984    "getBlockInsertionPoint": function() { return getBlockInsertionPoint; },
 985    "getBlockListSettings": function() { return getBlockListSettings; },
 986    "getBlockMode": function() { return getBlockMode; },
 987    "getBlockName": function() { return getBlockName; },
 988    "getBlockOrder": function() { return getBlockOrder; },
 989    "getBlockRootClientId": function() { return getBlockRootClientId; },
 990    "getBlockSelectionEnd": function() { return getBlockSelectionEnd; },
 991    "getBlockSelectionStart": function() { return getBlockSelectionStart; },
 992    "getBlocks": function() { return getBlocks; },
 993    "getBlocksByClientId": function() { return getBlocksByClientId; },
 994    "getClientIdsOfDescendants": function() { return getClientIdsOfDescendants; },
 995    "getClientIdsWithDescendants": function() { return getClientIdsWithDescendants; },
 996    "getCurrentPost": function() { return getCurrentPost; },
 997    "getCurrentPostAttribute": function() { return getCurrentPostAttribute; },
 998    "getCurrentPostId": function() { return getCurrentPostId; },
 999    "getCurrentPostLastRevisionId": function() { return getCurrentPostLastRevisionId; },
1000    "getCurrentPostRevisionsCount": function() { return getCurrentPostRevisionsCount; },
1001    "getCurrentPostType": function() { return getCurrentPostType; },
1002    "getEditedPostAttribute": function() { return getEditedPostAttribute; },
1003    "getEditedPostContent": function() { return getEditedPostContent; },
1004    "getEditedPostPreviewLink": function() { return getEditedPostPreviewLink; },
1005    "getEditedPostSlug": function() { return getEditedPostSlug; },
1006    "getEditedPostVisibility": function() { return getEditedPostVisibility; },
1007    "getEditorBlocks": function() { return getEditorBlocks; },
1008    "getEditorSelection": function() { return getEditorSelection; },
1009    "getEditorSelectionEnd": function() { return getEditorSelectionEnd; },
1010    "getEditorSelectionStart": function() { return getEditorSelectionStart; },
1011    "getEditorSettings": function() { return getEditorSettings; },
1012    "getFirstMultiSelectedBlockClientId": function() { return getFirstMultiSelectedBlockClientId; },
1013    "getGlobalBlockCount": function() { return getGlobalBlockCount; },
1014    "getInserterItems": function() { return getInserterItems; },
1015    "getLastMultiSelectedBlockClientId": function() { return getLastMultiSelectedBlockClientId; },
1016    "getMultiSelectedBlockClientIds": function() { return getMultiSelectedBlockClientIds; },
1017    "getMultiSelectedBlocks": function() { return getMultiSelectedBlocks; },
1018    "getMultiSelectedBlocksEndClientId": function() { return getMultiSelectedBlocksEndClientId; },
1019    "getMultiSelectedBlocksStartClientId": function() { return getMultiSelectedBlocksStartClientId; },
1020    "getNextBlockClientId": function() { return getNextBlockClientId; },
1021    "getPermalink": function() { return getPermalink; },
1022    "getPermalinkParts": function() { return getPermalinkParts; },
1023    "getPostEdits": function() { return getPostEdits; },
1024    "getPostLockUser": function() { return getPostLockUser; },
1025    "getPostTypeLabel": function() { return getPostTypeLabel; },
1026    "getPreviousBlockClientId": function() { return getPreviousBlockClientId; },
1027    "getSelectedBlock": function() { return getSelectedBlock; },
1028    "getSelectedBlockClientId": function() { return getSelectedBlockClientId; },
1029    "getSelectedBlockCount": function() { return getSelectedBlockCount; },
1030    "getSelectedBlocksInitialCaretPosition": function() { return getSelectedBlocksInitialCaretPosition; },
1031    "getStateBeforeOptimisticTransaction": function() { return getStateBeforeOptimisticTransaction; },
1032    "getSuggestedPostFormat": function() { return getSuggestedPostFormat; },
1033    "getTemplate": function() { return getTemplate; },
1034    "getTemplateLock": function() { return getTemplateLock; },
1035    "hasChangedContent": function() { return hasChangedContent; },
1036    "hasEditorRedo": function() { return hasEditorRedo; },
1037    "hasEditorUndo": function() { return hasEditorUndo; },
1038    "hasInserterItems": function() { return hasInserterItems; },
1039    "hasMultiSelection": function() { return hasMultiSelection; },
1040    "hasNonPostEntityChanges": function() { return hasNonPostEntityChanges; },
1041    "hasSelectedBlock": function() { return hasSelectedBlock; },
1042    "hasSelectedInnerBlock": function() { return hasSelectedInnerBlock; },
1043    "inSomeHistory": function() { return inSomeHistory; },
1044    "isAncestorMultiSelected": function() { return isAncestorMultiSelected; },
1045    "isAutosavingPost": function() { return isAutosavingPost; },
1046    "isBlockInsertionPointVisible": function() { return isBlockInsertionPointVisible; },
1047    "isBlockMultiSelected": function() { return isBlockMultiSelected; },
1048    "isBlockSelected": function() { return isBlockSelected; },
1049    "isBlockValid": function() { return isBlockValid; },
1050    "isBlockWithinSelection": function() { return isBlockWithinSelection; },
1051    "isCaretWithinFormattedText": function() { return isCaretWithinFormattedText; },
1052    "isCleanNewPost": function() { return isCleanNewPost; },
1053    "isCurrentPostPending": function() { return isCurrentPostPending; },
1054    "isCurrentPostPublished": function() { return isCurrentPostPublished; },
1055    "isCurrentPostScheduled": function() { return isCurrentPostScheduled; },
1056    "isEditedPostAutosaveable": function() { return isEditedPostAutosaveable; },
1057    "isEditedPostBeingScheduled": function() { return isEditedPostBeingScheduled; },
1058    "isEditedPostDateFloating": function() { return isEditedPostDateFloating; },
1059    "isEditedPostDirty": function() { return isEditedPostDirty; },
1060    "isEditedPostEmpty": function() { return isEditedPostEmpty; },
1061    "isEditedPostNew": function() { return isEditedPostNew; },
1062    "isEditedPostPublishable": function() { return isEditedPostPublishable; },
1063    "isEditedPostSaveable": function() { return isEditedPostSaveable; },
1064    "isFirstMultiSelectedBlock": function() { return isFirstMultiSelectedBlock; },
1065    "isMultiSelecting": function() { return isMultiSelecting; },
1066    "isPermalinkEditable": function() { return isPermalinkEditable; },
1067    "isPostAutosavingLocked": function() { return isPostAutosavingLocked; },
1068    "isPostLockTakeover": function() { return isPostLockTakeover; },
1069    "isPostLocked": function() { return isPostLocked; },
1070    "isPostSavingLocked": function() { return isPostSavingLocked; },
1071    "isPreviewingPost": function() { return isPreviewingPost; },
1072    "isPublishSidebarEnabled": function() { return isPublishSidebarEnabled; },
1073    "isPublishingPost": function() { return isPublishingPost; },
1074    "isSavingNonPostEntityChanges": function() { return isSavingNonPostEntityChanges; },
1075    "isSavingPost": function() { return isSavingPost; },
1076    "isSelectionEnabled": function() { return isSelectionEnabled; },
1077    "isTyping": function() { return isTyping; },
1078    "isValidTemplate": function() { return isValidTemplate; }
1079  });
1080  
1081  // NAMESPACE OBJECT: ./node_modules/@wordpress/editor/build-module/store/actions.js
1082  var actions_namespaceObject = {};
1083  __webpack_require__.r(actions_namespaceObject);
1084  __webpack_require__.d(actions_namespaceObject, {
1085    "__experimentalTearDownEditor": function() { return __experimentalTearDownEditor; },
1086    "autosave": function() { return autosave; },
1087    "clearSelectedBlock": function() { return clearSelectedBlock; },
1088    "createUndoLevel": function() { return createUndoLevel; },
1089    "disablePublishSidebar": function() { return disablePublishSidebar; },
1090    "editPost": function() { return editPost; },
1091    "enablePublishSidebar": function() { return enablePublishSidebar; },
1092    "enterFormattedText": function() { return enterFormattedText; },
1093    "exitFormattedText": function() { return exitFormattedText; },
1094    "hideInsertionPoint": function() { return hideInsertionPoint; },
1095    "insertBlock": function() { return insertBlock; },
1096    "insertBlocks": function() { return insertBlocks; },
1097    "insertDefaultBlock": function() { return insertDefaultBlock; },
1098    "lockPostAutosaving": function() { return lockPostAutosaving; },
1099    "lockPostSaving": function() { return lockPostSaving; },
1100    "mergeBlocks": function() { return mergeBlocks; },
1101    "moveBlockToPosition": function() { return moveBlockToPosition; },
1102    "moveBlocksDown": function() { return moveBlocksDown; },
1103    "moveBlocksUp": function() { return moveBlocksUp; },
1104    "multiSelect": function() { return multiSelect; },
1105    "receiveBlocks": function() { return receiveBlocks; },
1106    "redo": function() { return redo; },
1107    "refreshPost": function() { return refreshPost; },
1108    "removeBlock": function() { return removeBlock; },
1109    "removeBlocks": function() { return removeBlocks; },
1110    "replaceBlock": function() { return replaceBlock; },
1111    "replaceBlocks": function() { return replaceBlocks; },
1112    "resetBlocks": function() { return resetBlocks; },
1113    "resetEditorBlocks": function() { return resetEditorBlocks; },
1114    "resetPost": function() { return resetPost; },
1115    "savePost": function() { return savePost; },
1116    "selectBlock": function() { return selectBlock; },
1117    "setTemplateValidity": function() { return setTemplateValidity; },
1118    "setupEditor": function() { return setupEditor; },
1119    "setupEditorState": function() { return setupEditorState; },
1120    "showInsertionPoint": function() { return showInsertionPoint; },
1121    "startMultiSelect": function() { return startMultiSelect; },
1122    "startTyping": function() { return startTyping; },
1123    "stopMultiSelect": function() { return stopMultiSelect; },
1124    "stopTyping": function() { return stopTyping; },
1125    "synchronizeTemplate": function() { return synchronizeTemplate; },
1126    "toggleBlockMode": function() { return toggleBlockMode; },
1127    "toggleSelection": function() { return toggleSelection; },
1128    "trashPost": function() { return trashPost; },
1129    "undo": function() { return undo; },
1130    "unlockPostAutosaving": function() { return unlockPostAutosaving; },
1131    "unlockPostSaving": function() { return unlockPostSaving; },
1132    "updateBlock": function() { return updateBlock; },
1133    "updateBlockAttributes": function() { return updateBlockAttributes; },
1134    "updateBlockListSettings": function() { return updateBlockListSettings; },
1135    "updateEditorSettings": function() { return updateEditorSettings; },
1136    "updatePost": function() { return updatePost; },
1137    "updatePostLock": function() { return updatePostLock; }
1138  });
1139  
1140  ;// CONCATENATED MODULE: ./node_modules/@babel/runtime/helpers/esm/extends.js
1141  function _extends() {
1142    _extends = Object.assign || function (target) {
1143      for (var i = 1; i < arguments.length; i++) {
1144        var source = arguments[i];
1145  
1146        for (var key in source) {
1147          if (Object.prototype.hasOwnProperty.call(source, key)) {
1148            target[key] = source[key];
1149          }
1150        }
1151      }
1152  
1153      return target;
1154    };
1155  
1156    return _extends.apply(this, arguments);
1157  }
1158  ;// CONCATENATED MODULE: external ["wp","element"]
1159  var external_wp_element_namespaceObject = window["wp"]["element"];
1160  ;// CONCATENATED MODULE: external "lodash"
1161  var external_lodash_namespaceObject = window["lodash"];
1162  ;// CONCATENATED MODULE: external ["wp","blocks"]
1163  var external_wp_blocks_namespaceObject = window["wp"]["blocks"];
1164  ;// CONCATENATED MODULE: external ["wp","data"]
1165  var external_wp_data_namespaceObject = window["wp"]["data"];
1166  ;// CONCATENATED MODULE: external ["wp","coreData"]
1167  var external_wp_coreData_namespaceObject = window["wp"]["coreData"];
1168  ;// CONCATENATED MODULE: external ["wp","compose"]
1169  var external_wp_compose_namespaceObject = window["wp"]["compose"];
1170  ;// CONCATENATED MODULE: external ["wp","hooks"]
1171  var external_wp_hooks_namespaceObject = window["wp"]["hooks"];
1172  ;// CONCATENATED MODULE: external ["wp","blockEditor"]
1173  var external_wp_blockEditor_namespaceObject = window["wp"]["blockEditor"];
1174  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/store/defaults.js
1175  /**
1176   * WordPress dependencies
1177   */
1178  
1179  /**
1180   * The default post editor settings.
1181   *
1182   * @property {boolean|Array} allowedBlockTypes     Allowed block types
1183   * @property {boolean}       richEditingEnabled    Whether rich editing is enabled or not
1184   * @property {boolean}       codeEditingEnabled    Whether code editing is enabled or not
1185   * @property {boolean}       enableCustomFields    Whether the WordPress custom fields are enabled or not.
1186   *                                                 true  = the user has opted to show the Custom Fields panel at the bottom of the editor.
1187   *                                                 false = the user has opted to hide the Custom Fields panel at the bottom of the editor.
1188   *                                                 undefined = the current environment does not support Custom Fields, so the option toggle in Preferences -> Panels to enable the Custom Fields panel is not displayed.
1189   * @property {number}        autosaveInterval      How often in seconds the post will be auto-saved via the REST API.
1190   * @property {number}        localAutosaveInterval How often in seconds the post will be backed up to sessionStorage.
1191   * @property {Array?}        availableTemplates    The available post templates
1192   * @property {boolean}       disablePostFormats    Whether or not the post formats are disabled
1193   * @property {Array?}        allowedMimeTypes      List of allowed mime types and file extensions
1194   * @property {number}        maxUploadFileSize     Maximum upload file size
1195   * @property {boolean}       supportsLayout        Whether the editor supports layouts.
1196   */
1197  
1198  const EDITOR_SETTINGS_DEFAULTS = { ...external_wp_blockEditor_namespaceObject.SETTINGS_DEFAULTS,
1199    richEditingEnabled: true,
1200    codeEditingEnabled: true,
1201    enableCustomFields: undefined,
1202    supportsLayout: true
1203  };
1204  
1205  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/store/reducer.js
1206  /**
1207   * External dependencies
1208   */
1209  
1210  /**
1211   * WordPress dependencies
1212   */
1213  
1214  
1215  /**
1216   * Internal dependencies
1217   */
1218  
1219  
1220  /**
1221   * Returns a post attribute value, flattening nested rendered content using its
1222   * raw value in place of its original object form.
1223   *
1224   * @param {*} value Original value.
1225   *
1226   * @return {*} Raw value.
1227   */
1228  
1229  function getPostRawValue(value) {
1230    if (value && 'object' === typeof value && 'raw' in value) {
1231      return value.raw;
1232    }
1233  
1234    return value;
1235  }
1236  /**
1237   * Returns true if the two object arguments have the same keys, or false
1238   * otherwise.
1239   *
1240   * @param {Object} a First object.
1241   * @param {Object} b Second object.
1242   *
1243   * @return {boolean} Whether the two objects have the same keys.
1244   */
1245  
1246  function hasSameKeys(a, b) {
1247    return isEqual(keys(a), keys(b));
1248  }
1249  /**
1250   * Returns true if, given the currently dispatching action and the previously
1251   * dispatched action, the two actions are editing the same post property, or
1252   * false otherwise.
1253   *
1254   * @param {Object} action         Currently dispatching action.
1255   * @param {Object} previousAction Previously dispatched action.
1256   *
1257   * @return {boolean} Whether actions are updating the same post property.
1258   */
1259  
1260  function isUpdatingSamePostProperty(action, previousAction) {
1261    return action.type === 'EDIT_POST' && hasSameKeys(action.edits, previousAction.edits);
1262  }
1263  /**
1264   * Returns true if, given the currently dispatching action and the previously
1265   * dispatched action, the two actions are modifying the same property such that
1266   * undo history should be batched.
1267   *
1268   * @param {Object} action         Currently dispatching action.
1269   * @param {Object} previousAction Previously dispatched action.
1270   *
1271   * @return {boolean} Whether to overwrite present state.
1272   */
1273  
1274  function shouldOverwriteState(action, previousAction) {
1275    if (action.type === 'RESET_EDITOR_BLOCKS') {
1276      return !action.shouldCreateUndoLevel;
1277    }
1278  
1279    if (!previousAction || action.type !== previousAction.type) {
1280      return false;
1281    }
1282  
1283    return isUpdatingSamePostProperty(action, previousAction);
1284  }
1285  function postId() {
1286    let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : null;
1287    let action = arguments.length > 1 ? arguments[1] : undefined;
1288  
1289    switch (action.type) {
1290      case 'SETUP_EDITOR_STATE':
1291        return action.post.id;
1292    }
1293  
1294    return state;
1295  }
1296  function postType() {
1297    let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : null;
1298    let action = arguments.length > 1 ? arguments[1] : undefined;
1299  
1300    switch (action.type) {
1301      case 'SETUP_EDITOR_STATE':
1302        return action.post.type;
1303    }
1304  
1305    return state;
1306  }
1307  /**
1308   * Reducer returning whether the post blocks match the defined template or not.
1309   *
1310   * @param {Object} state  Current state.
1311   * @param {Object} action Dispatched action.
1312   *
1313   * @return {boolean} Updated state.
1314   */
1315  
1316  function template() {
1317    let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {
1318      isValid: true
1319    };
1320    let action = arguments.length > 1 ? arguments[1] : undefined;
1321  
1322    switch (action.type) {
1323      case 'SET_TEMPLATE_VALIDITY':
1324        return { ...state,
1325          isValid: action.isValid
1326        };
1327    }
1328  
1329    return state;
1330  }
1331  /**
1332   * Reducer returning current network request state (whether a request to
1333   * the WP REST API is in progress, successful, or failed).
1334   *
1335   * @param {Object} state  Current state.
1336   * @param {Object} action Dispatched action.
1337   *
1338   * @return {Object} Updated state.
1339   */
1340  
1341  function saving() {
1342    let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
1343    let action = arguments.length > 1 ? arguments[1] : undefined;
1344  
1345    switch (action.type) {
1346      case 'REQUEST_POST_UPDATE_START':
1347      case 'REQUEST_POST_UPDATE_FINISH':
1348        return {
1349          pending: action.type === 'REQUEST_POST_UPDATE_START',
1350          options: action.options || {}
1351        };
1352    }
1353  
1354    return state;
1355  }
1356  /**
1357   * Post Lock State.
1358   *
1359   * @typedef {Object} PostLockState
1360   *
1361   * @property {boolean}  isLocked       Whether the post is locked.
1362   * @property {?boolean} isTakeover     Whether the post editing has been taken over.
1363   * @property {?boolean} activePostLock Active post lock value.
1364   * @property {?Object}  user           User that took over the post.
1365   */
1366  
1367  /**
1368   * Reducer returning the post lock status.
1369   *
1370   * @param {PostLockState} state  Current state.
1371   * @param {Object}        action Dispatched action.
1372   *
1373   * @return {PostLockState} Updated state.
1374   */
1375  
1376  function postLock() {
1377    let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {
1378      isLocked: false
1379    };
1380    let action = arguments.length > 1 ? arguments[1] : undefined;
1381  
1382    switch (action.type) {
1383      case 'UPDATE_POST_LOCK':
1384        return action.lock;
1385    }
1386  
1387    return state;
1388  }
1389  /**
1390   * Post saving lock.
1391   *
1392   * When post saving is locked, the post cannot be published or updated.
1393   *
1394   * @param {PostLockState} state  Current state.
1395   * @param {Object}        action Dispatched action.
1396   *
1397   * @return {PostLockState} Updated state.
1398   */
1399  
1400  function postSavingLock() {
1401    let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
1402    let action = arguments.length > 1 ? arguments[1] : undefined;
1403  
1404    switch (action.type) {
1405      case 'LOCK_POST_SAVING':
1406        return { ...state,
1407          [action.lockName]: true
1408        };
1409  
1410      case 'UNLOCK_POST_SAVING':
1411        return (0,external_lodash_namespaceObject.omit)(state, action.lockName);
1412    }
1413  
1414    return state;
1415  }
1416  /**
1417   * Post autosaving lock.
1418   *
1419   * When post autosaving is locked, the post will not autosave.
1420   *
1421   * @param {PostLockState} state  Current state.
1422   * @param {Object}        action Dispatched action.
1423   *
1424   * @return {PostLockState} Updated state.
1425   */
1426  
1427  function postAutosavingLock() {
1428    let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
1429    let action = arguments.length > 1 ? arguments[1] : undefined;
1430  
1431    switch (action.type) {
1432      case 'LOCK_POST_AUTOSAVING':
1433        return { ...state,
1434          [action.lockName]: true
1435        };
1436  
1437      case 'UNLOCK_POST_AUTOSAVING':
1438        return (0,external_lodash_namespaceObject.omit)(state, action.lockName);
1439    }
1440  
1441    return state;
1442  }
1443  /**
1444   * Reducer returning whether the editor is ready to be rendered.
1445   * The editor is considered ready to be rendered once
1446   * the post object is loaded properly and the initial blocks parsed.
1447   *
1448   * @param {boolean} state
1449   * @param {Object}  action
1450   *
1451   * @return {boolean} Updated state.
1452   */
1453  
1454  function isReady() {
1455    let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;
1456    let action = arguments.length > 1 ? arguments[1] : undefined;
1457  
1458    switch (action.type) {
1459      case 'SETUP_EDITOR_STATE':
1460        return true;
1461  
1462      case 'TEAR_DOWN_EDITOR':
1463        return false;
1464    }
1465  
1466    return state;
1467  }
1468  /**
1469   * Reducer returning the post editor setting.
1470   *
1471   * @param {Object} state  Current state.
1472   * @param {Object} action Dispatched action.
1473   *
1474   * @return {Object} Updated state.
1475   */
1476  
1477  function editorSettings() {
1478    let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : EDITOR_SETTINGS_DEFAULTS;
1479    let action = arguments.length > 1 ? arguments[1] : undefined;
1480  
1481    switch (action.type) {
1482      case 'UPDATE_EDITOR_SETTINGS':
1483        return { ...state,
1484          ...action.settings
1485        };
1486    }
1487  
1488    return state;
1489  }
1490  /* harmony default export */ var reducer = ((0,external_wp_data_namespaceObject.combineReducers)({
1491    postId,
1492    postType,
1493    saving,
1494    postLock,
1495    template,
1496    postSavingLock,
1497    isReady,
1498    editorSettings,
1499    postAutosavingLock
1500  }));
1501  
1502  ;// CONCATENATED MODULE: ./node_modules/rememo/es/rememo.js
1503  
1504  
1505  var LEAF_KEY, hasWeakMap;
1506  
1507  /**
1508   * Arbitrary value used as key for referencing cache object in WeakMap tree.
1509   *
1510   * @type {Object}
1511   */
1512  LEAF_KEY = {};
1513  
1514  /**
1515   * Whether environment supports WeakMap.
1516   *
1517   * @type {boolean}
1518   */
1519  hasWeakMap = typeof WeakMap !== 'undefined';
1520  
1521  /**
1522   * Returns the first argument as the sole entry in an array.
1523   *
1524   * @param {*} value Value to return.
1525   *
1526   * @return {Array} Value returned as entry in array.
1527   */
1528  function arrayOf( value ) {
1529      return [ value ];
1530  }
1531  
1532  /**
1533   * Returns true if the value passed is object-like, or false otherwise. A value
1534   * is object-like if it can support property assignment, e.g. object or array.
1535   *
1536   * @param {*} value Value to test.
1537   *
1538   * @return {boolean} Whether value is object-like.
1539   */
1540  function isObjectLike( value ) {
1541      return !! value && 'object' === typeof value;
1542  }
1543  
1544  /**
1545   * Creates and returns a new cache object.
1546   *
1547   * @return {Object} Cache object.
1548   */
1549  function createCache() {
1550      var cache = {
1551          clear: function() {
1552              cache.head = null;
1553          },
1554      };
1555  
1556      return cache;
1557  }
1558  
1559  /**
1560   * Returns true if entries within the two arrays are strictly equal by
1561   * reference from a starting index.
1562   *
1563   * @param {Array}  a         First array.
1564   * @param {Array}  b         Second array.
1565   * @param {number} fromIndex Index from which to start comparison.
1566   *
1567   * @return {boolean} Whether arrays are shallowly equal.
1568   */
1569  function isShallowEqual( a, b, fromIndex ) {
1570      var i;
1571  
1572      if ( a.length !== b.length ) {
1573          return false;
1574      }
1575  
1576      for ( i = fromIndex; i < a.length; i++ ) {
1577          if ( a[ i ] !== b[ i ] ) {
1578              return false;
1579          }
1580      }
1581  
1582      return true;
1583  }
1584  
1585  /**
1586   * Returns a memoized selector function. The getDependants function argument is
1587   * called before the memoized selector and is expected to return an immutable
1588   * reference or array of references on which the selector depends for computing
1589   * its own return value. The memoize cache is preserved only as long as those
1590   * dependant references remain the same. If getDependants returns a different
1591   * reference(s), the cache is cleared and the selector value regenerated.
1592   *
1593   * @param {Function} selector      Selector function.
1594   * @param {Function} getDependants Dependant getter returning an immutable
1595   *                                 reference or array of reference used in
1596   *                                 cache bust consideration.
1597   *
1598   * @return {Function} Memoized selector.
1599   */
1600  /* harmony default export */ function rememo(selector, getDependants ) {
1601      var rootCache, getCache;
1602  
1603      // Use object source as dependant if getter not provided
1604      if ( ! getDependants ) {
1605          getDependants = arrayOf;
1606      }
1607  
1608      /**
1609       * Returns the root cache. If WeakMap is supported, this is assigned to the
1610       * root WeakMap cache set, otherwise it is a shared instance of the default
1611       * cache object.
1612       *
1613       * @return {(WeakMap|Object)} Root cache object.
1614       */
1615  	function getRootCache() {
1616          return rootCache;
1617      }
1618  
1619      /**
1620       * Returns the cache for a given dependants array. When possible, a WeakMap
1621       * will be used to create a unique cache for each set of dependants. This
1622       * is feasible due to the nature of WeakMap in allowing garbage collection
1623       * to occur on entries where the key object is no longer referenced. Since
1624       * WeakMap requires the key to be an object, this is only possible when the
1625       * dependant is object-like. The root cache is created as a hierarchy where
1626       * each top-level key is the first entry in a dependants set, the value a
1627       * WeakMap where each key is the next dependant, and so on. This continues
1628       * so long as the dependants are object-like. If no dependants are object-
1629       * like, then the cache is shared across all invocations.
1630       *
1631       * @see isObjectLike
1632       *
1633       * @param {Array} dependants Selector dependants.
1634       *
1635       * @return {Object} Cache object.
1636       */
1637  	function getWeakMapCache( dependants ) {
1638          var caches = rootCache,
1639              isUniqueByDependants = true,
1640              i, dependant, map, cache;
1641  
1642          for ( i = 0; i < dependants.length; i++ ) {
1643              dependant = dependants[ i ];
1644  
1645              // Can only compose WeakMap from object-like key.
1646              if ( ! isObjectLike( dependant ) ) {
1647                  isUniqueByDependants = false;
1648                  break;
1649              }
1650  
1651              // Does current segment of cache already have a WeakMap?
1652              if ( caches.has( dependant ) ) {
1653                  // Traverse into nested WeakMap.
1654                  caches = caches.get( dependant );
1655              } else {
1656                  // Create, set, and traverse into a new one.
1657                  map = new WeakMap();
1658                  caches.set( dependant, map );
1659                  caches = map;
1660              }
1661          }
1662  
1663          // We use an arbitrary (but consistent) object as key for the last item
1664          // in the WeakMap to serve as our running cache.
1665          if ( ! caches.has( LEAF_KEY ) ) {
1666              cache = createCache();
1667              cache.isUniqueByDependants = isUniqueByDependants;
1668              caches.set( LEAF_KEY, cache );
1669          }
1670  
1671          return caches.get( LEAF_KEY );
1672      }
1673  
1674      // Assign cache handler by availability of WeakMap
1675      getCache = hasWeakMap ? getWeakMapCache : getRootCache;
1676  
1677      /**
1678       * Resets root memoization cache.
1679       */
1680  	function clear() {
1681          rootCache = hasWeakMap ? new WeakMap() : createCache();
1682      }
1683  
1684      // eslint-disable-next-line jsdoc/check-param-names
1685      /**
1686       * The augmented selector call, considering first whether dependants have
1687       * changed before passing it to underlying memoize function.
1688       *
1689       * @param {Object} source    Source object for derivation.
1690       * @param {...*}   extraArgs Additional arguments to pass to selector.
1691       *
1692       * @return {*} Selector result.
1693       */
1694  	function callSelector( /* source, ...extraArgs */ ) {
1695          var len = arguments.length,
1696              cache, node, i, args, dependants;
1697  
1698          // Create copy of arguments (avoid leaking deoptimization).
1699          args = new Array( len );
1700          for ( i = 0; i < len; i++ ) {
1701              args[ i ] = arguments[ i ];
1702          }
1703  
1704          dependants = getDependants.apply( null, args );
1705          cache = getCache( dependants );
1706  
1707          // If not guaranteed uniqueness by dependants (primitive type or lack
1708          // of WeakMap support), shallow compare against last dependants and, if
1709          // references have changed, destroy cache to recalculate result.
1710          if ( ! cache.isUniqueByDependants ) {
1711              if ( cache.lastDependants && ! isShallowEqual( dependants, cache.lastDependants, 0 ) ) {
1712                  cache.clear();
1713              }
1714  
1715              cache.lastDependants = dependants;
1716          }
1717  
1718          node = cache.head;
1719          while ( node ) {
1720              // Check whether node arguments match arguments
1721              if ( ! isShallowEqual( node.args, args, 1 ) ) {
1722                  node = node.next;
1723                  continue;
1724              }
1725  
1726              // At this point we can assume we've found a match
1727  
1728              // Surface matched node to head if not already
1729              if ( node !== cache.head ) {
1730                  // Adjust siblings to point to each other.
1731                  node.prev.next = node.next;
1732                  if ( node.next ) {
1733                      node.next.prev = node.prev;
1734                  }
1735  
1736                  node.next = cache.head;
1737                  node.prev = null;
1738                  cache.head.prev = node;
1739                  cache.head = node;
1740              }
1741  
1742              // Return immediately
1743              return node.val;
1744          }
1745  
1746          // No cached value found. Continue to insertion phase:
1747  
1748          node = {
1749              // Generate the result from original function
1750              val: selector.apply( null, args ),
1751          };
1752  
1753          // Avoid including the source object in the cache.
1754          args[ 0 ] = null;
1755          node.args = args;
1756  
1757          // Don't need to check whether node is already head, since it would
1758          // have been returned above already if it was
1759  
1760          // Shift existing head down list
1761          if ( cache.head ) {
1762              cache.head.prev = node;
1763              node.next = cache.head;
1764          }
1765  
1766          cache.head = node;
1767  
1768          return node.val;
1769      }
1770  
1771      callSelector.getDependants = getDependants;
1772      callSelector.clear = clear;
1773      clear();
1774  
1775      return callSelector;
1776  }
1777  
1778  ;// CONCATENATED MODULE: external ["wp","date"]
1779  var external_wp_date_namespaceObject = window["wp"]["date"];
1780  ;// CONCATENATED MODULE: external ["wp","url"]
1781  var external_wp_url_namespaceObject = window["wp"]["url"];
1782  ;// CONCATENATED MODULE: external ["wp","deprecated"]
1783  var external_wp_deprecated_namespaceObject = window["wp"]["deprecated"];
1784  var external_wp_deprecated_default = /*#__PURE__*/__webpack_require__.n(external_wp_deprecated_namespaceObject);
1785  ;// CONCATENATED MODULE: external ["wp","primitives"]
1786  var external_wp_primitives_namespaceObject = window["wp"]["primitives"];
1787  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/layout.js
1788  
1789  
1790  /**
1791   * WordPress dependencies
1792   */
1793  
1794  const layout = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
1795    xmlns: "http://www.w3.org/2000/svg",
1796    viewBox: "0 0 24 24"
1797  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
1798    d: "M18 5.5H6a.5.5 0 00-.5.5v3h13V6a.5.5 0 00-.5-.5zm.5 5H10v8h8a.5.5 0 00.5-.5v-7.5zm-10 0h-3V18a.5.5 0 00.5.5h2.5v-8zM6 4h12a2 2 0 012 2v12a2 2 0 01-2 2H6a2 2 0 01-2-2V6a2 2 0 012-2z"
1799  }));
1800  /* harmony default export */ var library_layout = (layout);
1801  
1802  ;// CONCATENATED MODULE: external ["wp","preferences"]
1803  var external_wp_preferences_namespaceObject = window["wp"]["preferences"];
1804  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/store/constants.js
1805  /**
1806   * Set of post properties for which edits should assume a merging behavior,
1807   * assuming an object value.
1808   *
1809   * @type {Set}
1810   */
1811  const EDIT_MERGE_PROPERTIES = new Set(['meta']);
1812  /**
1813   * Constant for the store module (or reducer) key.
1814   *
1815   * @type {string}
1816   */
1817  
1818  const STORE_NAME = 'core/editor';
1819  const SAVE_POST_NOTICE_ID = 'SAVE_POST_NOTICE_ID';
1820  const TRASH_POST_NOTICE_ID = 'TRASH_POST_NOTICE_ID';
1821  const PERMALINK_POSTNAME_REGEX = /%(?:postname|pagename)%/;
1822  const ONE_MINUTE_IN_MS = 60 * 1000;
1823  const AUTOSAVE_PROPERTIES = ['title', 'excerpt', 'content'];
1824  
1825  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/header.js
1826  
1827  
1828  /**
1829   * WordPress dependencies
1830   */
1831  
1832  const header = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
1833    xmlns: "http://www.w3.org/2000/svg",
1834    viewBox: "0 0 24 24"
1835  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
1836    d: "M18.5 10.5H10v8h8a.5.5 0 00.5-.5v-7.5zm-10 0h-3V18a.5.5 0 00.5.5h2.5v-8zM6 4h12a2 2 0 012 2v12a2 2 0 01-2 2H6a2 2 0 01-2-2V6a2 2 0 012-2z"
1837  }));
1838  /* harmony default export */ var library_header = (header);
1839  
1840  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/footer.js
1841  
1842  
1843  /**
1844   * WordPress dependencies
1845   */
1846  
1847  const footer = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
1848    xmlns: "http://www.w3.org/2000/svg",
1849    viewBox: "0 0 24 24"
1850  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
1851    fillRule: "evenodd",
1852    d: "M18 5.5h-8v8h8.5V6a.5.5 0 00-.5-.5zm-9.5 8h-3V6a.5.5 0 01.5-.5h2.5v8zM6 4h12a2 2 0 012 2v12a2 2 0 01-2 2H6a2 2 0 01-2-2V6a2 2 0 012-2z"
1853  }));
1854  /* harmony default export */ var library_footer = (footer);
1855  
1856  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/sidebar.js
1857  
1858  
1859  /**
1860   * WordPress dependencies
1861   */
1862  
1863  const sidebar = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
1864    xmlns: "http://www.w3.org/2000/svg",
1865    viewBox: "0 0 24 24"
1866  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
1867    d: "M18 5.5H6a.5.5 0 00-.5.5v3h13V6a.5.5 0 00-.5-.5zm.5 5H10v8h8a.5.5 0 00.5-.5v-7.5zM6 4h12a2 2 0 012 2v12a2 2 0 01-2 2H6a2 2 0 01-2-2V6a2 2 0 012-2z"
1868  }));
1869  /* harmony default export */ var library_sidebar = (sidebar);
1870  
1871  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/symbol-filled.js
1872  
1873  
1874  /**
1875   * WordPress dependencies
1876   */
1877  
1878  const symbolFilled = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
1879    xmlns: "http://www.w3.org/2000/svg",
1880    viewBox: "0 0 24 24"
1881  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
1882    d: "M21.3 10.8l-5.6-5.6c-.7-.7-1.8-.7-2.5 0l-5.6 5.6c-.7.7-.7 1.8 0 2.5l5.6 5.6c.3.3.8.5 1.2.5s.9-.2 1.2-.5l5.6-5.6c.8-.7.8-1.9.1-2.5zm-17.6 1L10 5.5l-1-1-6.3 6.3c-.7.7-.7 1.8 0 2.5L9 19.5l1.1-1.1-6.3-6.3c-.2 0-.2-.2-.1-.3z"
1883  }));
1884  /* harmony default export */ var symbol_filled = (symbolFilled);
1885  
1886  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/utils/get-template-part-icon.js
1887  /**
1888   * WordPress dependencies
1889   */
1890  
1891  /**
1892   * Helper function to retrieve the corresponding icon by name.
1893   *
1894   * @param {string} iconName The name of the icon.
1895   *
1896   * @return {Object} The corresponding icon.
1897   */
1898  
1899  function getTemplatePartIcon(iconName) {
1900    if ('header' === iconName) {
1901      return library_header;
1902    } else if ('footer' === iconName) {
1903      return library_footer;
1904    } else if ('sidebar' === iconName) {
1905      return library_sidebar;
1906    }
1907  
1908    return symbol_filled;
1909  }
1910  
1911  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/store/selectors.js
1912  /**
1913   * External dependencies
1914   */
1915  
1916  
1917  /**
1918   * WordPress dependencies
1919   */
1920  
1921  
1922  
1923  
1924  
1925  
1926  
1927  
1928  
1929  
1930  
1931  /**
1932   * Internal dependencies
1933   */
1934  
1935  
1936  
1937  
1938  /**
1939   * Shared reference to an empty object for cases where it is important to avoid
1940   * returning a new object reference on every invocation, as in a connected or
1941   * other pure component which performs `shouldComponentUpdate` check on props.
1942   * This should be used as a last resort, since the normalized data should be
1943   * maintained by the reducer result in state.
1944   */
1945  
1946  const EMPTY_OBJECT = {};
1947  /**
1948   * Shared reference to an empty array for cases where it is important to avoid
1949   * returning a new array reference on every invocation, as in a connected or
1950   * other pure component which performs `shouldComponentUpdate` check on props.
1951   * This should be used as a last resort, since the normalized data should be
1952   * maintained by the reducer result in state.
1953   */
1954  
1955  const EMPTY_ARRAY = [];
1956  /**
1957   * Returns true if any past editor history snapshots exist, or false otherwise.
1958   *
1959   * @param {Object} state Global application state.
1960   *
1961   * @return {boolean} Whether undo history exists.
1962   */
1963  
1964  const hasEditorUndo = (0,external_wp_data_namespaceObject.createRegistrySelector)(select => () => {
1965    return select(external_wp_coreData_namespaceObject.store).hasUndo();
1966  });
1967  /**
1968   * Returns true if any future editor history snapshots exist, or false
1969   * otherwise.
1970   *
1971   * @param {Object} state Global application state.
1972   *
1973   * @return {boolean} Whether redo history exists.
1974   */
1975  
1976  const hasEditorRedo = (0,external_wp_data_namespaceObject.createRegistrySelector)(select => () => {
1977    return select(external_wp_coreData_namespaceObject.store).hasRedo();
1978  });
1979  /**
1980   * Returns true if the currently edited post is yet to be saved, or false if
1981   * the post has been saved.
1982   *
1983   * @param {Object} state Global application state.
1984   *
1985   * @return {boolean} Whether the post is new.
1986   */
1987  
1988  function isEditedPostNew(state) {
1989    return getCurrentPost(state).status === 'auto-draft';
1990  }
1991  /**
1992   * Returns true if content includes unsaved changes, or false otherwise.
1993   *
1994   * @param {Object} state Editor state.
1995   *
1996   * @return {boolean} Whether content includes unsaved changes.
1997   */
1998  
1999  function hasChangedContent(state) {
2000    const edits = getPostEdits(state);
2001    return 'blocks' in edits || // `edits` is intended to contain only values which are different from
2002    // the saved post, so the mere presence of a property is an indicator
2003    // that the value is different than what is known to be saved. While
2004    // content in Visual mode is represented by the blocks state, in Text
2005    // mode it is tracked by `edits.content`.
2006    'content' in edits;
2007  }
2008  /**
2009   * Returns true if there are unsaved values for the current edit session, or
2010   * false if the editing state matches the saved or new post.
2011   *
2012   * @param {Object} state Global application state.
2013   *
2014   * @return {boolean} Whether unsaved values exist.
2015   */
2016  
2017  const isEditedPostDirty = (0,external_wp_data_namespaceObject.createRegistrySelector)(select => state => {
2018    // Edits should contain only fields which differ from the saved post (reset
2019    // at initial load and save complete). Thus, a non-empty edits state can be
2020    // inferred to contain unsaved values.
2021    const postType = getCurrentPostType(state);
2022    const postId = getCurrentPostId(state);
2023  
2024    if (select(external_wp_coreData_namespaceObject.store).hasEditsForEntityRecord('postType', postType, postId)) {
2025      return true;
2026    }
2027  
2028    return false;
2029  });
2030  /**
2031   * Returns true if there are unsaved edits for entities other than
2032   * the editor's post, and false otherwise.
2033   *
2034   * @param {Object} state Global application state.
2035   *
2036   * @return {boolean} Whether there are edits or not.
2037   */
2038  
2039  const hasNonPostEntityChanges = (0,external_wp_data_namespaceObject.createRegistrySelector)(select => state => {
2040    const dirtyEntityRecords = select(external_wp_coreData_namespaceObject.store).__experimentalGetDirtyEntityRecords();
2041  
2042    const {
2043      type,
2044      id
2045    } = getCurrentPost(state);
2046    return (0,external_lodash_namespaceObject.some)(dirtyEntityRecords, entityRecord => entityRecord.kind !== 'postType' || entityRecord.name !== type || entityRecord.key !== id);
2047  });
2048  /**
2049   * Returns true if there are no unsaved values for the current edit session and
2050   * if the currently edited post is new (has never been saved before).
2051   *
2052   * @param {Object} state Global application state.
2053   *
2054   * @return {boolean} Whether new post and unsaved values exist.
2055   */
2056  
2057  function isCleanNewPost(state) {
2058    return !isEditedPostDirty(state) && isEditedPostNew(state);
2059  }
2060  /**
2061   * Returns the post currently being edited in its last known saved state, not
2062   * including unsaved edits. Returns an object containing relevant default post
2063   * values if the post has not yet been saved.
2064   *
2065   * @param {Object} state Global application state.
2066   *
2067   * @return {Object} Post object.
2068   */
2069  
2070  const getCurrentPost = (0,external_wp_data_namespaceObject.createRegistrySelector)(select => state => {
2071    const postId = getCurrentPostId(state);
2072    const postType = getCurrentPostType(state);
2073    const post = select(external_wp_coreData_namespaceObject.store).getRawEntityRecord('postType', postType, postId);
2074  
2075    if (post) {
2076      return post;
2077    } // This exists for compatibility with the previous selector behavior
2078    // which would guarantee an object return based on the editor reducer's
2079    // default empty object state.
2080  
2081  
2082    return EMPTY_OBJECT;
2083  });
2084  /**
2085   * Returns the post type of the post currently being edited.
2086   *
2087   * @param {Object} state Global application state.
2088   *
2089   * @return {string} Post type.
2090   */
2091  
2092  function getCurrentPostType(state) {
2093    return state.postType;
2094  }
2095  /**
2096   * Returns the ID of the post currently being edited, or null if the post has
2097   * not yet been saved.
2098   *
2099   * @param {Object} state Global application state.
2100   *
2101   * @return {?number} ID of current post.
2102   */
2103  
2104  function getCurrentPostId(state) {
2105    return state.postId;
2106  }
2107  /**
2108   * Returns the number of revisions of the post currently being edited.
2109   *
2110   * @param {Object} state Global application state.
2111   *
2112   * @return {number} Number of revisions.
2113   */
2114  
2115  function getCurrentPostRevisionsCount(state) {
2116    return (0,external_lodash_namespaceObject.get)(getCurrentPost(state), ['_links', 'version-history', 0, 'count'], 0);
2117  }
2118  /**
2119   * Returns the last revision ID of the post currently being edited,
2120   * or null if the post has no revisions.
2121   *
2122   * @param {Object} state Global application state.
2123   *
2124   * @return {?number} ID of the last revision.
2125   */
2126  
2127  function getCurrentPostLastRevisionId(state) {
2128    return (0,external_lodash_namespaceObject.get)(getCurrentPost(state), ['_links', 'predecessor-version', 0, 'id'], null);
2129  }
2130  /**
2131   * Returns any post values which have been changed in the editor but not yet
2132   * been saved.
2133   *
2134   * @param {Object} state Global application state.
2135   *
2136   * @return {Object} Object of key value pairs comprising unsaved edits.
2137   */
2138  
2139  const getPostEdits = (0,external_wp_data_namespaceObject.createRegistrySelector)(select => state => {
2140    const postType = getCurrentPostType(state);
2141    const postId = getCurrentPostId(state);
2142    return select(external_wp_coreData_namespaceObject.store).getEntityRecordEdits('postType', postType, postId) || EMPTY_OBJECT;
2143  });
2144  /**
2145   * Returns an attribute value of the saved post.
2146   *
2147   * @param {Object} state         Global application state.
2148   * @param {string} attributeName Post attribute name.
2149   *
2150   * @return {*} Post attribute value.
2151   */
2152  
2153  function getCurrentPostAttribute(state, attributeName) {
2154    switch (attributeName) {
2155      case 'type':
2156        return getCurrentPostType(state);
2157  
2158      case 'id':
2159        return getCurrentPostId(state);
2160  
2161      default:
2162        const post = getCurrentPost(state);
2163  
2164        if (!post.hasOwnProperty(attributeName)) {
2165          break;
2166        }
2167  
2168        return getPostRawValue(post[attributeName]);
2169    }
2170  }
2171  /**
2172   * Returns a single attribute of the post being edited, preferring the unsaved
2173   * edit if one exists, but merging with the attribute value for the last known
2174   * saved state of the post (this is needed for some nested attributes like meta).
2175   *
2176   * @param {Object} state         Global application state.
2177   * @param {string} attributeName Post attribute name.
2178   *
2179   * @return {*} Post attribute value.
2180   */
2181  
2182  const getNestedEditedPostProperty = (state, attributeName) => {
2183    const edits = getPostEdits(state);
2184  
2185    if (!edits.hasOwnProperty(attributeName)) {
2186      return getCurrentPostAttribute(state, attributeName);
2187    }
2188  
2189    return { ...getCurrentPostAttribute(state, attributeName),
2190      ...edits[attributeName]
2191    };
2192  };
2193  /**
2194   * Returns a single attribute of the post being edited, preferring the unsaved
2195   * edit if one exists, but falling back to the attribute for the last known
2196   * saved state of the post.
2197   *
2198   * @param {Object} state         Global application state.
2199   * @param {string} attributeName Post attribute name.
2200   *
2201   * @return {*} Post attribute value.
2202   */
2203  
2204  
2205  function getEditedPostAttribute(state, attributeName) {
2206    // Special cases.
2207    switch (attributeName) {
2208      case 'content':
2209        return getEditedPostContent(state);
2210    } // Fall back to saved post value if not edited.
2211  
2212  
2213    const edits = getPostEdits(state);
2214  
2215    if (!edits.hasOwnProperty(attributeName)) {
2216      return getCurrentPostAttribute(state, attributeName);
2217    } // Merge properties are objects which contain only the patch edit in state,
2218    // and thus must be merged with the current post attribute.
2219  
2220  
2221    if (EDIT_MERGE_PROPERTIES.has(attributeName)) {
2222      return getNestedEditedPostProperty(state, attributeName);
2223    }
2224  
2225    return edits[attributeName];
2226  }
2227  /**
2228   * Returns an attribute value of the current autosave revision for a post, or
2229   * null if there is no autosave for the post.
2230   *
2231   * @deprecated since 5.6. Callers should use the `getAutosave( postType, postId, userId )` selector
2232   *                from the '@wordpress/core-data' package and access properties on the returned
2233   *                autosave object using getPostRawValue.
2234   *
2235   * @param {Object} state         Global application state.
2236   * @param {string} attributeName Autosave attribute name.
2237   *
2238   * @return {*} Autosave attribute value.
2239   */
2240  
2241  const getAutosaveAttribute = (0,external_wp_data_namespaceObject.createRegistrySelector)(select => (state, attributeName) => {
2242    if (!(0,external_lodash_namespaceObject.includes)(AUTOSAVE_PROPERTIES, attributeName) && attributeName !== 'preview_link') {
2243      return;
2244    }
2245  
2246    const postType = getCurrentPostType(state);
2247    const postId = getCurrentPostId(state);
2248    const currentUserId = (0,external_lodash_namespaceObject.get)(select(external_wp_coreData_namespaceObject.store).getCurrentUser(), ['id']);
2249    const autosave = select(external_wp_coreData_namespaceObject.store).getAutosave(postType, postId, currentUserId);
2250  
2251    if (autosave) {
2252      return getPostRawValue(autosave[attributeName]);
2253    }
2254  });
2255  /**
2256   * Returns the current visibility of the post being edited, preferring the
2257   * unsaved value if different than the saved post. The return value is one of
2258   * "private", "password", or "public".
2259   *
2260   * @param {Object} state Global application state.
2261   *
2262   * @return {string} Post visibility.
2263   */
2264  
2265  function getEditedPostVisibility(state) {
2266    const status = getEditedPostAttribute(state, 'status');
2267  
2268    if (status === 'private') {
2269      return 'private';
2270    }
2271  
2272    const password = getEditedPostAttribute(state, 'password');
2273  
2274    if (password) {
2275      return 'password';
2276    }
2277  
2278    return 'public';
2279  }
2280  /**
2281   * Returns true if post is pending review.
2282   *
2283   * @param {Object} state Global application state.
2284   *
2285   * @return {boolean} Whether current post is pending review.
2286   */
2287  
2288  function isCurrentPostPending(state) {
2289    return getCurrentPost(state).status === 'pending';
2290  }
2291  /**
2292   * Return true if the current post has already been published.
2293   *
2294   * @param {Object}  state       Global application state.
2295   * @param {Object?} currentPost Explicit current post for bypassing registry selector.
2296   *
2297   * @return {boolean} Whether the post has been published.
2298   */
2299  
2300  function isCurrentPostPublished(state, currentPost) {
2301    const post = currentPost || getCurrentPost(state);
2302    return ['publish', 'private'].indexOf(post.status) !== -1 || post.status === 'future' && !(0,external_wp_date_namespaceObject.isInTheFuture)(new Date(Number((0,external_wp_date_namespaceObject.getDate)(post.date)) - ONE_MINUTE_IN_MS));
2303  }
2304  /**
2305   * Returns true if post is already scheduled.
2306   *
2307   * @param {Object} state Global application state.
2308   *
2309   * @return {boolean} Whether current post is scheduled to be posted.
2310   */
2311  
2312  function isCurrentPostScheduled(state) {
2313    return getCurrentPost(state).status === 'future' && !isCurrentPostPublished(state);
2314  }
2315  /**
2316   * Return true if the post being edited can be published.
2317   *
2318   * @param {Object} state Global application state.
2319   *
2320   * @return {boolean} Whether the post can been published.
2321   */
2322  
2323  function isEditedPostPublishable(state) {
2324    const post = getCurrentPost(state); // TODO: Post being publishable should be superset of condition of post
2325    // being saveable. Currently this restriction is imposed at UI.
2326    //
2327    //  See: <PostPublishButton /> (`isButtonEnabled` assigned by `isSaveable`).
2328  
2329    return isEditedPostDirty(state) || ['publish', 'private', 'future'].indexOf(post.status) === -1;
2330  }
2331  /**
2332   * Returns true if the post can be saved, or false otherwise. A post must
2333   * contain a title, an excerpt, or non-empty content to be valid for save.
2334   *
2335   * @param {Object} state Global application state.
2336   *
2337   * @return {boolean} Whether the post can be saved.
2338   */
2339  
2340  function isEditedPostSaveable(state) {
2341    if (isSavingPost(state)) {
2342      return false;
2343    } // TODO: Post should not be saveable if not dirty. Cannot be added here at
2344    // this time since posts where meta boxes are present can be saved even if
2345    // the post is not dirty. Currently this restriction is imposed at UI, but
2346    // should be moved here.
2347    //
2348    //  See: `isEditedPostPublishable` (includes `isEditedPostDirty` condition)
2349    //  See: <PostSavedState /> (`forceIsDirty` prop)
2350    //  See: <PostPublishButton /> (`forceIsDirty` prop)
2351    //  See: https://github.com/WordPress/gutenberg/pull/4184.
2352  
2353  
2354    return !!getEditedPostAttribute(state, 'title') || !!getEditedPostAttribute(state, 'excerpt') || !isEditedPostEmpty(state) || external_wp_element_namespaceObject.Platform.OS === 'native';
2355  }
2356  /**
2357   * Returns true if the edited post has content. A post has content if it has at
2358   * least one saveable block or otherwise has a non-empty content property
2359   * assigned.
2360   *
2361   * @param {Object} state Global application state.
2362   *
2363   * @return {boolean} Whether post has content.
2364   */
2365  
2366  function isEditedPostEmpty(state) {
2367    // While the condition of truthy content string is sufficient to determine
2368    // emptiness, testing saveable blocks length is a trivial operation. Since
2369    // this function can be called frequently, optimize for the fast case as a
2370    // condition of the mere existence of blocks. Note that the value of edited
2371    // content takes precedent over block content, and must fall through to the
2372    // default logic.
2373    const blocks = getEditorBlocks(state);
2374  
2375    if (blocks.length) {
2376      // Pierce the abstraction of the serializer in knowing that blocks are
2377      // joined with with newlines such that even if every individual block
2378      // produces an empty save result, the serialized content is non-empty.
2379      if (blocks.length > 1) {
2380        return false;
2381      } // There are two conditions under which the optimization cannot be
2382      // assumed, and a fallthrough to getEditedPostContent must occur:
2383      //
2384      // 1. getBlocksForSerialization has special treatment in omitting a
2385      //    single unmodified default block.
2386      // 2. Comment delimiters are omitted for a freeform or unregistered
2387      //    block in its serialization. The freeform block specifically may
2388      //    produce an empty string in its saved output.
2389      //
2390      // For all other content, the single block is assumed to make a post
2391      // non-empty, if only by virtue of its own comment delimiters.
2392  
2393  
2394      const blockName = blocks[0].name;
2395  
2396      if (blockName !== (0,external_wp_blocks_namespaceObject.getDefaultBlockName)() && blockName !== (0,external_wp_blocks_namespaceObject.getFreeformContentHandlerName)()) {
2397        return false;
2398      }
2399    }
2400  
2401    return !getEditedPostContent(state);
2402  }
2403  /**
2404   * Returns true if the post can be autosaved, or false otherwise.
2405   *
2406   * @param {Object} state    Global application state.
2407   * @param {Object} autosave A raw autosave object from the REST API.
2408   *
2409   * @return {boolean} Whether the post can be autosaved.
2410   */
2411  
2412  const isEditedPostAutosaveable = (0,external_wp_data_namespaceObject.createRegistrySelector)(select => state => {
2413    // A post must contain a title, an excerpt, or non-empty content to be valid for autosaving.
2414    if (!isEditedPostSaveable(state)) {
2415      return false;
2416    } // A post is not autosavable when there is a post autosave lock.
2417  
2418  
2419    if (isPostAutosavingLocked(state)) {
2420      return false;
2421    }
2422  
2423    const postType = getCurrentPostType(state);
2424    const postId = getCurrentPostId(state);
2425    const hasFetchedAutosave = select(external_wp_coreData_namespaceObject.store).hasFetchedAutosaves(postType, postId);
2426    const currentUserId = (0,external_lodash_namespaceObject.get)(select(external_wp_coreData_namespaceObject.store).getCurrentUser(), ['id']); // Disable reason - this line causes the side-effect of fetching the autosave
2427    // via a resolver, moving below the return would result in the autosave never
2428    // being fetched.
2429    // eslint-disable-next-line @wordpress/no-unused-vars-before-return
2430  
2431    const autosave = select(external_wp_coreData_namespaceObject.store).getAutosave(postType, postId, currentUserId); // If any existing autosaves have not yet been fetched, this function is
2432    // unable to determine if the post is autosaveable, so return false.
2433  
2434    if (!hasFetchedAutosave) {
2435      return false;
2436    } // If we don't already have an autosave, the post is autosaveable.
2437  
2438  
2439    if (!autosave) {
2440      return true;
2441    } // To avoid an expensive content serialization, use the content dirtiness
2442    // flag in place of content field comparison against the known autosave.
2443    // This is not strictly accurate, and relies on a tolerance toward autosave
2444    // request failures for unnecessary saves.
2445  
2446  
2447    if (hasChangedContent(state)) {
2448      return true;
2449    } // If the title or excerpt has changed, the post is autosaveable.
2450  
2451  
2452    return ['title', 'excerpt'].some(field => getPostRawValue(autosave[field]) !== getEditedPostAttribute(state, field));
2453  });
2454  /**
2455   * Return true if the post being edited is being scheduled. Preferring the
2456   * unsaved status values.
2457   *
2458   * @param {Object} state Global application state.
2459   *
2460   * @return {boolean} Whether the post has been published.
2461   */
2462  
2463  function isEditedPostBeingScheduled(state) {
2464    const date = getEditedPostAttribute(state, 'date'); // Offset the date by one minute (network latency).
2465  
2466    const checkedDate = new Date(Number((0,external_wp_date_namespaceObject.getDate)(date)) - ONE_MINUTE_IN_MS);
2467    return (0,external_wp_date_namespaceObject.isInTheFuture)(checkedDate);
2468  }
2469  /**
2470   * Returns whether the current post should be considered to have a "floating"
2471   * date (i.e. that it would publish "Immediately" rather than at a set time).
2472   *
2473   * Unlike in the PHP backend, the REST API returns a full date string for posts
2474   * where the 0000-00-00T00:00:00 placeholder is present in the database. To
2475   * infer that a post is set to publish "Immediately" we check whether the date
2476   * and modified date are the same.
2477   *
2478   * @param {Object} state Editor state.
2479   *
2480   * @return {boolean} Whether the edited post has a floating date value.
2481   */
2482  
2483  function isEditedPostDateFloating(state) {
2484    const date = getEditedPostAttribute(state, 'date');
2485    const modified = getEditedPostAttribute(state, 'modified'); // This should be the status of the persisted post
2486    // It shouldn't use the "edited" status otherwise it breaks the
2487    // inferred post data floating status
2488    // See https://github.com/WordPress/gutenberg/issues/28083.
2489  
2490    const status = getCurrentPost(state).status;
2491  
2492    if (status === 'draft' || status === 'auto-draft' || status === 'pending') {
2493      return date === modified || date === null;
2494    }
2495  
2496    return false;
2497  }
2498  /**
2499   * Returns true if the post is currently being saved, or false otherwise.
2500   *
2501   * @param {Object} state Global application state.
2502   *
2503   * @return {boolean} Whether post is being saved.
2504   */
2505  
2506  const isSavingPost = (0,external_wp_data_namespaceObject.createRegistrySelector)(select => state => {
2507    const postType = getCurrentPostType(state);
2508    const postId = getCurrentPostId(state);
2509    return select(external_wp_coreData_namespaceObject.store).isSavingEntityRecord('postType', postType, postId);
2510  });
2511  /**
2512   * Returns true if non-post entities are currently being saved, or false otherwise.
2513   *
2514   * @param {Object} state Global application state.
2515   *
2516   * @return {boolean} Whether non-post entities are being saved.
2517   */
2518  
2519  const isSavingNonPostEntityChanges = (0,external_wp_data_namespaceObject.createRegistrySelector)(select => state => {
2520    const entitiesBeingSaved = select(external_wp_coreData_namespaceObject.store).__experimentalGetEntitiesBeingSaved();
2521  
2522    const {
2523      type,
2524      id
2525    } = getCurrentPost(state);
2526    return (0,external_lodash_namespaceObject.some)(entitiesBeingSaved, entityRecord => entityRecord.kind !== 'postType' || entityRecord.name !== type || entityRecord.key !== id);
2527  });
2528  /**
2529   * Returns true if a previous post save was attempted successfully, or false
2530   * otherwise.
2531   *
2532   * @param {Object} state Global application state.
2533   *
2534   * @return {boolean} Whether the post was saved successfully.
2535   */
2536  
2537  const didPostSaveRequestSucceed = (0,external_wp_data_namespaceObject.createRegistrySelector)(select => state => {
2538    const postType = getCurrentPostType(state);
2539    const postId = getCurrentPostId(state);
2540    return !select(external_wp_coreData_namespaceObject.store).getLastEntitySaveError('postType', postType, postId);
2541  });
2542  /**
2543   * Returns true if a previous post save was attempted but failed, or false
2544   * otherwise.
2545   *
2546   * @param {Object} state Global application state.
2547   *
2548   * @return {boolean} Whether the post save failed.
2549   */
2550  
2551  const didPostSaveRequestFail = (0,external_wp_data_namespaceObject.createRegistrySelector)(select => state => {
2552    const postType = getCurrentPostType(state);
2553    const postId = getCurrentPostId(state);
2554    return !!select(external_wp_coreData_namespaceObject.store).getLastEntitySaveError('postType', postType, postId);
2555  });
2556  /**
2557   * Returns true if the post is autosaving, or false otherwise.
2558   *
2559   * @param {Object} state Global application state.
2560   *
2561   * @return {boolean} Whether the post is autosaving.
2562   */
2563  
2564  function isAutosavingPost(state) {
2565    if (!isSavingPost(state)) {
2566      return false;
2567    }
2568  
2569    return !!(0,external_lodash_namespaceObject.get)(state.saving, ['options', 'isAutosave']);
2570  }
2571  /**
2572   * Returns true if the post is being previewed, or false otherwise.
2573   *
2574   * @param {Object} state Global application state.
2575   *
2576   * @return {boolean} Whether the post is being previewed.
2577   */
2578  
2579  function isPreviewingPost(state) {
2580    if (!isSavingPost(state)) {
2581      return false;
2582    }
2583  
2584    return !!(0,external_lodash_namespaceObject.get)(state.saving, ['options', 'isPreview']);
2585  }
2586  /**
2587   * Returns the post preview link
2588   *
2589   * @param {Object} state Global application state.
2590   *
2591   * @return {string?} Preview Link.
2592   */
2593  
2594  function getEditedPostPreviewLink(state) {
2595    if (state.saving.pending || isSavingPost(state)) {
2596      return;
2597    }
2598  
2599    let previewLink = getAutosaveAttribute(state, 'preview_link'); // Fix for issue: https://github.com/WordPress/gutenberg/issues/33616
2600    // If the post is draft, ignore the preview link from the autosave record,
2601    // because the preview could be a stale autosave if the post was switched from
2602    // published to draft.
2603    // See: https://github.com/WordPress/gutenberg/pull/37952.
2604  
2605    if (!previewLink || 'draft' === getCurrentPost(state).status) {
2606      previewLink = getEditedPostAttribute(state, 'link');
2607  
2608      if (previewLink) {
2609        previewLink = (0,external_wp_url_namespaceObject.addQueryArgs)(previewLink, {
2610          preview: true
2611        });
2612      }
2613    }
2614  
2615    const featuredImageId = getEditedPostAttribute(state, 'featured_media');
2616  
2617    if (previewLink && featuredImageId) {
2618      return (0,external_wp_url_namespaceObject.addQueryArgs)(previewLink, {
2619        _thumbnail_id: featuredImageId
2620      });
2621    }
2622  
2623    return previewLink;
2624  }
2625  /**
2626   * Returns a suggested post format for the current post, inferred only if there
2627   * is a single block within the post and it is of a type known to match a
2628   * default post format. Returns null if the format cannot be determined.
2629   *
2630   * @param {Object} state Global application state.
2631   *
2632   * @return {?string} Suggested post format.
2633   */
2634  
2635  function getSuggestedPostFormat(state) {
2636    const blocks = getEditorBlocks(state);
2637    if (blocks.length > 2) return null;
2638    let name; // If there is only one block in the content of the post grab its name
2639    // so we can derive a suitable post format from it.
2640  
2641    if (blocks.length === 1) {
2642      name = blocks[0].name; // Check for core/embed `video` and `audio` eligible suggestions.
2643  
2644      if (name === 'core/embed') {
2645        var _blocks$0$attributes;
2646  
2647        const provider = (_blocks$0$attributes = blocks[0].attributes) === null || _blocks$0$attributes === void 0 ? void 0 : _blocks$0$attributes.providerNameSlug;
2648  
2649        if (['youtube', 'vimeo'].includes(provider)) {
2650          name = 'core/video';
2651        } else if (['spotify', 'soundcloud'].includes(provider)) {
2652          name = 'core/audio';
2653        }
2654      }
2655    } // If there are two blocks in the content and the last one is a text blocks
2656    // grab the name of the first one to also suggest a post format from it.
2657  
2658  
2659    if (blocks.length === 2 && blocks[1].name === 'core/paragraph') {
2660      name = blocks[0].name;
2661    } // We only convert to default post formats in core.
2662  
2663  
2664    switch (name) {
2665      case 'core/image':
2666        return 'image';
2667  
2668      case 'core/quote':
2669      case 'core/pullquote':
2670        return 'quote';
2671  
2672      case 'core/gallery':
2673        return 'gallery';
2674  
2675      case 'core/video':
2676        return 'video';
2677  
2678      case 'core/audio':
2679        return 'audio';
2680  
2681      default:
2682        return null;
2683    }
2684  }
2685  /**
2686   * Returns the content of the post being edited.
2687   *
2688   * @param {Object} state Global application state.
2689   *
2690   * @return {string} Post content.
2691   */
2692  
2693  const getEditedPostContent = (0,external_wp_data_namespaceObject.createRegistrySelector)(select => state => {
2694    const postId = getCurrentPostId(state);
2695    const postType = getCurrentPostType(state);
2696    const record = select(external_wp_coreData_namespaceObject.store).getEditedEntityRecord('postType', postType, postId);
2697  
2698    if (record) {
2699      if (typeof record.content === 'function') {
2700        return record.content(record);
2701      } else if (record.blocks) {
2702        return (0,external_wp_blocks_namespaceObject.__unstableSerializeAndClean)(record.blocks);
2703      } else if (record.content) {
2704        return record.content;
2705      }
2706    }
2707  
2708    return '';
2709  });
2710  /**
2711   * Returns true if the post is being published, or false otherwise.
2712   *
2713   * @param {Object} state Global application state.
2714   *
2715   * @return {boolean} Whether post is being published.
2716   */
2717  
2718  function isPublishingPost(state) {
2719    return isSavingPost(state) && !isCurrentPostPublished(state) && getEditedPostAttribute(state, 'status') === 'publish';
2720  }
2721  /**
2722   * Returns whether the permalink is editable or not.
2723   *
2724   * @param {Object} state Editor state.
2725   *
2726   * @return {boolean} Whether or not the permalink is editable.
2727   */
2728  
2729  function isPermalinkEditable(state) {
2730    const permalinkTemplate = getEditedPostAttribute(state, 'permalink_template');
2731    return PERMALINK_POSTNAME_REGEX.test(permalinkTemplate);
2732  }
2733  /**
2734   * Returns the permalink for the post.
2735   *
2736   * @param {Object} state Editor state.
2737   *
2738   * @return {?string} The permalink, or null if the post is not viewable.
2739   */
2740  
2741  function getPermalink(state) {
2742    const permalinkParts = getPermalinkParts(state);
2743  
2744    if (!permalinkParts) {
2745      return null;
2746    }
2747  
2748    const {
2749      prefix,
2750      postName,
2751      suffix
2752    } = permalinkParts;
2753  
2754    if (isPermalinkEditable(state)) {
2755      return prefix + postName + suffix;
2756    }
2757  
2758    return prefix;
2759  }
2760  /**
2761   * Returns the slug for the post being edited, preferring a manually edited
2762   * value if one exists, then a sanitized version of the current post title, and
2763   * finally the post ID.
2764   *
2765   * @param {Object} state Editor state.
2766   *
2767   * @return {string} The current slug to be displayed in the editor
2768   */
2769  
2770  function getEditedPostSlug(state) {
2771    return getEditedPostAttribute(state, 'slug') || (0,external_wp_url_namespaceObject.cleanForSlug)(getEditedPostAttribute(state, 'title')) || getCurrentPostId(state);
2772  }
2773  /**
2774   * Returns the permalink for a post, split into it's three parts: the prefix,
2775   * the postName, and the suffix.
2776   *
2777   * @param {Object} state Editor state.
2778   *
2779   * @return {Object} An object containing the prefix, postName, and suffix for
2780   *                  the permalink, or null if the post is not viewable.
2781   */
2782  
2783  function getPermalinkParts(state) {
2784    const permalinkTemplate = getEditedPostAttribute(state, 'permalink_template');
2785  
2786    if (!permalinkTemplate) {
2787      return null;
2788    }
2789  
2790    const postName = getEditedPostAttribute(state, 'slug') || getEditedPostAttribute(state, 'generated_slug');
2791    const [prefix, suffix] = permalinkTemplate.split(PERMALINK_POSTNAME_REGEX);
2792    return {
2793      prefix,
2794      postName,
2795      suffix
2796    };
2797  }
2798  /**
2799   * Returns whether the post is locked.
2800   *
2801   * @param {Object} state Global application state.
2802   *
2803   * @return {boolean} Is locked.
2804   */
2805  
2806  function isPostLocked(state) {
2807    return state.postLock.isLocked;
2808  }
2809  /**
2810   * Returns whether post saving is locked.
2811   *
2812   * @param {Object} state Global application state.
2813   *
2814   * @return {boolean} Is locked.
2815   */
2816  
2817  function isPostSavingLocked(state) {
2818    return Object.keys(state.postSavingLock).length > 0;
2819  }
2820  /**
2821   * Returns whether post autosaving is locked.
2822   *
2823   * @param {Object} state Global application state.
2824   *
2825   * @return {boolean} Is locked.
2826   */
2827  
2828  function isPostAutosavingLocked(state) {
2829    return Object.keys(state.postAutosavingLock).length > 0;
2830  }
2831  /**
2832   * Returns whether the edition of the post has been taken over.
2833   *
2834   * @param {Object} state Global application state.
2835   *
2836   * @return {boolean} Is post lock takeover.
2837   */
2838  
2839  function isPostLockTakeover(state) {
2840    return state.postLock.isTakeover;
2841  }
2842  /**
2843   * Returns details about the post lock user.
2844   *
2845   * @param {Object} state Global application state.
2846   *
2847   * @return {Object} A user object.
2848   */
2849  
2850  function getPostLockUser(state) {
2851    return state.postLock.user;
2852  }
2853  /**
2854   * Returns the active post lock.
2855   *
2856   * @param {Object} state Global application state.
2857   *
2858   * @return {Object} The lock object.
2859   */
2860  
2861  function getActivePostLock(state) {
2862    return state.postLock.activePostLock;
2863  }
2864  /**
2865   * Returns whether or not the user has the unfiltered_html capability.
2866   *
2867   * @param {Object} state Editor state.
2868   *
2869   * @return {boolean} Whether the user can or can't post unfiltered HTML.
2870   */
2871  
2872  function canUserUseUnfilteredHTML(state) {
2873    return (0,external_lodash_namespaceObject.has)(getCurrentPost(state), ['_links', 'wp:action-unfiltered-html']);
2874  }
2875  /**
2876   * Returns whether the pre-publish panel should be shown
2877   * or skipped when the user clicks the "publish" button.
2878   *
2879   * @return {boolean} Whether the pre-publish panel should be shown or not.
2880   */
2881  
2882  const isPublishSidebarEnabled = (0,external_wp_data_namespaceObject.createRegistrySelector)(select => () => !!select(external_wp_preferences_namespaceObject.store).get('core/edit-post', 'isPublishSidebarEnabled'));
2883  /**
2884   * Return the current block list.
2885   *
2886   * @param {Object} state
2887   * @return {Array} Block list.
2888   */
2889  
2890  function getEditorBlocks(state) {
2891    return getEditedPostAttribute(state, 'blocks') || EMPTY_ARRAY;
2892  }
2893  /**
2894   * A block selection object.
2895   *
2896   * @typedef {Object} WPBlockSelection
2897   *
2898   * @property {string} clientId     A block client ID.
2899   * @property {string} attributeKey A block attribute key.
2900   * @property {number} offset       An attribute value offset, based on the rich
2901   *                                 text value. See `wp.richText.create`.
2902   */
2903  
2904  /**
2905   * Returns the current selection start.
2906   *
2907   * @param {Object} state
2908   * @return {WPBlockSelection} The selection start.
2909   *
2910   * @deprecated since Gutenberg 10.0.0.
2911   */
2912  
2913  function getEditorSelectionStart(state) {
2914    var _getEditedPostAttribu;
2915  
2916    external_wp_deprecated_default()("select('core/editor').getEditorSelectionStart", {
2917      since: '5.8',
2918      alternative: "select('core/editor').getEditorSelection"
2919    });
2920    return (_getEditedPostAttribu = getEditedPostAttribute(state, 'selection')) === null || _getEditedPostAttribu === void 0 ? void 0 : _getEditedPostAttribu.selectionStart;
2921  }
2922  /**
2923   * Returns the current selection end.
2924   *
2925   * @param {Object} state
2926   * @return {WPBlockSelection} The selection end.
2927   *
2928   * @deprecated since Gutenberg 10.0.0.
2929   */
2930  
2931  function getEditorSelectionEnd(state) {
2932    var _getEditedPostAttribu2;
2933  
2934    external_wp_deprecated_default()("select('core/editor').getEditorSelectionStart", {
2935      since: '5.8',
2936      alternative: "select('core/editor').getEditorSelection"
2937    });
2938    return (_getEditedPostAttribu2 = getEditedPostAttribute(state, 'selection')) === null || _getEditedPostAttribu2 === void 0 ? void 0 : _getEditedPostAttribu2.selectionEnd;
2939  }
2940  /**
2941   * Returns the current selection.
2942   *
2943   * @param {Object} state
2944   * @return {WPBlockSelection} The selection end.
2945   */
2946  
2947  function getEditorSelection(state) {
2948    return getEditedPostAttribute(state, 'selection');
2949  }
2950  /**
2951   * Is the editor ready
2952   *
2953   * @param {Object} state
2954   * @return {boolean} is Ready.
2955   */
2956  
2957  function __unstableIsEditorReady(state) {
2958    return state.isReady;
2959  }
2960  /**
2961   * Returns the post editor settings.
2962   *
2963   * @param {Object} state Editor state.
2964   *
2965   * @return {Object} The editor settings object.
2966   */
2967  
2968  function getEditorSettings(state) {
2969    return state.editorSettings;
2970  }
2971  /*
2972   * Backward compatibility
2973   */
2974  
2975  /**
2976   * Returns state object prior to a specified optimist transaction ID, or `null`
2977   * if the transaction corresponding to the given ID cannot be found.
2978   *
2979   * @deprecated since Gutenberg 9.7.0.
2980   */
2981  
2982  function getStateBeforeOptimisticTransaction() {
2983    external_wp_deprecated_default()("select('core/editor').getStateBeforeOptimisticTransaction", {
2984      since: '5.7',
2985      hint: 'No state history is kept on this store anymore'
2986    });
2987    return null;
2988  }
2989  /**
2990   * Returns true if an optimistic transaction is pending commit, for which the
2991   * before state satisfies the given predicate function.
2992   *
2993   * @deprecated since Gutenberg 9.7.0.
2994   */
2995  
2996  function inSomeHistory() {
2997    external_wp_deprecated_default()("select('core/editor').inSomeHistory", {
2998      since: '5.7',
2999      hint: 'No state history is kept on this store anymore'
3000    });
3001    return false;
3002  }
3003  
3004  function getBlockEditorSelector(name) {
3005    return (0,external_wp_data_namespaceObject.createRegistrySelector)(select => function (state) {
3006      external_wp_deprecated_default()("`wp.data.select( 'core/editor' )." + name + '`', {
3007        since: '5.3',
3008        alternative: "`wp.data.select( 'core/block-editor' )." + name + '`',
3009        version: '6.2'
3010      });
3011  
3012      for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {
3013        args[_key - 1] = arguments[_key];
3014      }
3015  
3016      return select(external_wp_blockEditor_namespaceObject.store)[name](...args);
3017    });
3018  }
3019  /**
3020   * @see getBlockName in core/block-editor store.
3021   */
3022  
3023  
3024  const getBlockName = getBlockEditorSelector('getBlockName');
3025  /**
3026   * @see isBlockValid in core/block-editor store.
3027   */
3028  
3029  const isBlockValid = getBlockEditorSelector('isBlockValid');
3030  /**
3031   * @see getBlockAttributes in core/block-editor store.
3032   */
3033  
3034  const getBlockAttributes = getBlockEditorSelector('getBlockAttributes');
3035  /**
3036   * @see getBlock in core/block-editor store.
3037   */
3038  
3039  const getBlock = getBlockEditorSelector('getBlock');
3040  /**
3041   * @see getBlocks in core/block-editor store.
3042   */
3043  
3044  const getBlocks = getBlockEditorSelector('getBlocks');
3045  /**
3046   * @see getClientIdsOfDescendants in core/block-editor store.
3047   */
3048  
3049  const getClientIdsOfDescendants = getBlockEditorSelector('getClientIdsOfDescendants');
3050  /**
3051   * @see getClientIdsWithDescendants in core/block-editor store.
3052   */
3053  
3054  const getClientIdsWithDescendants = getBlockEditorSelector('getClientIdsWithDescendants');
3055  /**
3056   * @see getGlobalBlockCount in core/block-editor store.
3057   */
3058  
3059  const getGlobalBlockCount = getBlockEditorSelector('getGlobalBlockCount');
3060  /**
3061   * @see getBlocksByClientId in core/block-editor store.
3062   */
3063  
3064  const getBlocksByClientId = getBlockEditorSelector('getBlocksByClientId');
3065  /**
3066   * @see getBlockCount in core/block-editor store.
3067   */
3068  
3069  const getBlockCount = getBlockEditorSelector('getBlockCount');
3070  /**
3071   * @see getBlockSelectionStart in core/block-editor store.
3072   */
3073  
3074  const getBlockSelectionStart = getBlockEditorSelector('getBlockSelectionStart');
3075  /**
3076   * @see getBlockSelectionEnd in core/block-editor store.
3077   */
3078  
3079  const getBlockSelectionEnd = getBlockEditorSelector('getBlockSelectionEnd');
3080  /**
3081   * @see getSelectedBlockCount in core/block-editor store.
3082   */
3083  
3084  const getSelectedBlockCount = getBlockEditorSelector('getSelectedBlockCount');
3085  /**
3086   * @see hasSelectedBlock in core/block-editor store.
3087   */
3088  
3089  const hasSelectedBlock = getBlockEditorSelector('hasSelectedBlock');
3090  /**
3091   * @see getSelectedBlockClientId in core/block-editor store.
3092   */
3093  
3094  const getSelectedBlockClientId = getBlockEditorSelector('getSelectedBlockClientId');
3095  /**
3096   * @see getSelectedBlock in core/block-editor store.
3097   */
3098  
3099  const getSelectedBlock = getBlockEditorSelector('getSelectedBlock');
3100  /**
3101   * @see getBlockRootClientId in core/block-editor store.
3102   */
3103  
3104  const getBlockRootClientId = getBlockEditorSelector('getBlockRootClientId');
3105  /**
3106   * @see getBlockHierarchyRootClientId in core/block-editor store.
3107   */
3108  
3109  const getBlockHierarchyRootClientId = getBlockEditorSelector('getBlockHierarchyRootClientId');
3110  /**
3111   * @see getAdjacentBlockClientId in core/block-editor store.
3112   */
3113  
3114  const getAdjacentBlockClientId = getBlockEditorSelector('getAdjacentBlockClientId');
3115  /**
3116   * @see getPreviousBlockClientId in core/block-editor store.
3117   */
3118  
3119  const getPreviousBlockClientId = getBlockEditorSelector('getPreviousBlockClientId');
3120  /**
3121   * @see getNextBlockClientId in core/block-editor store.
3122   */
3123  
3124  const getNextBlockClientId = getBlockEditorSelector('getNextBlockClientId');
3125  /**
3126   * @see getSelectedBlocksInitialCaretPosition in core/block-editor store.
3127   */
3128  
3129  const getSelectedBlocksInitialCaretPosition = getBlockEditorSelector('getSelectedBlocksInitialCaretPosition');
3130  /**
3131   * @see getMultiSelectedBlockClientIds in core/block-editor store.
3132   */
3133  
3134  const getMultiSelectedBlockClientIds = getBlockEditorSelector('getMultiSelectedBlockClientIds');
3135  /**
3136   * @see getMultiSelectedBlocks in core/block-editor store.
3137   */
3138  
3139  const getMultiSelectedBlocks = getBlockEditorSelector('getMultiSelectedBlocks');
3140  /**
3141   * @see getFirstMultiSelectedBlockClientId in core/block-editor store.
3142   */
3143  
3144  const getFirstMultiSelectedBlockClientId = getBlockEditorSelector('getFirstMultiSelectedBlockClientId');
3145  /**
3146   * @see getLastMultiSelectedBlockClientId in core/block-editor store.
3147   */
3148  
3149  const getLastMultiSelectedBlockClientId = getBlockEditorSelector('getLastMultiSelectedBlockClientId');
3150  /**
3151   * @see isFirstMultiSelectedBlock in core/block-editor store.
3152   */
3153  
3154  const isFirstMultiSelectedBlock = getBlockEditorSelector('isFirstMultiSelectedBlock');
3155  /**
3156   * @see isBlockMultiSelected in core/block-editor store.
3157   */
3158  
3159  const isBlockMultiSelected = getBlockEditorSelector('isBlockMultiSelected');
3160  /**
3161   * @see isAncestorMultiSelected in core/block-editor store.
3162   */
3163  
3164  const isAncestorMultiSelected = getBlockEditorSelector('isAncestorMultiSelected');
3165  /**
3166   * @see getMultiSelectedBlocksStartClientId in core/block-editor store.
3167   */
3168  
3169  const getMultiSelectedBlocksStartClientId = getBlockEditorSelector('getMultiSelectedBlocksStartClientId');
3170  /**
3171   * @see getMultiSelectedBlocksEndClientId in core/block-editor store.
3172   */
3173  
3174  const getMultiSelectedBlocksEndClientId = getBlockEditorSelector('getMultiSelectedBlocksEndClientId');
3175  /**
3176   * @see getBlockOrder in core/block-editor store.
3177   */
3178  
3179  const getBlockOrder = getBlockEditorSelector('getBlockOrder');
3180  /**
3181   * @see getBlockIndex in core/block-editor store.
3182   */
3183  
3184  const getBlockIndex = getBlockEditorSelector('getBlockIndex');
3185  /**
3186   * @see isBlockSelected in core/block-editor store.
3187   */
3188  
3189  const isBlockSelected = getBlockEditorSelector('isBlockSelected');
3190  /**
3191   * @see hasSelectedInnerBlock in core/block-editor store.
3192   */
3193  
3194  const hasSelectedInnerBlock = getBlockEditorSelector('hasSelectedInnerBlock');
3195  /**
3196   * @see isBlockWithinSelection in core/block-editor store.
3197   */
3198  
3199  const isBlockWithinSelection = getBlockEditorSelector('isBlockWithinSelection');
3200  /**
3201   * @see hasMultiSelection in core/block-editor store.
3202   */
3203  
3204  const hasMultiSelection = getBlockEditorSelector('hasMultiSelection');
3205  /**
3206   * @see isMultiSelecting in core/block-editor store.
3207   */
3208  
3209  const isMultiSelecting = getBlockEditorSelector('isMultiSelecting');
3210  /**
3211   * @see isSelectionEnabled in core/block-editor store.
3212   */
3213  
3214  const isSelectionEnabled = getBlockEditorSelector('isSelectionEnabled');
3215  /**
3216   * @see getBlockMode in core/block-editor store.
3217   */
3218  
3219  const getBlockMode = getBlockEditorSelector('getBlockMode');
3220  /**
3221   * @see isTyping in core/block-editor store.
3222   */
3223  
3224  const isTyping = getBlockEditorSelector('isTyping');
3225  /**
3226   * @see isCaretWithinFormattedText in core/block-editor store.
3227   */
3228  
3229  const isCaretWithinFormattedText = getBlockEditorSelector('isCaretWithinFormattedText');
3230  /**
3231   * @see getBlockInsertionPoint in core/block-editor store.
3232   */
3233  
3234  const getBlockInsertionPoint = getBlockEditorSelector('getBlockInsertionPoint');
3235  /**
3236   * @see isBlockInsertionPointVisible in core/block-editor store.
3237   */
3238  
3239  const isBlockInsertionPointVisible = getBlockEditorSelector('isBlockInsertionPointVisible');
3240  /**
3241   * @see isValidTemplate in core/block-editor store.
3242   */
3243  
3244  const isValidTemplate = getBlockEditorSelector('isValidTemplate');
3245  /**
3246   * @see getTemplate in core/block-editor store.
3247   */
3248  
3249  const getTemplate = getBlockEditorSelector('getTemplate');
3250  /**
3251   * @see getTemplateLock in core/block-editor store.
3252   */
3253  
3254  const getTemplateLock = getBlockEditorSelector('getTemplateLock');
3255  /**
3256   * @see canInsertBlockType in core/block-editor store.
3257   */
3258  
3259  const canInsertBlockType = getBlockEditorSelector('canInsertBlockType');
3260  /**
3261   * @see getInserterItems in core/block-editor store.
3262   */
3263  
3264  const getInserterItems = getBlockEditorSelector('getInserterItems');
3265  /**
3266   * @see hasInserterItems in core/block-editor store.
3267   */
3268  
3269  const hasInserterItems = getBlockEditorSelector('hasInserterItems');
3270  /**
3271   * @see getBlockListSettings in core/block-editor store.
3272   */
3273  
3274  const getBlockListSettings = getBlockEditorSelector('getBlockListSettings');
3275  /**
3276   * Returns the default template types.
3277   *
3278   * @param {Object} state Global application state.
3279   *
3280   * @return {Object} The template types.
3281   */
3282  
3283  function __experimentalGetDefaultTemplateTypes(state) {
3284    var _getEditorSettings;
3285  
3286    return (_getEditorSettings = getEditorSettings(state)) === null || _getEditorSettings === void 0 ? void 0 : _getEditorSettings.defaultTemplateTypes;
3287  }
3288  /**
3289   * Returns the default template part areas.
3290   *
3291   * @param {Object} state Global application state.
3292   *
3293   * @return {Array} The template part areas.
3294   */
3295  
3296  const __experimentalGetDefaultTemplatePartAreas = rememo(state => {
3297    var _getEditorSettings2;
3298  
3299    const areas = ((_getEditorSettings2 = getEditorSettings(state)) === null || _getEditorSettings2 === void 0 ? void 0 : _getEditorSettings2.defaultTemplatePartAreas) || [];
3300    return areas === null || areas === void 0 ? void 0 : areas.map(item => {
3301      return { ...item,
3302        icon: getTemplatePartIcon(item.icon)
3303      };
3304    });
3305  }, state => {
3306    var _getEditorSettings3;
3307  
3308    return [(_getEditorSettings3 = getEditorSettings(state)) === null || _getEditorSettings3 === void 0 ? void 0 : _getEditorSettings3.defaultTemplatePartAreas];
3309  });
3310  /**
3311   * Returns a default template type searched by slug.
3312   *
3313   * @param {Object} state Global application state.
3314   * @param {string} slug  The template type slug.
3315   *
3316   * @return {Object} The template type.
3317   */
3318  
3319  const __experimentalGetDefaultTemplateType = rememo((state, slug) => (0,external_lodash_namespaceObject.find)(__experimentalGetDefaultTemplateTypes(state), {
3320    slug
3321  }) || {}, (state, slug) => [__experimentalGetDefaultTemplateTypes(state), slug]);
3322  /**
3323   * Given a template entity, return information about it which is ready to be
3324   * rendered, such as the title, description, and icon.
3325   *
3326   * @param {Object} state    Global application state.
3327   * @param {Object} template The template for which we need information.
3328   * @return {Object} Information about the template, including title, description, and icon.
3329   */
3330  
3331  function __experimentalGetTemplateInfo(state, template) {
3332    var _experimentalGetDefa;
3333  
3334    if (!template) {
3335      return {};
3336    }
3337  
3338    const {
3339      excerpt,
3340      slug,
3341      title,
3342      area
3343    } = template;
3344  
3345    const {
3346      title: defaultTitle,
3347      description: defaultDescription
3348    } = __experimentalGetDefaultTemplateType(state, slug);
3349  
3350    const templateTitle = (0,external_lodash_namespaceObject.isString)(title) ? title : title === null || title === void 0 ? void 0 : title.rendered;
3351    const templateDescription = (0,external_lodash_namespaceObject.isString)(excerpt) ? excerpt : excerpt === null || excerpt === void 0 ? void 0 : excerpt.raw;
3352    const templateIcon = ((_experimentalGetDefa = __experimentalGetDefaultTemplatePartAreas(state).find(item => area === item.area)) === null || _experimentalGetDefa === void 0 ? void 0 : _experimentalGetDefa.icon) || library_layout;
3353    return {
3354      title: templateTitle && templateTitle !== slug ? templateTitle : defaultTitle || slug,
3355      description: templateDescription || defaultDescription,
3356      icon: templateIcon
3357    };
3358  }
3359  /**
3360   * Returns a post type label depending on the current post.
3361   *
3362   * @param {Object} state Global application state.
3363   *
3364   * @return {string|undefined} The post type label if available, otherwise undefined.
3365   */
3366  
3367  const getPostTypeLabel = (0,external_wp_data_namespaceObject.createRegistrySelector)(select => state => {
3368    var _postType$labels;
3369  
3370    const currentPostType = getCurrentPostType(state);
3371    const postType = select(external_wp_coreData_namespaceObject.store).getPostType(currentPostType); // Disable reason: Post type labels object is shaped like this.
3372    // eslint-disable-next-line camelcase
3373  
3374    return postType === null || postType === void 0 ? void 0 : (_postType$labels = postType.labels) === null || _postType$labels === void 0 ? void 0 : _postType$labels.singular_name;
3375  });
3376  
3377  ;// CONCATENATED MODULE: external ["wp","apiFetch"]
3378  var external_wp_apiFetch_namespaceObject = window["wp"]["apiFetch"];
3379  var external_wp_apiFetch_default = /*#__PURE__*/__webpack_require__.n(external_wp_apiFetch_namespaceObject);
3380  ;// CONCATENATED MODULE: external ["wp","notices"]
3381  var external_wp_notices_namespaceObject = window["wp"]["notices"];
3382  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/store/local-autosave.js
3383  /**
3384   * Function returning a sessionStorage key to set or retrieve a given post's
3385   * automatic session backup.
3386   *
3387   * Keys are crucially prefixed with 'wp-autosave-' so that wp-login.php's
3388   * `loggedout` handler can clear sessionStorage of any user-private content.
3389   *
3390   * @see https://github.com/WordPress/wordpress-develop/blob/6dad32d2aed47e6c0cf2aee8410645f6d7aba6bd/src/wp-login.php#L103
3391   *
3392   * @param {string}  postId    Post ID.
3393   * @param {boolean} isPostNew Whether post new.
3394   *
3395   * @return {string} sessionStorage key
3396   */
3397  function postKey(postId, isPostNew) {
3398    return `wp-autosave-block-editor-post-$isPostNew ? 'auto-draft' : postId}`;
3399  }
3400  
3401  function localAutosaveGet(postId, isPostNew) {
3402    return window.sessionStorage.getItem(postKey(postId, isPostNew));
3403  }
3404  function localAutosaveSet(postId, isPostNew, title, content, excerpt) {
3405    window.sessionStorage.setItem(postKey(postId, isPostNew), JSON.stringify({
3406      post_title: title,
3407      content,
3408      excerpt
3409    }));
3410  }
3411  function localAutosaveClear(postId, isPostNew) {
3412    window.sessionStorage.removeItem(postKey(postId, isPostNew));
3413  }
3414  
3415  ;// CONCATENATED MODULE: external ["wp","i18n"]
3416  var external_wp_i18n_namespaceObject = window["wp"]["i18n"];
3417  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/store/utils/notice-builder.js
3418  /**
3419   * WordPress dependencies
3420   */
3421  
3422  /**
3423   * Internal dependencies
3424   */
3425  
3426  
3427  /**
3428   * External dependencies
3429   */
3430  
3431  
3432  /**
3433   * Builds the arguments for a success notification dispatch.
3434   *
3435   * @param {Object} data Incoming data to build the arguments from.
3436   *
3437   * @return {Array} Arguments for dispatch. An empty array signals no
3438   *                 notification should be sent.
3439   */
3440  
3441  function getNotificationArgumentsForSaveSuccess(data) {
3442    const {
3443      previousPost,
3444      post,
3445      postType
3446    } = data; // Autosaves are neither shown a notice nor redirected.
3447  
3448    if ((0,external_lodash_namespaceObject.get)(data.options, ['isAutosave'])) {
3449      return [];
3450    } // No notice is shown after trashing a post
3451  
3452  
3453    if (post.status === 'trash' && previousPost.status !== 'trash') {
3454      return [];
3455    }
3456  
3457    const publishStatus = ['publish', 'private', 'future'];
3458    const isPublished = (0,external_lodash_namespaceObject.includes)(publishStatus, previousPost.status);
3459    const willPublish = (0,external_lodash_namespaceObject.includes)(publishStatus, post.status);
3460    let noticeMessage;
3461    let shouldShowLink = (0,external_lodash_namespaceObject.get)(postType, ['viewable'], false);
3462    let isDraft; // Always should a notice, which will be spoken for accessibility.
3463  
3464    if (!isPublished && !willPublish) {
3465      // If saving a non-published post, don't show notice.
3466      noticeMessage = (0,external_wp_i18n_namespaceObject.__)('Draft saved.');
3467      isDraft = true;
3468    } else if (isPublished && !willPublish) {
3469      // If undoing publish status, show specific notice.
3470      noticeMessage = postType.labels.item_reverted_to_draft;
3471      shouldShowLink = false;
3472    } else if (!isPublished && willPublish) {
3473      // If publishing or scheduling a post, show the corresponding
3474      // publish message.
3475      noticeMessage = {
3476        publish: postType.labels.item_published,
3477        private: postType.labels.item_published_privately,
3478        future: postType.labels.item_scheduled
3479      }[post.status];
3480    } else {
3481      // Generic fallback notice.
3482      noticeMessage = postType.labels.item_updated;
3483    }
3484  
3485    const actions = [];
3486  
3487    if (shouldShowLink) {
3488      actions.push({
3489        label: isDraft ? (0,external_wp_i18n_namespaceObject.__)('View Preview') : postType.labels.view_item,
3490        url: post.link
3491      });
3492    }
3493  
3494    return [noticeMessage, {
3495      id: SAVE_POST_NOTICE_ID,
3496      type: 'snackbar',
3497      actions
3498    }];
3499  }
3500  /**
3501   * Builds the fail notification arguments for dispatch.
3502   *
3503   * @param {Object} data Incoming data to build the arguments with.
3504   *
3505   * @return {Array} Arguments for dispatch. An empty array signals no
3506   *                 notification should be sent.
3507   */
3508  
3509  function getNotificationArgumentsForSaveFail(data) {
3510    const {
3511      post,
3512      edits,
3513      error
3514    } = data;
3515  
3516    if (error && 'rest_autosave_no_changes' === error.code) {
3517      // Autosave requested a new autosave, but there were no changes. This shouldn't
3518      // result in an error notice for the user.
3519      return [];
3520    }
3521  
3522    const publishStatus = ['publish', 'private', 'future'];
3523    const isPublished = publishStatus.indexOf(post.status) !== -1; // If the post was being published, we show the corresponding publish error message
3524    // Unless we publish an "updating failed" message.
3525  
3526    const messages = {
3527      publish: (0,external_wp_i18n_namespaceObject.__)('Publishing failed.'),
3528      private: (0,external_wp_i18n_namespaceObject.__)('Publishing failed.'),
3529      future: (0,external_wp_i18n_namespaceObject.__)('Scheduling failed.')
3530    };
3531    let noticeMessage = !isPublished && publishStatus.indexOf(edits.status) !== -1 ? messages[edits.status] : (0,external_wp_i18n_namespaceObject.__)('Updating failed.'); // Check if message string contains HTML. Notice text is currently only
3532    // supported as plaintext, and stripping the tags may muddle the meaning.
3533  
3534    if (error.message && !/<\/?[^>]*>/.test(error.message)) {
3535      noticeMessage = [noticeMessage, error.message].join(' ');
3536    }
3537  
3538    return [noticeMessage, {
3539      id: SAVE_POST_NOTICE_ID
3540    }];
3541  }
3542  /**
3543   * Builds the trash fail notification arguments for dispatch.
3544   *
3545   * @param {Object} data
3546   *
3547   * @return {Array} Arguments for dispatch.
3548   */
3549  
3550  function getNotificationArgumentsForTrashFail(data) {
3551    return [data.error.message && data.error.code !== 'unknown_error' ? data.error.message : (0,external_wp_i18n_namespaceObject.__)('Trashing failed'), {
3552      id: TRASH_POST_NOTICE_ID
3553    }];
3554  }
3555  
3556  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/store/actions.js
3557  /**
3558   * External dependencies
3559   */
3560  
3561  /**
3562   * WordPress dependencies
3563   */
3564  
3565  
3566  
3567  
3568  
3569  
3570  
3571  
3572  /**
3573   * Internal dependencies
3574   */
3575  
3576  
3577  
3578  
3579  /**
3580   * Returns an action generator used in signalling that editor has initialized with
3581   * the specified post object and editor settings.
3582   *
3583   * @param {Object} post     Post object.
3584   * @param {Object} edits    Initial edited attributes object.
3585   * @param {Array?} template Block Template.
3586   */
3587  
3588  const setupEditor = (post, edits, template) => _ref => {
3589    let {
3590      dispatch
3591    } = _ref;
3592    dispatch.setupEditorState(post); // Apply a template for new posts only, if exists.
3593  
3594    const isNewPost = post.status === 'auto-draft';
3595  
3596    if (isNewPost && template) {
3597      // In order to ensure maximum of a single parse during setup, edits are
3598      // included as part of editor setup action. Assume edited content as
3599      // canonical if provided, falling back to post.
3600      let content;
3601  
3602      if ((0,external_lodash_namespaceObject.has)(edits, ['content'])) {
3603        content = edits.content;
3604      } else {
3605        content = post.content.raw;
3606      }
3607  
3608      let blocks = (0,external_wp_blocks_namespaceObject.parse)(content);
3609      blocks = (0,external_wp_blocks_namespaceObject.synchronizeBlocksWithTemplate)(blocks, template);
3610      dispatch.resetEditorBlocks(blocks, {
3611        __unstableShouldCreateUndoLevel: false
3612      });
3613    }
3614  
3615    if (edits && Object.values(edits).some(_ref2 => {
3616      var _post$key$raw, _post$key;
3617  
3618      let [key, edit] = _ref2;
3619      return edit !== ((_post$key$raw = (_post$key = post[key]) === null || _post$key === void 0 ? void 0 : _post$key.raw) !== null && _post$key$raw !== void 0 ? _post$key$raw : post[key]);
3620    })) {
3621      dispatch.editPost(edits);
3622    }
3623  };
3624  /**
3625   * Returns an action object signalling that the editor is being destroyed and
3626   * that any necessary state or side-effect cleanup should occur.
3627   *
3628   * @return {Object} Action object.
3629   */
3630  
3631  function __experimentalTearDownEditor() {
3632    return {
3633      type: 'TEAR_DOWN_EDITOR'
3634    };
3635  }
3636  /**
3637   * Returns an action object used in signalling that the latest version of the
3638   * post has been received, either by initialization or save.
3639   *
3640   * @deprecated Since WordPress 6.0.
3641   */
3642  
3643  function resetPost() {
3644    external_wp_deprecated_default()("wp.data.dispatch( 'core/editor' ).resetPost", {
3645      since: '6.0',
3646      version: '6.3',
3647      alternative: 'Initialize the editor with the setupEditorState action'
3648    });
3649    return {
3650      type: 'DO_NOTHING'
3651    };
3652  }
3653  /**
3654   * Returns an action object used in signalling that a patch of updates for the
3655   * latest version of the post have been received.
3656   *
3657   * @return {Object} Action object.
3658   * @deprecated since Gutenberg 9.7.0.
3659   */
3660  
3661  function updatePost() {
3662    external_wp_deprecated_default()("wp.data.dispatch( 'core/editor' ).updatePost", {
3663      since: '5.7',
3664      alternative: 'Use the core entities store instead'
3665    });
3666    return {
3667      type: 'DO_NOTHING'
3668    };
3669  }
3670  /**
3671   * Returns an action object used to setup the editor state when first opening
3672   * an editor.
3673   *
3674   * @param {Object} post Post object.
3675   *
3676   * @return {Object} Action object.
3677   */
3678  
3679  function setupEditorState(post) {
3680    return {
3681      type: 'SETUP_EDITOR_STATE',
3682      post
3683    };
3684  }
3685  /**
3686   * Returns an action object used in signalling that attributes of the post have
3687   * been edited.
3688   *
3689   * @param {Object} edits   Post attributes to edit.
3690   * @param {Object} options Options for the edit.
3691   */
3692  
3693  const editPost = (edits, options) => _ref3 => {
3694    let {
3695      select,
3696      registry
3697    } = _ref3;
3698    const {
3699      id,
3700      type
3701    } = select.getCurrentPost();
3702    registry.dispatch(external_wp_coreData_namespaceObject.store).editEntityRecord('postType', type, id, edits, options);
3703  };
3704  /**
3705   * Action for saving the current post in the editor.
3706   *
3707   * @param {Object} options
3708   */
3709  
3710  const savePost = function () {
3711    let options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3712    return async _ref4 => {
3713      let {
3714        select,
3715        dispatch,
3716        registry
3717      } = _ref4;
3718  
3719      if (!select.isEditedPostSaveable()) {
3720        return;
3721      }
3722  
3723      const content = select.getEditedPostContent();
3724  
3725      if (!options.isAutosave) {
3726        dispatch.editPost({
3727          content
3728        }, {
3729          undoIgnore: true
3730        });
3731      }
3732  
3733      const previousRecord = select.getCurrentPost();
3734      const edits = {
3735        id: previousRecord.id,
3736        ...registry.select(external_wp_coreData_namespaceObject.store).getEntityRecordNonTransientEdits('postType', previousRecord.type, previousRecord.id),
3737        content
3738      };
3739      dispatch({
3740        type: 'REQUEST_POST_UPDATE_START',
3741        options
3742      });
3743      await registry.dispatch(external_wp_coreData_namespaceObject.store).saveEntityRecord('postType', previousRecord.type, edits, options);
3744      dispatch({
3745        type: 'REQUEST_POST_UPDATE_FINISH',
3746        options
3747      });
3748      const error = registry.select(external_wp_coreData_namespaceObject.store).getLastEntitySaveError('postType', previousRecord.type, previousRecord.id);
3749  
3750      if (error) {
3751        const args = getNotificationArgumentsForSaveFail({
3752          post: previousRecord,
3753          edits,
3754          error
3755        });
3756  
3757        if (args.length) {
3758          registry.dispatch(external_wp_notices_namespaceObject.store).createErrorNotice(...args);
3759        }
3760      } else {
3761        const updatedRecord = select.getCurrentPost();
3762        const args = getNotificationArgumentsForSaveSuccess({
3763          previousPost: previousRecord,
3764          post: updatedRecord,
3765          postType: await registry.resolveSelect(external_wp_coreData_namespaceObject.store).getPostType(updatedRecord.type),
3766          options
3767        });
3768  
3769        if (args.length) {
3770          registry.dispatch(external_wp_notices_namespaceObject.store).createSuccessNotice(...args);
3771        } // Make sure that any edits after saving create an undo level and are
3772        // considered for change detection.
3773  
3774  
3775        if (!options.isAutosave) {
3776          registry.dispatch(external_wp_blockEditor_namespaceObject.store).__unstableMarkLastChangeAsPersistent();
3777        }
3778      }
3779    };
3780  };
3781  /**
3782   * Action for refreshing the current post.
3783   *
3784   * @deprecated Since WordPress 6.0.
3785   */
3786  
3787  function refreshPost() {
3788    external_wp_deprecated_default()("wp.data.dispatch( 'core/editor' ).refreshPost", {
3789      since: '6.0',
3790      version: '6.3',
3791      alternative: 'Use the core entities store instead'
3792    });
3793    return {
3794      type: 'DO_NOTHING'
3795    };
3796  }
3797  /**
3798   * Action for trashing the current post in the editor.
3799   */
3800  
3801  const trashPost = () => async _ref5 => {
3802    let {
3803      select,
3804      dispatch,
3805      registry
3806    } = _ref5;
3807    const postTypeSlug = select.getCurrentPostType();
3808    const postType = await registry.resolveSelect(external_wp_coreData_namespaceObject.store).getPostType(postTypeSlug);
3809    registry.dispatch(external_wp_notices_namespaceObject.store).removeNotice(TRASH_POST_NOTICE_ID);
3810  
3811    try {
3812      const post = select.getCurrentPost();
3813      await external_wp_apiFetch_default()({
3814        path: `/wp/v2/$postType.rest_base}/$post.id}`,
3815        method: 'DELETE'
3816      });
3817      await dispatch.savePost();
3818    } catch (error) {
3819      registry.dispatch(external_wp_notices_namespaceObject.store).createErrorNotice(...getNotificationArgumentsForTrashFail({
3820        error
3821      }));
3822    }
3823  };
3824  /**
3825   * Action that autosaves the current post.  This
3826   * includes server-side autosaving (default) and client-side (a.k.a. local)
3827   * autosaving (e.g. on the Web, the post might be committed to Session
3828   * Storage).
3829   *
3830   * @param {Object?} options Extra flags to identify the autosave.
3831   */
3832  
3833  const autosave = function () {
3834    let {
3835      local = false,
3836      ...options
3837    } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
3838    return async _ref6 => {
3839      let {
3840        select,
3841        dispatch
3842      } = _ref6;
3843  
3844      if (local) {
3845        const post = select.getCurrentPost();
3846        const isPostNew = select.isEditedPostNew();
3847        const title = select.getEditedPostAttribute('title');
3848        const content = select.getEditedPostAttribute('content');
3849        const excerpt = select.getEditedPostAttribute('excerpt');
3850        localAutosaveSet(post.id, isPostNew, title, content, excerpt);
3851      } else {
3852        await dispatch.savePost({
3853          isAutosave: true,
3854          ...options
3855        });
3856      }
3857    };
3858  };
3859  /**
3860   * Action that restores last popped state in undo history.
3861   */
3862  
3863  const redo = () => _ref7 => {
3864    let {
3865      registry
3866    } = _ref7;
3867    registry.dispatch(external_wp_coreData_namespaceObject.store).redo();
3868  };
3869  /**
3870   * Action that pops a record from undo history and undoes the edit.
3871   */
3872  
3873  const undo = () => _ref8 => {
3874    let {
3875      registry
3876    } = _ref8;
3877    registry.dispatch(external_wp_coreData_namespaceObject.store).undo();
3878  };
3879  /**
3880   * Action that creates an undo history record.
3881   *
3882   * @deprecated Since WordPress 6.0
3883   */
3884  
3885  function createUndoLevel() {
3886    external_wp_deprecated_default()("wp.data.dispatch( 'core/editor' ).createUndoLevel", {
3887      since: '6.0',
3888      version: '6.3',
3889      alternative: 'Use the core entities store instead'
3890    });
3891    return {
3892      type: 'DO_NOTHING'
3893    };
3894  }
3895  /**
3896   * Action that locks the editor.
3897   *
3898   * @param {Object} lock Details about the post lock status, user, and nonce.
3899   * @return {Object} Action object.
3900   */
3901  
3902  function updatePostLock(lock) {
3903    return {
3904      type: 'UPDATE_POST_LOCK',
3905      lock
3906    };
3907  }
3908  /**
3909   * Enable the publish sidebar.
3910   */
3911  
3912  const enablePublishSidebar = () => _ref9 => {
3913    let {
3914      registry
3915    } = _ref9;
3916    registry.dispatch(external_wp_preferences_namespaceObject.store).set('core/edit-post', 'isPublishSidebarEnabled', true);
3917  };
3918  /**
3919   * Disables the publish sidebar.
3920   */
3921  
3922  const disablePublishSidebar = () => _ref10 => {
3923    let {
3924      registry
3925    } = _ref10;
3926    registry.dispatch(external_wp_preferences_namespaceObject.store).set('core/edit-post', 'isPublishSidebarEnabled', false);
3927  };
3928  /**
3929   * Action that locks post saving.
3930   *
3931   * @param {string} lockName The lock name.
3932   *
3933   * @example
3934   * ```
3935   * const { subscribe } = wp.data;
3936   *
3937   * const initialPostStatus = wp.data.select( 'core/editor' ).getEditedPostAttribute( 'status' );
3938   *
3939   * // Only allow publishing posts that are set to a future date.
3940   * if ( 'publish' !== initialPostStatus ) {
3941   *
3942   *     // Track locking.
3943   *     let locked = false;
3944   *
3945   *     // Watch for the publish event.
3946   *     let unssubscribe = subscribe( () => {
3947   *         const currentPostStatus = wp.data.select( 'core/editor' ).getEditedPostAttribute( 'status' );
3948   *         if ( 'publish' !== currentPostStatus ) {
3949   *
3950   *             // Compare the post date to the current date, lock the post if the date isn't in the future.
3951   *             const postDate = new Date( wp.data.select( 'core/editor' ).getEditedPostAttribute( 'date' ) );
3952   *             const currentDate = new Date();
3953   *             if ( postDate.getTime() <= currentDate.getTime() ) {
3954   *                 if ( ! locked ) {
3955   *                     locked = true;
3956   *                     wp.data.dispatch( 'core/editor' ).lockPostSaving( 'futurelock' );
3957   *                 }
3958   *             } else {
3959   *                 if ( locked ) {
3960   *                     locked = false;
3961   *                     wp.data.dispatch( 'core/editor' ).unlockPostSaving( 'futurelock' );
3962   *                 }
3963   *             }
3964   *         }
3965   *     } );
3966   * }
3967   * ```
3968   *
3969   * @return {Object} Action object
3970   */
3971  
3972  function lockPostSaving(lockName) {
3973    return {
3974      type: 'LOCK_POST_SAVING',
3975      lockName
3976    };
3977  }
3978  /**
3979   * Action that unlocks post saving.
3980   *
3981   * @param {string} lockName The lock name.
3982   *
3983   * @example
3984   * ```
3985   * // Unlock post saving with the lock key `mylock`:
3986   * wp.data.dispatch( 'core/editor' ).unlockPostSaving( 'mylock' );
3987   * ```
3988   *
3989   * @return {Object} Action object
3990   */
3991  
3992  function unlockPostSaving(lockName) {
3993    return {
3994      type: 'UNLOCK_POST_SAVING',
3995      lockName
3996    };
3997  }
3998  /**
3999   * Action that locks post autosaving.
4000   *
4001   * @param {string} lockName The lock name.
4002   *
4003   * @example
4004   * ```
4005   * // Lock post autosaving with the lock key `mylock`:
4006   * wp.data.dispatch( 'core/editor' ).lockPostAutosaving( 'mylock' );
4007   * ```
4008   *
4009   * @return {Object} Action object
4010   */
4011  
4012  function lockPostAutosaving(lockName) {
4013    return {
4014      type: 'LOCK_POST_AUTOSAVING',
4015      lockName
4016    };
4017  }
4018  /**
4019   * Action that unlocks post autosaving.
4020   *
4021   * @param {string} lockName The lock name.
4022   *
4023   * @example
4024   * ```
4025   * // Unlock post saving with the lock key `mylock`:
4026   * wp.data.dispatch( 'core/editor' ).unlockPostAutosaving( 'mylock' );
4027   * ```
4028   *
4029   * @return {Object} Action object
4030   */
4031  
4032  function unlockPostAutosaving(lockName) {
4033    return {
4034      type: 'UNLOCK_POST_AUTOSAVING',
4035      lockName
4036    };
4037  }
4038  /**
4039   * Returns an action object used to signal that the blocks have been updated.
4040   *
4041   * @param {Array}   blocks  Block Array.
4042   * @param {?Object} options Optional options.
4043   */
4044  
4045  const resetEditorBlocks = function (blocks) {
4046    let options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
4047    return _ref11 => {
4048      let {
4049        select,
4050        dispatch,
4051        registry
4052      } = _ref11;
4053      const {
4054        __unstableShouldCreateUndoLevel,
4055        selection
4056      } = options;
4057      const edits = {
4058        blocks,
4059        selection
4060      };
4061  
4062      if (__unstableShouldCreateUndoLevel !== false) {
4063        const {
4064          id,
4065          type
4066        } = select.getCurrentPost();
4067        const noChange = registry.select(external_wp_coreData_namespaceObject.store).getEditedEntityRecord('postType', type, id).blocks === edits.blocks;
4068  
4069        if (noChange) {
4070          registry.dispatch(external_wp_coreData_namespaceObject.store).__unstableCreateUndoLevel('postType', type, id);
4071  
4072          return;
4073        } // We create a new function here on every persistent edit
4074        // to make sure the edit makes the post dirty and creates
4075        // a new undo level.
4076  
4077  
4078        edits.content = _ref12 => {
4079          let {
4080            blocks: blocksForSerialization = []
4081          } = _ref12;
4082          return (0,external_wp_blocks_namespaceObject.__unstableSerializeAndClean)(blocksForSerialization);
4083        };
4084      }
4085  
4086      dispatch.editPost(edits);
4087    };
4088  };
4089  /*
4090   * Returns an action object used in signalling that the post editor settings have been updated.
4091   *
4092   * @param {Object} settings Updated settings
4093   *
4094   * @return {Object} Action object
4095   */
4096  
4097  function updateEditorSettings(settings) {
4098    return {
4099      type: 'UPDATE_EDITOR_SETTINGS',
4100      settings
4101    };
4102  }
4103  /**
4104   * Backward compatibility
4105   */
4106  
4107  const getBlockEditorAction = name => function () {
4108    for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
4109      args[_key] = arguments[_key];
4110    }
4111  
4112    return _ref13 => {
4113      let {
4114        registry
4115      } = _ref13;
4116      external_wp_deprecated_default()("`wp.data.dispatch( 'core/editor' )." + name + '`', {
4117        since: '5.3',
4118        alternative: "`wp.data.dispatch( 'core/block-editor' )." + name + '`',
4119        version: '6.2'
4120      });
4121      registry.dispatch(external_wp_blockEditor_namespaceObject.store)[name](...args);
4122    };
4123  };
4124  /**
4125   * @see resetBlocks in core/block-editor store.
4126   */
4127  
4128  
4129  const resetBlocks = getBlockEditorAction('resetBlocks');
4130  /**
4131   * @see receiveBlocks in core/block-editor store.
4132   */
4133  
4134  const receiveBlocks = getBlockEditorAction('receiveBlocks');
4135  /**
4136   * @see updateBlock in core/block-editor store.
4137   */
4138  
4139  const updateBlock = getBlockEditorAction('updateBlock');
4140  /**
4141   * @see updateBlockAttributes in core/block-editor store.
4142   */
4143  
4144  const updateBlockAttributes = getBlockEditorAction('updateBlockAttributes');
4145  /**
4146   * @see selectBlock in core/block-editor store.
4147   */
4148  
4149  const selectBlock = getBlockEditorAction('selectBlock');
4150  /**
4151   * @see startMultiSelect in core/block-editor store.
4152   */
4153  
4154  const startMultiSelect = getBlockEditorAction('startMultiSelect');
4155  /**
4156   * @see stopMultiSelect in core/block-editor store.
4157   */
4158  
4159  const stopMultiSelect = getBlockEditorAction('stopMultiSelect');
4160  /**
4161   * @see multiSelect in core/block-editor store.
4162   */
4163  
4164  const multiSelect = getBlockEditorAction('multiSelect');
4165  /**
4166   * @see clearSelectedBlock in core/block-editor store.
4167   */
4168  
4169  const clearSelectedBlock = getBlockEditorAction('clearSelectedBlock');
4170  /**
4171   * @see toggleSelection in core/block-editor store.
4172   */
4173  
4174  const toggleSelection = getBlockEditorAction('toggleSelection');
4175  /**
4176   * @see replaceBlocks in core/block-editor store.
4177   */
4178  
4179  const replaceBlocks = getBlockEditorAction('replaceBlocks');
4180  /**
4181   * @see replaceBlock in core/block-editor store.
4182   */
4183  
4184  const replaceBlock = getBlockEditorAction('replaceBlock');
4185  /**
4186   * @see moveBlocksDown in core/block-editor store.
4187   */
4188  
4189  const moveBlocksDown = getBlockEditorAction('moveBlocksDown');
4190  /**
4191   * @see moveBlocksUp in core/block-editor store.
4192   */
4193  
4194  const moveBlocksUp = getBlockEditorAction('moveBlocksUp');
4195  /**
4196   * @see moveBlockToPosition in core/block-editor store.
4197   */
4198  
4199  const moveBlockToPosition = getBlockEditorAction('moveBlockToPosition');
4200  /**
4201   * @see insertBlock in core/block-editor store.
4202   */
4203  
4204  const insertBlock = getBlockEditorAction('insertBlock');
4205  /**
4206   * @see insertBlocks in core/block-editor store.
4207   */
4208  
4209  const insertBlocks = getBlockEditorAction('insertBlocks');
4210  /**
4211   * @see showInsertionPoint in core/block-editor store.
4212   */
4213  
4214  const showInsertionPoint = getBlockEditorAction('showInsertionPoint');
4215  /**
4216   * @see hideInsertionPoint in core/block-editor store.
4217   */
4218  
4219  const hideInsertionPoint = getBlockEditorAction('hideInsertionPoint');
4220  /**
4221   * @see setTemplateValidity in core/block-editor store.
4222   */
4223  
4224  const setTemplateValidity = getBlockEditorAction('setTemplateValidity');
4225  /**
4226   * @see synchronizeTemplate in core/block-editor store.
4227   */
4228  
4229  const synchronizeTemplate = getBlockEditorAction('synchronizeTemplate');
4230  /**
4231   * @see mergeBlocks in core/block-editor store.
4232   */
4233  
4234  const mergeBlocks = getBlockEditorAction('mergeBlocks');
4235  /**
4236   * @see removeBlocks in core/block-editor store.
4237   */
4238  
4239  const removeBlocks = getBlockEditorAction('removeBlocks');
4240  /**
4241   * @see removeBlock in core/block-editor store.
4242   */
4243  
4244  const removeBlock = getBlockEditorAction('removeBlock');
4245  /**
4246   * @see toggleBlockMode in core/block-editor store.
4247   */
4248  
4249  const toggleBlockMode = getBlockEditorAction('toggleBlockMode');
4250  /**
4251   * @see startTyping in core/block-editor store.
4252   */
4253  
4254  const startTyping = getBlockEditorAction('startTyping');
4255  /**
4256   * @see stopTyping in core/block-editor store.
4257   */
4258  
4259  const stopTyping = getBlockEditorAction('stopTyping');
4260  /**
4261   * @see enterFormattedText in core/block-editor store.
4262   */
4263  
4264  const enterFormattedText = getBlockEditorAction('enterFormattedText');
4265  /**
4266   * @see exitFormattedText in core/block-editor store.
4267   */
4268  
4269  const exitFormattedText = getBlockEditorAction('exitFormattedText');
4270  /**
4271   * @see insertDefaultBlock in core/block-editor store.
4272   */
4273  
4274  const insertDefaultBlock = getBlockEditorAction('insertDefaultBlock');
4275  /**
4276   * @see updateBlockListSettings in core/block-editor store.
4277   */
4278  
4279  const updateBlockListSettings = getBlockEditorAction('updateBlockListSettings');
4280  
4281  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/store/index.js
4282  /**
4283   * WordPress dependencies
4284   */
4285  
4286  /**
4287   * Internal dependencies
4288   */
4289  
4290  
4291  
4292  
4293  
4294  /**
4295   * Post editor data store configuration.
4296   *
4297   * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/data/README.md#registerStore
4298   *
4299   * @type {Object}
4300   */
4301  
4302  const storeConfig = {
4303    reducer: reducer,
4304    selectors: selectors_namespaceObject,
4305    actions: actions_namespaceObject
4306  };
4307  /**
4308   * Store definition for the editor namespace.
4309   *
4310   * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/data/README.md#createReduxStore
4311   *
4312   * @type {Object}
4313   */
4314  
4315  const store_store = (0,external_wp_data_namespaceObject.createReduxStore)(STORE_NAME, { ...storeConfig
4316  });
4317  (0,external_wp_data_namespaceObject.register)(store_store);
4318  
4319  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/hooks/custom-sources-backwards-compatibility.js
4320  
4321  
4322  
4323  /**
4324   * External dependencies
4325   */
4326  
4327  /**
4328   * WordPress dependencies
4329   */
4330  
4331  
4332  
4333  
4334  
4335  
4336  
4337  /**
4338   * Internal dependencies
4339   */
4340  
4341  
4342  /** @typedef {import('@wordpress/compose').WPHigherOrderComponent} WPHigherOrderComponent */
4343  
4344  /** @typedef {import('@wordpress/blocks').WPBlockSettings} WPBlockSettings */
4345  
4346  /**
4347   * Object whose keys are the names of block attributes, where each value
4348   * represents the meta key to which the block attribute is intended to save.
4349   *
4350   * @see https://developer.wordpress.org/reference/functions/register_meta/
4351   *
4352   * @typedef {Object<string,string>} WPMetaAttributeMapping
4353   */
4354  
4355  /**
4356   * Given a mapping of attribute names (meta source attributes) to their
4357   * associated meta key, returns a higher order component that overrides its
4358   * `attributes` and `setAttributes` props to sync any changes with the edited
4359   * post's meta keys.
4360   *
4361   * @param {WPMetaAttributeMapping} metaAttributes Meta attribute mapping.
4362   *
4363   * @return {WPHigherOrderComponent} Higher-order component.
4364   */
4365  
4366  const createWithMetaAttributeSource = metaAttributes => (0,external_wp_compose_namespaceObject.createHigherOrderComponent)(BlockEdit => _ref => {
4367    let {
4368      attributes,
4369      setAttributes,
4370      ...props
4371    } = _ref;
4372    const postType = (0,external_wp_data_namespaceObject.useSelect)(select => select(store_store).getCurrentPostType(), []);
4373    const [meta, setMeta] = (0,external_wp_coreData_namespaceObject.useEntityProp)('postType', postType, 'meta');
4374    const mergedAttributes = (0,external_wp_element_namespaceObject.useMemo)(() => ({ ...attributes,
4375      ...(0,external_lodash_namespaceObject.mapValues)(metaAttributes, metaKey => meta[metaKey])
4376    }), [attributes, meta]);
4377    return (0,external_wp_element_namespaceObject.createElement)(BlockEdit, _extends({
4378      attributes: mergedAttributes,
4379      setAttributes: nextAttributes => {
4380        const nextMeta = (0,external_lodash_namespaceObject.mapKeys)( // Filter to intersection of keys between the updated
4381        // attributes and those with an associated meta key.
4382        (0,external_lodash_namespaceObject.pickBy)(nextAttributes, (value, key) => metaAttributes[key]), // Rename the keys to the expected meta key name.
4383        (value, attributeKey) => metaAttributes[attributeKey]);
4384  
4385        if (!(0,external_lodash_namespaceObject.isEmpty)(nextMeta)) {
4386          setMeta(nextMeta);
4387        }
4388  
4389        setAttributes(nextAttributes);
4390      }
4391    }, props));
4392  }, 'withMetaAttributeSource');
4393  /**
4394   * Filters a registered block's settings to enhance a block's `edit` component
4395   * to upgrade meta-sourced attributes to use the post's meta entity property.
4396   *
4397   * @param {WPBlockSettings} settings Registered block settings.
4398   *
4399   * @return {WPBlockSettings} Filtered block settings.
4400   */
4401  
4402  
4403  function shimAttributeSource(settings) {
4404    /** @type {WPMetaAttributeMapping} */
4405    const metaAttributes = (0,external_lodash_namespaceObject.mapValues)((0,external_lodash_namespaceObject.pickBy)(settings.attributes, {
4406      source: 'meta'
4407    }), 'meta');
4408  
4409    if (!(0,external_lodash_namespaceObject.isEmpty)(metaAttributes)) {
4410      settings.edit = createWithMetaAttributeSource(metaAttributes)(settings.edit);
4411    }
4412  
4413    return settings;
4414  }
4415  
4416  (0,external_wp_hooks_namespaceObject.addFilter)('blocks.registerBlockType', 'core/editor/custom-sources-backwards-compatibility/shim-attribute-source', shimAttributeSource); // The above filter will only capture blocks registered after the filter was
4417  // added. There may already be blocks registered by this point, and those must
4418  // be updated to apply the shim.
4419  //
4420  // The following implementation achieves this, albeit with a couple caveats:
4421  // - Only blocks registered on the global store will be modified.
4422  // - The block settings are directly mutated, since there is currently no
4423  //   mechanism to update an existing block registration. This is the reason for
4424  //   `getBlockType` separate from `getBlockTypes`, since the latter returns a
4425  //   _copy_ of the block registration (i.e. the mutation would not affect the
4426  //   actual registered block settings).
4427  //
4428  // `getBlockTypes` or `getBlockType` implementation could change in the future
4429  // in regards to creating settings clones, but the corresponding end-to-end
4430  // tests for meta blocks should cover against any potential regressions.
4431  //
4432  // In the future, we could support updating block settings, at which point this
4433  // implementation could use that mechanism instead.
4434  
4435  (0,external_wp_data_namespaceObject.select)(external_wp_blocks_namespaceObject.store).getBlockTypes().map(_ref2 => {
4436    let {
4437      name
4438    } = _ref2;
4439    return (0,external_wp_data_namespaceObject.select)(external_wp_blocks_namespaceObject.store).getBlockType(name);
4440  }).forEach(shimAttributeSource);
4441  
4442  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/autocompleters/user.js
4443  
4444  
4445  /**
4446   * WordPress dependencies
4447   */
4448  
4449  
4450  
4451  /** @typedef {import('@wordpress/components').WPCompleter} WPCompleter */
4452  
4453  function getUserLabel(user) {
4454    const avatar = user.avatar_urls && user.avatar_urls[24] ? (0,external_wp_element_namespaceObject.createElement)("img", {
4455      className: "editor-autocompleters__user-avatar",
4456      alt: "",
4457      src: user.avatar_urls[24]
4458    }) : (0,external_wp_element_namespaceObject.createElement)("span", {
4459      className: "editor-autocompleters__no-avatar"
4460    });
4461    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, avatar, (0,external_wp_element_namespaceObject.createElement)("span", {
4462      className: "editor-autocompleters__user-name"
4463    }, user.name), (0,external_wp_element_namespaceObject.createElement)("span", {
4464      className: "editor-autocompleters__user-slug"
4465    }, user.slug));
4466  }
4467  /**
4468   * A user mentions completer.
4469   *
4470   * @type {WPCompleter}
4471   */
4472  
4473  /* harmony default export */ var user = ({
4474    name: 'users',
4475    className: 'editor-autocompleters__user',
4476    triggerPrefix: '@',
4477  
4478    useItems(filterValue) {
4479      const users = (0,external_wp_data_namespaceObject.useSelect)(select => {
4480        const {
4481          getUsers
4482        } = select(external_wp_coreData_namespaceObject.store);
4483        return getUsers({
4484          context: 'view',
4485          search: encodeURIComponent(filterValue)
4486        });
4487      }, [filterValue]);
4488      const options = (0,external_wp_element_namespaceObject.useMemo)(() => users ? users.map(user => ({
4489        key: `user-$user.slug}`,
4490        value: user,
4491        label: getUserLabel(user)
4492      })) : [], [users]);
4493      return [options];
4494    },
4495  
4496    getOptionCompletion(user) {
4497      return `@$user.slug}`;
4498    }
4499  
4500  });
4501  
4502  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/hooks/default-autocompleters.js
4503  /**
4504   * External dependencies
4505   */
4506  
4507  /**
4508   * WordPress dependencies
4509   */
4510  
4511  
4512  /**
4513   * Internal dependencies
4514   */
4515  
4516  
4517  
4518  function setDefaultCompleters() {
4519    let completers = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
4520    // Provide copies so filters may directly modify them.
4521    completers.push((0,external_lodash_namespaceObject.clone)(user));
4522    return completers;
4523  }
4524  
4525  (0,external_wp_hooks_namespaceObject.addFilter)('editor.Autocomplete.completers', 'editor/autocompleters/set-default-completers', setDefaultCompleters);
4526  
4527  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/hooks/index.js
4528  /**
4529   * Internal dependencies
4530   */
4531  
4532  
4533  
4534  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/autocompleters/index.js
4535  
4536  
4537  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/autosave-monitor/index.js
4538  /**
4539   * WordPress dependencies
4540   */
4541  
4542  
4543  
4544  
4545  /**
4546   * Internal dependencies
4547   */
4548  
4549  
4550  /**
4551   * AutosaveMonitor invokes `props.autosave()` within at most `interval` seconds after an unsaved change is detected.
4552   *
4553   * The logic is straightforward: a check is performed every `props.interval` seconds. If any changes are detected, `props.autosave()` is called.
4554   * The time between the change and the autosave varies but is no larger than `props.interval` seconds. Refer to the code below for more details, such as
4555   * the specific way of detecting changes.
4556   *
4557   * There are two caveats:
4558   * * If `props.isAutosaveable` happens to be false at a time of checking for changes, the check is retried every second.
4559   * * The timer may be disabled by setting `props.disableIntervalChecks` to `true`. In that mode, any change will immediately trigger `props.autosave()`.
4560   */
4561  
4562  class AutosaveMonitor extends external_wp_element_namespaceObject.Component {
4563    constructor(props) {
4564      super(props);
4565      this.needsAutosave = !!(props.isDirty && props.isAutosaveable);
4566    }
4567  
4568    componentDidMount() {
4569      if (!this.props.disableIntervalChecks) {
4570        this.setAutosaveTimer();
4571      }
4572    }
4573  
4574    componentDidUpdate(prevProps) {
4575      if (this.props.disableIntervalChecks) {
4576        if (this.props.editsReference !== prevProps.editsReference) {
4577          this.props.autosave();
4578        }
4579  
4580        return;
4581      }
4582  
4583      if (this.props.interval !== prevProps.interval) {
4584        clearTimeout(this.timerId);
4585        this.setAutosaveTimer();
4586      }
4587  
4588      if (!this.props.isDirty) {
4589        this.needsAutosave = false;
4590        return;
4591      }
4592  
4593      if (this.props.isAutosaving && !prevProps.isAutosaving) {
4594        this.needsAutosave = false;
4595        return;
4596      }
4597  
4598      if (this.props.editsReference !== prevProps.editsReference) {
4599        this.needsAutosave = true;
4600      }
4601    }
4602  
4603    componentWillUnmount() {
4604      clearTimeout(this.timerId);
4605    }
4606  
4607    setAutosaveTimer() {
4608      let timeout = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.props.interval * 1000;
4609      this.timerId = setTimeout(() => {
4610        this.autosaveTimerHandler();
4611      }, timeout);
4612    }
4613  
4614    autosaveTimerHandler() {
4615      if (!this.props.isAutosaveable) {
4616        this.setAutosaveTimer(1000);
4617        return;
4618      }
4619  
4620      if (this.needsAutosave) {
4621        this.needsAutosave = false;
4622        this.props.autosave();
4623      }
4624  
4625      this.setAutosaveTimer();
4626    }
4627  
4628    render() {
4629      return null;
4630    }
4631  
4632  }
4633  /* harmony default export */ var autosave_monitor = ((0,external_wp_compose_namespaceObject.compose)([(0,external_wp_data_namespaceObject.withSelect)((select, ownProps) => {
4634    const {
4635      getReferenceByDistinctEdits
4636    } = select(external_wp_coreData_namespaceObject.store);
4637    const {
4638      isEditedPostDirty,
4639      isEditedPostAutosaveable,
4640      isAutosavingPost,
4641      getEditorSettings
4642    } = select(store_store);
4643    const {
4644      interval = getEditorSettings().autosaveInterval
4645    } = ownProps;
4646    return {
4647      editsReference: getReferenceByDistinctEdits(),
4648      isDirty: isEditedPostDirty(),
4649      isAutosaveable: isEditedPostAutosaveable(),
4650      isAutosaving: isAutosavingPost(),
4651      interval
4652    };
4653  }), (0,external_wp_data_namespaceObject.withDispatch)((dispatch, ownProps) => ({
4654    autosave() {
4655      const {
4656        autosave = dispatch(store_store).autosave
4657      } = ownProps;
4658      autosave();
4659    }
4660  
4661  }))])(AutosaveMonitor));
4662  
4663  ;// CONCATENATED MODULE: external ["wp","richText"]
4664  var external_wp_richText_namespaceObject = window["wp"]["richText"];
4665  // EXTERNAL MODULE: ./node_modules/classnames/index.js
4666  var classnames = __webpack_require__(4403);
4667  var classnames_default = /*#__PURE__*/__webpack_require__.n(classnames);
4668  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/document-outline/item.js
4669  
4670  
4671  /**
4672   * External dependencies
4673   */
4674  
4675  
4676  const TableOfContentsItem = _ref => {
4677    let {
4678      children,
4679      isValid,
4680      level,
4681      href,
4682      onSelect
4683    } = _ref;
4684    return (0,external_wp_element_namespaceObject.createElement)("li", {
4685      className: classnames_default()('document-outline__item', `is-$level.toLowerCase()}`, {
4686        'is-invalid': !isValid
4687      })
4688    }, (0,external_wp_element_namespaceObject.createElement)("a", {
4689      href: href,
4690      className: "document-outline__button",
4691      onClick: onSelect
4692    }, (0,external_wp_element_namespaceObject.createElement)("span", {
4693      className: "document-outline__emdash",
4694      "aria-hidden": "true"
4695    }), (0,external_wp_element_namespaceObject.createElement)("strong", {
4696      className: "document-outline__level"
4697    }, level), (0,external_wp_element_namespaceObject.createElement)("span", {
4698      className: "document-outline__item-content"
4699    }, children)));
4700  };
4701  
4702  /* harmony default export */ var document_outline_item = (TableOfContentsItem);
4703  
4704  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/document-outline/index.js
4705  
4706  
4707  /**
4708   * External dependencies
4709   */
4710  
4711  /**
4712   * WordPress dependencies
4713   */
4714  
4715  
4716  
4717  
4718  
4719  
4720  
4721  /**
4722   * Internal dependencies
4723   */
4724  
4725  
4726  
4727  /**
4728   * Module constants
4729   */
4730  
4731  const emptyHeadingContent = (0,external_wp_element_namespaceObject.createElement)("em", null, (0,external_wp_i18n_namespaceObject.__)('(Empty heading)'));
4732  const incorrectLevelContent = [(0,external_wp_element_namespaceObject.createElement)("br", {
4733    key: "incorrect-break"
4734  }), (0,external_wp_element_namespaceObject.createElement)("em", {
4735    key: "incorrect-message"
4736  }, (0,external_wp_i18n_namespaceObject.__)('(Incorrect heading level)'))];
4737  const singleH1Headings = [(0,external_wp_element_namespaceObject.createElement)("br", {
4738    key: "incorrect-break-h1"
4739  }), (0,external_wp_element_namespaceObject.createElement)("em", {
4740    key: "incorrect-message-h1"
4741  }, (0,external_wp_i18n_namespaceObject.__)('(Your theme may already use a H1 for the post title)'))];
4742  const multipleH1Headings = [(0,external_wp_element_namespaceObject.createElement)("br", {
4743    key: "incorrect-break-multiple-h1"
4744  }), (0,external_wp_element_namespaceObject.createElement)("em", {
4745    key: "incorrect-message-multiple-h1"
4746  }, (0,external_wp_i18n_namespaceObject.__)('(Multiple H1 headings are not recommended)'))];
4747  /**
4748   * Returns an array of heading blocks enhanced with the following properties:
4749   * level   - An integer with the heading level.
4750   * isEmpty - Flag indicating if the heading has no content.
4751   *
4752   * @param {?Array} blocks An array of blocks.
4753   *
4754   * @return {Array} An array of heading blocks enhanced with the properties described above.
4755   */
4756  
4757  const computeOutlineHeadings = function () {
4758    let blocks = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
4759    return (0,external_lodash_namespaceObject.flatMap)(blocks, function () {
4760      let block = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
4761  
4762      if (block.name === 'core/heading') {
4763        return { ...block,
4764          level: block.attributes.level,
4765          isEmpty: isEmptyHeading(block)
4766        };
4767      }
4768  
4769      return computeOutlineHeadings(block.innerBlocks);
4770    });
4771  };
4772  
4773  const isEmptyHeading = heading => !heading.attributes.content || heading.attributes.content.length === 0;
4774  
4775  const DocumentOutline = _ref => {
4776    let {
4777      blocks = [],
4778      title,
4779      onSelect,
4780      isTitleSupported,
4781      hasOutlineItemsDisabled
4782    } = _ref;
4783    const headings = computeOutlineHeadings(blocks);
4784  
4785    if (headings.length < 1) {
4786      return null;
4787    }
4788  
4789    let prevHeadingLevel = 1; // Not great but it's the simplest way to locate the title right now.
4790  
4791    const titleNode = document.querySelector('.editor-post-title__input');
4792    const hasTitle = isTitleSupported && title && titleNode;
4793    const countByLevel = (0,external_lodash_namespaceObject.countBy)(headings, 'level');
4794    const hasMultipleH1 = countByLevel[1] > 1;
4795    return (0,external_wp_element_namespaceObject.createElement)("div", {
4796      className: "document-outline"
4797    }, (0,external_wp_element_namespaceObject.createElement)("ul", null, hasTitle && (0,external_wp_element_namespaceObject.createElement)(document_outline_item, {
4798      level: (0,external_wp_i18n_namespaceObject.__)('Title'),
4799      isValid: true,
4800      onSelect: onSelect,
4801      href: `#$titleNode.id}`,
4802      isDisabled: hasOutlineItemsDisabled
4803    }, title), headings.map((item, index) => {
4804      // Headings remain the same, go up by one, or down by any amount.
4805      // Otherwise there are missing levels.
4806      const isIncorrectLevel = item.level > prevHeadingLevel + 1;
4807      const isValid = !item.isEmpty && !isIncorrectLevel && !!item.level && (item.level !== 1 || !hasMultipleH1 && !hasTitle);
4808      prevHeadingLevel = item.level;
4809      return (0,external_wp_element_namespaceObject.createElement)(document_outline_item, {
4810        key: index,
4811        level: `H$item.level}`,
4812        isValid: isValid,
4813        isDisabled: hasOutlineItemsDisabled,
4814        href: `#block-$item.clientId}`,
4815        onSelect: onSelect
4816      }, item.isEmpty ? emptyHeadingContent : (0,external_wp_richText_namespaceObject.getTextContent)((0,external_wp_richText_namespaceObject.create)({
4817        html: item.attributes.content
4818      })), isIncorrectLevel && incorrectLevelContent, item.level === 1 && hasMultipleH1 && multipleH1Headings, hasTitle && item.level === 1 && !hasMultipleH1 && singleH1Headings);
4819    })));
4820  };
4821  /* harmony default export */ var document_outline = ((0,external_wp_compose_namespaceObject.compose)((0,external_wp_data_namespaceObject.withSelect)(select => {
4822    const {
4823      getBlocks
4824    } = select(external_wp_blockEditor_namespaceObject.store);
4825    const {
4826      getEditedPostAttribute
4827    } = select(store_store);
4828    const {
4829      getPostType
4830    } = select(external_wp_coreData_namespaceObject.store);
4831    const postType = getPostType(getEditedPostAttribute('type'));
4832    return {
4833      title: getEditedPostAttribute('title'),
4834      blocks: getBlocks(),
4835      isTitleSupported: (0,external_lodash_namespaceObject.get)(postType, ['supports', 'title'], false)
4836    };
4837  }))(DocumentOutline));
4838  
4839  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/document-outline/check.js
4840  /**
4841   * External dependencies
4842   */
4843  
4844  /**
4845   * WordPress dependencies
4846   */
4847  
4848  
4849  
4850  
4851  function DocumentOutlineCheck(_ref) {
4852    let {
4853      blocks,
4854      children
4855    } = _ref;
4856    const headings = (0,external_lodash_namespaceObject.filter)(blocks, block => block.name === 'core/heading');
4857  
4858    if (headings.length < 1) {
4859      return null;
4860    }
4861  
4862    return children;
4863  }
4864  
4865  /* harmony default export */ var check = ((0,external_wp_data_namespaceObject.withSelect)(select => ({
4866    blocks: select(external_wp_blockEditor_namespaceObject.store).getBlocks()
4867  }))(DocumentOutlineCheck));
4868  
4869  ;// CONCATENATED MODULE: external ["wp","keyboardShortcuts"]
4870  var external_wp_keyboardShortcuts_namespaceObject = window["wp"]["keyboardShortcuts"];
4871  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/global-keyboard-shortcuts/save-shortcut.js
4872  /**
4873   * WordPress dependencies
4874   */
4875  
4876  
4877  
4878  /**
4879   * Internal dependencies
4880   */
4881  
4882  
4883  
4884  function SaveShortcut(_ref) {
4885    let {
4886      resetBlocksOnSave
4887    } = _ref;
4888    const {
4889      resetEditorBlocks,
4890      savePost
4891    } = (0,external_wp_data_namespaceObject.useDispatch)(store_store);
4892    const {
4893      isEditedPostDirty,
4894      getPostEdits,
4895      isPostSavingLocked
4896    } = (0,external_wp_data_namespaceObject.useSelect)(store_store);
4897    (0,external_wp_keyboardShortcuts_namespaceObject.useShortcut)('core/editor/save', event => {
4898      event.preventDefault();
4899      /**
4900       * Do not save the post if post saving is locked.
4901       */
4902  
4903      if (isPostSavingLocked()) {
4904        return;
4905      } // TODO: This should be handled in the `savePost` effect in
4906      // considering `isSaveable`. See note on `isEditedPostSaveable`
4907      // selector about dirtiness and meta-boxes.
4908      //
4909      // See: `isEditedPostSaveable`
4910  
4911  
4912      if (!isEditedPostDirty()) {
4913        return;
4914      } // The text editor requires that editor blocks are updated for a
4915      // save to work correctly. Usually this happens when the textarea
4916      // for the code editors blurs, but the shortcut can be used without
4917      // blurring the textarea.
4918  
4919  
4920      if (resetBlocksOnSave) {
4921        const postEdits = getPostEdits();
4922  
4923        if (postEdits.content && typeof postEdits.content === 'string') {
4924          const blocks = (0,external_wp_blocks_namespaceObject.parse)(postEdits.content);
4925          resetEditorBlocks(blocks);
4926        }
4927      }
4928  
4929      savePost();
4930    });
4931    return null;
4932  }
4933  
4934  /* harmony default export */ var save_shortcut = (SaveShortcut);
4935  
4936  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/global-keyboard-shortcuts/visual-editor-shortcuts.js
4937  
4938  
4939  /**
4940   * WordPress dependencies
4941   */
4942  
4943  
4944  /**
4945   * Internal dependencies
4946   */
4947  
4948  
4949  
4950  
4951  function VisualEditorGlobalKeyboardShortcuts() {
4952    const {
4953      redo,
4954      undo
4955    } = (0,external_wp_data_namespaceObject.useDispatch)(store_store);
4956    (0,external_wp_keyboardShortcuts_namespaceObject.useShortcut)('core/editor/undo', event => {
4957      undo();
4958      event.preventDefault();
4959    });
4960    (0,external_wp_keyboardShortcuts_namespaceObject.useShortcut)('core/editor/redo', event => {
4961      redo();
4962      event.preventDefault();
4963    });
4964    return (0,external_wp_element_namespaceObject.createElement)(save_shortcut, null);
4965  }
4966  
4967  /* harmony default export */ var visual_editor_shortcuts = (VisualEditorGlobalKeyboardShortcuts);
4968  
4969  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/global-keyboard-shortcuts/text-editor-shortcuts.js
4970  
4971  
4972  /**
4973   * Internal dependencies
4974   */
4975  
4976  function TextEditorGlobalKeyboardShortcuts() {
4977    return (0,external_wp_element_namespaceObject.createElement)(save_shortcut, {
4978      resetBlocksOnSave: true
4979    });
4980  }
4981  
4982  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/global-keyboard-shortcuts/register-shortcuts.js
4983  
4984  
4985  /**
4986   * WordPress dependencies
4987   */
4988  
4989  
4990  
4991  
4992  
4993  
4994  function EditorKeyboardShortcutsRegister() {
4995    // Registering the shortcuts.
4996    const {
4997      registerShortcut
4998    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_keyboardShortcuts_namespaceObject.store);
4999    (0,external_wp_element_namespaceObject.useEffect)(() => {
5000      registerShortcut({
5001        name: 'core/editor/save',
5002        category: 'global',
5003        description: (0,external_wp_i18n_namespaceObject.__)('Save your changes.'),
5004        keyCombination: {
5005          modifier: 'primary',
5006          character: 's'
5007        }
5008      });
5009      registerShortcut({
5010        name: 'core/editor/undo',
5011        category: 'global',
5012        description: (0,external_wp_i18n_namespaceObject.__)('Undo your last changes.'),
5013        keyCombination: {
5014          modifier: 'primary',
5015          character: 'z'
5016        }
5017      });
5018      registerShortcut({
5019        name: 'core/editor/redo',
5020        category: 'global',
5021        description: (0,external_wp_i18n_namespaceObject.__)('Redo your last undo.'),
5022        keyCombination: {
5023          modifier: 'primaryShift',
5024          character: 'z'
5025        }
5026      });
5027    }, [registerShortcut]);
5028    return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockEditorKeyboardShortcuts.Register, null);
5029  }
5030  
5031  /* harmony default export */ var register_shortcuts = (EditorKeyboardShortcutsRegister);
5032  
5033  ;// CONCATENATED MODULE: external ["wp","components"]
5034  var external_wp_components_namespaceObject = window["wp"]["components"];
5035  ;// CONCATENATED MODULE: external ["wp","keycodes"]
5036  var external_wp_keycodes_namespaceObject = window["wp"]["keycodes"];
5037  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/redo.js
5038  
5039  
5040  /**
5041   * WordPress dependencies
5042   */
5043  
5044  const redo_redo = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
5045    xmlns: "http://www.w3.org/2000/svg",
5046    viewBox: "0 0 24 24"
5047  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
5048    d: "M15.6 6.5l-1.1 1 2.9 3.3H8c-.9 0-1.7.3-2.3.9-1.4 1.5-1.4 4.2-1.4 5.6v.2h1.5v-.3c0-1.1 0-3.5 1-4.5.3-.3.7-.5 1.3-.5h9.2L14.5 15l1.1 1.1 4.6-4.6-4.6-5z"
5049  }));
5050  /* harmony default export */ var library_redo = (redo_redo);
5051  
5052  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/undo.js
5053  
5054  
5055  /**
5056   * WordPress dependencies
5057   */
5058  
5059  const undo_undo = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
5060    xmlns: "http://www.w3.org/2000/svg",
5061    viewBox: "0 0 24 24"
5062  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
5063    d: "M18.3 11.7c-.6-.6-1.4-.9-2.3-.9H6.7l2.9-3.3-1.1-1-4.5 5L8.5 16l1-1-2.7-2.7H16c.5 0 .9.2 1.3.5 1 1 1 3.4 1 4.5v.3h1.5v-.2c0-1.5 0-4.3-1.5-5.7z"
5064  }));
5065  /* harmony default export */ var library_undo = (undo_undo);
5066  
5067  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/editor-history/redo.js
5068  
5069  
5070  
5071  /**
5072   * WordPress dependencies
5073   */
5074  
5075  
5076  
5077  
5078  
5079  
5080  /**
5081   * Internal dependencies
5082   */
5083  
5084  
5085  
5086  function EditorHistoryRedo(props, ref) {
5087    const hasRedo = (0,external_wp_data_namespaceObject.useSelect)(select => select(store_store).hasEditorRedo(), []);
5088    const {
5089      redo
5090    } = (0,external_wp_data_namespaceObject.useDispatch)(store_store);
5091    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, _extends({}, props, {
5092      ref: ref,
5093      icon: !(0,external_wp_i18n_namespaceObject.isRTL)() ? library_redo : library_undo
5094      /* translators: button label text should, if possible, be under 16 characters. */
5095      ,
5096      label: (0,external_wp_i18n_namespaceObject.__)('Redo'),
5097      shortcut: external_wp_keycodes_namespaceObject.displayShortcut.primaryShift('z') // If there are no redo levels we don't want to actually disable this
5098      // button, because it will remove focus for keyboard users.
5099      // See: https://github.com/WordPress/gutenberg/issues/3486
5100      ,
5101      "aria-disabled": !hasRedo,
5102      onClick: hasRedo ? redo : undefined,
5103      className: "editor-history__redo"
5104    }));
5105  }
5106  
5107  /* harmony default export */ var editor_history_redo = ((0,external_wp_element_namespaceObject.forwardRef)(EditorHistoryRedo));
5108  
5109  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/editor-history/undo.js
5110  
5111  
5112  
5113  /**
5114   * WordPress dependencies
5115   */
5116  
5117  
5118  
5119  
5120  
5121  
5122  /**
5123   * Internal dependencies
5124   */
5125  
5126  
5127  
5128  function EditorHistoryUndo(props, ref) {
5129    const hasUndo = (0,external_wp_data_namespaceObject.useSelect)(select => select(store_store).hasEditorUndo(), []);
5130    const {
5131      undo
5132    } = (0,external_wp_data_namespaceObject.useDispatch)(store_store);
5133    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, _extends({}, props, {
5134      ref: ref,
5135      icon: !(0,external_wp_i18n_namespaceObject.isRTL)() ? library_undo : library_redo
5136      /* translators: button label text should, if possible, be under 16 characters. */
5137      ,
5138      label: (0,external_wp_i18n_namespaceObject.__)('Undo'),
5139      shortcut: external_wp_keycodes_namespaceObject.displayShortcut.primary('z') // If there are no undo levels we don't want to actually disable this
5140      // button, because it will remove focus for keyboard users.
5141      // See: https://github.com/WordPress/gutenberg/issues/3486
5142      ,
5143      "aria-disabled": !hasUndo,
5144      onClick: hasUndo ? undo : undefined,
5145      className: "editor-history__undo"
5146    }));
5147  }
5148  
5149  /* harmony default export */ var editor_history_undo = ((0,external_wp_element_namespaceObject.forwardRef)(EditorHistoryUndo));
5150  
5151  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/template-validation-notice/index.js
5152  
5153  
5154  /**
5155   * WordPress dependencies
5156   */
5157  
5158  
5159  
5160  
5161  
5162  
5163  function TemplateValidationNotice(_ref) {
5164    let {
5165      isValid,
5166      ...props
5167    } = _ref;
5168  
5169    if (isValid) {
5170      return null;
5171    }
5172  
5173    const confirmSynchronization = () => {
5174      if ( // eslint-disable-next-line no-alert
5175      window.confirm((0,external_wp_i18n_namespaceObject.__)('Resetting the template may result in loss of content, do you want to continue?'))) {
5176        props.synchronizeTemplate();
5177      }
5178    };
5179  
5180    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Notice, {
5181      className: "editor-template-validation-notice",
5182      isDismissible: false,
5183      status: "warning",
5184      actions: [{
5185        label: (0,external_wp_i18n_namespaceObject.__)('Keep it as is'),
5186        onClick: props.resetTemplateValidity
5187      }, {
5188        label: (0,external_wp_i18n_namespaceObject.__)('Reset the template'),
5189        onClick: confirmSynchronization
5190      }]
5191    }, (0,external_wp_i18n_namespaceObject.__)('The content of your post doesn’t match the template assigned to your post type.'));
5192  }
5193  
5194  /* harmony default export */ var template_validation_notice = ((0,external_wp_compose_namespaceObject.compose)([(0,external_wp_data_namespaceObject.withSelect)(select => ({
5195    isValid: select(external_wp_blockEditor_namespaceObject.store).isValidTemplate()
5196  })), (0,external_wp_data_namespaceObject.withDispatch)(dispatch => {
5197    const {
5198      setTemplateValidity,
5199      synchronizeTemplate
5200    } = dispatch(external_wp_blockEditor_namespaceObject.store);
5201    return {
5202      resetTemplateValidity: () => setTemplateValidity(true),
5203      synchronizeTemplate
5204    };
5205  })])(TemplateValidationNotice));
5206  
5207  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/editor-notices/index.js
5208  
5209  
5210  /**
5211   * External dependencies
5212   */
5213  
5214  /**
5215   * WordPress dependencies
5216   */
5217  
5218  
5219  
5220  
5221  
5222  /**
5223   * Internal dependencies
5224   */
5225  
5226  
5227  function EditorNotices(_ref) {
5228    let {
5229      notices,
5230      onRemove
5231    } = _ref;
5232    const dismissibleNotices = (0,external_lodash_namespaceObject.filter)(notices, {
5233      isDismissible: true,
5234      type: 'default'
5235    });
5236    const nonDismissibleNotices = (0,external_lodash_namespaceObject.filter)(notices, {
5237      isDismissible: false,
5238      type: 'default'
5239    });
5240    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.NoticeList, {
5241      notices: nonDismissibleNotices,
5242      className: "components-editor-notices__pinned"
5243    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.NoticeList, {
5244      notices: dismissibleNotices,
5245      className: "components-editor-notices__dismissible",
5246      onRemove: onRemove
5247    }, (0,external_wp_element_namespaceObject.createElement)(template_validation_notice, null)));
5248  }
5249  /* harmony default export */ var editor_notices = ((0,external_wp_compose_namespaceObject.compose)([(0,external_wp_data_namespaceObject.withSelect)(select => ({
5250    notices: select(external_wp_notices_namespaceObject.store).getNotices()
5251  })), (0,external_wp_data_namespaceObject.withDispatch)(dispatch => ({
5252    onRemove: dispatch(external_wp_notices_namespaceObject.store).removeNotice
5253  }))])(EditorNotices));
5254  
5255  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/editor-snackbars/index.js
5256  
5257  
5258  /**
5259   * External dependencies
5260   */
5261  
5262  /**
5263   * WordPress dependencies
5264   */
5265  
5266  
5267  
5268  
5269  function EditorSnackbars() {
5270    const notices = (0,external_wp_data_namespaceObject.useSelect)(select => select(external_wp_notices_namespaceObject.store).getNotices(), []);
5271    const {
5272      removeNotice
5273    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_notices_namespaceObject.store);
5274    const snackbarNotices = (0,external_lodash_namespaceObject.filter)(notices, {
5275      type: 'snackbar'
5276    });
5277    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SnackbarList, {
5278      notices: snackbarNotices,
5279      className: "components-editor-notices__snackbar",
5280      onRemove: removeNotice
5281    });
5282  }
5283  
5284  ;// CONCATENATED MODULE: external ["wp","htmlEntities"]
5285  var external_wp_htmlEntities_namespaceObject = window["wp"]["htmlEntities"];
5286  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/entities-saved-states/entity-record-item.js
5287  
5288  
5289  /**
5290   * WordPress dependencies
5291   */
5292  
5293  
5294  
5295  
5296  
5297  
5298  
5299  /**
5300   * Internal dependencies
5301   */
5302  
5303  
5304  function EntityRecordItem(_ref) {
5305    let {
5306      record,
5307      checked,
5308      onChange,
5309      closePanel
5310    } = _ref;
5311    const {
5312      name,
5313      kind,
5314      title,
5315      key
5316    } = record;
5317    const parentBlockId = (0,external_wp_data_namespaceObject.useSelect)(select => {
5318      var _blocks$;
5319  
5320      // Get entity's blocks.
5321      const {
5322        blocks = []
5323      } = select(external_wp_coreData_namespaceObject.store).getEditedEntityRecord(kind, name, key); // Get parents of the entity's first block.
5324  
5325      const parents = select(external_wp_blockEditor_namespaceObject.store).getBlockParents((_blocks$ = blocks[0]) === null || _blocks$ === void 0 ? void 0 : _blocks$.clientId); // Return closest parent block's clientId.
5326  
5327      return parents[parents.length - 1];
5328    }, []); // Handle templates that might use default descriptive titles.
5329  
5330    const entityRecordTitle = (0,external_wp_data_namespaceObject.useSelect)(select => {
5331      if ('postType' !== kind || 'wp_template' !== name) {
5332        return title;
5333      }
5334  
5335      const template = select(external_wp_coreData_namespaceObject.store).getEditedEntityRecord(kind, name, key);
5336      return select(store_store).__experimentalGetTemplateInfo(template).title;
5337    }, [name, kind, title, key]);
5338    const isSelected = (0,external_wp_data_namespaceObject.useSelect)(select => {
5339      const selectedBlockId = select(external_wp_blockEditor_namespaceObject.store).getSelectedBlockClientId();
5340      return selectedBlockId === parentBlockId;
5341    }, [parentBlockId]);
5342    const isSelectedText = isSelected ? (0,external_wp_i18n_namespaceObject.__)('Selected') : (0,external_wp_i18n_namespaceObject.__)('Select');
5343    const {
5344      selectBlock
5345    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_blockEditor_namespaceObject.store);
5346    const selectParentBlock = (0,external_wp_element_namespaceObject.useCallback)(() => selectBlock(parentBlockId), [parentBlockId]);
5347    const selectAndDismiss = (0,external_wp_element_namespaceObject.useCallback)(() => {
5348      selectBlock(parentBlockId);
5349      closePanel();
5350    }, [parentBlockId]);
5351    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelRow, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.CheckboxControl, {
5352      label: (0,external_wp_element_namespaceObject.createElement)("strong", null, (0,external_wp_htmlEntities_namespaceObject.decodeEntities)(entityRecordTitle) || (0,external_wp_i18n_namespaceObject.__)('Untitled')),
5353      checked: checked,
5354      onChange: onChange
5355    }), parentBlockId ? (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
5356      onClick: selectParentBlock,
5357      className: "entities-saved-states__find-entity",
5358      disabled: isSelected
5359    }, isSelectedText), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
5360      onClick: selectAndDismiss,
5361      className: "entities-saved-states__find-entity-small",
5362      disabled: isSelected
5363    }, isSelectedText)) : null);
5364  }
5365  
5366  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/entities-saved-states/entity-type-list.js
5367  
5368  
5369  /**
5370   * External dependencies
5371   */
5372  
5373  /**
5374   * WordPress dependencies
5375   */
5376  
5377  
5378  
5379  
5380  
5381  /**
5382   * Internal dependencies
5383   */
5384  
5385  
5386  
5387  function getEntityDescription(entity, count) {
5388    switch (entity) {
5389      case 'site':
5390        return 1 === count ? (0,external_wp_i18n_namespaceObject.__)('This change will affect your whole site.') : (0,external_wp_i18n_namespaceObject.__)('These changes will affect your whole site.');
5391  
5392      case 'wp_template':
5393        return (0,external_wp_i18n_namespaceObject.__)('This change will affect pages and posts that use this template.');
5394  
5395      case 'page':
5396      case 'post':
5397        return (0,external_wp_i18n_namespaceObject.__)('The following content has been modified.');
5398    }
5399  }
5400  
5401  function EntityTypeList(_ref) {
5402    let {
5403      list,
5404      unselectedEntities,
5405      setUnselectedEntities,
5406      closePanel
5407    } = _ref;
5408    const count = list.length;
5409    const firstRecord = list[0];
5410    const entityConfig = (0,external_wp_data_namespaceObject.useSelect)(select => select(external_wp_coreData_namespaceObject.store).getEntityConfig(firstRecord.kind, firstRecord.name), [firstRecord.kind, firstRecord.name]);
5411    const {
5412      name
5413    } = firstRecord;
5414    let entityLabel = entityConfig.label;
5415  
5416    if (name === 'wp_template_part') {
5417      entityLabel = 1 === count ? (0,external_wp_i18n_namespaceObject.__)('Template Part') : (0,external_wp_i18n_namespaceObject.__)('Template Parts');
5418    } // Set description based on type of entity.
5419  
5420  
5421    const description = getEntityDescription(name, count);
5422    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
5423      title: entityLabel,
5424      initialOpen: true
5425    }, description && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelRow, null, description), list.map(record => {
5426      return (0,external_wp_element_namespaceObject.createElement)(EntityRecordItem, {
5427        key: record.key || record.property,
5428        record: record,
5429        checked: !(0,external_lodash_namespaceObject.some)(unselectedEntities, elt => elt.kind === record.kind && elt.name === record.name && elt.key === record.key && elt.property === record.property),
5430        onChange: value => setUnselectedEntities(record, value),
5431        closePanel: closePanel
5432      });
5433    }));
5434  }
5435  
5436  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/entities-saved-states/index.js
5437  
5438  
5439  
5440  /**
5441   * External dependencies
5442   */
5443  
5444  /**
5445   * WordPress dependencies
5446   */
5447  
5448  
5449  
5450  
5451  
5452  
5453  
5454  
5455  
5456  /**
5457   * Internal dependencies
5458   */
5459  
5460  
5461  const TRANSLATED_SITE_PROPERTIES = {
5462    title: (0,external_wp_i18n_namespaceObject.__)('Title'),
5463    description: (0,external_wp_i18n_namespaceObject.__)('Tagline'),
5464    site_logo: (0,external_wp_i18n_namespaceObject.__)('Logo'),
5465    site_icon: (0,external_wp_i18n_namespaceObject.__)('Icon'),
5466    show_on_front: (0,external_wp_i18n_namespaceObject.__)('Show on front'),
5467    page_on_front: (0,external_wp_i18n_namespaceObject.__)('Page on front')
5468  };
5469  const PUBLISH_ON_SAVE_ENTITIES = [{
5470    kind: 'postType',
5471    name: 'wp_navigation'
5472  }];
5473  function EntitiesSavedStates(_ref) {
5474    let {
5475      close
5476    } = _ref;
5477    const saveButtonRef = (0,external_wp_element_namespaceObject.useRef)();
5478    const {
5479      dirtyEntityRecords
5480    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
5481      const dirtyRecords = select(external_wp_coreData_namespaceObject.store).__experimentalGetDirtyEntityRecords(); // Remove site object and decouple into its edited pieces.
5482  
5483  
5484      const dirtyRecordsWithoutSite = dirtyRecords.filter(record => !(record.kind === 'root' && record.name === 'site'));
5485      const siteEdits = select(external_wp_coreData_namespaceObject.store).getEntityRecordEdits('root', 'site');
5486      const siteEditsAsEntities = [];
5487  
5488      for (const property in siteEdits) {
5489        siteEditsAsEntities.push({
5490          kind: 'root',
5491          name: 'site',
5492          title: TRANSLATED_SITE_PROPERTIES[property] || property,
5493          property
5494        });
5495      }
5496  
5497      const dirtyRecordsWithSiteItems = [...dirtyRecordsWithoutSite, ...siteEditsAsEntities];
5498      return {
5499        dirtyEntityRecords: dirtyRecordsWithSiteItems
5500      };
5501    }, []);
5502    const {
5503      editEntityRecord,
5504      saveEditedEntityRecord,
5505      __experimentalSaveSpecifiedEntityEdits: saveSpecifiedEntityEdits
5506    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_coreData_namespaceObject.store);
5507    const {
5508      __unstableMarkLastChangeAsPersistent
5509    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_blockEditor_namespaceObject.store);
5510    const {
5511      createSuccessNotice,
5512      createErrorNotice
5513    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_notices_namespaceObject.store); // To group entities by type.
5514  
5515    const partitionedSavables = (0,external_lodash_namespaceObject.groupBy)(dirtyEntityRecords, 'name'); // Sort entity groups.
5516  
5517    const {
5518      site: siteSavables,
5519      wp_template: templateSavables,
5520      wp_template_part: templatePartSavables,
5521      ...contentSavables
5522    } = partitionedSavables;
5523    const sortedPartitionedSavables = [siteSavables, templateSavables, templatePartSavables, ...Object.values(contentSavables)].filter(Array.isArray); // Unchecked entities to be ignored by save function.
5524  
5525    const [unselectedEntities, _setUnselectedEntities] = (0,external_wp_element_namespaceObject.useState)([]);
5526  
5527    const setUnselectedEntities = (_ref2, checked) => {
5528      let {
5529        kind,
5530        name,
5531        key,
5532        property
5533      } = _ref2;
5534  
5535      if (checked) {
5536        _setUnselectedEntities(unselectedEntities.filter(elt => elt.kind !== kind || elt.name !== name || elt.key !== key || elt.property !== property));
5537      } else {
5538        _setUnselectedEntities([...unselectedEntities, {
5539          kind,
5540          name,
5541          key,
5542          property
5543        }]);
5544      }
5545    };
5546  
5547    const saveCheckedEntities = () => {
5548      const entitiesToSave = dirtyEntityRecords.filter(_ref3 => {
5549        let {
5550          kind,
5551          name,
5552          key,
5553          property
5554        } = _ref3;
5555        return !(0,external_lodash_namespaceObject.some)(unselectedEntities, elt => elt.kind === kind && elt.name === name && elt.key === key && elt.property === property);
5556      });
5557      close(entitiesToSave);
5558      const siteItemsToSave = [];
5559      const pendingSavedRecords = [];
5560      entitiesToSave.forEach(_ref4 => {
5561        let {
5562          kind,
5563          name,
5564          key,
5565          property
5566        } = _ref4;
5567  
5568        if ('root' === kind && 'site' === name) {
5569          siteItemsToSave.push(property);
5570        } else {
5571          if (PUBLISH_ON_SAVE_ENTITIES.some(typeToPublish => typeToPublish.kind === kind && typeToPublish.name === name)) {
5572            editEntityRecord(kind, name, key, {
5573              status: 'publish'
5574            });
5575          }
5576  
5577          pendingSavedRecords.push(saveEditedEntityRecord(kind, name, key));
5578        }
5579      });
5580  
5581      if (siteItemsToSave.length) {
5582        pendingSavedRecords.push(saveSpecifiedEntityEdits('root', 'site', undefined, siteItemsToSave));
5583      }
5584  
5585      __unstableMarkLastChangeAsPersistent();
5586  
5587      Promise.all(pendingSavedRecords).then(values => {
5588        if (values.some(value => typeof value === 'undefined')) {
5589          createErrorNotice((0,external_wp_i18n_namespaceObject.__)('Saving failed.'));
5590        } else {
5591          createSuccessNotice((0,external_wp_i18n_namespaceObject.__)('Site updated.'), {
5592            type: 'snackbar'
5593          });
5594        }
5595      }).catch(error => createErrorNotice(`${(0,external_wp_i18n_namespaceObject.__)('Saving failed.')} $error}`));
5596    }; // Explicitly define this with no argument passed.  Using `close` on
5597    // its own will use the event object in place of the expected saved entities.
5598  
5599  
5600    const dismissPanel = (0,external_wp_element_namespaceObject.useCallback)(() => close(), [close]);
5601    const [saveDialogRef, saveDialogProps] = (0,external_wp_compose_namespaceObject.__experimentalUseDialog)({
5602      onClose: () => dismissPanel()
5603    });
5604    return (0,external_wp_element_namespaceObject.createElement)("div", _extends({
5605      ref: saveDialogRef
5606    }, saveDialogProps, {
5607      className: "entities-saved-states__panel"
5608    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Flex, {
5609      className: "entities-saved-states__panel-header",
5610      gap: 2
5611    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.FlexItem, {
5612      isBlock: true,
5613      as: external_wp_components_namespaceObject.Button,
5614      ref: saveButtonRef,
5615      variant: "primary",
5616      disabled: dirtyEntityRecords.length - unselectedEntities.length === 0,
5617      onClick: saveCheckedEntities,
5618      className: "editor-entities-saved-states__save-button"
5619    }, (0,external_wp_i18n_namespaceObject.__)('Save')), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.FlexItem, {
5620      isBlock: true,
5621      as: external_wp_components_namespaceObject.Button,
5622      variant: "secondary",
5623      onClick: dismissPanel
5624    }, (0,external_wp_i18n_namespaceObject.__)('Cancel'))), (0,external_wp_element_namespaceObject.createElement)("div", {
5625      className: "entities-saved-states__text-prompt"
5626    }, (0,external_wp_element_namespaceObject.createElement)("strong", null, (0,external_wp_i18n_namespaceObject.__)('Are you ready to save?')), (0,external_wp_element_namespaceObject.createElement)("p", null, (0,external_wp_i18n_namespaceObject.__)('The following changes have been made to your site, templates, and content.'))), sortedPartitionedSavables.map(list => {
5627      return (0,external_wp_element_namespaceObject.createElement)(EntityTypeList, {
5628        key: list[0].name,
5629        list: list,
5630        closePanel: dismissPanel,
5631        unselectedEntities: unselectedEntities,
5632        setUnselectedEntities: setUnselectedEntities
5633      });
5634    }));
5635  }
5636  
5637  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/error-boundary/index.js
5638  
5639  
5640  /**
5641   * WordPress dependencies
5642   */
5643  
5644  
5645  
5646  
5647  
5648  
5649  /**
5650   * Internal dependencies
5651   */
5652  
5653  
5654  
5655  function CopyButton(_ref) {
5656    let {
5657      text,
5658      children
5659    } = _ref;
5660    const ref = (0,external_wp_compose_namespaceObject.useCopyToClipboard)(text);
5661    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
5662      variant: "secondary",
5663      ref: ref
5664    }, children);
5665  }
5666  
5667  class ErrorBoundary extends external_wp_element_namespaceObject.Component {
5668    constructor() {
5669      super(...arguments);
5670      this.reboot = this.reboot.bind(this);
5671      this.getContent = this.getContent.bind(this);
5672      this.state = {
5673        error: null
5674      };
5675    }
5676  
5677    componentDidCatch(error) {
5678      this.setState({
5679        error
5680      });
5681    }
5682  
5683    reboot() {
5684      this.props.onError();
5685    }
5686  
5687    getContent() {
5688      try {
5689        // While `select` in a component is generally discouraged, it is
5690        // used here because it (a) reduces the chance of data loss in the
5691        // case of additional errors by performing a direct retrieval and
5692        // (b) avoids the performance cost associated with unnecessary
5693        // content serialization throughout the lifetime of a non-erroring
5694        // application.
5695        return (0,external_wp_data_namespaceObject.select)(store_store).getEditedPostContent();
5696      } catch (error) {}
5697    }
5698  
5699    render() {
5700      const {
5701        error
5702      } = this.state;
5703  
5704      if (!error) {
5705        return this.props.children;
5706      }
5707  
5708      return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.Warning, {
5709        className: "editor-error-boundary",
5710        actions: [(0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
5711          key: "recovery",
5712          onClick: this.reboot,
5713          variant: "secondary"
5714        }, (0,external_wp_i18n_namespaceObject.__)('Attempt Recovery')), (0,external_wp_element_namespaceObject.createElement)(CopyButton, {
5715          key: "copy-post",
5716          text: this.getContent
5717        }, (0,external_wp_i18n_namespaceObject.__)('Copy Post Text')), (0,external_wp_element_namespaceObject.createElement)(CopyButton, {
5718          key: "copy-error",
5719          text: error.stack
5720        }, (0,external_wp_i18n_namespaceObject.__)('Copy Error'))]
5721      }, (0,external_wp_i18n_namespaceObject.__)('The editor has encountered an unexpected error.'));
5722    }
5723  
5724  }
5725  
5726  /* harmony default export */ var error_boundary = (ErrorBoundary);
5727  
5728  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/local-autosave-monitor/index.js
5729  
5730  
5731  /**
5732   * External dependencies
5733   */
5734  
5735  /**
5736   * WordPress dependencies
5737   */
5738  
5739  
5740  
5741  
5742  
5743  
5744  
5745  /**
5746   * Internal dependencies
5747   */
5748  
5749  
5750  
5751  
5752  const requestIdleCallback = window.requestIdleCallback ? window.requestIdleCallback : window.requestAnimationFrame;
5753  /**
5754   * Function which returns true if the current environment supports browser
5755   * sessionStorage, or false otherwise. The result of this function is cached and
5756   * reused in subsequent invocations.
5757   */
5758  
5759  const hasSessionStorageSupport = (0,external_lodash_namespaceObject.once)(() => {
5760    try {
5761      // Private Browsing in Safari 10 and earlier will throw an error when
5762      // attempting to set into sessionStorage. The test here is intentional in
5763      // causing a thrown error as condition bailing from local autosave.
5764      window.sessionStorage.setItem('__wpEditorTestSessionStorage', '');
5765      window.sessionStorage.removeItem('__wpEditorTestSessionStorage');
5766      return true;
5767    } catch (error) {
5768      return false;
5769    }
5770  });
5771  /**
5772   * Custom hook which manages the creation of a notice prompting the user to
5773   * restore a local autosave, if one exists.
5774   */
5775  
5776  function useAutosaveNotice() {
5777    const {
5778      postId,
5779      isEditedPostNew,
5780      hasRemoteAutosave
5781    } = (0,external_wp_data_namespaceObject.useSelect)(select => ({
5782      postId: select(store_store).getCurrentPostId(),
5783      isEditedPostNew: select(store_store).isEditedPostNew(),
5784      hasRemoteAutosave: !!select(store_store).getEditorSettings().autosave
5785    }), []);
5786    const {
5787      getEditedPostAttribute
5788    } = (0,external_wp_data_namespaceObject.useSelect)(store_store);
5789    const {
5790      createWarningNotice,
5791      removeNotice
5792    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_notices_namespaceObject.store);
5793    const {
5794      editPost,
5795      resetEditorBlocks
5796    } = (0,external_wp_data_namespaceObject.useDispatch)(store_store);
5797    (0,external_wp_element_namespaceObject.useEffect)(() => {
5798      let localAutosave = localAutosaveGet(postId, isEditedPostNew);
5799  
5800      if (!localAutosave) {
5801        return;
5802      }
5803  
5804      try {
5805        localAutosave = JSON.parse(localAutosave);
5806      } catch (error) {
5807        // Not usable if it can't be parsed.
5808        return;
5809      }
5810  
5811      const {
5812        post_title: title,
5813        content,
5814        excerpt
5815      } = localAutosave;
5816      const edits = {
5817        title,
5818        content,
5819        excerpt
5820      };
5821      {
5822        // Only display a notice if there is a difference between what has been
5823        // saved and that which is stored in sessionStorage.
5824        const hasDifference = Object.keys(edits).some(key => {
5825          return edits[key] !== getEditedPostAttribute(key);
5826        });
5827  
5828        if (!hasDifference) {
5829          // If there is no difference, it can be safely ejected from storage.
5830          localAutosaveClear(postId, isEditedPostNew);
5831          return;
5832        }
5833      }
5834  
5835      if (hasRemoteAutosave) {
5836        return;
5837      }
5838  
5839      const noticeId = (0,external_lodash_namespaceObject.uniqueId)('wpEditorAutosaveRestore');
5840      createWarningNotice((0,external_wp_i18n_namespaceObject.__)('The backup of this post in your browser is different from the version below.'), {
5841        id: noticeId,
5842        actions: [{
5843          label: (0,external_wp_i18n_namespaceObject.__)('Restore the backup'),
5844  
5845          onClick() {
5846            editPost((0,external_lodash_namespaceObject.omit)(edits, ['content']));
5847            resetEditorBlocks((0,external_wp_blocks_namespaceObject.parse)(edits.content));
5848            removeNotice(noticeId);
5849          }
5850  
5851        }]
5852      });
5853    }, [isEditedPostNew, postId]);
5854  }
5855  /**
5856   * Custom hook which ejects a local autosave after a successful save occurs.
5857   */
5858  
5859  
5860  function useAutosavePurge() {
5861    const {
5862      postId,
5863      isEditedPostNew,
5864      isDirty,
5865      isAutosaving,
5866      didError
5867    } = (0,external_wp_data_namespaceObject.useSelect)(select => ({
5868      postId: select(store_store).getCurrentPostId(),
5869      isEditedPostNew: select(store_store).isEditedPostNew(),
5870      isDirty: select(store_store).isEditedPostDirty(),
5871      isAutosaving: select(store_store).isAutosavingPost(),
5872      didError: select(store_store).didPostSaveRequestFail()
5873    }), []);
5874    const lastIsDirty = (0,external_wp_element_namespaceObject.useRef)(isDirty);
5875    const lastIsAutosaving = (0,external_wp_element_namespaceObject.useRef)(isAutosaving);
5876    (0,external_wp_element_namespaceObject.useEffect)(() => {
5877      if (!didError && (lastIsAutosaving.current && !isAutosaving || lastIsDirty.current && !isDirty)) {
5878        localAutosaveClear(postId, isEditedPostNew);
5879      }
5880  
5881      lastIsDirty.current = isDirty;
5882      lastIsAutosaving.current = isAutosaving;
5883    }, [isDirty, isAutosaving, didError]); // Once the isEditedPostNew changes from true to false, let's clear the auto-draft autosave.
5884  
5885    const wasEditedPostNew = (0,external_wp_compose_namespaceObject.usePrevious)(isEditedPostNew);
5886    const prevPostId = (0,external_wp_compose_namespaceObject.usePrevious)(postId);
5887    (0,external_wp_element_namespaceObject.useEffect)(() => {
5888      if (prevPostId === postId && wasEditedPostNew && !isEditedPostNew) {
5889        localAutosaveClear(postId, true);
5890      }
5891    }, [isEditedPostNew, postId]);
5892  }
5893  
5894  function LocalAutosaveMonitor() {
5895    const {
5896      autosave
5897    } = (0,external_wp_data_namespaceObject.useDispatch)(store_store);
5898    const deferredAutosave = (0,external_wp_element_namespaceObject.useCallback)(() => {
5899      requestIdleCallback(() => autosave({
5900        local: true
5901      }));
5902    }, []);
5903    useAutosaveNotice();
5904    useAutosavePurge();
5905    const {
5906      localAutosaveInterval
5907    } = (0,external_wp_data_namespaceObject.useSelect)(select => ({
5908      localAutosaveInterval: select(store_store).getEditorSettings().localAutosaveInterval
5909    }), []);
5910    return (0,external_wp_element_namespaceObject.createElement)(autosave_monitor, {
5911      interval: localAutosaveInterval,
5912      autosave: deferredAutosave
5913    });
5914  }
5915  
5916  /* harmony default export */ var local_autosave_monitor = ((0,external_wp_compose_namespaceObject.ifCondition)(hasSessionStorageSupport)(LocalAutosaveMonitor));
5917  
5918  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/page-attributes/check.js
5919  /**
5920   * External dependencies
5921   */
5922  
5923  /**
5924   * WordPress dependencies
5925   */
5926  
5927  
5928  
5929  /**
5930   * Internal dependencies
5931   */
5932  
5933  
5934  function PageAttributesCheck(_ref) {
5935    let {
5936      children
5937    } = _ref;
5938    const postType = (0,external_wp_data_namespaceObject.useSelect)(select => {
5939      const {
5940        getEditedPostAttribute
5941      } = select(store_store);
5942      const {
5943        getPostType
5944      } = select(external_wp_coreData_namespaceObject.store);
5945      return getPostType(getEditedPostAttribute('type'));
5946    }, []);
5947    const supportsPageAttributes = (0,external_lodash_namespaceObject.get)(postType, ['supports', 'page-attributes'], false); // Only render fields if post type supports page attributes or available templates exist.
5948  
5949    if (!supportsPageAttributes) {
5950      return null;
5951    }
5952  
5953    return children;
5954  }
5955  /* harmony default export */ var page_attributes_check = (PageAttributesCheck);
5956  
5957  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-type-support-check/index.js
5958  /**
5959   * External dependencies
5960   */
5961  
5962  /**
5963   * WordPress dependencies
5964   */
5965  
5966  
5967  
5968  /**
5969   * Internal dependencies
5970   */
5971  
5972  
5973  /**
5974   * A component which renders its own children only if the current editor post
5975   * type supports one of the given `supportKeys` prop.
5976   *
5977   * @param {Object}            props             Props.
5978   * @param {string}            [props.postType]  Current post type.
5979   * @param {WPElement}         props.children    Children to be rendered if post
5980   *                                              type supports.
5981   * @param {(string|string[])} props.supportKeys String or string array of keys
5982   *                                              to test.
5983   *
5984   * @return {WPComponent} The component to be rendered.
5985   */
5986  
5987  function PostTypeSupportCheck(_ref) {
5988    let {
5989      postType,
5990      children,
5991      supportKeys
5992    } = _ref;
5993    let isSupported = true;
5994  
5995    if (postType) {
5996      isSupported = (0,external_lodash_namespaceObject.some)((0,external_lodash_namespaceObject.castArray)(supportKeys), key => !!postType.supports[key]);
5997    }
5998  
5999    if (!isSupported) {
6000      return null;
6001    }
6002  
6003    return children;
6004  }
6005  /* harmony default export */ var post_type_support_check = ((0,external_wp_data_namespaceObject.withSelect)(select => {
6006    const {
6007      getEditedPostAttribute
6008    } = select(store_store);
6009    const {
6010      getPostType
6011    } = select(external_wp_coreData_namespaceObject.store);
6012    return {
6013      postType: getPostType(getEditedPostAttribute('type'))
6014    };
6015  })(PostTypeSupportCheck));
6016  
6017  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/page-attributes/order.js
6018  
6019  
6020  /**
6021   * External dependencies
6022   */
6023  
6024  /**
6025   * WordPress dependencies
6026   */
6027  
6028  
6029  
6030  
6031  
6032  
6033  /**
6034   * Internal dependencies
6035   */
6036  
6037  
6038  
6039  const PageAttributesOrder = _ref => {
6040    let {
6041      onUpdateOrder,
6042      order = 0
6043    } = _ref;
6044    const [orderInput, setOrderInput] = (0,external_wp_element_namespaceObject.useState)(null);
6045  
6046    const setUpdatedOrder = value => {
6047      setOrderInput(value);
6048      const newOrder = Number(value);
6049  
6050      if (Number.isInteger(newOrder) && (0,external_lodash_namespaceObject.invoke)(value, ['trim']) !== '') {
6051        onUpdateOrder(Number(value));
6052      }
6053    };
6054  
6055    const value = orderInput === null ? order : orderInput;
6056    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TextControl, {
6057      className: "editor-page-attributes__order",
6058      type: "number",
6059      label: (0,external_wp_i18n_namespaceObject.__)('Order'),
6060      value: value,
6061      onChange: setUpdatedOrder,
6062      size: 6,
6063      onBlur: () => {
6064        setOrderInput(null);
6065      }
6066    });
6067  };
6068  
6069  function PageAttributesOrderWithChecks(props) {
6070    return (0,external_wp_element_namespaceObject.createElement)(post_type_support_check, {
6071      supportKeys: "page-attributes"
6072    }, (0,external_wp_element_namespaceObject.createElement)(PageAttributesOrder, props));
6073  }
6074  
6075  /* harmony default export */ var order = ((0,external_wp_compose_namespaceObject.compose)([(0,external_wp_data_namespaceObject.withSelect)(select => {
6076    return {
6077      order: select(store_store).getEditedPostAttribute('menu_order')
6078    };
6079  }), (0,external_wp_data_namespaceObject.withDispatch)(dispatch => ({
6080    onUpdateOrder(order) {
6081      dispatch(store_store).editPost({
6082        menu_order: order
6083      });
6084    }
6085  
6086  }))])(PageAttributesOrderWithChecks));
6087  
6088  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/utils/terms.js
6089  /**
6090   * External dependencies
6091   */
6092  
6093  /**
6094   * Returns terms in a tree form.
6095   *
6096   * @param {Array} flatTerms Array of terms in flat format.
6097   *
6098   * @return {Array} Array of terms in tree format.
6099   */
6100  
6101  function buildTermsTree(flatTerms) {
6102    const flatTermsWithParentAndChildren = flatTerms.map(term => {
6103      return {
6104        children: [],
6105        parent: null,
6106        ...term
6107      };
6108    });
6109    const termsByParent = (0,external_lodash_namespaceObject.groupBy)(flatTermsWithParentAndChildren, 'parent');
6110  
6111    if (termsByParent.null && termsByParent.null.length) {
6112      return flatTermsWithParentAndChildren;
6113    }
6114  
6115    const fillWithChildren = terms => {
6116      return terms.map(term => {
6117        const children = termsByParent[term.id];
6118        return { ...term,
6119          children: children && children.length ? fillWithChildren(children) : []
6120        };
6121      });
6122    };
6123  
6124    return fillWithChildren(termsByParent['0'] || []);
6125  } // Lodash unescape function handles &#39; but not &#039; which may be return in some API requests.
6126  
6127  const unescapeString = arg => {
6128    return (0,external_lodash_namespaceObject.unescape)(arg.replace('&#039;', "'"));
6129  };
6130  /**
6131   * Returns a term object with name unescaped.
6132   * The unescape of the name property is done using lodash unescape function.
6133   *
6134   * @param {Object} term The term object to unescape.
6135   *
6136   * @return {Object} Term object with name property unescaped.
6137   */
6138  
6139  const unescapeTerm = term => {
6140    return { ...term,
6141      name: unescapeString(term.name)
6142    };
6143  };
6144  /**
6145   * Returns an array of term objects with names unescaped.
6146   * The unescape of each term is performed using the unescapeTerm function.
6147   *
6148   * @param {Object[]} terms Array of term objects to unescape.
6149   *
6150   * @return {Object[]} Array of term objects unescaped.
6151   */
6152  
6153  const unescapeTerms = terms => {
6154    return (0,external_lodash_namespaceObject.map)(terms, unescapeTerm);
6155  };
6156  
6157  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/page-attributes/parent.js
6158  
6159  
6160  /**
6161   * External dependencies
6162   */
6163  
6164  /**
6165   * WordPress dependencies
6166   */
6167  
6168  
6169  
6170  
6171  
6172  
6173  
6174  /**
6175   * Internal dependencies
6176   */
6177  
6178  
6179  
6180  
6181  function getTitle(post) {
6182    var _post$title;
6183  
6184    return post !== null && post !== void 0 && (_post$title = post.title) !== null && _post$title !== void 0 && _post$title.rendered ? (0,external_wp_htmlEntities_namespaceObject.decodeEntities)(post.title.rendered) : `#$post.id} (${(0,external_wp_i18n_namespaceObject.__)('no title')})`;
6185  }
6186  
6187  const getItemPriority = (name, searchValue) => {
6188    const normalizedName = (0,external_lodash_namespaceObject.deburr)(name).toLowerCase();
6189    const normalizedSearch = (0,external_lodash_namespaceObject.deburr)(searchValue).toLowerCase();
6190  
6191    if (normalizedName === normalizedSearch) {
6192      return 0;
6193    }
6194  
6195    if (normalizedName.startsWith(normalizedSearch)) {
6196      return normalizedName.length;
6197    }
6198  
6199    return Infinity;
6200  };
6201  function PageAttributesParent() {
6202    const {
6203      editPost
6204    } = (0,external_wp_data_namespaceObject.useDispatch)(store_store);
6205    const [fieldValue, setFieldValue] = (0,external_wp_element_namespaceObject.useState)(false);
6206    const {
6207      parentPost,
6208      parentPostId,
6209      items,
6210      postType
6211    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
6212      const {
6213        getPostType,
6214        getEntityRecords,
6215        getEntityRecord
6216      } = select(external_wp_coreData_namespaceObject.store);
6217      const {
6218        getCurrentPostId,
6219        getEditedPostAttribute
6220      } = select(store_store);
6221      const postTypeSlug = getEditedPostAttribute('type');
6222      const pageId = getEditedPostAttribute('parent');
6223      const pType = getPostType(postTypeSlug);
6224      const postId = getCurrentPostId();
6225      const isHierarchical = (0,external_lodash_namespaceObject.get)(pType, ['hierarchical'], false);
6226      const query = {
6227        per_page: 100,
6228        exclude: postId,
6229        parent_exclude: postId,
6230        orderby: 'menu_order',
6231        order: 'asc',
6232        _fields: 'id,title,parent'
6233      }; // Perform a search when the field is changed.
6234  
6235      if (!!fieldValue) {
6236        query.search = fieldValue;
6237      }
6238  
6239      return {
6240        parentPostId: pageId,
6241        parentPost: pageId ? getEntityRecord('postType', postTypeSlug, pageId) : null,
6242        items: isHierarchical ? getEntityRecords('postType', postTypeSlug, query) : [],
6243        postType: pType
6244      };
6245    }, [fieldValue]);
6246    const isHierarchical = (0,external_lodash_namespaceObject.get)(postType, ['hierarchical'], false);
6247    const parentPageLabel = (0,external_lodash_namespaceObject.get)(postType, ['labels', 'parent_item_colon']);
6248    const pageItems = items || [];
6249    const parentOptions = (0,external_wp_element_namespaceObject.useMemo)(() => {
6250      const getOptionsFromTree = function (tree) {
6251        let level = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;
6252        const mappedNodes = tree.map(treeNode => [{
6253          value: treeNode.id,
6254          label: (0,external_lodash_namespaceObject.repeat)('— ', level) + (0,external_lodash_namespaceObject.unescape)(treeNode.name),
6255          rawName: treeNode.name
6256        }, ...getOptionsFromTree(treeNode.children || [], level + 1)]);
6257        const sortedNodes = mappedNodes.sort((_ref, _ref2) => {
6258          let [a] = _ref;
6259          let [b] = _ref2;
6260          const priorityA = getItemPriority(a.rawName, fieldValue);
6261          const priorityB = getItemPriority(b.rawName, fieldValue);
6262          return priorityA >= priorityB ? 1 : -1;
6263        });
6264        return (0,external_lodash_namespaceObject.flatten)(sortedNodes);
6265      };
6266  
6267      let tree = pageItems.map(item => ({
6268        id: item.id,
6269        parent: item.parent,
6270        name: getTitle(item)
6271      })); // Only build a hierarchical tree when not searching.
6272  
6273      if (!fieldValue) {
6274        tree = buildTermsTree(tree);
6275      }
6276  
6277      const opts = getOptionsFromTree(tree); // Ensure the current parent is in the options list.
6278  
6279      const optsHasParent = (0,external_lodash_namespaceObject.find)(opts, item => item.value === parentPostId);
6280  
6281      if (parentPost && !optsHasParent) {
6282        opts.unshift({
6283          value: parentPostId,
6284          label: getTitle(parentPost)
6285        });
6286      }
6287  
6288      return opts;
6289    }, [pageItems, fieldValue]);
6290  
6291    if (!isHierarchical || !parentPageLabel) {
6292      return null;
6293    }
6294    /**
6295     * Handle user input.
6296     *
6297     * @param {string} inputValue The current value of the input field.
6298     */
6299  
6300  
6301    const handleKeydown = inputValue => {
6302      setFieldValue(inputValue);
6303    };
6304    /**
6305     * Handle author selection.
6306     *
6307     * @param {Object} selectedPostId The selected Author.
6308     */
6309  
6310  
6311    const handleChange = selectedPostId => {
6312      editPost({
6313        parent: selectedPostId
6314      });
6315    };
6316  
6317    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ComboboxControl, {
6318      className: "editor-page-attributes__parent",
6319      label: parentPageLabel,
6320      value: parentPostId,
6321      options: parentOptions,
6322      onFilterValueChange: (0,external_lodash_namespaceObject.debounce)(handleKeydown, 300),
6323      onChange: handleChange
6324    });
6325  }
6326  /* harmony default export */ var page_attributes_parent = (PageAttributesParent);
6327  
6328  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-template/index.js
6329  
6330  
6331  /**
6332   * External dependencies
6333   */
6334  
6335  /**
6336   * WordPress dependencies
6337   */
6338  
6339  
6340  
6341  
6342  
6343  /**
6344   * Internal dependencies
6345   */
6346  
6347  
6348  function PostTemplate(_ref) {
6349    let {} = _ref;
6350    const {
6351      availableTemplates,
6352      selectedTemplate,
6353      isViewable
6354    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
6355      var _getPostType$viewable, _getPostType;
6356  
6357      const {
6358        getEditedPostAttribute,
6359        getEditorSettings,
6360        getCurrentPostType
6361      } = select(store_store);
6362      const {
6363        getPostType
6364      } = select(external_wp_coreData_namespaceObject.store);
6365      return {
6366        selectedTemplate: getEditedPostAttribute('template'),
6367        availableTemplates: getEditorSettings().availableTemplates,
6368        isViewable: (_getPostType$viewable = (_getPostType = getPostType(getCurrentPostType())) === null || _getPostType === void 0 ? void 0 : _getPostType.viewable) !== null && _getPostType$viewable !== void 0 ? _getPostType$viewable : false
6369      };
6370    }, []);
6371    const {
6372      editPost
6373    } = (0,external_wp_data_namespaceObject.useDispatch)(store_store);
6374  
6375    if (!isViewable || (0,external_lodash_namespaceObject.isEmpty)(availableTemplates)) {
6376      return null;
6377    }
6378  
6379    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SelectControl, {
6380      label: (0,external_wp_i18n_namespaceObject.__)('Template:'),
6381      value: selectedTemplate,
6382      onChange: templateSlug => {
6383        editPost({
6384          template: templateSlug || ''
6385        });
6386      },
6387      options: (0,external_lodash_namespaceObject.map)(availableTemplates, (templateName, templateSlug) => ({
6388        value: templateSlug,
6389        label: templateName
6390      }))
6391    });
6392  }
6393  /* harmony default export */ var post_template = (PostTemplate);
6394  
6395  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-author/constants.js
6396  const AUTHORS_QUERY = {
6397    who: 'authors',
6398    per_page: 50,
6399    _fields: 'id,name',
6400    context: 'view' // Allows non-admins to perform requests.
6401  
6402  };
6403  
6404  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-author/combobox.js
6405  
6406  
6407  /**
6408   * External dependencies
6409   */
6410  
6411  /**
6412   * WordPress dependencies
6413   */
6414  
6415  
6416  
6417  
6418  
6419  
6420  
6421  /**
6422   * Internal dependencies
6423   */
6424  
6425  
6426  
6427  
6428  function PostAuthorCombobox() {
6429    const [fieldValue, setFieldValue] = (0,external_wp_element_namespaceObject.useState)();
6430    const {
6431      authorId,
6432      isLoading,
6433      authors,
6434      postAuthor
6435    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
6436      const {
6437        getUser,
6438        getUsers,
6439        isResolving
6440      } = select(external_wp_coreData_namespaceObject.store);
6441      const {
6442        getEditedPostAttribute
6443      } = select(store_store);
6444      const author = getUser(getEditedPostAttribute('author'), {
6445        context: 'view'
6446      });
6447      const query = { ...AUTHORS_QUERY
6448      };
6449  
6450      if (fieldValue) {
6451        query.search = fieldValue;
6452      }
6453  
6454      return {
6455        authorId: getEditedPostAttribute('author'),
6456        postAuthor: author,
6457        authors: getUsers(query),
6458        isLoading: isResolving('core', 'getUsers', [query])
6459      };
6460    }, [fieldValue]);
6461    const {
6462      editPost
6463    } = (0,external_wp_data_namespaceObject.useDispatch)(store_store);
6464    const authorOptions = (0,external_wp_element_namespaceObject.useMemo)(() => {
6465      const fetchedAuthors = (authors !== null && authors !== void 0 ? authors : []).map(author => {
6466        return {
6467          value: author.id,
6468          label: (0,external_wp_htmlEntities_namespaceObject.decodeEntities)(author.name)
6469        };
6470      }); // Ensure the current author is included in the dropdown list.
6471  
6472      const foundAuthor = fetchedAuthors.findIndex(_ref => {
6473        let {
6474          value
6475        } = _ref;
6476        return (postAuthor === null || postAuthor === void 0 ? void 0 : postAuthor.id) === value;
6477      });
6478  
6479      if (foundAuthor < 0 && postAuthor) {
6480        return [{
6481          value: postAuthor.id,
6482          label: (0,external_wp_htmlEntities_namespaceObject.decodeEntities)(postAuthor.name)
6483        }, ...fetchedAuthors];
6484      }
6485  
6486      return fetchedAuthors;
6487    }, [authors, postAuthor]);
6488    /**
6489     * Handle author selection.
6490     *
6491     * @param {number} postAuthorId The selected Author.
6492     */
6493  
6494    const handleSelect = postAuthorId => {
6495      if (!postAuthorId) {
6496        return;
6497      }
6498  
6499      editPost({
6500        author: postAuthorId
6501      });
6502    };
6503    /**
6504     * Handle user input.
6505     *
6506     * @param {string} inputValue The current value of the input field.
6507     */
6508  
6509  
6510    const handleKeydown = inputValue => {
6511      setFieldValue(inputValue);
6512    };
6513  
6514    if (!postAuthor) {
6515      return null;
6516    }
6517  
6518    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ComboboxControl, {
6519      label: (0,external_wp_i18n_namespaceObject.__)('Author'),
6520      options: authorOptions,
6521      value: authorId,
6522      onFilterValueChange: (0,external_lodash_namespaceObject.debounce)(handleKeydown, 300),
6523      onChange: handleSelect,
6524      isLoading: isLoading,
6525      allowReset: false
6526    });
6527  }
6528  
6529  /* harmony default export */ var combobox = (PostAuthorCombobox);
6530  
6531  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-author/select.js
6532  
6533  
6534  /**
6535   * WordPress dependencies
6536   */
6537  
6538  
6539  
6540  
6541  
6542  
6543  /**
6544   * Internal dependencies
6545   */
6546  
6547  
6548  
6549  
6550  function PostAuthorSelect() {
6551    const {
6552      editPost
6553    } = (0,external_wp_data_namespaceObject.useDispatch)(store_store);
6554    const {
6555      postAuthor,
6556      authors
6557    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
6558      return {
6559        postAuthor: select(store_store).getEditedPostAttribute('author'),
6560        authors: select(external_wp_coreData_namespaceObject.store).getUsers(AUTHORS_QUERY)
6561      };
6562    }, []);
6563    const authorOptions = (0,external_wp_element_namespaceObject.useMemo)(() => {
6564      return (authors !== null && authors !== void 0 ? authors : []).map(author => {
6565        return {
6566          value: author.id,
6567          label: (0,external_wp_htmlEntities_namespaceObject.decodeEntities)(author.name)
6568        };
6569      });
6570    }, [authors]);
6571  
6572    const setAuthorId = value => {
6573      const author = Number(value);
6574      editPost({
6575        author
6576      });
6577    };
6578  
6579    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SelectControl, {
6580      className: "post-author-selector",
6581      label: (0,external_wp_i18n_namespaceObject.__)('Author'),
6582      options: authorOptions,
6583      onChange: setAuthorId,
6584      value: postAuthor
6585    });
6586  }
6587  
6588  /* harmony default export */ var post_author_select = (PostAuthorSelect);
6589  
6590  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-author/index.js
6591  
6592  
6593  /**
6594   * WordPress dependencies
6595   */
6596  
6597  
6598  /**
6599   * Internal dependencies
6600   */
6601  
6602  
6603  
6604  
6605  const minimumUsersForCombobox = 25;
6606  
6607  function PostAuthor() {
6608    const showCombobox = (0,external_wp_data_namespaceObject.useSelect)(select => {
6609      const authors = select(external_wp_coreData_namespaceObject.store).getUsers(AUTHORS_QUERY);
6610      return (authors === null || authors === void 0 ? void 0 : authors.length) >= minimumUsersForCombobox;
6611    }, []);
6612  
6613    if (showCombobox) {
6614      return (0,external_wp_element_namespaceObject.createElement)(combobox, null);
6615    }
6616  
6617    return (0,external_wp_element_namespaceObject.createElement)(post_author_select, null);
6618  }
6619  
6620  /* harmony default export */ var post_author = (PostAuthor);
6621  
6622  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-author/check.js
6623  
6624  
6625  /**
6626   * External dependencies
6627   */
6628  
6629  /**
6630   * WordPress dependencies
6631   */
6632  
6633  
6634  
6635  /**
6636   * Internal dependencies
6637   */
6638  
6639  
6640  
6641  
6642  function PostAuthorCheck(_ref) {
6643    let {
6644      children
6645    } = _ref;
6646    const {
6647      hasAssignAuthorAction,
6648      hasAuthors
6649    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
6650      const post = select(store_store).getCurrentPost();
6651      const authors = select(external_wp_coreData_namespaceObject.store).getUsers(AUTHORS_QUERY);
6652      return {
6653        hasAssignAuthorAction: (0,external_lodash_namespaceObject.get)(post, ['_links', 'wp:action-assign-author'], false),
6654        hasAuthors: (authors === null || authors === void 0 ? void 0 : authors.length) >= 1
6655      };
6656    }, []);
6657  
6658    if (!hasAssignAuthorAction || !hasAuthors) {
6659      return null;
6660    }
6661  
6662    return (0,external_wp_element_namespaceObject.createElement)(post_type_support_check, {
6663      supportKeys: "author"
6664    }, children);
6665  }
6666  
6667  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-comments/index.js
6668  
6669  
6670  /**
6671   * WordPress dependencies
6672   */
6673  
6674  
6675  
6676  
6677  /**
6678   * Internal dependencies
6679   */
6680  
6681  
6682  
6683  function PostComments(_ref) {
6684    let {
6685      commentStatus = 'open',
6686      ...props
6687    } = _ref;
6688  
6689    const onToggleComments = () => props.editPost({
6690      comment_status: commentStatus === 'open' ? 'closed' : 'open'
6691    });
6692  
6693    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.CheckboxControl, {
6694      label: (0,external_wp_i18n_namespaceObject.__)('Allow comments'),
6695      checked: commentStatus === 'open',
6696      onChange: onToggleComments
6697    });
6698  }
6699  
6700  /* harmony default export */ var post_comments = ((0,external_wp_compose_namespaceObject.compose)([(0,external_wp_data_namespaceObject.withSelect)(select => {
6701    return {
6702      commentStatus: select(store_store).getEditedPostAttribute('comment_status')
6703    };
6704  }), (0,external_wp_data_namespaceObject.withDispatch)(dispatch => ({
6705    editPost: dispatch(store_store).editPost
6706  }))])(PostComments));
6707  
6708  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-excerpt/index.js
6709  
6710  
6711  /**
6712   * WordPress dependencies
6713   */
6714  
6715  
6716  
6717  
6718  /**
6719   * Internal dependencies
6720   */
6721  
6722  
6723  
6724  function PostExcerpt(_ref) {
6725    let {
6726      excerpt,
6727      onUpdateExcerpt
6728    } = _ref;
6729    return (0,external_wp_element_namespaceObject.createElement)("div", {
6730      className: "editor-post-excerpt"
6731    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TextareaControl, {
6732      label: (0,external_wp_i18n_namespaceObject.__)('Write an excerpt (optional)'),
6733      className: "editor-post-excerpt__textarea",
6734      onChange: value => onUpdateExcerpt(value),
6735      value: excerpt
6736    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ExternalLink, {
6737      href: (0,external_wp_i18n_namespaceObject.__)('https://wordpress.org/support/article/settings-sidebar/#excerpt')
6738    }, (0,external_wp_i18n_namespaceObject.__)('Learn more about manual excerpts')));
6739  }
6740  
6741  /* harmony default export */ var post_excerpt = ((0,external_wp_compose_namespaceObject.compose)([(0,external_wp_data_namespaceObject.withSelect)(select => {
6742    return {
6743      excerpt: select(store_store).getEditedPostAttribute('excerpt')
6744    };
6745  }), (0,external_wp_data_namespaceObject.withDispatch)(dispatch => ({
6746    onUpdateExcerpt(excerpt) {
6747      dispatch(store_store).editPost({
6748        excerpt
6749      });
6750    }
6751  
6752  }))])(PostExcerpt));
6753  
6754  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-excerpt/check.js
6755  
6756  
6757  
6758  /**
6759   * Internal dependencies
6760   */
6761  
6762  
6763  function PostExcerptCheck(props) {
6764    return (0,external_wp_element_namespaceObject.createElement)(post_type_support_check, _extends({}, props, {
6765      supportKeys: "excerpt"
6766    }));
6767  }
6768  
6769  /* harmony default export */ var post_excerpt_check = (PostExcerptCheck);
6770  
6771  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/theme-support-check/index.js
6772  /**
6773   * External dependencies
6774   */
6775  
6776  /**
6777   * WordPress dependencies
6778   */
6779  
6780  
6781  
6782  /**
6783   * Internal dependencies
6784   */
6785  
6786  
6787  function ThemeSupportCheck(_ref) {
6788    let {
6789      themeSupports,
6790      children,
6791      postType,
6792      supportKeys
6793    } = _ref;
6794    const isSupported = (0,external_lodash_namespaceObject.some)((0,external_lodash_namespaceObject.castArray)(supportKeys), key => {
6795      const supported = (0,external_lodash_namespaceObject.get)(themeSupports, [key], false); // 'post-thumbnails' can be boolean or an array of post types.
6796      // In the latter case, we need to verify `postType` exists
6797      // within `supported`. If `postType` isn't passed, then the check
6798      // should fail.
6799  
6800      if ('post-thumbnails' === key && (0,external_lodash_namespaceObject.isArray)(supported)) {
6801        return (0,external_lodash_namespaceObject.includes)(supported, postType);
6802      }
6803  
6804      return supported;
6805    });
6806  
6807    if (!isSupported) {
6808      return null;
6809    }
6810  
6811    return children;
6812  }
6813  /* harmony default export */ var theme_support_check = ((0,external_wp_data_namespaceObject.withSelect)(select => {
6814    const {
6815      getThemeSupports
6816    } = select(external_wp_coreData_namespaceObject.store);
6817    const {
6818      getEditedPostAttribute
6819    } = select(store_store);
6820    return {
6821      postType: getEditedPostAttribute('type'),
6822      themeSupports: getThemeSupports()
6823    };
6824  })(ThemeSupportCheck));
6825  
6826  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-featured-image/check.js
6827  
6828  
6829  
6830  /**
6831   * Internal dependencies
6832   */
6833  
6834  
6835  
6836  function PostFeaturedImageCheck(props) {
6837    return (0,external_wp_element_namespaceObject.createElement)(theme_support_check, {
6838      supportKeys: "post-thumbnails"
6839    }, (0,external_wp_element_namespaceObject.createElement)(post_type_support_check, _extends({}, props, {
6840      supportKeys: "thumbnail"
6841    })));
6842  }
6843  
6844  /* harmony default export */ var post_featured_image_check = (PostFeaturedImageCheck);
6845  
6846  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-featured-image/index.js
6847  
6848  
6849  /**
6850   * External dependencies
6851   */
6852  
6853  /**
6854   * WordPress dependencies
6855   */
6856  
6857  
6858  
6859  
6860  
6861  
6862  
6863  
6864  /**
6865   * Internal dependencies
6866   */
6867  
6868  
6869  
6870  const ALLOWED_MEDIA_TYPES = ['image']; // Used when labels from post type were not yet loaded or when they are not present.
6871  
6872  const DEFAULT_FEATURE_IMAGE_LABEL = (0,external_wp_i18n_namespaceObject.__)('Featured image');
6873  
6874  const DEFAULT_SET_FEATURE_IMAGE_LABEL = (0,external_wp_i18n_namespaceObject.__)('Set featured image');
6875  
6876  const DEFAULT_REMOVE_FEATURE_IMAGE_LABEL = (0,external_wp_i18n_namespaceObject.__)('Remove image');
6877  
6878  function PostFeaturedImage(_ref) {
6879    var _media$media_details$, _media$media_details$2;
6880  
6881    let {
6882      currentPostId,
6883      featuredImageId,
6884      onUpdateImage,
6885      onDropImage,
6886      onRemoveImage,
6887      media,
6888      postType,
6889      noticeUI
6890    } = _ref;
6891    const postLabel = (0,external_lodash_namespaceObject.get)(postType, ['labels'], {});
6892    const instructions = (0,external_wp_element_namespaceObject.createElement)("p", null, (0,external_wp_i18n_namespaceObject.__)('To edit the featured image, you need permission to upload media.'));
6893    let mediaWidth, mediaHeight, mediaSourceUrl;
6894  
6895    if (media) {
6896      const mediaSize = (0,external_wp_hooks_namespaceObject.applyFilters)('editor.PostFeaturedImage.imageSize', 'post-thumbnail', media.id, currentPostId);
6897  
6898      if ((0,external_lodash_namespaceObject.has)(media, ['media_details', 'sizes', mediaSize])) {
6899        // Use mediaSize when available.
6900        mediaWidth = media.media_details.sizes[mediaSize].width;
6901        mediaHeight = media.media_details.sizes[mediaSize].height;
6902        mediaSourceUrl = media.media_details.sizes[mediaSize].source_url;
6903      } else {
6904        // Get fallbackMediaSize if mediaSize is not available.
6905        const fallbackMediaSize = (0,external_wp_hooks_namespaceObject.applyFilters)('editor.PostFeaturedImage.imageSize', 'thumbnail', media.id, currentPostId);
6906  
6907        if ((0,external_lodash_namespaceObject.has)(media, ['media_details', 'sizes', fallbackMediaSize])) {
6908          // Use fallbackMediaSize when mediaSize is not available.
6909          mediaWidth = media.media_details.sizes[fallbackMediaSize].width;
6910          mediaHeight = media.media_details.sizes[fallbackMediaSize].height;
6911          mediaSourceUrl = media.media_details.sizes[fallbackMediaSize].source_url;
6912        } else {
6913          // Use full image size when mediaFallbackSize and mediaSize are not available.
6914          mediaWidth = media.media_details.width;
6915          mediaHeight = media.media_details.height;
6916          mediaSourceUrl = media.source_url;
6917        }
6918      }
6919    }
6920  
6921    return (0,external_wp_element_namespaceObject.createElement)(post_featured_image_check, null, noticeUI, (0,external_wp_element_namespaceObject.createElement)("div", {
6922      className: "editor-post-featured-image"
6923    }, media && (0,external_wp_element_namespaceObject.createElement)("div", {
6924      id: `editor-post-featured-image-$featuredImageId}-describedby`,
6925      className: "hidden"
6926    }, media.alt_text && (0,external_wp_i18n_namespaceObject.sprintf)( // Translators: %s: The selected image alt text.
6927    (0,external_wp_i18n_namespaceObject.__)('Current image: %s'), media.alt_text), !media.alt_text && (0,external_wp_i18n_namespaceObject.sprintf)( // Translators: %s: The selected image filename.
6928    (0,external_wp_i18n_namespaceObject.__)('The current image has no alternative text. The file name is: %s'), ((_media$media_details$ = media.media_details.sizes) === null || _media$media_details$ === void 0 ? void 0 : (_media$media_details$2 = _media$media_details$.full) === null || _media$media_details$2 === void 0 ? void 0 : _media$media_details$2.file) || media.slug)), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.MediaUploadCheck, {
6929      fallback: instructions
6930    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.MediaUpload, {
6931      title: postLabel.featured_image || DEFAULT_FEATURE_IMAGE_LABEL,
6932      onSelect: onUpdateImage,
6933      unstableFeaturedImageFlow: true,
6934      allowedTypes: ALLOWED_MEDIA_TYPES,
6935      modalClass: "editor-post-featured-image__media-modal",
6936      render: _ref2 => {
6937        let {
6938          open
6939        } = _ref2;
6940        return (0,external_wp_element_namespaceObject.createElement)("div", {
6941          className: "editor-post-featured-image__container"
6942        }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
6943          className: !featuredImageId ? 'editor-post-featured-image__toggle' : 'editor-post-featured-image__preview',
6944          onClick: open,
6945          "aria-label": !featuredImageId ? null : (0,external_wp_i18n_namespaceObject.__)('Edit or update the image'),
6946          "aria-describedby": !featuredImageId ? null : `editor-post-featured-image-$featuredImageId}-describedby`
6947        }, !!featuredImageId && media && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ResponsiveWrapper, {
6948          naturalWidth: mediaWidth,
6949          naturalHeight: mediaHeight,
6950          isInline: true
6951        }, (0,external_wp_element_namespaceObject.createElement)("img", {
6952          src: mediaSourceUrl,
6953          alt: ""
6954        })), !!featuredImageId && !media && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Spinner, null), !featuredImageId && (postLabel.set_featured_image || DEFAULT_SET_FEATURE_IMAGE_LABEL)), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.DropZone, {
6955          onFilesDrop: onDropImage
6956        }));
6957      },
6958      value: featuredImageId
6959    })), !!featuredImageId && media && !media.isLoading && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.MediaUploadCheck, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.MediaUpload, {
6960      title: postLabel.featured_image || DEFAULT_FEATURE_IMAGE_LABEL,
6961      onSelect: onUpdateImage,
6962      unstableFeaturedImageFlow: true,
6963      allowedTypes: ALLOWED_MEDIA_TYPES,
6964      modalClass: "editor-post-featured-image__media-modal",
6965      render: _ref3 => {
6966        let {
6967          open
6968        } = _ref3;
6969        return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
6970          onClick: open,
6971          variant: "secondary"
6972        }, (0,external_wp_i18n_namespaceObject.__)('Replace Image'));
6973      }
6974    })), !!featuredImageId && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.MediaUploadCheck, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
6975      onClick: onRemoveImage,
6976      variant: "link",
6977      isDestructive: true
6978    }, postLabel.remove_featured_image || DEFAULT_REMOVE_FEATURE_IMAGE_LABEL))));
6979  }
6980  
6981  const applyWithSelect = (0,external_wp_data_namespaceObject.withSelect)(select => {
6982    const {
6983      getMedia,
6984      getPostType
6985    } = select(external_wp_coreData_namespaceObject.store);
6986    const {
6987      getCurrentPostId,
6988      getEditedPostAttribute
6989    } = select(store_store);
6990    const featuredImageId = getEditedPostAttribute('featured_media');
6991    return {
6992      media: featuredImageId ? getMedia(featuredImageId, {
6993        context: 'view'
6994      }) : null,
6995      currentPostId: getCurrentPostId(),
6996      postType: getPostType(getEditedPostAttribute('type')),
6997      featuredImageId
6998    };
6999  });
7000  const applyWithDispatch = (0,external_wp_data_namespaceObject.withDispatch)((dispatch, _ref4, _ref5) => {
7001    let {
7002      noticeOperations
7003    } = _ref4;
7004    let {
7005      select
7006    } = _ref5;
7007    const {
7008      editPost
7009    } = dispatch(store_store);
7010    return {
7011      onUpdateImage(image) {
7012        editPost({
7013          featured_media: image.id
7014        });
7015      },
7016  
7017      onDropImage(filesList) {
7018        select(external_wp_blockEditor_namespaceObject.store).getSettings().mediaUpload({
7019          allowedTypes: ['image'],
7020          filesList,
7021  
7022          onFileChange(_ref6) {
7023            let [image] = _ref6;
7024            editPost({
7025              featured_media: image.id
7026            });
7027          },
7028  
7029          onError(message) {
7030            noticeOperations.removeAllNotices();
7031            noticeOperations.createErrorNotice(message);
7032          }
7033  
7034        });
7035      },
7036  
7037      onRemoveImage() {
7038        editPost({
7039          featured_media: 0
7040        });
7041      }
7042  
7043    };
7044  });
7045  /* harmony default export */ var post_featured_image = ((0,external_wp_compose_namespaceObject.compose)(external_wp_components_namespaceObject.withNotices, applyWithSelect, applyWithDispatch, (0,external_wp_components_namespaceObject.withFilters)('editor.PostFeaturedImage'))(PostFeaturedImage));
7046  
7047  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-format/check.js
7048  
7049  
7050  
7051  /**
7052   * WordPress dependencies
7053   */
7054  
7055  /**
7056   * Internal dependencies
7057   */
7058  
7059  
7060  
7061  
7062  function PostFormatCheck(_ref) {
7063    let {
7064      disablePostFormats,
7065      ...props
7066    } = _ref;
7067    return !disablePostFormats && (0,external_wp_element_namespaceObject.createElement)(post_type_support_check, _extends({}, props, {
7068      supportKeys: "post-formats"
7069    }));
7070  }
7071  
7072  /* harmony default export */ var post_format_check = ((0,external_wp_data_namespaceObject.withSelect)(select => {
7073    const editorSettings = select(store_store).getEditorSettings();
7074    return {
7075      disablePostFormats: editorSettings.disablePostFormats
7076    };
7077  })(PostFormatCheck));
7078  
7079  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-format/index.js
7080  
7081  
7082  /**
7083   * External dependencies
7084   */
7085  
7086  /**
7087   * WordPress dependencies
7088   */
7089  
7090  
7091  
7092  
7093  
7094  
7095  /**
7096   * Internal dependencies
7097   */
7098  
7099  
7100   // All WP post formats, sorted alphabetically by translated name.
7101  
7102  const POST_FORMATS = [{
7103    id: 'aside',
7104    caption: (0,external_wp_i18n_namespaceObject.__)('Aside')
7105  }, {
7106    id: 'audio',
7107    caption: (0,external_wp_i18n_namespaceObject.__)('Audio')
7108  }, {
7109    id: 'chat',
7110    caption: (0,external_wp_i18n_namespaceObject.__)('Chat')
7111  }, {
7112    id: 'gallery',
7113    caption: (0,external_wp_i18n_namespaceObject.__)('Gallery')
7114  }, {
7115    id: 'image',
7116    caption: (0,external_wp_i18n_namespaceObject.__)('Image')
7117  }, {
7118    id: 'link',
7119    caption: (0,external_wp_i18n_namespaceObject.__)('Link')
7120  }, {
7121    id: 'quote',
7122    caption: (0,external_wp_i18n_namespaceObject.__)('Quote')
7123  }, {
7124    id: 'standard',
7125    caption: (0,external_wp_i18n_namespaceObject.__)('Standard')
7126  }, {
7127    id: 'status',
7128    caption: (0,external_wp_i18n_namespaceObject.__)('Status')
7129  }, {
7130    id: 'video',
7131    caption: (0,external_wp_i18n_namespaceObject.__)('Video')
7132  }].sort((a, b) => {
7133    const normalizedA = a.caption.toUpperCase();
7134    const normalizedB = b.caption.toUpperCase();
7135  
7136    if (normalizedA < normalizedB) {
7137      return -1;
7138    }
7139  
7140    if (normalizedA > normalizedB) {
7141      return 1;
7142    }
7143  
7144    return 0;
7145  });
7146  function PostFormat() {
7147    const instanceId = (0,external_wp_compose_namespaceObject.useInstanceId)(PostFormat);
7148    const postFormatSelectorId = `post-format-selector-$instanceId}`;
7149    const {
7150      postFormat,
7151      suggestedFormat,
7152      supportedFormats
7153    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
7154      const {
7155        getEditedPostAttribute,
7156        getSuggestedPostFormat
7157      } = select(store_store);
7158  
7159      const _postFormat = getEditedPostAttribute('format');
7160  
7161      const themeSupports = select(external_wp_coreData_namespaceObject.store).getThemeSupports();
7162      return {
7163        postFormat: _postFormat !== null && _postFormat !== void 0 ? _postFormat : 'standard',
7164        suggestedFormat: getSuggestedPostFormat(),
7165        supportedFormats: themeSupports.formats
7166      };
7167    }, []);
7168    const formats = POST_FORMATS.filter(format => {
7169      // Ensure current format is always in the set.
7170      // The current format may not be a format supported by the theme.
7171      return (0,external_lodash_namespaceObject.includes)(supportedFormats, format.id) || postFormat === format.id;
7172    });
7173    const suggestion = (0,external_lodash_namespaceObject.find)(formats, format => format.id === suggestedFormat);
7174    const {
7175      editPost
7176    } = (0,external_wp_data_namespaceObject.useDispatch)(store_store);
7177  
7178    const onUpdatePostFormat = format => editPost({
7179      format
7180    });
7181  
7182    return (0,external_wp_element_namespaceObject.createElement)(post_format_check, null, (0,external_wp_element_namespaceObject.createElement)("div", {
7183      className: "editor-post-format"
7184    }, (0,external_wp_element_namespaceObject.createElement)("div", {
7185      className: "editor-post-format__content"
7186    }, (0,external_wp_element_namespaceObject.createElement)("label", {
7187      htmlFor: postFormatSelectorId
7188    }, (0,external_wp_i18n_namespaceObject.__)('Post Format')), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SelectControl, {
7189      value: postFormat,
7190      onChange: format => onUpdatePostFormat(format),
7191      id: postFormatSelectorId,
7192      options: formats.map(format => ({
7193        label: format.caption,
7194        value: format.id
7195      }))
7196    })), suggestion && suggestion.id !== postFormat && (0,external_wp_element_namespaceObject.createElement)("div", {
7197      className: "editor-post-format__suggestion"
7198    }, (0,external_wp_i18n_namespaceObject.__)('Suggestion:'), ' ', (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
7199      variant: "link",
7200      onClick: () => onUpdatePostFormat(suggestion.id)
7201    }, (0,external_wp_i18n_namespaceObject.sprintf)(
7202    /* translators: %s: post format */
7203    (0,external_wp_i18n_namespaceObject.__)('Apply format: %s'), suggestion.caption)))));
7204  }
7205  
7206  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/backup.js
7207  
7208  
7209  /**
7210   * WordPress dependencies
7211   */
7212  
7213  const backup = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
7214    xmlns: "http://www.w3.org/2000/svg",
7215    viewBox: "0 0 24 24"
7216  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
7217    d: "M5.5 12h1.75l-2.5 3-2.5-3H4a8 8 0 113.134 6.35l.907-1.194A6.5 6.5 0 105.5 12zm9.53 1.97l-2.28-2.28V8.5a.75.75 0 00-1.5 0V12a.747.747 0 00.218.529l1.282-.84-1.28.842 2.5 2.5a.75.75 0 101.06-1.061z"
7218  }));
7219  /* harmony default export */ var library_backup = (backup);
7220  
7221  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-last-revision/check.js
7222  
7223  
7224  /**
7225   * WordPress dependencies
7226   */
7227  
7228  /**
7229   * Internal dependencies
7230   */
7231  
7232  
7233  
7234  function PostLastRevisionCheck(_ref) {
7235    let {
7236      lastRevisionId,
7237      revisionsCount,
7238      children
7239    } = _ref;
7240  
7241    if (!lastRevisionId || revisionsCount < 2) {
7242      return null;
7243    }
7244  
7245    return (0,external_wp_element_namespaceObject.createElement)(post_type_support_check, {
7246      supportKeys: "revisions"
7247    }, children);
7248  }
7249  /* harmony default export */ var post_last_revision_check = ((0,external_wp_data_namespaceObject.withSelect)(select => {
7250    const {
7251      getCurrentPostLastRevisionId,
7252      getCurrentPostRevisionsCount
7253    } = select(store_store);
7254    return {
7255      lastRevisionId: getCurrentPostLastRevisionId(),
7256      revisionsCount: getCurrentPostRevisionsCount()
7257    };
7258  })(PostLastRevisionCheck));
7259  
7260  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-last-revision/index.js
7261  
7262  
7263  /**
7264   * WordPress dependencies
7265   */
7266  
7267  
7268  
7269  
7270  
7271  /**
7272   * Internal dependencies
7273   */
7274  
7275  
7276  
7277  
7278  function LastRevision(_ref) {
7279    let {
7280      lastRevisionId,
7281      revisionsCount
7282    } = _ref;
7283    return (0,external_wp_element_namespaceObject.createElement)(post_last_revision_check, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
7284      href: (0,external_wp_url_namespaceObject.addQueryArgs)('revision.php', {
7285        revision: lastRevisionId,
7286        gutenberg: true
7287      }),
7288      className: "editor-post-last-revision__title",
7289      icon: library_backup
7290    }, (0,external_wp_i18n_namespaceObject.sprintf)(
7291    /* translators: %d: number of revisions */
7292    (0,external_wp_i18n_namespaceObject._n)('%d Revision', '%d Revisions', revisionsCount), revisionsCount)));
7293  }
7294  
7295  /* harmony default export */ var post_last_revision = ((0,external_wp_data_namespaceObject.withSelect)(select => {
7296    const {
7297      getCurrentPostLastRevisionId,
7298      getCurrentPostRevisionsCount
7299    } = select(store_store);
7300    return {
7301      lastRevisionId: getCurrentPostLastRevisionId(),
7302      revisionsCount: getCurrentPostRevisionsCount()
7303    };
7304  })(LastRevision));
7305  
7306  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-locked-modal/index.js
7307  
7308  
7309  /**
7310   * External dependencies
7311   */
7312  
7313  /**
7314   * WordPress dependencies
7315   */
7316  
7317  
7318  
7319  
7320  
7321  
7322  
7323  
7324  
7325  /**
7326   * Internal dependencies
7327   */
7328  
7329  
7330  function PostLockedModal() {
7331    const instanceId = (0,external_wp_compose_namespaceObject.useInstanceId)(PostLockedModal);
7332    const hookName = 'core/editor/post-locked-modal-' + instanceId;
7333    const {
7334      autosave,
7335      updatePostLock
7336    } = (0,external_wp_data_namespaceObject.useDispatch)(store_store);
7337    const {
7338      isLocked,
7339      isTakeover,
7340      user,
7341      postId,
7342      postLockUtils,
7343      activePostLock,
7344      postType,
7345      previewLink
7346    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
7347      const {
7348        isPostLocked,
7349        isPostLockTakeover,
7350        getPostLockUser,
7351        getCurrentPostId,
7352        getActivePostLock,
7353        getEditedPostAttribute,
7354        getEditedPostPreviewLink,
7355        getEditorSettings
7356      } = select(store_store);
7357      const {
7358        getPostType
7359      } = select(external_wp_coreData_namespaceObject.store);
7360      return {
7361        isLocked: isPostLocked(),
7362        isTakeover: isPostLockTakeover(),
7363        user: getPostLockUser(),
7364        postId: getCurrentPostId(),
7365        postLockUtils: getEditorSettings().postLockUtils,
7366        activePostLock: getActivePostLock(),
7367        postType: getPostType(getEditedPostAttribute('type')),
7368        previewLink: getEditedPostPreviewLink()
7369      };
7370    }, []);
7371    (0,external_wp_element_namespaceObject.useEffect)(() => {
7372      /**
7373       * Keep the lock refreshed.
7374       *
7375       * When the user does not send a heartbeat in a heartbeat-tick
7376       * the user is no longer editing and another user can start editing.
7377       *
7378       * @param {Object} data Data to send in the heartbeat request.
7379       */
7380      function sendPostLock(data) {
7381        if (isLocked) {
7382          return;
7383        }
7384  
7385        data['wp-refresh-post-lock'] = {
7386          lock: activePostLock,
7387          post_id: postId
7388        };
7389      }
7390      /**
7391       * Refresh post locks: update the lock string or show the dialog if somebody has taken over editing.
7392       *
7393       * @param {Object} data Data received in the heartbeat request
7394       */
7395  
7396  
7397      function receivePostLock(data) {
7398        if (!data['wp-refresh-post-lock']) {
7399          return;
7400        }
7401  
7402        const received = data['wp-refresh-post-lock'];
7403  
7404        if (received.lock_error) {
7405          // Auto save and display the takeover modal.
7406          autosave();
7407          updatePostLock({
7408            isLocked: true,
7409            isTakeover: true,
7410            user: {
7411              name: received.lock_error.name,
7412              avatar: received.lock_error.avatar_src_2x
7413            }
7414          });
7415        } else if (received.new_lock) {
7416          updatePostLock({
7417            isLocked: false,
7418            activePostLock: received.new_lock
7419          });
7420        }
7421      }
7422      /**
7423       * Unlock the post before the window is exited.
7424       */
7425  
7426  
7427      function releasePostLock() {
7428        if (isLocked || !activePostLock) {
7429          return;
7430        }
7431  
7432        const data = new window.FormData();
7433        data.append('action', 'wp-remove-post-lock');
7434        data.append('_wpnonce', postLockUtils.unlockNonce);
7435        data.append('post_ID', postId);
7436        data.append('active_post_lock', activePostLock);
7437  
7438        if (window.navigator.sendBeacon) {
7439          window.navigator.sendBeacon(postLockUtils.ajaxUrl, data);
7440        } else {
7441          const xhr = new window.XMLHttpRequest();
7442          xhr.open('POST', postLockUtils.ajaxUrl, false);
7443          xhr.send(data);
7444        }
7445      } // Details on these events on the Heartbeat API docs
7446      // https://developer.wordpress.org/plugins/javascript/heartbeat-api/
7447  
7448  
7449      (0,external_wp_hooks_namespaceObject.addAction)('heartbeat.send', hookName, sendPostLock);
7450      (0,external_wp_hooks_namespaceObject.addAction)('heartbeat.tick', hookName, receivePostLock);
7451      window.addEventListener('beforeunload', releasePostLock);
7452      return () => {
7453        (0,external_wp_hooks_namespaceObject.removeAction)('heartbeat.send', hookName);
7454        (0,external_wp_hooks_namespaceObject.removeAction)('heartbeat.tick', hookName);
7455        window.removeEventListener('beforeunload', releasePostLock);
7456      };
7457    }, []);
7458  
7459    if (!isLocked) {
7460      return null;
7461    }
7462  
7463    const userDisplayName = user.name;
7464    const userAvatar = user.avatar;
7465    const unlockUrl = (0,external_wp_url_namespaceObject.addQueryArgs)('post.php', {
7466      'get-post-lock': '1',
7467      lockKey: true,
7468      post: postId,
7469      action: 'edit',
7470      _wpnonce: postLockUtils.nonce
7471    });
7472    const allPostsUrl = (0,external_wp_url_namespaceObject.addQueryArgs)('edit.php', {
7473      post_type: (0,external_lodash_namespaceObject.get)(postType, ['slug'])
7474    });
7475  
7476    const allPostsLabel = (0,external_wp_i18n_namespaceObject.__)('Exit editor');
7477  
7478    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Modal, {
7479      title: isTakeover ? (0,external_wp_i18n_namespaceObject.__)('Someone else has taken over this post') : (0,external_wp_i18n_namespaceObject.__)('This post is already being edited'),
7480      focusOnMount: true,
7481      shouldCloseOnClickOutside: false,
7482      shouldCloseOnEsc: false,
7483      isDismissible: false,
7484      className: "editor-post-locked-modal"
7485    }, !!userAvatar && (0,external_wp_element_namespaceObject.createElement)("img", {
7486      src: userAvatar,
7487      alt: (0,external_wp_i18n_namespaceObject.__)('Avatar'),
7488      className: "editor-post-locked-modal__avatar",
7489      width: 64,
7490      height: 64
7491    }), (0,external_wp_element_namespaceObject.createElement)("div", null, !!isTakeover && (0,external_wp_element_namespaceObject.createElement)("p", null, (0,external_wp_element_namespaceObject.createInterpolateElement)(userDisplayName ? (0,external_wp_i18n_namespaceObject.sprintf)(
7492    /* translators: %s: user's display name */
7493    (0,external_wp_i18n_namespaceObject.__)('<strong>%s</strong> now has editing control of this posts (<PreviewLink />). Don’t worry, your changes up to this moment have been saved.'), userDisplayName) : (0,external_wp_i18n_namespaceObject.__)('Another user now has editing control of this post (<PreviewLink />). Don’t worry, your changes up to this moment have been saved.'), {
7494      strong: (0,external_wp_element_namespaceObject.createElement)("strong", null),
7495      PreviewLink: (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ExternalLink, {
7496        href: previewLink
7497      }, (0,external_wp_i18n_namespaceObject.__)('preview'))
7498    })), !isTakeover && (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)("p", null, (0,external_wp_element_namespaceObject.createInterpolateElement)(userDisplayName ? (0,external_wp_i18n_namespaceObject.sprintf)(
7499    /* translators: %s: user's display name */
7500    (0,external_wp_i18n_namespaceObject.__)('<strong>%s</strong> is currently working on this post (<PreviewLink />), which means you cannot make changes, unless you take over.'), userDisplayName) : (0,external_wp_i18n_namespaceObject.__)('Another user is currently working on this post (<PreviewLink />), which means you cannot make changes, unless you take over.'), {
7501      strong: (0,external_wp_element_namespaceObject.createElement)("strong", null),
7502      PreviewLink: (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ExternalLink, {
7503        href: previewLink
7504      }, (0,external_wp_i18n_namespaceObject.__)('preview'))
7505    })), (0,external_wp_element_namespaceObject.createElement)("p", null, (0,external_wp_i18n_namespaceObject.__)('If you take over, the other user will lose editing control to the post, but their changes will be saved.'))), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Flex, {
7506      className: "editor-post-locked-modal__buttons",
7507      justify: "flex-end",
7508      expanded: false
7509    }, !isTakeover && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.FlexItem, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
7510      variant: "tertiary",
7511      href: unlockUrl
7512    }, (0,external_wp_i18n_namespaceObject.__)('Take over'))), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.FlexItem, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
7513      variant: "primary",
7514      href: allPostsUrl
7515    }, allPostsLabel)))));
7516  }
7517  
7518  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-pending-status/check.js
7519  /**
7520   * External dependencies
7521   */
7522  
7523  /**
7524   * WordPress dependencies
7525   */
7526  
7527  
7528  
7529  /**
7530   * Internal dependencies
7531   */
7532  
7533  
7534  function PostPendingStatusCheck(_ref) {
7535    let {
7536      hasPublishAction,
7537      isPublished,
7538      children
7539    } = _ref;
7540  
7541    if (isPublished || !hasPublishAction) {
7542      return null;
7543    }
7544  
7545    return children;
7546  }
7547  /* harmony default export */ var post_pending_status_check = ((0,external_wp_compose_namespaceObject.compose)((0,external_wp_data_namespaceObject.withSelect)(select => {
7548    const {
7549      isCurrentPostPublished,
7550      getCurrentPostType,
7551      getCurrentPost
7552    } = select(store_store);
7553    return {
7554      hasPublishAction: (0,external_lodash_namespaceObject.get)(getCurrentPost(), ['_links', 'wp:action-publish'], false),
7555      isPublished: isCurrentPostPublished(),
7556      postType: getCurrentPostType()
7557    };
7558  }))(PostPendingStatusCheck));
7559  
7560  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-pending-status/index.js
7561  
7562  
7563  /**
7564   * WordPress dependencies
7565   */
7566  
7567  
7568  
7569  
7570  /**
7571   * Internal dependencies
7572   */
7573  
7574  
7575  
7576  function PostPendingStatus(_ref) {
7577    let {
7578      status,
7579      onUpdateStatus
7580    } = _ref;
7581  
7582    const togglePendingStatus = () => {
7583      const updatedStatus = status === 'pending' ? 'draft' : 'pending';
7584      onUpdateStatus(updatedStatus);
7585    };
7586  
7587    return (0,external_wp_element_namespaceObject.createElement)(post_pending_status_check, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.CheckboxControl, {
7588      label: (0,external_wp_i18n_namespaceObject.__)('Pending review'),
7589      checked: status === 'pending',
7590      onChange: togglePendingStatus
7591    }));
7592  }
7593  /* harmony default export */ var post_pending_status = ((0,external_wp_compose_namespaceObject.compose)((0,external_wp_data_namespaceObject.withSelect)(select => ({
7594    status: select(store_store).getEditedPostAttribute('status')
7595  })), (0,external_wp_data_namespaceObject.withDispatch)(dispatch => ({
7596    onUpdateStatus(status) {
7597      dispatch(store_store).editPost({
7598        status
7599      });
7600    }
7601  
7602  })))(PostPendingStatus));
7603  
7604  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-pingbacks/index.js
7605  
7606  
7607  /**
7608   * WordPress dependencies
7609   */
7610  
7611  
7612  
7613  
7614  /**
7615   * Internal dependencies
7616   */
7617  
7618  
7619  
7620  function PostPingbacks(_ref) {
7621    let {
7622      pingStatus = 'open',
7623      ...props
7624    } = _ref;
7625  
7626    const onTogglePingback = () => props.editPost({
7627      ping_status: pingStatus === 'open' ? 'closed' : 'open'
7628    });
7629  
7630    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.CheckboxControl, {
7631      label: (0,external_wp_i18n_namespaceObject.__)('Allow pingbacks & trackbacks'),
7632      checked: pingStatus === 'open',
7633      onChange: onTogglePingback
7634    });
7635  }
7636  
7637  /* harmony default export */ var post_pingbacks = ((0,external_wp_compose_namespaceObject.compose)([(0,external_wp_data_namespaceObject.withSelect)(select => {
7638    return {
7639      pingStatus: select(store_store).getEditedPostAttribute('ping_status')
7640    };
7641  }), (0,external_wp_data_namespaceObject.withDispatch)(dispatch => ({
7642    editPost: dispatch(store_store).editPost
7643  }))])(PostPingbacks));
7644  
7645  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-preview-button/index.js
7646  
7647  
7648  /**
7649   * External dependencies
7650   */
7651  
7652  
7653  /**
7654   * WordPress dependencies
7655   */
7656  
7657  
7658  
7659  
7660  
7661  
7662  
7663  
7664  /**
7665   * Internal dependencies
7666   */
7667  
7668  
7669  
7670  function writeInterstitialMessage(targetDocument) {
7671    let markup = (0,external_wp_element_namespaceObject.renderToString)((0,external_wp_element_namespaceObject.createElement)("div", {
7672      className: "editor-post-preview-button__interstitial-message"
7673    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, {
7674      xmlns: "http://www.w3.org/2000/svg",
7675      viewBox: "0 0 96 96"
7676    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
7677      className: "outer",
7678      d: "M48 12c19.9 0 36 16.1 36 36S67.9 84 48 84 12 67.9 12 48s16.1-36 36-36",
7679      fill: "none"
7680    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
7681      className: "inner",
7682      d: "M69.5 46.4c0-3.9-1.4-6.7-2.6-8.8-1.6-2.6-3.1-4.9-3.1-7.5 0-2.9 2.2-5.7 5.4-5.7h.4C63.9 19.2 56.4 16 48 16c-11.2 0-21 5.7-26.7 14.4h2.1c3.3 0 8.5-.4 8.5-.4 1.7-.1 1.9 2.4.2 2.6 0 0-1.7.2-3.7.3L40 67.5l7-20.9L42 33c-1.7-.1-3.3-.3-3.3-.3-1.7-.1-1.5-2.7.2-2.6 0 0 5.3.4 8.4.4 3.3 0 8.5-.4 8.5-.4 1.7-.1 1.9 2.4.2 2.6 0 0-1.7.2-3.7.3l11.5 34.3 3.3-10.4c1.6-4.5 2.4-7.8 2.4-10.5zM16.1 48c0 12.6 7.3 23.5 18 28.7L18.8 35c-1.7 4-2.7 8.4-2.7 13zm32.5 2.8L39 78.6c2.9.8 5.9 1.3 9 1.3 3.7 0 7.3-.6 10.6-1.8-.1-.1-.2-.3-.2-.4l-9.8-26.9zM76.2 36c0 3.2-.6 6.9-2.4 11.4L64 75.6c9.5-5.5 15.9-15.8 15.9-27.6 0-5.5-1.4-10.8-3.9-15.3.1 1 .2 2.1.2 3.3z",
7683      fill: "none"
7684    })), (0,external_wp_element_namespaceObject.createElement)("p", null, (0,external_wp_i18n_namespaceObject.__)('Generating preview…'))));
7685    markup += `
7686          <style>
7687              body {
7688                  margin: 0;
7689              }
7690              .editor-post-preview-button__interstitial-message {
7691                  display: flex;
7692                  flex-direction: column;
7693                  align-items: center;
7694                  justify-content: center;
7695                  height: 100vh;
7696                  width: 100vw;
7697              }
7698              @-webkit-keyframes paint {
7699                  0% {
7700                      stroke-dashoffset: 0;
7701                  }
7702              }
7703              @-moz-keyframes paint {
7704                  0% {
7705                      stroke-dashoffset: 0;
7706                  }
7707              }
7708              @-o-keyframes paint {
7709                  0% {
7710                      stroke-dashoffset: 0;
7711                  }
7712              }
7713              @keyframes paint {
7714                  0% {
7715                      stroke-dashoffset: 0;
7716                  }
7717              }
7718              .editor-post-preview-button__interstitial-message svg {
7719                  width: 192px;
7720                  height: 192px;
7721                  stroke: #555d66;
7722                  stroke-width: 0.75;
7723              }
7724              .editor-post-preview-button__interstitial-message svg .outer,
7725              .editor-post-preview-button__interstitial-message svg .inner {
7726                  stroke-dasharray: 280;
7727                  stroke-dashoffset: 280;
7728                  -webkit-animation: paint 1.5s ease infinite alternate;
7729                  -moz-animation: paint 1.5s ease infinite alternate;
7730                  -o-animation: paint 1.5s ease infinite alternate;
7731                  animation: paint 1.5s ease infinite alternate;
7732              }
7733              p {
7734                  text-align: center;
7735                  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
7736              }
7737          </style>
7738      `;
7739    /**
7740     * Filters the interstitial message shown when generating previews.
7741     *
7742     * @param {string} markup The preview interstitial markup.
7743     */
7744  
7745    markup = (0,external_wp_hooks_namespaceObject.applyFilters)('editor.PostPreview.interstitialMarkup', markup);
7746    targetDocument.write(markup);
7747    targetDocument.title = (0,external_wp_i18n_namespaceObject.__)('Generating preview…');
7748    targetDocument.close();
7749  }
7750  
7751  class PostPreviewButton extends external_wp_element_namespaceObject.Component {
7752    constructor() {
7753      super(...arguments);
7754      this.buttonRef = (0,external_wp_element_namespaceObject.createRef)();
7755      this.openPreviewWindow = this.openPreviewWindow.bind(this);
7756    }
7757  
7758    componentDidUpdate(prevProps) {
7759      const {
7760        previewLink
7761      } = this.props; // This relies on the window being responsible to unset itself when
7762      // navigation occurs or a new preview window is opened, to avoid
7763      // unintentional forceful redirects.
7764  
7765      if (previewLink && !prevProps.previewLink) {
7766        this.setPreviewWindowLink(previewLink);
7767      }
7768    }
7769    /**
7770     * Sets the preview window's location to the given URL, if a preview window
7771     * exists and is not closed.
7772     *
7773     * @param {string} url URL to assign as preview window location.
7774     */
7775  
7776  
7777    setPreviewWindowLink(url) {
7778      const {
7779        previewWindow
7780      } = this;
7781  
7782      if (previewWindow && !previewWindow.closed) {
7783        previewWindow.location = url;
7784  
7785        if (this.buttonRef.current) {
7786          this.buttonRef.current.focus();
7787        }
7788      }
7789    }
7790  
7791    getWindowTarget() {
7792      const {
7793        postId
7794      } = this.props;
7795      return `wp-preview-$postId}`;
7796    }
7797  
7798    openPreviewWindow(event) {
7799      // Our Preview button has its 'href' and 'target' set correctly for a11y
7800      // purposes. Unfortunately, though, we can't rely on the default 'click'
7801      // handler since sometimes it incorrectly opens a new tab instead of reusing
7802      // the existing one.
7803      // https://github.com/WordPress/gutenberg/pull/8330
7804      event.preventDefault(); // Open up a Preview tab if needed. This is where we'll show the preview.
7805  
7806      if (!this.previewWindow || this.previewWindow.closed) {
7807        this.previewWindow = window.open('', this.getWindowTarget());
7808      } // Focus the Preview tab. This might not do anything, depending on the browser's
7809      // and user's preferences.
7810      // https://html.spec.whatwg.org/multipage/interaction.html#dom-window-focus
7811  
7812  
7813      this.previewWindow.focus();
7814  
7815      if ( // If we don't need to autosave the post before previewing, then we simply
7816      // load the Preview URL in the Preview tab.
7817      !this.props.isAutosaveable || // Do not save or overwrite the post, if the post is already locked.
7818      this.props.isPostLocked) {
7819        this.setPreviewWindowLink(event.target.href);
7820        return;
7821      } // Request an autosave. This happens asynchronously and causes the component
7822      // to update when finished.
7823  
7824  
7825      if (this.props.isDraft) {
7826        this.props.savePost({
7827          isPreview: true
7828        });
7829      } else {
7830        this.props.autosave({
7831          isPreview: true
7832        });
7833      } // Display a 'Generating preview' message in the Preview tab while we wait for the
7834      // autosave to finish.
7835  
7836  
7837      writeInterstitialMessage(this.previewWindow.document);
7838    }
7839  
7840    render() {
7841      const {
7842        previewLink,
7843        currentPostLink,
7844        isSaveable,
7845        role
7846      } = this.props; // Link to the `?preview=true` URL if we have it, since this lets us see
7847      // changes that were autosaved since the post was last published. Otherwise,
7848      // just link to the post's URL.
7849  
7850      const href = previewLink || currentPostLink;
7851      const classNames = classnames_default()({
7852        'editor-post-preview': !this.props.className
7853      }, this.props.className);
7854      return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
7855        variant: !this.props.className ? 'tertiary' : undefined,
7856        className: classNames,
7857        href: href,
7858        target: this.getWindowTarget(),
7859        disabled: !isSaveable,
7860        onClick: this.openPreviewWindow,
7861        ref: this.buttonRef,
7862        role: role
7863      }, this.props.textContent ? this.props.textContent : (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_i18n_namespaceObject._x)('Preview', 'imperative verb'), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.VisuallyHidden, {
7864        as: "span"
7865      },
7866      /* translators: accessibility text */
7867      (0,external_wp_i18n_namespaceObject.__)('(opens in a new tab)'))));
7868    }
7869  
7870  }
7871  /* harmony default export */ var post_preview_button = ((0,external_wp_compose_namespaceObject.compose)([(0,external_wp_data_namespaceObject.withSelect)((select, _ref) => {
7872    let {
7873      forcePreviewLink,
7874      forceIsAutosaveable
7875    } = _ref;
7876    const {
7877      getCurrentPostId,
7878      getCurrentPostAttribute,
7879      getEditedPostAttribute,
7880      isEditedPostSaveable,
7881      isEditedPostAutosaveable,
7882      getEditedPostPreviewLink,
7883      isPostLocked
7884    } = select(store_store);
7885    const {
7886      getPostType
7887    } = select(external_wp_coreData_namespaceObject.store);
7888    const previewLink = getEditedPostPreviewLink();
7889    const postType = getPostType(getEditedPostAttribute('type'));
7890    return {
7891      postId: getCurrentPostId(),
7892      currentPostLink: getCurrentPostAttribute('link'),
7893      previewLink: forcePreviewLink !== undefined ? forcePreviewLink : previewLink,
7894      isSaveable: isEditedPostSaveable(),
7895      isAutosaveable: forceIsAutosaveable || isEditedPostAutosaveable(),
7896      isViewable: (0,external_lodash_namespaceObject.get)(postType, ['viewable'], false),
7897      isDraft: ['draft', 'auto-draft'].indexOf(getEditedPostAttribute('status')) !== -1,
7898      isPostLocked: isPostLocked()
7899    };
7900  }), (0,external_wp_data_namespaceObject.withDispatch)(dispatch => ({
7901    autosave: dispatch(store_store).autosave,
7902    savePost: dispatch(store_store).savePost
7903  })), (0,external_wp_compose_namespaceObject.ifCondition)(_ref2 => {
7904    let {
7905      isViewable
7906    } = _ref2;
7907    return isViewable;
7908  })])(PostPreviewButton));
7909  
7910  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-publish-button/label.js
7911  /**
7912   * External dependencies
7913   */
7914  
7915  /**
7916   * WordPress dependencies
7917   */
7918  
7919  
7920  
7921  
7922  /**
7923   * Internal dependencies
7924   */
7925  
7926  
7927  function PublishButtonLabel(_ref) {
7928    let {
7929      isPublished,
7930      isBeingScheduled,
7931      isSaving,
7932      isPublishing,
7933      hasPublishAction,
7934      isAutosaving,
7935      hasNonPostEntityChanges
7936    } = _ref;
7937  
7938    if (isPublishing) {
7939      /* translators: button label text should, if possible, be under 16 characters. */
7940      return (0,external_wp_i18n_namespaceObject.__)('Publishing…');
7941    } else if (isPublished && isSaving && !isAutosaving) {
7942      /* translators: button label text should, if possible, be under 16 characters. */
7943      return (0,external_wp_i18n_namespaceObject.__)('Updating…');
7944    } else if (isBeingScheduled && isSaving && !isAutosaving) {
7945      /* translators: button label text should, if possible, be under 16 characters. */
7946      return (0,external_wp_i18n_namespaceObject.__)('Scheduling…');
7947    }
7948  
7949    if (!hasPublishAction) {
7950      return hasNonPostEntityChanges ? (0,external_wp_i18n_namespaceObject.__)('Submit for Review…') : (0,external_wp_i18n_namespaceObject.__)('Submit for Review');
7951    } else if (isPublished) {
7952      return hasNonPostEntityChanges ? (0,external_wp_i18n_namespaceObject.__)('Update…') : (0,external_wp_i18n_namespaceObject.__)('Update');
7953    } else if (isBeingScheduled) {
7954      return hasNonPostEntityChanges ? (0,external_wp_i18n_namespaceObject.__)('Schedule…') : (0,external_wp_i18n_namespaceObject.__)('Schedule');
7955    }
7956  
7957    return (0,external_wp_i18n_namespaceObject.__)('Publish');
7958  }
7959  /* harmony default export */ var label = ((0,external_wp_compose_namespaceObject.compose)([(0,external_wp_data_namespaceObject.withSelect)((select, _ref2) => {
7960    let {
7961      forceIsSaving
7962    } = _ref2;
7963    const {
7964      isCurrentPostPublished,
7965      isEditedPostBeingScheduled,
7966      isSavingPost,
7967      isPublishingPost,
7968      getCurrentPost,
7969      getCurrentPostType,
7970      isAutosavingPost
7971    } = select(store_store);
7972    return {
7973      isPublished: isCurrentPostPublished(),
7974      isBeingScheduled: isEditedPostBeingScheduled(),
7975      isSaving: forceIsSaving || isSavingPost(),
7976      isPublishing: isPublishingPost(),
7977      hasPublishAction: (0,external_lodash_namespaceObject.get)(getCurrentPost(), ['_links', 'wp:action-publish'], false),
7978      postType: getCurrentPostType(),
7979      isAutosaving: isAutosavingPost()
7980    };
7981  })])(PublishButtonLabel));
7982  
7983  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-publish-button/index.js
7984  
7985  
7986  
7987  /**
7988   * External dependencies
7989   */
7990  
7991  
7992  /**
7993   * WordPress dependencies
7994   */
7995  
7996  
7997  
7998  
7999  
8000  
8001  /**
8002   * Internal dependencies
8003   */
8004  
8005  
8006  
8007  class PostPublishButton extends external_wp_element_namespaceObject.Component {
8008    constructor(props) {
8009      super(props);
8010      this.buttonNode = (0,external_wp_element_namespaceObject.createRef)();
8011      this.createOnClick = this.createOnClick.bind(this);
8012      this.closeEntitiesSavedStates = this.closeEntitiesSavedStates.bind(this);
8013      this.state = {
8014        entitiesSavedStatesCallback: false
8015      };
8016    }
8017  
8018    componentDidMount() {
8019      if (this.props.focusOnMount) {
8020        this.buttonNode.current.focus();
8021      }
8022    }
8023  
8024    createOnClick(callback) {
8025      var _this = this;
8026  
8027      return function () {
8028        for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
8029          args[_key] = arguments[_key];
8030        }
8031  
8032        const {
8033          hasNonPostEntityChanges,
8034          setEntitiesSavedStatesCallback
8035        } = _this.props; // If a post with non-post entities is published, but the user
8036        // elects to not save changes to the non-post entities, those
8037        // entities will still be dirty when the Publish button is clicked.
8038        // We also need to check that the `setEntitiesSavedStatesCallback`
8039        // prop was passed. See https://github.com/WordPress/gutenberg/pull/37383
8040  
8041        if (hasNonPostEntityChanges && setEntitiesSavedStatesCallback) {
8042          // The modal for multiple entity saving will open,
8043          // hold the callback for saving/publishing the post
8044          // so that we can call it if the post entity is checked.
8045          _this.setState({
8046            entitiesSavedStatesCallback: () => callback(...args)
8047          }); // Open the save panel by setting its callback.
8048          // To set a function on the useState hook, we must set it
8049          // with another function (() => myFunction). Passing the
8050          // function on its own will cause an error when called.
8051  
8052  
8053          setEntitiesSavedStatesCallback(() => _this.closeEntitiesSavedStates);
8054          return external_lodash_namespaceObject.noop;
8055        }
8056  
8057        return callback(...args);
8058      };
8059    }
8060  
8061    closeEntitiesSavedStates(savedEntities) {
8062      const {
8063        postType,
8064        postId
8065      } = this.props;
8066      const {
8067        entitiesSavedStatesCallback
8068      } = this.state;
8069      this.setState({
8070        entitiesSavedStatesCallback: false
8071      }, () => {
8072        if (savedEntities && (0,external_lodash_namespaceObject.some)(savedEntities, elt => elt.kind === 'postType' && elt.name === postType && elt.key === postId)) {
8073          // The post entity was checked, call the held callback from `createOnClick`.
8074          entitiesSavedStatesCallback();
8075        }
8076      });
8077    }
8078  
8079    render() {
8080      const {
8081        forceIsDirty,
8082        forceIsSaving,
8083        hasPublishAction,
8084        isBeingScheduled,
8085        isOpen,
8086        isPostSavingLocked,
8087        isPublishable,
8088        isPublished,
8089        isSaveable,
8090        isSaving,
8091        isAutoSaving,
8092        isToggle,
8093        onSave,
8094        onStatusChange,
8095        onSubmit = external_lodash_namespaceObject.noop,
8096        onToggle,
8097        visibility,
8098        hasNonPostEntityChanges,
8099        isSavingNonPostEntityChanges
8100      } = this.props;
8101      const isButtonDisabled = (isSaving || forceIsSaving || !isSaveable || isPostSavingLocked || !isPublishable && !forceIsDirty) && (!hasNonPostEntityChanges || isSavingNonPostEntityChanges);
8102      const isToggleDisabled = (isPublished || isSaving || forceIsSaving || !isSaveable || !isPublishable && !forceIsDirty) && (!hasNonPostEntityChanges || isSavingNonPostEntityChanges);
8103      let publishStatus;
8104  
8105      if (!hasPublishAction) {
8106        publishStatus = 'pending';
8107      } else if (visibility === 'private') {
8108        publishStatus = 'private';
8109      } else if (isBeingScheduled) {
8110        publishStatus = 'future';
8111      } else {
8112        publishStatus = 'publish';
8113      }
8114  
8115      const onClickButton = () => {
8116        if (isButtonDisabled) {
8117          return;
8118        }
8119  
8120        onSubmit();
8121        onStatusChange(publishStatus);
8122        onSave();
8123      };
8124  
8125      const onClickToggle = () => {
8126        if (isToggleDisabled) {
8127          return;
8128        }
8129  
8130        onToggle();
8131      };
8132  
8133      const buttonProps = {
8134        'aria-disabled': isButtonDisabled,
8135        className: 'editor-post-publish-button',
8136        isBusy: !isAutoSaving && isSaving && isPublished,
8137        variant: 'primary',
8138        onClick: this.createOnClick(onClickButton)
8139      };
8140      const toggleProps = {
8141        'aria-disabled': isToggleDisabled,
8142        'aria-expanded': isOpen,
8143        className: 'editor-post-publish-panel__toggle',
8144        isBusy: isSaving && isPublished,
8145        variant: 'primary',
8146        onClick: this.createOnClick(onClickToggle)
8147      };
8148      const toggleChildren = isBeingScheduled ? (0,external_wp_i18n_namespaceObject.__)('Schedule…') : (0,external_wp_i18n_namespaceObject.__)('Publish');
8149      const buttonChildren = (0,external_wp_element_namespaceObject.createElement)(label, {
8150        forceIsSaving: forceIsSaving,
8151        hasNonPostEntityChanges: hasNonPostEntityChanges
8152      });
8153      const componentProps = isToggle ? toggleProps : buttonProps;
8154      const componentChildren = isToggle ? toggleChildren : buttonChildren;
8155      return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, _extends({
8156        ref: this.buttonNode
8157      }, componentProps, {
8158        className: classnames_default()(componentProps.className, 'editor-post-publish-button__button', {
8159          'has-changes-dot': hasNonPostEntityChanges
8160        })
8161      }), componentChildren));
8162    }
8163  
8164  }
8165  /* harmony default export */ var post_publish_button = ((0,external_wp_compose_namespaceObject.compose)([(0,external_wp_data_namespaceObject.withSelect)(select => {
8166    const {
8167      isSavingPost,
8168      isAutosavingPost,
8169      isEditedPostBeingScheduled,
8170      getEditedPostVisibility,
8171      isCurrentPostPublished,
8172      isEditedPostSaveable,
8173      isEditedPostPublishable,
8174      isPostSavingLocked,
8175      getCurrentPost,
8176      getCurrentPostType,
8177      getCurrentPostId,
8178      hasNonPostEntityChanges,
8179      isSavingNonPostEntityChanges
8180    } = select(store_store);
8181  
8182    const _isAutoSaving = isAutosavingPost();
8183  
8184    return {
8185      isSaving: isSavingPost() || _isAutoSaving,
8186      isAutoSaving: _isAutoSaving,
8187      isBeingScheduled: isEditedPostBeingScheduled(),
8188      visibility: getEditedPostVisibility(),
8189      isSaveable: isEditedPostSaveable(),
8190      isPostSavingLocked: isPostSavingLocked(),
8191      isPublishable: isEditedPostPublishable(),
8192      isPublished: isCurrentPostPublished(),
8193      hasPublishAction: (0,external_lodash_namespaceObject.get)(getCurrentPost(), ['_links', 'wp:action-publish'], false),
8194      postType: getCurrentPostType(),
8195      postId: getCurrentPostId(),
8196      hasNonPostEntityChanges: hasNonPostEntityChanges(),
8197      isSavingNonPostEntityChanges: isSavingNonPostEntityChanges()
8198    };
8199  }), (0,external_wp_data_namespaceObject.withDispatch)(dispatch => {
8200    const {
8201      editPost,
8202      savePost
8203    } = dispatch(store_store);
8204    return {
8205      onStatusChange: status => editPost({
8206        status
8207      }, {
8208        undoIgnore: true
8209      }),
8210      onSave: savePost
8211    };
8212  })])(PostPublishButton));
8213  
8214  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/close-small.js
8215  
8216  
8217  /**
8218   * WordPress dependencies
8219   */
8220  
8221  const closeSmall = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
8222    xmlns: "http://www.w3.org/2000/svg",
8223    viewBox: "0 0 24 24"
8224  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
8225    d: "M12 13.06l3.712 3.713 1.061-1.06L13.061 12l3.712-3.712-1.06-1.06L12 10.938 8.288 7.227l-1.061 1.06L10.939 12l-3.712 3.712 1.06 1.061L12 13.061z"
8226  }));
8227  /* harmony default export */ var close_small = (closeSmall);
8228  
8229  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/wordpress.js
8230  
8231  
8232  /**
8233   * WordPress dependencies
8234   */
8235  
8236  const wordpress = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
8237    xmlns: "http://www.w3.org/2000/svg",
8238    viewBox: "-2 -2 24 24"
8239  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
8240    d: "M20 10c0-5.51-4.49-10-10-10C4.48 0 0 4.49 0 10c0 5.52 4.48 10 10 10 5.51 0 10-4.48 10-10zM7.78 15.37L4.37 6.22c.55-.02 1.17-.08 1.17-.08.5-.06.44-1.13-.06-1.11 0 0-1.45.11-2.37.11-.18 0-.37 0-.58-.01C4.12 2.69 6.87 1.11 10 1.11c2.33 0 4.45.87 6.05 2.34-.68-.11-1.65.39-1.65 1.58 0 .74.45 1.36.9 2.1.35.61.55 1.36.55 2.46 0 1.49-1.4 5-1.4 5l-3.03-8.37c.54-.02.82-.17.82-.17.5-.05.44-1.25-.06-1.22 0 0-1.44.12-2.38.12-.87 0-2.33-.12-2.33-.12-.5-.03-.56 1.2-.06 1.22l.92.08 1.26 3.41zM17.41 10c.24-.64.74-1.87.43-4.25.7 1.29 1.05 2.71 1.05 4.25 0 3.29-1.73 6.24-4.4 7.78.97-2.59 1.94-5.2 2.92-7.78zM6.1 18.09C3.12 16.65 1.11 13.53 1.11 10c0-1.3.23-2.48.72-3.59C3.25 10.3 4.67 14.2 6.1 18.09zm4.03-6.63l2.58 6.98c-.86.29-1.76.45-2.71.45-.79 0-1.57-.11-2.29-.33.81-2.38 1.62-4.74 2.42-7.1z"
8241  }));
8242  /* harmony default export */ var library_wordpress = (wordpress);
8243  
8244  ;// CONCATENATED MODULE: ./node_modules/@babel/runtime/helpers/esm/defineProperty.js
8245  function _defineProperty(obj, key, value) {
8246    if (key in obj) {
8247      Object.defineProperty(obj, key, {
8248        value: value,
8249        enumerable: true,
8250        configurable: true,
8251        writable: true
8252      });
8253    } else {
8254      obj[key] = value;
8255    }
8256  
8257    return obj;
8258  }
8259  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-visibility/utils.js
8260  /**
8261   * WordPress dependencies
8262   */
8263  
8264  const visibilityOptions = [{
8265    value: 'public',
8266    label: (0,external_wp_i18n_namespaceObject.__)('Public'),
8267    info: (0,external_wp_i18n_namespaceObject.__)('Visible to everyone.')
8268  }, {
8269    value: 'private',
8270    label: (0,external_wp_i18n_namespaceObject.__)('Private'),
8271    info: (0,external_wp_i18n_namespaceObject.__)('Only visible to site admins and editors.')
8272  }, {
8273    value: 'password',
8274    label: (0,external_wp_i18n_namespaceObject.__)('Password Protected'),
8275    info: (0,external_wp_i18n_namespaceObject.__)('Protected with a password you choose. Only those with the password can view this post.')
8276  }];
8277  
8278  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-visibility/index.js
8279  
8280  
8281  
8282  /**
8283   * WordPress dependencies
8284   */
8285  
8286  
8287  
8288  
8289  
8290  /**
8291   * Internal dependencies
8292   */
8293  
8294  
8295  
8296  class PostVisibility extends external_wp_element_namespaceObject.Component {
8297    constructor(props) {
8298      super(...arguments);
8299  
8300      _defineProperty(this, "confirmPrivate", () => {
8301        const {
8302          onUpdateVisibility,
8303          onSave
8304        } = this.props;
8305        onUpdateVisibility('private');
8306        this.setState({
8307          hasPassword: false,
8308          showPrivateConfirmDialog: false
8309        });
8310        onSave();
8311      });
8312  
8313      _defineProperty(this, "handleDialogCancel", () => {
8314        this.setState({
8315          showPrivateConfirmDialog: false
8316        });
8317      });
8318  
8319      this.setPublic = this.setPublic.bind(this);
8320      this.setPrivate = this.setPrivate.bind(this);
8321      this.setPasswordProtected = this.setPasswordProtected.bind(this);
8322      this.updatePassword = this.updatePassword.bind(this);
8323      this.state = {
8324        hasPassword: !!props.password,
8325        showPrivateConfirmDialog: false
8326      };
8327    }
8328  
8329    setPublic() {
8330      const {
8331        visibility,
8332        onUpdateVisibility,
8333        status
8334      } = this.props;
8335      onUpdateVisibility(visibility === 'private' ? 'draft' : status);
8336      this.setState({
8337        hasPassword: false
8338      });
8339    }
8340  
8341    setPrivate() {
8342      this.setState({
8343        showPrivateConfirmDialog: true
8344      });
8345    }
8346  
8347    setPasswordProtected() {
8348      const {
8349        visibility,
8350        onUpdateVisibility,
8351        status,
8352        password
8353      } = this.props;
8354      onUpdateVisibility(visibility === 'private' ? 'draft' : status, password || '');
8355      this.setState({
8356        hasPassword: true
8357      });
8358    }
8359  
8360    updatePassword(event) {
8361      const {
8362        status,
8363        onUpdateVisibility
8364      } = this.props;
8365      onUpdateVisibility(status, event.target.value);
8366    }
8367  
8368    render() {
8369      const {
8370        visibility,
8371        password,
8372        instanceId
8373      } = this.props;
8374      const visibilityHandlers = {
8375        public: {
8376          onSelect: this.setPublic,
8377          checked: visibility === 'public' && !this.state.hasPassword
8378        },
8379        private: {
8380          onSelect: this.setPrivate,
8381          checked: visibility === 'private'
8382        },
8383        password: {
8384          onSelect: this.setPasswordProtected,
8385          checked: this.state.hasPassword
8386        }
8387      };
8388      return [(0,external_wp_element_namespaceObject.createElement)("fieldset", {
8389        key: "visibility-selector",
8390        className: "editor-post-visibility__dialog-fieldset"
8391      }, (0,external_wp_element_namespaceObject.createElement)("legend", {
8392        className: "editor-post-visibility__dialog-legend"
8393      }, (0,external_wp_i18n_namespaceObject.__)('Post Visibility')), visibilityOptions.map(_ref => {
8394        let {
8395          value,
8396          label,
8397          info
8398        } = _ref;
8399        return (0,external_wp_element_namespaceObject.createElement)("div", {
8400          key: value,
8401          className: "editor-post-visibility__choice"
8402        }, (0,external_wp_element_namespaceObject.createElement)("input", {
8403          type: "radio",
8404          name: `editor-post-visibility__setting-$instanceId}`,
8405          value: value,
8406          onChange: visibilityHandlers[value].onSelect,
8407          checked: visibilityHandlers[value].checked,
8408          id: `editor-post-$value}-$instanceId}`,
8409          "aria-describedby": `editor-post-$value}-$instanceId}-description`,
8410          className: "editor-post-visibility__dialog-radio"
8411        }), (0,external_wp_element_namespaceObject.createElement)("label", {
8412          htmlFor: `editor-post-$value}-$instanceId}`,
8413          className: "editor-post-visibility__dialog-label"
8414        }, label), (0,external_wp_element_namespaceObject.createElement)("p", {
8415          id: `editor-post-$value}-$instanceId}-description`,
8416          className: "editor-post-visibility__dialog-info"
8417        }, info));
8418      })), this.state.hasPassword && (0,external_wp_element_namespaceObject.createElement)("div", {
8419        className: "editor-post-visibility__dialog-password",
8420        key: "password-selector"
8421      }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.VisuallyHidden, {
8422        as: "label",
8423        htmlFor: `editor-post-visibility__dialog-password-input-$instanceId}`
8424      }, (0,external_wp_i18n_namespaceObject.__)('Create password')), (0,external_wp_element_namespaceObject.createElement)("input", {
8425        className: "editor-post-visibility__dialog-password-input",
8426        id: `editor-post-visibility__dialog-password-input-$instanceId}`,
8427        type: "text",
8428        onChange: this.updatePassword,
8429        value: password,
8430        placeholder: (0,external_wp_i18n_namespaceObject.__)('Use a secure password')
8431      })), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalConfirmDialog, {
8432        key: "private-publish-confirmation",
8433        isOpen: this.state.showPrivateConfirmDialog,
8434        onConfirm: this.confirmPrivate,
8435        onCancel: this.handleDialogCancel
8436      }, (0,external_wp_i18n_namespaceObject.__)('Would you like to privately publish this post now?'))];
8437    }
8438  
8439  }
8440  /* harmony default export */ var post_visibility = ((0,external_wp_compose_namespaceObject.compose)([(0,external_wp_data_namespaceObject.withSelect)(select => {
8441    const {
8442      getEditedPostAttribute,
8443      getEditedPostVisibility
8444    } = select(store_store);
8445    return {
8446      status: getEditedPostAttribute('status'),
8447      visibility: getEditedPostVisibility(),
8448      password: getEditedPostAttribute('password')
8449    };
8450  }), (0,external_wp_data_namespaceObject.withDispatch)(dispatch => {
8451    const {
8452      savePost,
8453      editPost
8454    } = dispatch(store_store);
8455    return {
8456      onSave: savePost,
8457  
8458      onUpdateVisibility(status) {
8459        let password = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';
8460        editPost({
8461          status,
8462          password
8463        });
8464      }
8465  
8466    };
8467  }), external_wp_compose_namespaceObject.withInstanceId])(PostVisibility));
8468  
8469  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-visibility/label.js
8470  /**
8471   * External dependencies
8472   */
8473  
8474  /**
8475   * WordPress dependencies
8476   */
8477  
8478  
8479  /**
8480   * Internal dependencies
8481   */
8482  
8483  
8484  
8485  
8486  function PostVisibilityLabel(_ref) {
8487    let {
8488      visibility
8489    } = _ref;
8490  
8491    const getVisibilityLabel = () => (0,external_lodash_namespaceObject.find)(visibilityOptions, {
8492      value: visibility
8493    }).label;
8494  
8495    return getVisibilityLabel(visibility);
8496  }
8497  
8498  /* harmony default export */ var post_visibility_label = ((0,external_wp_data_namespaceObject.withSelect)(select => ({
8499    visibility: select(store_store).getEditedPostVisibility()
8500  }))(PostVisibilityLabel));
8501  
8502  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-schedule/index.js
8503  
8504  
8505  /**
8506   * WordPress dependencies
8507   */
8508  
8509  
8510  
8511  
8512  
8513  /**
8514   * Internal dependencies
8515   */
8516  
8517  
8518  
8519  function getDayOfTheMonth() {
8520    let date = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : new Date();
8521    let firstDay = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;
8522    const d = new Date(date);
8523    return new Date(d.getFullYear(), d.getMonth() + (firstDay ? 0 : 1), firstDay ? 1 : 0).toISOString();
8524  }
8525  
8526  function PostSchedule() {
8527    const {
8528      postDate,
8529      postType
8530    } = (0,external_wp_data_namespaceObject.useSelect)(select => ({
8531      postDate: select(store_store).getEditedPostAttribute('date'),
8532      postType: select(store_store).getCurrentPostType()
8533    }), []);
8534    const {
8535      editPost
8536    } = (0,external_wp_data_namespaceObject.useDispatch)(store_store);
8537  
8538    const onUpdateDate = date => editPost({
8539      date
8540    });
8541  
8542    const [previewedMonth, setPreviewedMonth] = (0,external_wp_element_namespaceObject.useState)(getDayOfTheMonth(postDate)); // Pick up published and schduled site posts.
8543  
8544    const eventsByPostType = (0,external_wp_data_namespaceObject.useSelect)(select => select(external_wp_coreData_namespaceObject.store).getEntityRecords('postType', postType, {
8545      status: 'publish,future',
8546      after: getDayOfTheMonth(previewedMonth),
8547      before: getDayOfTheMonth(previewedMonth, false),
8548      exclude: [select(store_store).getCurrentPostId()]
8549    }), [previewedMonth, postType]);
8550    const events = (0,external_wp_element_namespaceObject.useMemo)(() => (eventsByPostType || []).map(_ref => {
8551      let {
8552        title,
8553        type,
8554        date: eventDate
8555      } = _ref;
8556      return {
8557        title: title === null || title === void 0 ? void 0 : title.rendered,
8558        type,
8559        date: new Date(eventDate)
8560      };
8561    }), [eventsByPostType]);
8562    const ref = (0,external_wp_element_namespaceObject.useRef)();
8563  
8564    const settings = (0,external_wp_date_namespaceObject.__experimentalGetSettings)(); // To know if the current timezone is a 12 hour time with look for "a" in the time format
8565    // We also make sure this a is not escaped by a "/"
8566  
8567  
8568    const is12HourTime = /a(?!\\)/i.test(settings.formats.time.toLowerCase() // Test only the lower case a.
8569    .replace(/\\\\/g, '') // Replace "//" with empty strings.
8570    .split('').reverse().join('') // Reverse the string and test for "a" not followed by a slash.
8571    );
8572  
8573    function onChange(newDate) {
8574      onUpdateDate(newDate);
8575      const {
8576        ownerDocument
8577      } = ref.current;
8578      ownerDocument.activeElement.blur();
8579    }
8580  
8581    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.DateTimePicker, {
8582      ref: ref,
8583      currentDate: postDate,
8584      onChange: onChange,
8585      is12Hour: is12HourTime,
8586      events: events,
8587      onMonthPreviewed: setPreviewedMonth
8588    });
8589  }
8590  
8591  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-schedule/label.js
8592  /**
8593   * WordPress dependencies
8594   */
8595  
8596  
8597  
8598  /**
8599   * Internal dependencies
8600   */
8601  
8602  
8603  function PostScheduleLabel(_ref) {
8604    let {
8605      date,
8606      isFloating
8607    } = _ref;
8608  
8609    const settings = (0,external_wp_date_namespaceObject.__experimentalGetSettings)();
8610  
8611    return date && !isFloating ? (0,external_wp_date_namespaceObject.format)(`$settings.formats.date} $settings.formats.time}`, date) : (0,external_wp_i18n_namespaceObject.__)('Immediately');
8612  }
8613  /* harmony default export */ var post_schedule_label = ((0,external_wp_data_namespaceObject.withSelect)(select => {
8614    return {
8615      date: select(store_store).getEditedPostAttribute('date'),
8616      isFloating: select(store_store).isEditedPostDateFloating()
8617    };
8618  })(PostScheduleLabel));
8619  
8620  ;// CONCATENATED MODULE: external ["wp","a11y"]
8621  var external_wp_a11y_namespaceObject = window["wp"]["a11y"];
8622  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-taxonomies/most-used-terms.js
8623  
8624  
8625  /**
8626   * External dependencies
8627   */
8628  
8629  /**
8630   * WordPress dependencies
8631   */
8632  
8633  
8634  
8635  
8636  /**
8637   * Internal dependencies
8638   */
8639  
8640  
8641  const MIN_MOST_USED_TERMS = 3;
8642  const DEFAULT_QUERY = {
8643    per_page: 10,
8644    orderby: 'count',
8645    order: 'desc',
8646    hide_empty: true,
8647    _fields: 'id,name,count',
8648    context: 'view'
8649  };
8650  function MostUsedTerms(_ref) {
8651    let {
8652      onSelect,
8653      taxonomy
8654    } = _ref;
8655    const {
8656      _terms,
8657      showTerms
8658    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
8659      const mostUsedTerms = select(external_wp_coreData_namespaceObject.store).getEntityRecords('taxonomy', taxonomy.slug, DEFAULT_QUERY);
8660      return {
8661        _terms: mostUsedTerms,
8662        showTerms: (mostUsedTerms === null || mostUsedTerms === void 0 ? void 0 : mostUsedTerms.length) >= MIN_MOST_USED_TERMS
8663      };
8664    }, []);
8665  
8666    if (!showTerms) {
8667      return null;
8668    }
8669  
8670    const terms = unescapeTerms(_terms);
8671    const label = (0,external_lodash_namespaceObject.get)(taxonomy, ['labels', 'most_used']);
8672    return (0,external_wp_element_namespaceObject.createElement)("div", {
8673      className: "editor-post-taxonomies__flat-term-most-used"
8674    }, (0,external_wp_element_namespaceObject.createElement)("h3", {
8675      className: "editor-post-taxonomies__flat-term-most-used-label"
8676    }, label), (0,external_wp_element_namespaceObject.createElement)("ul", {
8677      role: "list",
8678      className: "editor-post-taxonomies__flat-term-most-used-list"
8679    }, terms.map(term => (0,external_wp_element_namespaceObject.createElement)("li", {
8680      key: term.id
8681    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
8682      variant: "link",
8683      onClick: () => onSelect(term)
8684    }, term.name)))));
8685  }
8686  
8687  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-taxonomies/flat-term-selector.js
8688  
8689  
8690  /**
8691   * External dependencies
8692   */
8693  
8694  /**
8695   * WordPress dependencies
8696   */
8697  
8698  
8699  
8700  
8701  
8702  
8703  
8704  
8705  
8706  
8707  /**
8708   * Internal dependencies
8709   */
8710  
8711  
8712  
8713  
8714  /**
8715   * Shared reference to an empty array for cases where it is important to avoid
8716   * returning a new array reference on every invocation.
8717   *
8718   * @type {Array<any>}
8719   */
8720  
8721  const flat_term_selector_EMPTY_ARRAY = [];
8722  /**
8723   * Module constants
8724   */
8725  
8726  const MAX_TERMS_SUGGESTIONS = 20;
8727  const flat_term_selector_DEFAULT_QUERY = {
8728    per_page: MAX_TERMS_SUGGESTIONS,
8729    orderby: 'count',
8730    order: 'desc',
8731    _fields: 'id,name',
8732    context: 'view'
8733  };
8734  
8735  const isSameTermName = (termA, termB) => unescapeString(termA).toLowerCase() === unescapeString(termB).toLowerCase();
8736  
8737  const termNamesToIds = (names, terms) => {
8738    return names.map(termName => (0,external_lodash_namespaceObject.find)(terms, term => isSameTermName(term.name, termName)).id);
8739  }; // Tries to create a term or fetch it if it already exists.
8740  
8741  
8742  function findOrCreateTerm(termName, restBase) {
8743    const escapedTermName = (0,external_lodash_namespaceObject.escape)(termName);
8744    return external_wp_apiFetch_default()({
8745      path: `/wp/v2/$restBase}`,
8746      method: 'POST',
8747      data: {
8748        name: escapedTermName
8749      }
8750    }).catch(error => {
8751      const errorCode = error.code;
8752  
8753      if (errorCode === 'term_exists') {
8754        // If the terms exist, fetch it instead of creating a new one.
8755        const addRequest = external_wp_apiFetch_default()({
8756          path: (0,external_wp_url_namespaceObject.addQueryArgs)(`/wp/v2/$restBase}`, { ...flat_term_selector_DEFAULT_QUERY,
8757            search: escapedTermName
8758          })
8759        }).then(unescapeTerms);
8760        return addRequest.then(searchResult => {
8761          return (0,external_lodash_namespaceObject.find)(searchResult, result => isSameTermName(result.name, termName));
8762        });
8763      }
8764  
8765      return Promise.reject(error);
8766    }).then(unescapeTerm);
8767  }
8768  
8769  function FlatTermSelector(_ref) {
8770    let {
8771      slug
8772    } = _ref;
8773    const [values, setValues] = (0,external_wp_element_namespaceObject.useState)([]);
8774    const [search, setSearch] = (0,external_wp_element_namespaceObject.useState)('');
8775    const debouncedSearch = (0,external_wp_compose_namespaceObject.useDebounce)(setSearch, 500);
8776    const {
8777      terms,
8778      termIds,
8779      taxonomy,
8780      hasAssignAction,
8781      hasCreateAction,
8782      hasResolvedTerms
8783    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
8784      const {
8785        getCurrentPost,
8786        getEditedPostAttribute
8787      } = select(store_store);
8788      const {
8789        getEntityRecords,
8790        getTaxonomy,
8791        hasFinishedResolution
8792      } = select(external_wp_coreData_namespaceObject.store);
8793      const post = getCurrentPost();
8794  
8795      const _taxonomy = getTaxonomy(slug);
8796  
8797      const _termIds = _taxonomy ? getEditedPostAttribute(_taxonomy.rest_base) : flat_term_selector_EMPTY_ARRAY;
8798  
8799      const query = { ...flat_term_selector_DEFAULT_QUERY,
8800        include: _termIds.join(','),
8801        per_page: -1
8802      };
8803      return {
8804        hasCreateAction: _taxonomy ? (0,external_lodash_namespaceObject.get)(post, ['_links', 'wp:action-create-' + _taxonomy.rest_base], false) : false,
8805        hasAssignAction: _taxonomy ? (0,external_lodash_namespaceObject.get)(post, ['_links', 'wp:action-assign-' + _taxonomy.rest_base], false) : false,
8806        taxonomy: _taxonomy,
8807        termIds: _termIds,
8808        terms: _termIds.length ? getEntityRecords('taxonomy', slug, query) : flat_term_selector_EMPTY_ARRAY,
8809        hasResolvedTerms: hasFinishedResolution('getEntityRecords', ['taxonomy', slug, query])
8810      };
8811    }, [slug]);
8812    const {
8813      searchResults
8814    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
8815      const {
8816        getEntityRecords
8817      } = select(external_wp_coreData_namespaceObject.store);
8818      return {
8819        searchResults: !!search ? getEntityRecords('taxonomy', slug, { ...flat_term_selector_DEFAULT_QUERY,
8820          search
8821        }) : flat_term_selector_EMPTY_ARRAY
8822      };
8823    }, [search]); // Update terms state only after the selectors are resolved.
8824    // We're using this to avoid terms temporarily disappearing on slow networks
8825    // while core data makes REST API requests.
8826  
8827    (0,external_wp_element_namespaceObject.useEffect)(() => {
8828      if (hasResolvedTerms) {
8829        const newValues = terms.map(term => unescapeString(term.name));
8830        setValues(newValues);
8831      }
8832    }, [terms, hasResolvedTerms]);
8833    const suggestions = (0,external_wp_element_namespaceObject.useMemo)(() => {
8834      return (searchResults !== null && searchResults !== void 0 ? searchResults : []).map(term => unescapeString(term.name));
8835    }, [searchResults]);
8836    const {
8837      editPost
8838    } = (0,external_wp_data_namespaceObject.useDispatch)(store_store);
8839  
8840    if (!hasAssignAction) {
8841      return null;
8842    }
8843  
8844    function onUpdateTerms(newTermIds) {
8845      editPost({
8846        [taxonomy.rest_base]: newTermIds
8847      });
8848    }
8849  
8850    function onChange(termNames) {
8851      const availableTerms = [...terms, ...(searchResults !== null && searchResults !== void 0 ? searchResults : [])];
8852      const uniqueTerms = (0,external_lodash_namespaceObject.uniqBy)(termNames, term => term.toLowerCase());
8853      const newTermNames = uniqueTerms.filter(termName => !(0,external_lodash_namespaceObject.find)(availableTerms, term => isSameTermName(term.name, termName))); // Optimistically update term values.
8854      // The selector will always re-fetch terms later.
8855  
8856      setValues(uniqueTerms);
8857  
8858      if (newTermNames.length === 0) {
8859        return onUpdateTerms(termNamesToIds(uniqueTerms, availableTerms));
8860      }
8861  
8862      if (!hasCreateAction) {
8863        return;
8864      }
8865  
8866      Promise.all(newTermNames.map(termName => findOrCreateTerm(termName, taxonomy.rest_base))).then(newTerms => {
8867        const newAvailableTerms = availableTerms.concat(newTerms);
8868        return onUpdateTerms(termNamesToIds(uniqueTerms, newAvailableTerms));
8869      });
8870    }
8871  
8872    function appendTerm(newTerm) {
8873      if (termIds.includes(newTerm.id)) {
8874        return;
8875      }
8876  
8877      const newTermIds = [...termIds, newTerm.id];
8878      const termAddedMessage = (0,external_wp_i18n_namespaceObject.sprintf)(
8879      /* translators: %s: term name. */
8880      (0,external_wp_i18n_namespaceObject._x)('%s added', 'term'), (0,external_lodash_namespaceObject.get)(taxonomy, ['labels', 'singular_name'], slug === 'post_tag' ? (0,external_wp_i18n_namespaceObject.__)('Tag') : (0,external_wp_i18n_namespaceObject.__)('Term')));
8881      (0,external_wp_a11y_namespaceObject.speak)(termAddedMessage, 'assertive');
8882      onUpdateTerms(newTermIds);
8883    }
8884  
8885    const newTermLabel = (0,external_lodash_namespaceObject.get)(taxonomy, ['labels', 'add_new_item'], slug === 'post_tag' ? (0,external_wp_i18n_namespaceObject.__)('Add new tag') : (0,external_wp_i18n_namespaceObject.__)('Add new Term'));
8886    const singularName = (0,external_lodash_namespaceObject.get)(taxonomy, ['labels', 'singular_name'], slug === 'post_tag' ? (0,external_wp_i18n_namespaceObject.__)('Tag') : (0,external_wp_i18n_namespaceObject.__)('Term'));
8887    const termAddedLabel = (0,external_wp_i18n_namespaceObject.sprintf)(
8888    /* translators: %s: term name. */
8889    (0,external_wp_i18n_namespaceObject._x)('%s added', 'term'), singularName);
8890    const termRemovedLabel = (0,external_wp_i18n_namespaceObject.sprintf)(
8891    /* translators: %s: term name. */
8892    (0,external_wp_i18n_namespaceObject._x)('%s removed', 'term'), singularName);
8893    const removeTermLabel = (0,external_wp_i18n_namespaceObject.sprintf)(
8894    /* translators: %s: term name. */
8895    (0,external_wp_i18n_namespaceObject._x)('Remove %s', 'term'), singularName);
8896    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.FormTokenField, {
8897      value: values,
8898      suggestions: suggestions,
8899      onChange: onChange,
8900      onInputChange: debouncedSearch,
8901      maxSuggestions: MAX_TERMS_SUGGESTIONS,
8902      label: newTermLabel,
8903      messages: {
8904        added: termAddedLabel,
8905        removed: termRemovedLabel,
8906        remove: removeTermLabel
8907      }
8908    }), (0,external_wp_element_namespaceObject.createElement)(MostUsedTerms, {
8909      taxonomy: taxonomy,
8910      onSelect: appendTerm
8911    }));
8912  }
8913  
8914  /* harmony default export */ var flat_term_selector = ((0,external_wp_components_namespaceObject.withFilters)('editor.PostTaxonomyType')(FlatTermSelector));
8915  
8916  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-publish-panel/maybe-tags-panel.js
8917  
8918  
8919  /**
8920   * External dependencies
8921   */
8922  
8923  /**
8924   * WordPress dependencies
8925   */
8926  
8927  
8928  
8929  
8930  
8931  
8932  
8933  /**
8934   * Internal dependencies
8935   */
8936  
8937  
8938  
8939  
8940  const TagsPanel = () => {
8941    const panelBodyTitle = [(0,external_wp_i18n_namespaceObject.__)('Suggestion:'), (0,external_wp_element_namespaceObject.createElement)("span", {
8942      className: "editor-post-publish-panel__link",
8943      key: "label"
8944    }, (0,external_wp_i18n_namespaceObject.__)('Add tags'))];
8945    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
8946      initialOpen: false,
8947      title: panelBodyTitle
8948    }, (0,external_wp_element_namespaceObject.createElement)("p", null, (0,external_wp_i18n_namespaceObject.__)('Tags help users and search engines navigate your site and find your content. Add a few keywords to describe your post.')), (0,external_wp_element_namespaceObject.createElement)(flat_term_selector, {
8949      slug: 'post_tag'
8950    }));
8951  };
8952  
8953  class MaybeTagsPanel extends external_wp_element_namespaceObject.Component {
8954    constructor(props) {
8955      super(props);
8956      this.state = {
8957        hadTagsWhenOpeningThePanel: props.hasTags
8958      };
8959    }
8960    /*
8961     * We only want to show the tag panel if the post didn't have
8962     * any tags when the user hit the Publish button.
8963     *
8964     * We can't use the prop.hasTags because it'll change to true
8965     * if the user adds a new tag within the pre-publish panel.
8966     * This would force a re-render and a new prop.hasTags check,
8967     * hiding this panel and keeping the user from adding
8968     * more than one tag.
8969     */
8970  
8971  
8972    render() {
8973      if (!this.state.hadTagsWhenOpeningThePanel) {
8974        return (0,external_wp_element_namespaceObject.createElement)(TagsPanel, null);
8975      }
8976  
8977      return null;
8978    }
8979  
8980  }
8981  
8982  /* harmony default export */ var maybe_tags_panel = ((0,external_wp_compose_namespaceObject.compose)((0,external_wp_data_namespaceObject.withSelect)(select => {
8983    const postType = select(store_store).getCurrentPostType();
8984    const tagsTaxonomy = select(external_wp_coreData_namespaceObject.store).getTaxonomy('post_tag');
8985    const tags = tagsTaxonomy && select(store_store).getEditedPostAttribute(tagsTaxonomy.rest_base);
8986    return {
8987      areTagsFetched: tagsTaxonomy !== undefined,
8988      isPostTypeSupported: tagsTaxonomy && (0,external_lodash_namespaceObject.some)(tagsTaxonomy.types, type => type === postType),
8989      hasTags: tags && tags.length
8990    };
8991  }), (0,external_wp_compose_namespaceObject.ifCondition)(_ref => {
8992    let {
8993      areTagsFetched,
8994      isPostTypeSupported
8995    } = _ref;
8996    return isPostTypeSupported && areTagsFetched;
8997  }))(MaybeTagsPanel));
8998  
8999  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-publish-panel/maybe-post-format-panel.js
9000  
9001  
9002  /**
9003   * External dependencies
9004   */
9005  
9006  /**
9007   * WordPress dependencies
9008   */
9009  
9010  
9011  
9012  
9013  
9014  /**
9015   * Internal dependencies
9016   */
9017  
9018  
9019  
9020  
9021  const getSuggestion = (supportedFormats, suggestedPostFormat) => {
9022    const formats = POST_FORMATS.filter(format => (0,external_lodash_namespaceObject.includes)(supportedFormats, format.id));
9023    return (0,external_lodash_namespaceObject.find)(formats, format => format.id === suggestedPostFormat);
9024  };
9025  
9026  const PostFormatSuggestion = _ref => {
9027    let {
9028      suggestedPostFormat,
9029      suggestionText,
9030      onUpdatePostFormat
9031    } = _ref;
9032    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
9033      variant: "link",
9034      onClick: () => onUpdatePostFormat(suggestedPostFormat)
9035    }, suggestionText);
9036  };
9037  
9038  function PostFormatPanel() {
9039    const {
9040      currentPostFormat,
9041      suggestion
9042    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
9043      const {
9044        getEditedPostAttribute,
9045        getSuggestedPostFormat
9046      } = select(store_store);
9047      const supportedFormats = (0,external_lodash_namespaceObject.get)(select(external_wp_coreData_namespaceObject.store).getThemeSupports(), ['formats'], []);
9048      return {
9049        currentPostFormat: getEditedPostAttribute('format'),
9050        suggestion: getSuggestion(supportedFormats, getSuggestedPostFormat())
9051      };
9052    }, []);
9053    const {
9054      editPost
9055    } = (0,external_wp_data_namespaceObject.useDispatch)(store_store);
9056  
9057    const onUpdatePostFormat = format => editPost({
9058      format
9059    });
9060  
9061    const panelBodyTitle = [(0,external_wp_i18n_namespaceObject.__)('Suggestion:'), (0,external_wp_element_namespaceObject.createElement)("span", {
9062      className: "editor-post-publish-panel__link",
9063      key: "label"
9064    }, (0,external_wp_i18n_namespaceObject.__)('Use a post format'))];
9065  
9066    if (!suggestion || suggestion.id === currentPostFormat) {
9067      return null;
9068    }
9069  
9070    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
9071      initialOpen: false,
9072      title: panelBodyTitle
9073    }, (0,external_wp_element_namespaceObject.createElement)("p", null, (0,external_wp_i18n_namespaceObject.__)('Your theme uses post formats to highlight different kinds of content, like images or videos. Apply a post format to see this special styling.')), (0,external_wp_element_namespaceObject.createElement)("p", null, (0,external_wp_element_namespaceObject.createElement)(PostFormatSuggestion, {
9074      onUpdatePostFormat: onUpdatePostFormat,
9075      suggestedPostFormat: suggestion.id,
9076      suggestionText: (0,external_wp_i18n_namespaceObject.sprintf)(
9077      /* translators: %s: post format */
9078      (0,external_wp_i18n_namespaceObject.__)('Apply the "%1$s" format.'), suggestion.caption)
9079    })));
9080  }
9081  
9082  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-taxonomies/hierarchical-term-selector.js
9083  
9084  
9085  /**
9086   * External dependencies
9087   */
9088  
9089  /**
9090   * WordPress dependencies
9091   */
9092  
9093  
9094  
9095  
9096  
9097  
9098  
9099  
9100  /**
9101   * Internal dependencies
9102   */
9103  
9104  
9105  
9106  /**
9107   * Module Constants
9108   */
9109  
9110  const hierarchical_term_selector_DEFAULT_QUERY = {
9111    per_page: -1,
9112    orderby: 'name',
9113    order: 'asc',
9114    _fields: 'id,name,parent',
9115    context: 'view'
9116  };
9117  const MIN_TERMS_COUNT_FOR_FILTER = 8;
9118  const hierarchical_term_selector_EMPTY_ARRAY = [];
9119  /**
9120   * Sort Terms by Selected.
9121   *
9122   * @param {Object[]} termsTree Array of terms in tree format.
9123   * @param {number[]} terms     Selected terms.
9124   *
9125   * @return {Object[]} Sorted array of terms.
9126   */
9127  
9128  function sortBySelected(termsTree, terms) {
9129    const treeHasSelection = termTree => {
9130      if (terms.indexOf(termTree.id) !== -1) {
9131        return true;
9132      }
9133  
9134      if (undefined === termTree.children) {
9135        return false;
9136      }
9137  
9138      return termTree.children.map(treeHasSelection).filter(child => child).length > 0;
9139    };
9140  
9141    const termOrChildIsSelected = (termA, termB) => {
9142      const termASelected = treeHasSelection(termA);
9143      const termBSelected = treeHasSelection(termB);
9144  
9145      if (termASelected === termBSelected) {
9146        return 0;
9147      }
9148  
9149      if (termASelected && !termBSelected) {
9150        return -1;
9151      }
9152  
9153      if (!termASelected && termBSelected) {
9154        return 1;
9155      }
9156  
9157      return 0;
9158    };
9159  
9160    const newTermTree = [...termsTree];
9161    newTermTree.sort(termOrChildIsSelected);
9162    return newTermTree;
9163  }
9164  /**
9165   * Find term by parent id or name.
9166   *
9167   * @param {Object[]}      terms  Array of Terms.
9168   * @param {number|string} parent id.
9169   * @param {string}        name   Term name.
9170   * @return {Object} Term object.
9171   */
9172  
9173  function findTerm(terms, parent, name) {
9174    return (0,external_lodash_namespaceObject.find)(terms, term => {
9175      return (!term.parent && !parent || parseInt(term.parent) === parseInt(parent)) && term.name.toLowerCase() === name.toLowerCase();
9176    });
9177  }
9178  /**
9179   * Get filter matcher function.
9180   *
9181   * @param {string} filterValue Filter value.
9182   * @return {(function(Object): (Object|boolean))} Matcher function.
9183   */
9184  
9185  function getFilterMatcher(filterValue) {
9186    const matchTermsForFilter = originalTerm => {
9187      if ('' === filterValue) {
9188        return originalTerm;
9189      } // Shallow clone, because we'll be filtering the term's children and
9190      // don't want to modify the original term.
9191  
9192  
9193      const term = { ...originalTerm
9194      }; // Map and filter the children, recursive so we deal with grandchildren
9195      // and any deeper levels.
9196  
9197      if (term.children.length > 0) {
9198        term.children = term.children.map(matchTermsForFilter).filter(child => child);
9199      } // If the term's name contains the filterValue, or it has children
9200      // (i.e. some child matched at some point in the tree) then return it.
9201  
9202  
9203      if (-1 !== term.name.toLowerCase().indexOf(filterValue.toLowerCase()) || term.children.length > 0) {
9204        return term;
9205      } // Otherwise, return false. After mapping, the list of terms will need
9206      // to have false values filtered out.
9207  
9208  
9209      return false;
9210    };
9211  
9212    return matchTermsForFilter;
9213  }
9214  /**
9215   * Hierarchical term selector.
9216   *
9217   * @param {Object} props      Component props.
9218   * @param {string} props.slug Taxonomy slug.
9219   * @return {WPElement}        Hierarchical term selector component.
9220   */
9221  
9222  function HierarchicalTermSelector(_ref) {
9223    let {
9224      slug
9225    } = _ref;
9226    const [adding, setAdding] = (0,external_wp_element_namespaceObject.useState)(false);
9227    const [formName, setFormName] = (0,external_wp_element_namespaceObject.useState)('');
9228    /**
9229     * @type {[number|'', Function]}
9230     */
9231  
9232    const [formParent, setFormParent] = (0,external_wp_element_namespaceObject.useState)('');
9233    const [showForm, setShowForm] = (0,external_wp_element_namespaceObject.useState)(false);
9234    const [filterValue, setFilterValue] = (0,external_wp_element_namespaceObject.useState)('');
9235    const [filteredTermsTree, setFilteredTermsTree] = (0,external_wp_element_namespaceObject.useState)([]);
9236    const debouncedSpeak = (0,external_wp_compose_namespaceObject.useDebounce)(external_wp_a11y_namespaceObject.speak, 500);
9237    const {
9238      hasCreateAction,
9239      hasAssignAction,
9240      terms,
9241      loading,
9242      availableTerms,
9243      taxonomy
9244    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
9245      const {
9246        getCurrentPost,
9247        getEditedPostAttribute
9248      } = select(store_store);
9249      const {
9250        getTaxonomy,
9251        getEntityRecords,
9252        isResolving
9253      } = select(external_wp_coreData_namespaceObject.store);
9254  
9255      const _taxonomy = getTaxonomy(slug);
9256  
9257      return {
9258        hasCreateAction: _taxonomy ? (0,external_lodash_namespaceObject.get)(getCurrentPost(), ['_links', 'wp:action-create-' + _taxonomy.rest_base], false) : false,
9259        hasAssignAction: _taxonomy ? (0,external_lodash_namespaceObject.get)(getCurrentPost(), ['_links', 'wp:action-assign-' + _taxonomy.rest_base], false) : false,
9260        terms: _taxonomy ? getEditedPostAttribute(_taxonomy.rest_base) : hierarchical_term_selector_EMPTY_ARRAY,
9261        loading: isResolving('getEntityRecords', ['taxonomy', slug, hierarchical_term_selector_DEFAULT_QUERY]),
9262        availableTerms: getEntityRecords('taxonomy', slug, hierarchical_term_selector_DEFAULT_QUERY) || hierarchical_term_selector_EMPTY_ARRAY,
9263        taxonomy: _taxonomy
9264      };
9265    }, [slug]);
9266    const {
9267      editPost
9268    } = (0,external_wp_data_namespaceObject.useDispatch)(store_store);
9269    const {
9270      saveEntityRecord
9271    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_coreData_namespaceObject.store);
9272    const availableTermsTree = (0,external_wp_element_namespaceObject.useMemo)(() => sortBySelected(buildTermsTree(availableTerms), terms), // Remove `terms` from the dependency list to avoid reordering every time
9273    // checking or unchecking a term.
9274    [availableTerms]);
9275  
9276    if (!hasAssignAction) {
9277      return null;
9278    }
9279    /**
9280     * Append new term.
9281     *
9282     * @param {Object} term Term object.
9283     * @return {Promise} A promise that resolves to save term object.
9284     */
9285  
9286  
9287    const addTerm = term => {
9288      return saveEntityRecord('taxonomy', slug, term);
9289    };
9290    /**
9291     * Update terms for post.
9292     *
9293     * @param {number[]} termIds Term ids.
9294     */
9295  
9296  
9297    const onUpdateTerms = termIds => {
9298      editPost({
9299        [taxonomy.rest_base]: termIds
9300      });
9301    };
9302    /**
9303     * Handler for checking term.
9304     *
9305     * @param {number} termId
9306     */
9307  
9308  
9309    const onChange = termId => {
9310      const hasTerm = terms.includes(termId);
9311      const newTerms = hasTerm ? (0,external_lodash_namespaceObject.without)(terms, termId) : [...terms, termId];
9312      onUpdateTerms(newTerms);
9313    };
9314  
9315    const onChangeFormName = value => {
9316      setFormName(value);
9317    };
9318    /**
9319     * Handler for changing form parent.
9320     *
9321     * @param {number|''} parentId Parent post id.
9322     */
9323  
9324  
9325    const onChangeFormParent = parentId => {
9326      setFormParent(parentId);
9327    };
9328  
9329    const onToggleForm = () => {
9330      setShowForm(!showForm);
9331    };
9332  
9333    const onAddTerm = async event => {
9334      event.preventDefault();
9335  
9336      if (formName === '' || adding) {
9337        return;
9338      } // Check if the term we are adding already exists.
9339  
9340  
9341      const existingTerm = findTerm(availableTerms, formParent, formName);
9342  
9343      if (existingTerm) {
9344        // If the term we are adding exists but is not selected select it.
9345        if (!(0,external_lodash_namespaceObject.some)(terms, term => term === existingTerm.id)) {
9346          onUpdateTerms([...terms, existingTerm.id]);
9347        }
9348  
9349        setFormName('');
9350        setFormParent('');
9351        return;
9352      }
9353  
9354      setAdding(true);
9355      const newTerm = await addTerm({
9356        name: formName,
9357        parent: formParent ? formParent : undefined
9358      });
9359      const termAddedMessage = (0,external_wp_i18n_namespaceObject.sprintf)(
9360      /* translators: %s: taxonomy name */
9361      (0,external_wp_i18n_namespaceObject._x)('%s added', 'term'), (0,external_lodash_namespaceObject.get)(taxonomy, ['labels', 'singular_name'], slug === 'category' ? (0,external_wp_i18n_namespaceObject.__)('Category') : (0,external_wp_i18n_namespaceObject.__)('Term')));
9362      (0,external_wp_a11y_namespaceObject.speak)(termAddedMessage, 'assertive');
9363      setAdding(false);
9364      setFormName('');
9365      setFormParent('');
9366      onUpdateTerms([...terms, newTerm.id]);
9367    };
9368  
9369    const setFilter = value => {
9370      const newFilteredTermsTree = availableTermsTree.map(getFilterMatcher(value)).filter(term => term);
9371  
9372      const getResultCount = termsTree => {
9373        let count = 0;
9374  
9375        for (let i = 0; i < termsTree.length; i++) {
9376          count++;
9377  
9378          if (undefined !== termsTree[i].children) {
9379            count += getResultCount(termsTree[i].children);
9380          }
9381        }
9382  
9383        return count;
9384      };
9385  
9386      setFilterValue(value);
9387      setFilteredTermsTree(newFilteredTermsTree);
9388      const resultCount = getResultCount(newFilteredTermsTree);
9389      const resultsFoundMessage = (0,external_wp_i18n_namespaceObject.sprintf)(
9390      /* translators: %d: number of results */
9391      (0,external_wp_i18n_namespaceObject._n)('%d result found.', '%d results found.', resultCount), resultCount);
9392      debouncedSpeak(resultsFoundMessage, 'assertive');
9393    };
9394  
9395    const renderTerms = renderedTerms => {
9396      return renderedTerms.map(term => {
9397        return (0,external_wp_element_namespaceObject.createElement)("div", {
9398          key: term.id,
9399          className: "editor-post-taxonomies__hierarchical-terms-choice"
9400        }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.CheckboxControl, {
9401          checked: terms.indexOf(term.id) !== -1,
9402          onChange: () => {
9403            const termId = parseInt(term.id, 10);
9404            onChange(termId);
9405          },
9406          label: (0,external_lodash_namespaceObject.unescape)(term.name)
9407        }), !!term.children.length && (0,external_wp_element_namespaceObject.createElement)("div", {
9408          className: "editor-post-taxonomies__hierarchical-terms-subchoices"
9409        }, renderTerms(term.children)));
9410      });
9411    };
9412  
9413    const labelWithFallback = (labelProperty, fallbackIsCategory, fallbackIsNotCategory) => (0,external_lodash_namespaceObject.get)(taxonomy, ['labels', labelProperty], slug === 'category' ? fallbackIsCategory : fallbackIsNotCategory);
9414  
9415    const newTermButtonLabel = labelWithFallback('add_new_item', (0,external_wp_i18n_namespaceObject.__)('Add new category'), (0,external_wp_i18n_namespaceObject.__)('Add new term'));
9416    const newTermLabel = labelWithFallback('new_item_name', (0,external_wp_i18n_namespaceObject.__)('Add new category'), (0,external_wp_i18n_namespaceObject.__)('Add new term'));
9417    const parentSelectLabel = labelWithFallback('parent_item', (0,external_wp_i18n_namespaceObject.__)('Parent Category'), (0,external_wp_i18n_namespaceObject.__)('Parent Term'));
9418    const noParentOption = `— $parentSelectLabel} —`;
9419    const newTermSubmitLabel = newTermButtonLabel;
9420    const filterLabel = (0,external_lodash_namespaceObject.get)(taxonomy, ['labels', 'search_items'], (0,external_wp_i18n_namespaceObject.__)('Search Terms'));
9421    const groupLabel = (0,external_lodash_namespaceObject.get)(taxonomy, ['name'], (0,external_wp_i18n_namespaceObject.__)('Terms'));
9422    const showFilter = availableTerms.length >= MIN_TERMS_COUNT_FOR_FILTER;
9423    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, showFilter && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TextControl, {
9424      className: "editor-post-taxonomies__hierarchical-terms-filter",
9425      label: filterLabel,
9426      value: filterValue,
9427      onChange: setFilter
9428    }), (0,external_wp_element_namespaceObject.createElement)("div", {
9429      className: "editor-post-taxonomies__hierarchical-terms-list",
9430      tabIndex: "0",
9431      role: "group",
9432      "aria-label": groupLabel
9433    }, renderTerms('' !== filterValue ? filteredTermsTree : availableTermsTree)), !loading && hasCreateAction && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
9434      onClick: onToggleForm,
9435      className: "editor-post-taxonomies__hierarchical-terms-add",
9436      "aria-expanded": showForm,
9437      variant: "link"
9438    }, newTermButtonLabel), showForm && (0,external_wp_element_namespaceObject.createElement)("form", {
9439      onSubmit: onAddTerm
9440    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TextControl, {
9441      className: "editor-post-taxonomies__hierarchical-terms-input",
9442      label: newTermLabel,
9443      value: formName,
9444      onChange: onChangeFormName,
9445      required: true
9446    }), !!availableTerms.length && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TreeSelect, {
9447      label: parentSelectLabel,
9448      noOptionLabel: noParentOption,
9449      onChange: onChangeFormParent,
9450      selectedId: formParent,
9451      tree: availableTermsTree
9452    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
9453      variant: "secondary",
9454      type: "submit",
9455      className: "editor-post-taxonomies__hierarchical-terms-submit"
9456    }, newTermSubmitLabel)));
9457  }
9458  
9459  /* harmony default export */ var hierarchical_term_selector = ((0,external_wp_components_namespaceObject.withFilters)('editor.PostTaxonomyType')(HierarchicalTermSelector));
9460  
9461  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-publish-panel/maybe-category-panel.js
9462  
9463  
9464  /**
9465   * External dependencies
9466   */
9467  
9468  /**
9469   * WordPress dependencies
9470   */
9471  
9472  
9473  
9474  
9475  
9476  
9477  /**
9478   * Internal dependencies
9479   */
9480  
9481  
9482  
9483  
9484  function MaybeCategoryPanel() {
9485    const hasNoCategory = (0,external_wp_data_namespaceObject.useSelect)(select => {
9486      var _select$getEntityReco;
9487  
9488      const postType = select(store_store).getCurrentPostType();
9489      const categoriesTaxonomy = select(external_wp_coreData_namespaceObject.store).getTaxonomy('category');
9490      const defaultCategorySlug = 'uncategorized';
9491      const defaultCategory = (_select$getEntityReco = select(external_wp_coreData_namespaceObject.store).getEntityRecords('taxonomy', 'category', {
9492        slug: defaultCategorySlug
9493      })) === null || _select$getEntityReco === void 0 ? void 0 : _select$getEntityReco[0];
9494      const postTypeSupportsCategories = categoriesTaxonomy && (0,external_lodash_namespaceObject.some)(categoriesTaxonomy.types, type => type === postType);
9495      const categories = categoriesTaxonomy && select(store_store).getEditedPostAttribute(categoriesTaxonomy.rest_base); // This boolean should return true if everything is loaded
9496      // ( categoriesTaxonomy, defaultCategory )
9497      // and the post has not been assigned a category different than "uncategorized".
9498  
9499      return !!categoriesTaxonomy && !!defaultCategory && postTypeSupportsCategories && ((categories === null || categories === void 0 ? void 0 : categories.length) === 0 || (categories === null || categories === void 0 ? void 0 : categories.length) === 1 && defaultCategory.id === categories[0]);
9500    }, []);
9501    const [shouldShowPanel, setShouldShowPanel] = (0,external_wp_element_namespaceObject.useState)(false);
9502    (0,external_wp_element_namespaceObject.useEffect)(() => {
9503      // We use state to avoid hiding the panel if the user edits the categories
9504      // and adds one within the panel itself (while visible).
9505      if (hasNoCategory) {
9506        setShouldShowPanel(true);
9507      }
9508    }, [hasNoCategory]);
9509  
9510    if (!shouldShowPanel) {
9511      return null;
9512    }
9513  
9514    const panelBodyTitle = [(0,external_wp_i18n_namespaceObject.__)('Suggestion:'), (0,external_wp_element_namespaceObject.createElement)("span", {
9515      className: "editor-post-publish-panel__link",
9516      key: "label"
9517    }, (0,external_wp_i18n_namespaceObject.__)('Assign a category'))];
9518    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
9519      initialOpen: false,
9520      title: panelBodyTitle
9521    }, (0,external_wp_element_namespaceObject.createElement)("p", null, (0,external_wp_i18n_namespaceObject.__)('Categories provide a helpful way to group related posts together and to quickly tell readers what a post is about.')), (0,external_wp_element_namespaceObject.createElement)(hierarchical_term_selector, {
9522      slug: "category"
9523    }));
9524  }
9525  
9526  /* harmony default export */ var maybe_category_panel = (MaybeCategoryPanel);
9527  
9528  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-publish-panel/prepublish.js
9529  
9530  
9531  /**
9532   * External dependencies
9533   */
9534  
9535  /**
9536   * WordPress dependencies
9537   */
9538  
9539  
9540  
9541  
9542  
9543  
9544  
9545  
9546  /**
9547   * Internal dependencies
9548   */
9549  
9550  
9551  
9552  
9553  
9554  
9555  
9556  
9557  
9558  
9559  function PostPublishPanelPrepublish(_ref) {
9560    let {
9561      children
9562    } = _ref;
9563    const {
9564      isBeingScheduled,
9565      isRequestingSiteIcon,
9566      hasPublishAction,
9567      siteIconUrl,
9568      siteTitle,
9569      siteHome
9570    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
9571      const {
9572        getCurrentPost,
9573        isEditedPostBeingScheduled
9574      } = select(store_store);
9575      const {
9576        getEntityRecord,
9577        isResolving
9578      } = select(external_wp_coreData_namespaceObject.store);
9579      const siteData = getEntityRecord('root', '__unstableBase', undefined) || {};
9580      return {
9581        hasPublishAction: (0,external_lodash_namespaceObject.get)(getCurrentPost(), ['_links', 'wp:action-publish'], false),
9582        isBeingScheduled: isEditedPostBeingScheduled(),
9583        isRequestingSiteIcon: isResolving('getEntityRecord', ['root', '__unstableBase', undefined]),
9584        siteIconUrl: siteData.site_icon_url,
9585        siteTitle: siteData.name,
9586        siteHome: siteData.home && (0,external_wp_url_namespaceObject.filterURLForDisplay)(siteData.home)
9587      };
9588    }, []);
9589    let siteIcon = (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Icon, {
9590      className: "components-site-icon",
9591      size: "36px",
9592      icon: library_wordpress
9593    });
9594  
9595    if (siteIconUrl) {
9596      siteIcon = (0,external_wp_element_namespaceObject.createElement)("img", {
9597        alt: (0,external_wp_i18n_namespaceObject.__)('Site Icon'),
9598        className: "components-site-icon",
9599        src: siteIconUrl
9600      });
9601    }
9602  
9603    if (isRequestingSiteIcon) {
9604      siteIcon = null;
9605    }
9606  
9607    let prePublishTitle, prePublishBodyText;
9608  
9609    if (!hasPublishAction) {
9610      prePublishTitle = (0,external_wp_i18n_namespaceObject.__)('Are you ready to submit for review?');
9611      prePublishBodyText = (0,external_wp_i18n_namespaceObject.__)('When you’re ready, submit your work for review, and an Editor will be able to approve it for you.');
9612    } else if (isBeingScheduled) {
9613      prePublishTitle = (0,external_wp_i18n_namespaceObject.__)('Are you ready to schedule?');
9614      prePublishBodyText = (0,external_wp_i18n_namespaceObject.__)('Your work will be published at the specified date and time.');
9615    } else {
9616      prePublishTitle = (0,external_wp_i18n_namespaceObject.__)('Are you ready to publish?');
9617      prePublishBodyText = (0,external_wp_i18n_namespaceObject.__)('Double-check your settings before publishing.');
9618    }
9619  
9620    return (0,external_wp_element_namespaceObject.createElement)("div", {
9621      className: "editor-post-publish-panel__prepublish"
9622    }, (0,external_wp_element_namespaceObject.createElement)("div", null, (0,external_wp_element_namespaceObject.createElement)("strong", null, prePublishTitle)), (0,external_wp_element_namespaceObject.createElement)("p", null, prePublishBodyText), (0,external_wp_element_namespaceObject.createElement)("div", {
9623      className: "components-site-card"
9624    }, siteIcon, (0,external_wp_element_namespaceObject.createElement)("div", {
9625      className: "components-site-info"
9626    }, (0,external_wp_element_namespaceObject.createElement)("span", {
9627      className: "components-site-name"
9628    }, (0,external_wp_htmlEntities_namespaceObject.decodeEntities)(siteTitle) || (0,external_wp_i18n_namespaceObject.__)('(Untitled)')), (0,external_wp_element_namespaceObject.createElement)("span", {
9629      className: "components-site-home"
9630    }, siteHome))), hasPublishAction && (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
9631      initialOpen: false,
9632      title: [(0,external_wp_i18n_namespaceObject.__)('Visibility:'), (0,external_wp_element_namespaceObject.createElement)("span", {
9633        className: "editor-post-publish-panel__link",
9634        key: "label"
9635      }, (0,external_wp_element_namespaceObject.createElement)(post_visibility_label, null))]
9636    }, (0,external_wp_element_namespaceObject.createElement)(post_visibility, null)), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
9637      initialOpen: false,
9638      title: [(0,external_wp_i18n_namespaceObject.__)('Publish:'), (0,external_wp_element_namespaceObject.createElement)("span", {
9639        className: "editor-post-publish-panel__link",
9640        key: "label"
9641      }, (0,external_wp_element_namespaceObject.createElement)(post_schedule_label, null))]
9642    }, (0,external_wp_element_namespaceObject.createElement)(PostSchedule, null))), (0,external_wp_element_namespaceObject.createElement)(PostFormatPanel, null), (0,external_wp_element_namespaceObject.createElement)(maybe_tags_panel, null), (0,external_wp_element_namespaceObject.createElement)(maybe_category_panel, null), children);
9643  }
9644  
9645  /* harmony default export */ var prepublish = (PostPublishPanelPrepublish);
9646  
9647  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-publish-panel/postpublish.js
9648  
9649  
9650  /**
9651   * External dependencies
9652   */
9653  
9654  /**
9655   * WordPress dependencies
9656   */
9657  
9658  
9659  
9660  
9661  
9662  
9663  
9664  
9665  
9666  /**
9667   * Internal dependencies
9668   */
9669  
9670  
9671  
9672  const POSTNAME = '%postname%';
9673  /**
9674   * Returns URL for a future post.
9675   *
9676   * @param {Object} post Post object.
9677   *
9678   * @return {string} PostPublish URL.
9679   */
9680  
9681  const getFuturePostUrl = post => {
9682    const {
9683      slug
9684    } = post;
9685  
9686    if (post.permalink_template.includes(POSTNAME)) {
9687      return post.permalink_template.replace(POSTNAME, slug);
9688    }
9689  
9690    return post.permalink_template;
9691  };
9692  
9693  function postpublish_CopyButton(_ref) {
9694    let {
9695      text,
9696      onCopy,
9697      children
9698    } = _ref;
9699    const ref = (0,external_wp_compose_namespaceObject.useCopyToClipboard)(text, onCopy);
9700    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
9701      variant: "secondary",
9702      ref: ref
9703    }, children);
9704  }
9705  
9706  class PostPublishPanelPostpublish extends external_wp_element_namespaceObject.Component {
9707    constructor() {
9708      super(...arguments);
9709      this.state = {
9710        showCopyConfirmation: false
9711      };
9712      this.onCopy = this.onCopy.bind(this);
9713      this.onSelectInput = this.onSelectInput.bind(this);
9714      this.postLink = (0,external_wp_element_namespaceObject.createRef)();
9715    }
9716  
9717    componentDidMount() {
9718      if (this.props.focusOnMount) {
9719        this.postLink.current.focus();
9720      }
9721    }
9722  
9723    componentWillUnmount() {
9724      clearTimeout(this.dismissCopyConfirmation);
9725    }
9726  
9727    onCopy() {
9728      this.setState({
9729        showCopyConfirmation: true
9730      });
9731      clearTimeout(this.dismissCopyConfirmation);
9732      this.dismissCopyConfirmation = setTimeout(() => {
9733        this.setState({
9734          showCopyConfirmation: false
9735        });
9736      }, 4000);
9737    }
9738  
9739    onSelectInput(event) {
9740      event.target.select();
9741    }
9742  
9743    render() {
9744      const {
9745        children,
9746        isScheduled,
9747        post,
9748        postType
9749      } = this.props;
9750      const postLabel = (0,external_lodash_namespaceObject.get)(postType, ['labels', 'singular_name']);
9751      const viewPostLabel = (0,external_lodash_namespaceObject.get)(postType, ['labels', 'view_item']);
9752      const addNewPostLabel = (0,external_lodash_namespaceObject.get)(postType, ['labels', 'add_new_item']);
9753      const link = post.status === 'future' ? getFuturePostUrl(post) : post.link;
9754      const addLink = (0,external_wp_url_namespaceObject.addQueryArgs)('post-new.php', {
9755        post_type: post.type
9756      });
9757      const postPublishNonLinkHeader = isScheduled ? (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_i18n_namespaceObject.__)('is now scheduled. It will go live on'), ' ', (0,external_wp_element_namespaceObject.createElement)(post_schedule_label, null), ".") : (0,external_wp_i18n_namespaceObject.__)('is now live.');
9758      return (0,external_wp_element_namespaceObject.createElement)("div", {
9759        className: "post-publish-panel__postpublish"
9760      }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
9761        className: "post-publish-panel__postpublish-header"
9762      }, (0,external_wp_element_namespaceObject.createElement)("a", {
9763        ref: this.postLink,
9764        href: link
9765      }, (0,external_wp_htmlEntities_namespaceObject.decodeEntities)(post.title) || (0,external_wp_i18n_namespaceObject.__)('(no title)')), ' ', postPublishNonLinkHeader), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, null, (0,external_wp_element_namespaceObject.createElement)("p", {
9766        className: "post-publish-panel__postpublish-subheader"
9767      }, (0,external_wp_element_namespaceObject.createElement)("strong", null, (0,external_wp_i18n_namespaceObject.__)('What’s next?'))), (0,external_wp_element_namespaceObject.createElement)("div", {
9768        className: "post-publish-panel__postpublish-post-address-container"
9769      }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TextControl, {
9770        className: "post-publish-panel__postpublish-post-address",
9771        readOnly: true,
9772        label: (0,external_wp_i18n_namespaceObject.sprintf)(
9773        /* translators: %s: post type singular name */
9774        (0,external_wp_i18n_namespaceObject.__)('%s address'), postLabel),
9775        value: (0,external_wp_url_namespaceObject.safeDecodeURIComponent)(link),
9776        onFocus: this.onSelectInput
9777      }), (0,external_wp_element_namespaceObject.createElement)("div", {
9778        className: "post-publish-panel__postpublish-post-address__copy-button-wrap"
9779      }, (0,external_wp_element_namespaceObject.createElement)(postpublish_CopyButton, {
9780        text: link,
9781        onCopy: this.onCopy
9782      }, this.state.showCopyConfirmation ? (0,external_wp_i18n_namespaceObject.__)('Copied!') : (0,external_wp_i18n_namespaceObject.__)('Copy')))), (0,external_wp_element_namespaceObject.createElement)("div", {
9783        className: "post-publish-panel__postpublish-buttons"
9784      }, !isScheduled && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
9785        variant: "primary",
9786        href: link
9787      }, viewPostLabel), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
9788        variant: isScheduled ? 'primary' : 'secondary',
9789        href: addLink
9790      }, addNewPostLabel))), children);
9791    }
9792  
9793  }
9794  
9795  /* harmony default export */ var postpublish = ((0,external_wp_data_namespaceObject.withSelect)(select => {
9796    const {
9797      getEditedPostAttribute,
9798      getCurrentPost,
9799      isCurrentPostScheduled
9800    } = select(store_store);
9801    const {
9802      getPostType
9803    } = select(external_wp_coreData_namespaceObject.store);
9804    return {
9805      post: getCurrentPost(),
9806      postType: getPostType(getEditedPostAttribute('type')),
9807      isScheduled: isCurrentPostScheduled()
9808    };
9809  })(PostPublishPanelPostpublish));
9810  
9811  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-publish-panel/index.js
9812  
9813  
9814  
9815  /**
9816   * External dependencies
9817   */
9818  
9819  /**
9820   * WordPress dependencies
9821   */
9822  
9823  
9824  
9825  
9826  
9827  
9828  
9829  
9830  /**
9831   * Internal dependencies
9832   */
9833  
9834  
9835  
9836  
9837  
9838  class PostPublishPanel extends external_wp_element_namespaceObject.Component {
9839    constructor() {
9840      super(...arguments);
9841      this.onSubmit = this.onSubmit.bind(this);
9842    }
9843  
9844    componentDidUpdate(prevProps) {
9845      // Automatically collapse the publish sidebar when a post
9846      // is published and the user makes an edit.
9847      if (prevProps.isPublished && !this.props.isSaving && this.props.isDirty) {
9848        this.props.onClose();
9849      }
9850    }
9851  
9852    onSubmit() {
9853      const {
9854        onClose,
9855        hasPublishAction,
9856        isPostTypeViewable
9857      } = this.props;
9858  
9859      if (!hasPublishAction || !isPostTypeViewable) {
9860        onClose();
9861      }
9862    }
9863  
9864    render() {
9865      const {
9866        forceIsDirty,
9867        forceIsSaving,
9868        isBeingScheduled,
9869        isPublished,
9870        isPublishSidebarEnabled,
9871        isScheduled,
9872        isSaving,
9873        isSavingNonPostEntityChanges,
9874        onClose,
9875        onTogglePublishSidebar,
9876        PostPublishExtension,
9877        PrePublishExtension,
9878        ...additionalProps
9879      } = this.props;
9880      const propsForPanel = (0,external_lodash_namespaceObject.omit)(additionalProps, ['hasPublishAction', 'isDirty', 'isPostTypeViewable']);
9881      const isPublishedOrScheduled = isPublished || isScheduled && isBeingScheduled;
9882      const isPrePublish = !isPublishedOrScheduled && !isSaving;
9883      const isPostPublish = isPublishedOrScheduled && !isSaving;
9884      return (0,external_wp_element_namespaceObject.createElement)("div", _extends({
9885        className: "editor-post-publish-panel"
9886      }, propsForPanel), (0,external_wp_element_namespaceObject.createElement)("div", {
9887        className: "editor-post-publish-panel__header"
9888      }, isPostPublish ? (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
9889        onClick: onClose,
9890        icon: close_small,
9891        label: (0,external_wp_i18n_namespaceObject.__)('Close panel')
9892      }) : (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)("div", {
9893        className: "editor-post-publish-panel__header-publish-button"
9894      }, (0,external_wp_element_namespaceObject.createElement)(post_publish_button, {
9895        focusOnMount: true,
9896        onSubmit: this.onSubmit,
9897        forceIsDirty: forceIsDirty,
9898        forceIsSaving: forceIsSaving
9899      })), (0,external_wp_element_namespaceObject.createElement)("div", {
9900        className: "editor-post-publish-panel__header-cancel-button"
9901      }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
9902        disabled: isSavingNonPostEntityChanges,
9903        onClick: onClose,
9904        variant: "secondary"
9905      }, (0,external_wp_i18n_namespaceObject.__)('Cancel'))))), (0,external_wp_element_namespaceObject.createElement)("div", {
9906        className: "editor-post-publish-panel__content"
9907      }, isPrePublish && (0,external_wp_element_namespaceObject.createElement)(prepublish, null, PrePublishExtension && (0,external_wp_element_namespaceObject.createElement)(PrePublishExtension, null)), isPostPublish && (0,external_wp_element_namespaceObject.createElement)(postpublish, {
9908        focusOnMount: true
9909      }, PostPublishExtension && (0,external_wp_element_namespaceObject.createElement)(PostPublishExtension, null)), isSaving && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Spinner, null)), (0,external_wp_element_namespaceObject.createElement)("div", {
9910        className: "editor-post-publish-panel__footer"
9911      }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.CheckboxControl, {
9912        label: (0,external_wp_i18n_namespaceObject.__)('Always show pre-publish checks.'),
9913        checked: isPublishSidebarEnabled,
9914        onChange: onTogglePublishSidebar
9915      })));
9916    }
9917  
9918  }
9919  /* harmony default export */ var post_publish_panel = ((0,external_wp_compose_namespaceObject.compose)([(0,external_wp_data_namespaceObject.withSelect)(select => {
9920    const {
9921      getPostType
9922    } = select(external_wp_coreData_namespaceObject.store);
9923    const {
9924      getCurrentPost,
9925      getEditedPostAttribute,
9926      isCurrentPostPublished,
9927      isCurrentPostScheduled,
9928      isEditedPostBeingScheduled,
9929      isEditedPostDirty,
9930      isSavingPost,
9931      isSavingNonPostEntityChanges
9932    } = select(store_store);
9933    const {
9934      isPublishSidebarEnabled
9935    } = select(store_store);
9936    const postType = getPostType(getEditedPostAttribute('type'));
9937    return {
9938      hasPublishAction: (0,external_lodash_namespaceObject.get)(getCurrentPost(), ['_links', 'wp:action-publish'], false),
9939      isPostTypeViewable: (0,external_lodash_namespaceObject.get)(postType, ['viewable'], false),
9940      isBeingScheduled: isEditedPostBeingScheduled(),
9941      isDirty: isEditedPostDirty(),
9942      isPublished: isCurrentPostPublished(),
9943      isPublishSidebarEnabled: isPublishSidebarEnabled(),
9944      isSaving: isSavingPost(),
9945      isSavingNonPostEntityChanges: isSavingNonPostEntityChanges(),
9946      isScheduled: isCurrentPostScheduled()
9947    };
9948  }), (0,external_wp_data_namespaceObject.withDispatch)((dispatch, _ref) => {
9949    let {
9950      isPublishSidebarEnabled
9951    } = _ref;
9952    const {
9953      disablePublishSidebar,
9954      enablePublishSidebar
9955    } = dispatch(store_store);
9956    return {
9957      onTogglePublishSidebar: () => {
9958        if (isPublishSidebarEnabled) {
9959          disablePublishSidebar();
9960        } else {
9961          enablePublishSidebar();
9962        }
9963      }
9964    };
9965  }), external_wp_components_namespaceObject.withFocusReturn, external_wp_components_namespaceObject.withConstrainedTabbing])(PostPublishPanel));
9966  
9967  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/cloud-upload.js
9968  
9969  
9970  /**
9971   * WordPress dependencies
9972   */
9973  
9974  const cloudUpload = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
9975    xmlns: "http://www.w3.org/2000/svg",
9976    viewBox: "0 0 24 24"
9977  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
9978    d: "M17.3 10.1c0-2.5-2.1-4.4-4.8-4.4-2.2 0-4.1 1.4-4.6 3.3h-.2C5.7 9 4 10.7 4 12.8c0 2.1 1.7 3.8 3.7 3.8h9c1.8 0 3.2-1.5 3.2-3.3.1-1.6-1.1-2.9-2.6-3.2zm-.5 5.1h-4v-2.4L14 14l1-1-3-3-3 3 1 1 1.2-1.2v2.4H7.7c-1.2 0-2.2-1.1-2.2-2.3s1-2.4 2.2-2.4H9l.3-1.1c.4-1.3 1.7-2.2 3.2-2.2 1.8 0 3.3 1.3 3.3 2.9v1.3l1.3.2c.8.1 1.4.9 1.4 1.8 0 1-.8 1.8-1.7 1.8z"
9979  }));
9980  /* harmony default export */ var cloud_upload = (cloudUpload);
9981  
9982  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/icon/index.js
9983  /**
9984   * WordPress dependencies
9985   */
9986  
9987  /** @typedef {{icon: JSX.Element, size?: number} & import('@wordpress/primitives').SVGProps} IconProps */
9988  
9989  /**
9990   * Return an SVG icon.
9991   *
9992   * @param {IconProps} props icon is the SVG component to render
9993   *                          size is a number specifiying the icon size in pixels
9994   *                          Other props will be passed to wrapped SVG component
9995   *
9996   * @return {JSX.Element}  Icon component
9997   */
9998  
9999  function Icon(_ref) {
10000    let {
10001      icon,
10002      size = 24,
10003      ...props
10004    } = _ref;
10005    return (0,external_wp_element_namespaceObject.cloneElement)(icon, {
10006      width: size,
10007      height: size,
10008      ...props
10009    });
10010  }
10011  
10012  /* harmony default export */ var icon = (Icon);
10013  
10014  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/check.js
10015  
10016  
10017  /**
10018   * WordPress dependencies
10019   */
10020  
10021  const check_check = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
10022    xmlns: "http://www.w3.org/2000/svg",
10023    viewBox: "0 0 24 24"
10024  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
10025    d: "M16.7 7.1l-6.3 8.5-3.3-2.5-.9 1.2 4.5 3.4L17.9 8z"
10026  }));
10027  /* harmony default export */ var library_check = (check_check);
10028  
10029  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/cloud.js
10030  
10031  
10032  /**
10033   * WordPress dependencies
10034   */
10035  
10036  const cloud = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
10037    xmlns: "http://www.w3.org/2000/svg",
10038    viewBox: "0 0 24 24"
10039  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
10040    d: "M17.3 10.1c0-2.5-2.1-4.4-4.8-4.4-2.2 0-4.1 1.4-4.6 3.3h-.2C5.7 9 4 10.7 4 12.8c0 2.1 1.7 3.8 3.7 3.8h9c1.8 0 3.2-1.5 3.2-3.3.1-1.6-1.1-2.9-2.6-3.2zm-.5 5.1h-9c-1.2 0-2.2-1.1-2.2-2.3s1-2.4 2.2-2.4h1.3l.3-1.1c.4-1.3 1.7-2.2 3.2-2.2 1.8 0 3.3 1.3 3.3 2.9v1.3l1.3.2c.8.1 1.4.9 1.4 1.8-.1 1-.9 1.8-1.8 1.8z"
10041  }));
10042  /* harmony default export */ var library_cloud = (cloud);
10043  
10044  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-switch-to-draft-button/index.js
10045  
10046  
10047  /**
10048   * WordPress dependencies
10049   */
10050  
10051  
10052  
10053  
10054  
10055  /**
10056   * Internal dependencies
10057   */
10058  
10059  
10060  
10061  function PostSwitchToDraftButton(_ref) {
10062    let {
10063      isSaving,
10064      isPublished,
10065      isScheduled,
10066      onClick
10067    } = _ref;
10068    const isMobileViewport = (0,external_wp_compose_namespaceObject.useViewportMatch)('small', '<');
10069    const [showConfirmDialog, setShowConfirmDialog] = (0,external_wp_element_namespaceObject.useState)(false);
10070  
10071    if (!isPublished && !isScheduled) {
10072      return null;
10073    }
10074  
10075    let alertMessage;
10076  
10077    if (isPublished) {
10078      alertMessage = (0,external_wp_i18n_namespaceObject.__)('Are you sure you want to unpublish this post?');
10079    } else if (isScheduled) {
10080      alertMessage = (0,external_wp_i18n_namespaceObject.__)('Are you sure you want to unschedule this post?');
10081    }
10082  
10083    const handleConfirm = () => {
10084      setShowConfirmDialog(false);
10085      onClick();
10086    };
10087  
10088    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
10089      className: "editor-post-switch-to-draft",
10090      onClick: () => {
10091        setShowConfirmDialog(true);
10092      },
10093      disabled: isSaving,
10094      variant: "tertiary"
10095    }, isMobileViewport ? (0,external_wp_i18n_namespaceObject.__)('Draft') : (0,external_wp_i18n_namespaceObject.__)('Switch to draft')), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalConfirmDialog, {
10096      isOpen: showConfirmDialog,
10097      onConfirm: handleConfirm,
10098      onCancel: () => setShowConfirmDialog(false)
10099    }, alertMessage));
10100  }
10101  
10102  /* harmony default export */ var post_switch_to_draft_button = ((0,external_wp_compose_namespaceObject.compose)([(0,external_wp_data_namespaceObject.withSelect)(select => {
10103    const {
10104      isSavingPost,
10105      isCurrentPostPublished,
10106      isCurrentPostScheduled
10107    } = select(store_store);
10108    return {
10109      isSaving: isSavingPost(),
10110      isPublished: isCurrentPostPublished(),
10111      isScheduled: isCurrentPostScheduled()
10112    };
10113  }), (0,external_wp_data_namespaceObject.withDispatch)(dispatch => {
10114    const {
10115      editPost,
10116      savePost
10117    } = dispatch(store_store);
10118    return {
10119      onClick: () => {
10120        editPost({
10121          status: 'draft'
10122        });
10123        savePost();
10124      }
10125    };
10126  })])(PostSwitchToDraftButton));
10127  
10128  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-saved-state/index.js
10129  
10130  
10131  /**
10132   * External dependencies
10133   */
10134  
10135  /**
10136   * WordPress dependencies
10137   */
10138  
10139  
10140  
10141  
10142  
10143  
10144  
10145  
10146  /**
10147   * Internal dependencies
10148   */
10149  
10150  
10151  
10152  /**
10153   * Component showing whether the post is saved or not and providing save
10154   * buttons.
10155   *
10156   * @param {Object}   props                Component props.
10157   * @param {?boolean} props.forceIsDirty   Whether to force the post to be marked
10158   *                                        as dirty.
10159   * @param {?boolean} props.forceIsSaving  Whether to force the post to be marked
10160   *                                        as being saved.
10161   * @param {?boolean} props.showIconLabels Whether interface buttons show labels instead of icons
10162   * @return {import('@wordpress/element').WPComponent} The component.
10163   */
10164  
10165  function PostSavedState(_ref) {
10166    let {
10167      forceIsDirty,
10168      forceIsSaving,
10169      showIconLabels = false
10170    } = _ref;
10171    const [forceSavedMessage, setForceSavedMessage] = (0,external_wp_element_namespaceObject.useState)(false);
10172    const isLargeViewport = (0,external_wp_compose_namespaceObject.useViewportMatch)('small');
10173    const {
10174      isAutosaving,
10175      isDirty,
10176      isNew,
10177      isPending,
10178      isPublished,
10179      isSaveable,
10180      isSaving,
10181      isScheduled,
10182      hasPublishAction
10183    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
10184      var _getCurrentPost$_link, _getCurrentPost, _getCurrentPost$_link2;
10185  
10186      const {
10187        isEditedPostNew,
10188        isCurrentPostPublished,
10189        isCurrentPostScheduled,
10190        isEditedPostDirty,
10191        isSavingPost,
10192        isEditedPostSaveable,
10193        getCurrentPost,
10194        isAutosavingPost,
10195        getEditedPostAttribute
10196      } = select(store_store);
10197      return {
10198        isAutosaving: isAutosavingPost(),
10199        isDirty: forceIsDirty || isEditedPostDirty(),
10200        isNew: isEditedPostNew(),
10201        isPending: 'pending' === getEditedPostAttribute('status'),
10202        isPublished: isCurrentPostPublished(),
10203        isSaving: forceIsSaving || isSavingPost(),
10204        isSaveable: isEditedPostSaveable(),
10205        isScheduled: isCurrentPostScheduled(),
10206        hasPublishAction: (_getCurrentPost$_link = (_getCurrentPost = getCurrentPost()) === null || _getCurrentPost === void 0 ? void 0 : (_getCurrentPost$_link2 = _getCurrentPost._links) === null || _getCurrentPost$_link2 === void 0 ? void 0 : _getCurrentPost$_link2['wp:action-publish']) !== null && _getCurrentPost$_link !== void 0 ? _getCurrentPost$_link : false
10207      };
10208    }, [forceIsDirty, forceIsSaving]);
10209    const {
10210      savePost
10211    } = (0,external_wp_data_namespaceObject.useDispatch)(store_store);
10212    const wasSaving = (0,external_wp_compose_namespaceObject.usePrevious)(isSaving);
10213    (0,external_wp_element_namespaceObject.useEffect)(() => {
10214      let timeoutId;
10215  
10216      if (wasSaving && !isSaving) {
10217        setForceSavedMessage(true);
10218        timeoutId = setTimeout(() => {
10219          setForceSavedMessage(false);
10220        }, 1000);
10221      }
10222  
10223      return () => clearTimeout(timeoutId);
10224    }, [isSaving]); // Once the post has been submitted for review this button
10225    // is not needed for the contributor role.
10226  
10227    if (!hasPublishAction && isPending) {
10228      return null;
10229    }
10230  
10231    if (isPublished || isScheduled) {
10232      return (0,external_wp_element_namespaceObject.createElement)(post_switch_to_draft_button, null);
10233    }
10234    /* translators: button label text should, if possible, be under 16 characters. */
10235  
10236  
10237    const label = isPending ? (0,external_wp_i18n_namespaceObject.__)('Save as pending') : (0,external_wp_i18n_namespaceObject.__)('Save draft');
10238    /* translators: button label text should, if possible, be under 16 characters. */
10239  
10240    const shortLabel = (0,external_wp_i18n_namespaceObject.__)('Save');
10241  
10242    const isSaved = forceSavedMessage || !isNew && !isDirty;
10243    const isSavedState = isSaving || isSaved;
10244    const isDisabled = isSaving || isSaved || !isSaveable;
10245    let text;
10246  
10247    if (isSaving) {
10248      text = isAutosaving ? (0,external_wp_i18n_namespaceObject.__)('Autosaving') : (0,external_wp_i18n_namespaceObject.__)('Saving');
10249    } else if (isSaved) {
10250      text = (0,external_wp_i18n_namespaceObject.__)('Saved');
10251    } else if (isLargeViewport) {
10252      text = label;
10253    } else if (showIconLabels) {
10254      text = shortLabel;
10255    } // Use common Button instance for all saved states so that focus is not
10256    // lost.
10257  
10258  
10259    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
10260      className: isSaveable || isSaving ? classnames_default()({
10261        'editor-post-save-draft': !isSavedState,
10262        'editor-post-saved-state': isSavedState,
10263        'is-saving': isSaving,
10264        'is-autosaving': isAutosaving,
10265        'is-saved': isSaved,
10266        [(0,external_wp_components_namespaceObject.__unstableGetAnimateClassName)({
10267          type: 'loading'
10268        })]: isSaving
10269      }) : undefined,
10270      onClick: isDisabled ? undefined : () => savePost(),
10271      shortcut: external_wp_keycodes_namespaceObject.displayShortcut.primary('s'),
10272      variant: isLargeViewport ? 'tertiary' : undefined,
10273      icon: isLargeViewport ? undefined : cloud_upload,
10274      label: showIconLabels ? undefined : label,
10275      "aria-disabled": isDisabled
10276    }, isSavedState && (0,external_wp_element_namespaceObject.createElement)(icon, {
10277      icon: isSaved ? library_check : library_cloud
10278    }), text);
10279  }
10280  
10281  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-schedule/check.js
10282  /**
10283   * External dependencies
10284   */
10285  
10286  /**
10287   * WordPress dependencies
10288   */
10289  
10290  
10291  
10292  /**
10293   * Internal dependencies
10294   */
10295  
10296  
10297  function PostScheduleCheck(_ref) {
10298    let {
10299      hasPublishAction,
10300      children
10301    } = _ref;
10302  
10303    if (!hasPublishAction) {
10304      return null;
10305    }
10306  
10307    return children;
10308  }
10309  /* harmony default export */ var post_schedule_check = ((0,external_wp_compose_namespaceObject.compose)([(0,external_wp_data_namespaceObject.withSelect)(select => {
10310    const {
10311      getCurrentPost,
10312      getCurrentPostType
10313    } = select(store_store);
10314    return {
10315      hasPublishAction: (0,external_lodash_namespaceObject.get)(getCurrentPost(), ['_links', 'wp:action-publish'], false),
10316      postType: getCurrentPostType()
10317    };
10318  })])(PostScheduleCheck));
10319  
10320  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-slug/check.js
10321  
10322  
10323  /**
10324   * Internal dependencies
10325   */
10326  
10327  function PostSlugCheck(_ref) {
10328    let {
10329      children
10330    } = _ref;
10331    return (0,external_wp_element_namespaceObject.createElement)(post_type_support_check, {
10332      supportKeys: "slug"
10333    }, children);
10334  }
10335  
10336  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-slug/index.js
10337  
10338  
10339  /**
10340   * WordPress dependencies
10341   */
10342  
10343  
10344  
10345  
10346  
10347  /**
10348   * Internal dependencies
10349   */
10350  
10351  
10352  
10353  class PostSlug extends external_wp_element_namespaceObject.Component {
10354    constructor(_ref) {
10355      let {
10356        postSlug,
10357        postTitle,
10358        postID
10359      } = _ref;
10360      super(...arguments);
10361      this.state = {
10362        editedSlug: (0,external_wp_url_namespaceObject.safeDecodeURIComponent)(postSlug) || (0,external_wp_url_namespaceObject.cleanForSlug)(postTitle) || postID
10363      };
10364      this.setSlug = this.setSlug.bind(this);
10365    }
10366  
10367    setSlug(event) {
10368      const {
10369        postSlug,
10370        onUpdateSlug
10371      } = this.props;
10372      const {
10373        value
10374      } = event.target;
10375      const editedSlug = (0,external_wp_url_namespaceObject.cleanForSlug)(value);
10376  
10377      if (editedSlug === postSlug) {
10378        return;
10379      }
10380  
10381      onUpdateSlug(editedSlug);
10382    }
10383  
10384    render() {
10385      const {
10386        instanceId
10387      } = this.props;
10388      const {
10389        editedSlug
10390      } = this.state;
10391      const inputId = 'editor-post-slug-' + instanceId;
10392      return (0,external_wp_element_namespaceObject.createElement)(PostSlugCheck, null, (0,external_wp_element_namespaceObject.createElement)("label", {
10393        htmlFor: inputId
10394      }, (0,external_wp_i18n_namespaceObject.__)('Slug')), (0,external_wp_element_namespaceObject.createElement)("input", {
10395        autoComplete: "off",
10396        spellCheck: "false",
10397        type: "text",
10398        id: inputId,
10399        value: editedSlug,
10400        onChange: event => this.setState({
10401          editedSlug: event.target.value
10402        }),
10403        onBlur: this.setSlug,
10404        className: "editor-post-slug__input"
10405      }));
10406    }
10407  
10408  }
10409  /* harmony default export */ var post_slug = ((0,external_wp_compose_namespaceObject.compose)([(0,external_wp_data_namespaceObject.withSelect)(select => {
10410    const {
10411      getCurrentPost,
10412      getEditedPostAttribute
10413    } = select(store_store);
10414    const {
10415      id
10416    } = getCurrentPost();
10417    return {
10418      postSlug: getEditedPostAttribute('slug'),
10419      postTitle: getEditedPostAttribute('title'),
10420      postID: id
10421    };
10422  }), (0,external_wp_data_namespaceObject.withDispatch)(dispatch => {
10423    const {
10424      editPost
10425    } = dispatch(store_store);
10426    return {
10427      onUpdateSlug(slug) {
10428        editPost({
10429          slug
10430        });
10431      }
10432  
10433    };
10434  }), external_wp_compose_namespaceObject.withInstanceId])(PostSlug));
10435  
10436  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-sticky/check.js
10437  /**
10438   * External dependencies
10439   */
10440  
10441  /**
10442   * WordPress dependencies
10443   */
10444  
10445  
10446  
10447  /**
10448   * Internal dependencies
10449   */
10450  
10451  
10452  function PostStickyCheck(_ref) {
10453    let {
10454      hasStickyAction,
10455      postType,
10456      children
10457    } = _ref;
10458  
10459    if (postType !== 'post' || !hasStickyAction) {
10460      return null;
10461    }
10462  
10463    return children;
10464  }
10465  /* harmony default export */ var post_sticky_check = ((0,external_wp_compose_namespaceObject.compose)([(0,external_wp_data_namespaceObject.withSelect)(select => {
10466    const post = select(store_store).getCurrentPost();
10467    return {
10468      hasStickyAction: (0,external_lodash_namespaceObject.get)(post, ['_links', 'wp:action-sticky'], false),
10469      postType: select(store_store).getCurrentPostType()
10470    };
10471  })])(PostStickyCheck));
10472  
10473  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-sticky/index.js
10474  
10475  
10476  /**
10477   * WordPress dependencies
10478   */
10479  
10480  
10481  
10482  
10483  /**
10484   * Internal dependencies
10485   */
10486  
10487  
10488  
10489  function PostSticky(_ref) {
10490    let {
10491      onUpdateSticky,
10492      postSticky = false
10493    } = _ref;
10494    return (0,external_wp_element_namespaceObject.createElement)(post_sticky_check, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.CheckboxControl, {
10495      label: (0,external_wp_i18n_namespaceObject.__)('Stick to the top of the blog'),
10496      checked: postSticky,
10497      onChange: () => onUpdateSticky(!postSticky)
10498    }));
10499  }
10500  /* harmony default export */ var post_sticky = ((0,external_wp_compose_namespaceObject.compose)([(0,external_wp_data_namespaceObject.withSelect)(select => {
10501    return {
10502      postSticky: select(store_store).getEditedPostAttribute('sticky')
10503    };
10504  }), (0,external_wp_data_namespaceObject.withDispatch)(dispatch => {
10505    return {
10506      onUpdateSticky(postSticky) {
10507        dispatch(store_store).editPost({
10508          sticky: postSticky
10509        });
10510      }
10511  
10512    };
10513  })])(PostSticky));
10514  
10515  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-taxonomies/index.js
10516  
10517  
10518  /**
10519   * External dependencies
10520   */
10521  
10522  /**
10523   * WordPress dependencies
10524   */
10525  
10526  
10527  
10528  
10529  
10530  /**
10531   * Internal dependencies
10532   */
10533  
10534  
10535  
10536  
10537  function PostTaxonomies(_ref) {
10538    let {
10539      postType,
10540      taxonomies,
10541      taxonomyWrapper = external_lodash_namespaceObject.identity
10542    } = _ref;
10543    const availableTaxonomies = (0,external_lodash_namespaceObject.filter)(taxonomies, taxonomy => (0,external_lodash_namespaceObject.includes)(taxonomy.types, postType));
10544    const visibleTaxonomies = (0,external_lodash_namespaceObject.filter)(availableTaxonomies, // In some circumstances .visibility can end up as undefined so optional chaining operator required.
10545    // https://github.com/WordPress/gutenberg/issues/40326
10546    taxonomy => {
10547      var _taxonomy$visibility;
10548  
10549      return (_taxonomy$visibility = taxonomy.visibility) === null || _taxonomy$visibility === void 0 ? void 0 : _taxonomy$visibility.show_ui;
10550    });
10551    return visibleTaxonomies.map(taxonomy => {
10552      const TaxonomyComponent = taxonomy.hierarchical ? hierarchical_term_selector : flat_term_selector;
10553      return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, {
10554        key: `taxonomy-$taxonomy.slug}`
10555      }, taxonomyWrapper((0,external_wp_element_namespaceObject.createElement)(TaxonomyComponent, {
10556        slug: taxonomy.slug
10557      }), taxonomy));
10558    });
10559  }
10560  /* harmony default export */ var post_taxonomies = ((0,external_wp_compose_namespaceObject.compose)([(0,external_wp_data_namespaceObject.withSelect)(select => {
10561    return {
10562      postType: select(store_store).getCurrentPostType(),
10563      taxonomies: select(external_wp_coreData_namespaceObject.store).getTaxonomies({
10564        per_page: -1
10565      })
10566    };
10567  })])(PostTaxonomies));
10568  
10569  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-taxonomies/check.js
10570  /**
10571   * External dependencies
10572   */
10573  
10574  /**
10575   * WordPress dependencies
10576   */
10577  
10578  
10579  
10580  
10581  /**
10582   * Internal dependencies
10583   */
10584  
10585  
10586  function PostTaxonomiesCheck(_ref) {
10587    let {
10588      postType,
10589      taxonomies,
10590      children
10591    } = _ref;
10592    const hasTaxonomies = (0,external_lodash_namespaceObject.some)(taxonomies, taxonomy => (0,external_lodash_namespaceObject.includes)(taxonomy.types, postType));
10593  
10594    if (!hasTaxonomies) {
10595      return null;
10596    }
10597  
10598    return children;
10599  }
10600  /* harmony default export */ var post_taxonomies_check = ((0,external_wp_compose_namespaceObject.compose)([(0,external_wp_data_namespaceObject.withSelect)(select => {
10601    return {
10602      postType: select(store_store).getCurrentPostType(),
10603      taxonomies: select(external_wp_coreData_namespaceObject.store).getTaxonomies({
10604        per_page: -1
10605      })
10606    };
10607  })])(PostTaxonomiesCheck));
10608  
10609  // EXTERNAL MODULE: ./node_modules/react-autosize-textarea/lib/index.js
10610  var lib = __webpack_require__(773);
10611  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-text-editor/index.js
10612  
10613  
10614  /**
10615   * External dependencies
10616   */
10617  
10618  /**
10619   * WordPress dependencies
10620   */
10621  
10622  
10623  
10624  
10625  
10626  
10627  
10628  /**
10629   * Internal dependencies
10630   */
10631  
10632  
10633  function PostTextEditor() {
10634    const postContent = (0,external_wp_data_namespaceObject.useSelect)(select => select(store_store).getEditedPostContent(), []);
10635    const {
10636      editPost,
10637      resetEditorBlocks
10638    } = (0,external_wp_data_namespaceObject.useDispatch)(store_store);
10639    const [value, setValue] = (0,external_wp_element_namespaceObject.useState)(postContent);
10640    const [isDirty, setIsDirty] = (0,external_wp_element_namespaceObject.useState)(false);
10641    const instanceId = (0,external_wp_compose_namespaceObject.useInstanceId)(PostTextEditor);
10642  
10643    if (!isDirty && value !== postContent) {
10644      setValue(postContent);
10645    }
10646    /**
10647     * Handles a textarea change event to notify the onChange prop callback and
10648     * reflect the new value in the component's own state. This marks the start
10649     * of the user's edits, if not already changed, preventing future props
10650     * changes to value from replacing the rendered value. This is expected to
10651     * be followed by a reset to dirty state via `stopEditing`.
10652     *
10653     * @see stopEditing
10654     *
10655     * @param {Event} event Change event.
10656     */
10657  
10658  
10659    const onChange = event => {
10660      const newValue = event.target.value;
10661      editPost({
10662        content: newValue
10663      });
10664      setValue(newValue);
10665      setIsDirty(true);
10666    };
10667    /**
10668     * Function called when the user has completed their edits, responsible for
10669     * ensuring that changes, if made, are surfaced to the onPersist prop
10670     * callback and resetting dirty state.
10671     */
10672  
10673  
10674    const stopEditing = () => {
10675      if (isDirty) {
10676        const blocks = (0,external_wp_blocks_namespaceObject.parse)(value);
10677        resetEditorBlocks(blocks);
10678        setIsDirty(false);
10679      }
10680    };
10681  
10682    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.VisuallyHidden, {
10683      as: "label",
10684      htmlFor: `post-content-$instanceId}`
10685    }, (0,external_wp_i18n_namespaceObject.__)('Type text or HTML')), (0,external_wp_element_namespaceObject.createElement)(lib/* default */.Z, {
10686      autoComplete: "off",
10687      dir: "auto",
10688      value: value,
10689      onChange: onChange,
10690      onBlur: stopEditing,
10691      className: "editor-post-text-editor",
10692      id: `post-content-$instanceId}`,
10693      placeholder: (0,external_wp_i18n_namespaceObject.__)('Start writing with text or HTML')
10694    }));
10695  }
10696  
10697  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-title/index.js
10698  
10699  
10700  /**
10701   * External dependencies
10702   */
10703  
10704  /**
10705   * WordPress dependencies
10706   */
10707  
10708  
10709  
10710  
10711  
10712  
10713  
10714  
10715  
10716  
10717  /**
10718   * Internal dependencies
10719   */
10720  
10721  
10722  
10723  /**
10724   * Constants
10725   */
10726  
10727  const REGEXP_NEWLINES = /[\r\n]+/g;
10728  function PostTitle() {
10729    const ref = (0,external_wp_element_namespaceObject.useRef)();
10730    const [isSelected, setIsSelected] = (0,external_wp_element_namespaceObject.useState)(false);
10731    const {
10732      editPost
10733    } = (0,external_wp_data_namespaceObject.useDispatch)(store_store);
10734    const {
10735      insertDefaultBlock,
10736      clearSelectedBlock,
10737      insertBlocks
10738    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_blockEditor_namespaceObject.store);
10739    const {
10740      isCleanNewPost,
10741      title,
10742      placeholder,
10743      isFocusMode,
10744      hasFixedToolbar
10745    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
10746      const {
10747        getEditedPostAttribute,
10748        isCleanNewPost: _isCleanNewPost
10749      } = select(store_store);
10750      const {
10751        getSettings
10752      } = select(external_wp_blockEditor_namespaceObject.store);
10753      const {
10754        titlePlaceholder,
10755        focusMode,
10756        hasFixedToolbar: _hasFixedToolbar
10757      } = getSettings();
10758      return {
10759        isCleanNewPost: _isCleanNewPost(),
10760        title: getEditedPostAttribute('title'),
10761        placeholder: titlePlaceholder,
10762        isFocusMode: focusMode,
10763        hasFixedToolbar: _hasFixedToolbar
10764      };
10765    }, []);
10766    (0,external_wp_element_namespaceObject.useEffect)(() => {
10767      if (!ref.current) {
10768        return;
10769      }
10770  
10771      const {
10772        ownerDocument
10773      } = ref.current;
10774      const {
10775        activeElement,
10776        body
10777      } = ownerDocument; // Only autofocus the title when the post is entirely empty. This should
10778      // only happen for a new post, which means we focus the title on new
10779      // post so the author can start typing right away, without needing to
10780      // click anything.
10781  
10782      if (isCleanNewPost && (!activeElement || body === activeElement)) {
10783        ref.current.focus();
10784      }
10785    }, [isCleanNewPost]);
10786  
10787    function onEnterPress() {
10788      insertDefaultBlock(undefined, undefined, 0);
10789    }
10790  
10791    function onInsertBlockAfter(blocks) {
10792      insertBlocks(blocks, 0);
10793    }
10794  
10795    function onUpdate(newTitle) {
10796      editPost({
10797        title: newTitle
10798      });
10799    }
10800  
10801    const [selection, setSelection] = (0,external_wp_element_namespaceObject.useState)({});
10802  
10803    function onSelect() {
10804      setIsSelected(true);
10805      clearSelectedBlock();
10806    }
10807  
10808    function onUnselect() {
10809      setIsSelected(false);
10810      setSelection({});
10811    }
10812  
10813    function onChange(value) {
10814      onUpdate(value.replace(REGEXP_NEWLINES, ' '));
10815    }
10816  
10817    function onKeyDown(event) {
10818      if (event.keyCode === external_wp_keycodes_namespaceObject.ENTER) {
10819        event.preventDefault();
10820        onEnterPress();
10821      }
10822    }
10823  
10824    function onPaste(event) {
10825      const clipboardData = event.clipboardData;
10826      let plainText = '';
10827      let html = ''; // IE11 only supports `Text` as an argument for `getData` and will
10828      // otherwise throw an invalid argument error, so we try the standard
10829      // arguments first, then fallback to `Text` if they fail.
10830  
10831      try {
10832        plainText = clipboardData.getData('text/plain');
10833        html = clipboardData.getData('text/html');
10834      } catch (error1) {
10835        try {
10836          html = clipboardData.getData('Text');
10837        } catch (error2) {
10838          // Some browsers like UC Browser paste plain text by default and
10839          // don't support clipboardData at all, so allow default
10840          // behaviour.
10841          return;
10842        }
10843      } // Allows us to ask for this information when we get a report.
10844  
10845  
10846      window.console.log('Received HTML:\n\n', html);
10847      window.console.log('Received plain text:\n\n', plainText);
10848      const content = (0,external_wp_blocks_namespaceObject.pasteHandler)({
10849        HTML: html,
10850        plainText
10851      });
10852  
10853      if (typeof content !== 'string' && content.length) {
10854        event.preventDefault();
10855        const [firstBlock] = content;
10856  
10857        if (!title && (firstBlock.name === 'core/heading' || firstBlock.name === 'core/paragraph')) {
10858          onUpdate(firstBlock.attributes.content);
10859          onInsertBlockAfter(content.slice(1));
10860        } else {
10861          onInsertBlockAfter(content);
10862        }
10863      }
10864    } // The wp-block className is important for editor styles.
10865    // This same block is used in both the visual and the code editor.
10866  
10867  
10868    const className = classnames_default()('wp-block wp-block-post-title block-editor-block-list__block editor-post-title editor-post-title__input rich-text', {
10869      'is-selected': isSelected,
10870      'is-focus-mode': isFocusMode,
10871      'has-fixed-toolbar': hasFixedToolbar
10872    });
10873  
10874    const decodedPlaceholder = (0,external_wp_htmlEntities_namespaceObject.decodeEntities)(placeholder) || (0,external_wp_i18n_namespaceObject.__)('Add title');
10875  
10876    const {
10877      ref: richTextRef
10878    } = (0,external_wp_richText_namespaceObject.__unstableUseRichText)({
10879      value: title,
10880      onChange,
10881      placeholder: decodedPlaceholder,
10882      selectionStart: selection.start,
10883      selectionEnd: selection.end,
10884  
10885      onSelectionChange(newStart, newEnd) {
10886        setSelection(sel => {
10887          const {
10888            start,
10889            end
10890          } = sel;
10891  
10892          if (start === newStart && end === newEnd) {
10893            return sel;
10894          }
10895  
10896          return {
10897            start: newStart,
10898            end: newEnd
10899          };
10900        });
10901      },
10902  
10903      __unstableDisableFormats: true,
10904      preserveWhiteSpace: true
10905    });
10906    /* eslint-disable jsx-a11y/heading-has-content, jsx-a11y/no-noninteractive-element-to-interactive-role */
10907  
10908    return (0,external_wp_element_namespaceObject.createElement)(post_type_support_check, {
10909      supportKeys: "title"
10910    }, (0,external_wp_element_namespaceObject.createElement)("h1", {
10911      ref: (0,external_wp_compose_namespaceObject.useMergeRefs)([richTextRef, ref]),
10912      contentEditable: true,
10913      className: className,
10914      "aria-label": decodedPlaceholder,
10915      role: "textbox",
10916      "aria-multiline": "true",
10917      onFocus: onSelect,
10918      onBlur: onUnselect,
10919      onKeyDown: onKeyDown,
10920      onKeyPress: onUnselect,
10921      onPaste: onPaste
10922    }));
10923    /* eslint-enable jsx-a11y/heading-has-content, jsx-a11y/no-noninteractive-element-to-interactive-role */
10924  }
10925  
10926  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-trash/index.js
10927  
10928  
10929  /**
10930   * WordPress dependencies
10931   */
10932  
10933  
10934  
10935  /**
10936   * Internal dependencies
10937   */
10938  
10939  
10940  function PostTrash() {
10941    const {
10942      isNew,
10943      postId
10944    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
10945      const store = select(store_store);
10946      return {
10947        isNew: store.isEditedPostNew(),
10948        postId: store.getCurrentPostId()
10949      };
10950    }, []);
10951    const {
10952      trashPost
10953    } = (0,external_wp_data_namespaceObject.useDispatch)(store_store);
10954  
10955    if (isNew || !postId) {
10956      return null;
10957    }
10958  
10959    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
10960      className: "editor-post-trash",
10961      isDestructive: true,
10962      variant: "secondary",
10963      onClick: () => trashPost()
10964    }, (0,external_wp_i18n_namespaceObject.__)('Move to trash'));
10965  }
10966  
10967  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-trash/check.js
10968  /**
10969   * WordPress dependencies
10970   */
10971  
10972  
10973  /**
10974   * Internal dependencies
10975   */
10976  
10977  
10978  
10979  function PostTrashCheck(_ref) {
10980    let {
10981      isNew,
10982      postId,
10983      canUserDelete,
10984      children
10985    } = _ref;
10986  
10987    if (isNew || !postId || !canUserDelete) {
10988      return null;
10989    }
10990  
10991    return children;
10992  }
10993  
10994  /* harmony default export */ var post_trash_check = ((0,external_wp_data_namespaceObject.withSelect)(select => {
10995    const {
10996      isEditedPostNew,
10997      getCurrentPostId,
10998      getCurrentPostType
10999    } = select(store_store);
11000    const {
11001      getPostType,
11002      canUser
11003    } = select(external_wp_coreData_namespaceObject.store);
11004    const postId = getCurrentPostId();
11005    const postType = getPostType(getCurrentPostType());
11006    const resource = (postType === null || postType === void 0 ? void 0 : postType.rest_base) || ''; // eslint-disable-line camelcase
11007  
11008    return {
11009      isNew: isEditedPostNew(),
11010      postId,
11011      canUserDelete: postId && resource ? canUser('delete', resource, postId) : false
11012    };
11013  })(PostTrashCheck));
11014  
11015  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/post-visibility/check.js
11016  /**
11017   * External dependencies
11018   */
11019  
11020  /**
11021   * WordPress dependencies
11022   */
11023  
11024  
11025  
11026  /**
11027   * Internal dependencies
11028   */
11029  
11030  
11031  function PostVisibilityCheck(_ref) {
11032    let {
11033      hasPublishAction,
11034      render
11035    } = _ref;
11036    const canEdit = hasPublishAction;
11037    return render({
11038      canEdit
11039    });
11040  }
11041  /* harmony default export */ var post_visibility_check = ((0,external_wp_compose_namespaceObject.compose)([(0,external_wp_data_namespaceObject.withSelect)(select => {
11042    const {
11043      getCurrentPost,
11044      getCurrentPostType
11045    } = select(store_store);
11046    return {
11047      hasPublishAction: (0,external_lodash_namespaceObject.get)(getCurrentPost(), ['_links', 'wp:action-publish'], false),
11048      postType: getCurrentPostType()
11049    };
11050  })])(PostVisibilityCheck));
11051  
11052  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/info.js
11053  
11054  
11055  /**
11056   * WordPress dependencies
11057   */
11058  
11059  const info = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
11060    xmlns: "http://www.w3.org/2000/svg",
11061    viewBox: "0 0 24 24"
11062  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
11063    d: "M12 3.2c-4.8 0-8.8 3.9-8.8 8.8 0 4.8 3.9 8.8 8.8 8.8 4.8 0 8.8-3.9 8.8-8.8 0-4.8-4-8.8-8.8-8.8zm0 16c-4 0-7.2-3.3-7.2-7.2C4.8 8 8 4.8 12 4.8s7.2 3.3 7.2 7.2c0 4-3.2 7.2-7.2 7.2zM11 17h2v-6h-2v6zm0-8h2V7h-2v2z"
11064  }));
11065  /* harmony default export */ var library_info = (info);
11066  
11067  ;// CONCATENATED MODULE: external ["wp","wordcount"]
11068  var external_wp_wordcount_namespaceObject = window["wp"]["wordcount"];
11069  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/word-count/index.js
11070  
11071  
11072  /**
11073   * WordPress dependencies
11074   */
11075  
11076  
11077  
11078  /**
11079   * Internal dependencies
11080   */
11081  
11082  
11083  function WordCount() {
11084    const content = (0,external_wp_data_namespaceObject.useSelect)(select => select(store_store).getEditedPostAttribute('content'), []);
11085    /*
11086     * translators: If your word count is based on single characters (e.g. East Asian characters),
11087     * enter 'characters_excluding_spaces' or 'characters_including_spaces'. Otherwise, enter 'words'.
11088     * Do not translate into your own language.
11089     */
11090  
11091    const wordCountType = (0,external_wp_i18n_namespaceObject._x)('words', 'Word count type. Do not translate!');
11092  
11093    return (0,external_wp_element_namespaceObject.createElement)("span", {
11094      className: "word-count"
11095    }, (0,external_wp_wordcount_namespaceObject.count)(content, wordCountType));
11096  }
11097  
11098  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/character-count/index.js
11099  /**
11100   * WordPress dependencies
11101   */
11102  
11103  
11104  /**
11105   * Internal dependencies
11106   */
11107  
11108  
11109  function CharacterCount() {
11110    const content = (0,external_wp_data_namespaceObject.useSelect)(select => select(store_store).getEditedPostAttribute('content'), []);
11111    return (0,external_wp_wordcount_namespaceObject.count)(content, 'characters_including_spaces');
11112  }
11113  
11114  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/table-of-contents/panel.js
11115  
11116  
11117  /**
11118   * WordPress dependencies
11119   */
11120  
11121  
11122  
11123  /**
11124   * Internal dependencies
11125   */
11126  
11127  
11128  
11129  
11130  
11131  function TableOfContentsPanel(_ref) {
11132    let {
11133      hasOutlineItemsDisabled,
11134      onRequestClose
11135    } = _ref;
11136    const {
11137      headingCount,
11138      paragraphCount,
11139      numberOfBlocks
11140    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
11141      const {
11142        getGlobalBlockCount
11143      } = select(external_wp_blockEditor_namespaceObject.store);
11144      return {
11145        headingCount: getGlobalBlockCount('core/heading'),
11146        paragraphCount: getGlobalBlockCount('core/paragraph'),
11147        numberOfBlocks: getGlobalBlockCount()
11148      };
11149    }, []);
11150    return (
11151      /*
11152       * Disable reason: The `list` ARIA role is redundant but
11153       * Safari+VoiceOver won't announce the list otherwise.
11154       */
11155  
11156      /* eslint-disable jsx-a11y/no-redundant-roles */
11157      (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)("div", {
11158        className: "table-of-contents__wrapper",
11159        role: "note",
11160        "aria-label": (0,external_wp_i18n_namespaceObject.__)('Document Statistics'),
11161        tabIndex: "0"
11162      }, (0,external_wp_element_namespaceObject.createElement)("ul", {
11163        role: "list",
11164        className: "table-of-contents__counts"
11165      }, (0,external_wp_element_namespaceObject.createElement)("li", {
11166        className: "table-of-contents__count"
11167      }, (0,external_wp_i18n_namespaceObject.__)('Characters'), (0,external_wp_element_namespaceObject.createElement)("span", {
11168        className: "table-of-contents__number"
11169      }, (0,external_wp_element_namespaceObject.createElement)(CharacterCount, null))), (0,external_wp_element_namespaceObject.createElement)("li", {
11170        className: "table-of-contents__count"
11171      }, (0,external_wp_i18n_namespaceObject.__)('Words'), (0,external_wp_element_namespaceObject.createElement)(WordCount, null)), (0,external_wp_element_namespaceObject.createElement)("li", {
11172        className: "table-of-contents__count"
11173      }, (0,external_wp_i18n_namespaceObject.__)('Headings'), (0,external_wp_element_namespaceObject.createElement)("span", {
11174        className: "table-of-contents__number"
11175      }, headingCount)), (0,external_wp_element_namespaceObject.createElement)("li", {
11176        className: "table-of-contents__count"
11177      }, (0,external_wp_i18n_namespaceObject.__)('Paragraphs'), (0,external_wp_element_namespaceObject.createElement)("span", {
11178        className: "table-of-contents__number"
11179      }, paragraphCount)), (0,external_wp_element_namespaceObject.createElement)("li", {
11180        className: "table-of-contents__count"
11181      }, (0,external_wp_i18n_namespaceObject.__)('Blocks'), (0,external_wp_element_namespaceObject.createElement)("span", {
11182        className: "table-of-contents__number"
11183      }, numberOfBlocks)))), headingCount > 0 && (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)("hr", null), (0,external_wp_element_namespaceObject.createElement)("h2", {
11184        className: "table-of-contents__title"
11185      }, (0,external_wp_i18n_namespaceObject.__)('Document Outline')), (0,external_wp_element_namespaceObject.createElement)(document_outline, {
11186        onSelect: onRequestClose,
11187        hasOutlineItemsDisabled: hasOutlineItemsDisabled
11188      })))
11189      /* eslint-enable jsx-a11y/no-redundant-roles */
11190  
11191    );
11192  }
11193  
11194  /* harmony default export */ var panel = (TableOfContentsPanel);
11195  
11196  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/table-of-contents/index.js
11197  
11198  
11199  
11200  /**
11201   * WordPress dependencies
11202   */
11203  
11204  
11205  
11206  
11207  
11208  
11209  /**
11210   * Internal dependencies
11211   */
11212  
11213  
11214  
11215  function TableOfContents(_ref, ref) {
11216    let {
11217      hasOutlineItemsDisabled,
11218      repositionDropdown,
11219      ...props
11220    } = _ref;
11221    const hasBlocks = (0,external_wp_data_namespaceObject.useSelect)(select => !!select(external_wp_blockEditor_namespaceObject.store).getBlockCount(), []);
11222    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Dropdown, {
11223      position: repositionDropdown ? 'middle right right' : 'bottom',
11224      className: "table-of-contents",
11225      contentClassName: "table-of-contents__popover",
11226      renderToggle: _ref2 => {
11227        let {
11228          isOpen,
11229          onToggle
11230        } = _ref2;
11231        return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, _extends({}, props, {
11232          ref: ref,
11233          onClick: hasBlocks ? onToggle : undefined,
11234          icon: library_info,
11235          "aria-expanded": isOpen,
11236          "aria-haspopup": "true"
11237          /* translators: button label text should, if possible, be under 16 characters. */
11238          ,
11239          label: (0,external_wp_i18n_namespaceObject.__)('Details'),
11240          tooltipPosition: "bottom",
11241          "aria-disabled": !hasBlocks
11242        }));
11243      },
11244      renderContent: _ref3 => {
11245        let {
11246          onClose
11247        } = _ref3;
11248        return (0,external_wp_element_namespaceObject.createElement)(panel, {
11249          onRequestClose: onClose,
11250          hasOutlineItemsDisabled: hasOutlineItemsDisabled
11251        });
11252      }
11253    });
11254  }
11255  
11256  /* harmony default export */ var table_of_contents = ((0,external_wp_element_namespaceObject.forwardRef)(TableOfContents));
11257  
11258  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/unsaved-changes-warning/index.js
11259  /**
11260   * WordPress dependencies
11261   */
11262  
11263  
11264  
11265  
11266  /**
11267   * Warns the user if there are unsaved changes before leaving the editor.
11268   * Compatible with Post Editor and Site Editor.
11269   *
11270   * @return {WPComponent} The component.
11271   */
11272  
11273  function UnsavedChangesWarning() {
11274    const isDirty = (0,external_wp_data_namespaceObject.useSelect)(select => {
11275      return () => {
11276        const {
11277          __experimentalGetDirtyEntityRecords
11278        } = select(external_wp_coreData_namespaceObject.store);
11279  
11280        const dirtyEntityRecords = __experimentalGetDirtyEntityRecords();
11281  
11282        return dirtyEntityRecords.length > 0;
11283      };
11284    }, []);
11285    /**
11286     * Warns the user if there are unsaved changes before leaving the editor.
11287     *
11288     * @param {Event} event `beforeunload` event.
11289     *
11290     * @return {?string} Warning prompt message, if unsaved changes exist.
11291     */
11292  
11293    const warnIfUnsavedChanges = event => {
11294      // We need to call the selector directly in the listener to avoid race
11295      // conditions with `BrowserURL` where `componentDidUpdate` gets the
11296      // new value of `isEditedPostDirty` before this component does,
11297      // causing this component to incorrectly think a trashed post is still dirty.
11298      if (isDirty()) {
11299        event.returnValue = (0,external_wp_i18n_namespaceObject.__)('You have unsaved changes. If you proceed, they will be lost.');
11300        return event.returnValue;
11301      }
11302    };
11303  
11304    (0,external_wp_element_namespaceObject.useEffect)(() => {
11305      window.addEventListener('beforeunload', warnIfUnsavedChanges);
11306      return () => {
11307        window.removeEventListener('beforeunload', warnIfUnsavedChanges);
11308      };
11309    }, []);
11310    return null;
11311  }
11312  
11313  ;// CONCATENATED MODULE: external ["wp","reusableBlocks"]
11314  var external_wp_reusableBlocks_namespaceObject = window["wp"]["reusableBlocks"];
11315  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/provider/with-registry-provider.js
11316  
11317  
11318  /**
11319   * WordPress dependencies
11320   */
11321  
11322  
11323  
11324  
11325  /**
11326   * Internal dependencies
11327   */
11328  
11329  
11330  const withRegistryProvider = (0,external_wp_compose_namespaceObject.createHigherOrderComponent)(WrappedComponent => (0,external_wp_data_namespaceObject.withRegistry)(props => {
11331    const {
11332      useSubRegistry = true,
11333      registry,
11334      ...additionalProps
11335    } = props;
11336  
11337    if (!useSubRegistry) {
11338      return (0,external_wp_element_namespaceObject.createElement)(WrappedComponent, additionalProps);
11339    }
11340  
11341    const [subRegistry, setSubRegistry] = (0,external_wp_element_namespaceObject.useState)(null);
11342    (0,external_wp_element_namespaceObject.useEffect)(() => {
11343      const newRegistry = (0,external_wp_data_namespaceObject.createRegistry)({
11344        'core/block-editor': external_wp_blockEditor_namespaceObject.storeConfig
11345      }, registry);
11346      newRegistry.registerStore('core/editor', storeConfig);
11347      setSubRegistry(newRegistry);
11348    }, [registry]);
11349  
11350    if (!subRegistry) {
11351      return null;
11352    }
11353  
11354    return (0,external_wp_element_namespaceObject.createElement)(external_wp_data_namespaceObject.RegistryProvider, {
11355      value: subRegistry
11356    }, (0,external_wp_element_namespaceObject.createElement)(WrappedComponent, additionalProps));
11357  }), 'withRegistryProvider');
11358  /* harmony default export */ var with_registry_provider = (withRegistryProvider);
11359  
11360  ;// CONCATENATED MODULE: external ["wp","mediaUtils"]
11361  var external_wp_mediaUtils_namespaceObject = window["wp"]["mediaUtils"];
11362  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/utils/media-upload/index.js
11363  /**
11364   * External dependencies
11365   */
11366  
11367  /**
11368   * WordPress dependencies
11369   */
11370  
11371  
11372  
11373  /**
11374   * Internal dependencies
11375   */
11376  
11377  
11378  /**
11379   * Upload a media file when the file upload button is activated.
11380   * Wrapper around mediaUpload() that injects the current post ID.
11381   *
11382   * @param {Object}   $0                   Parameters object passed to the function.
11383   * @param {?Object}  $0.additionalData    Additional data to include in the request.
11384   * @param {string}   $0.allowedTypes      Array with the types of media that can be uploaded, if unset all types are allowed.
11385   * @param {Array}    $0.filesList         List of files.
11386   * @param {?number}  $0.maxUploadFileSize Maximum upload size in bytes allowed for the site.
11387   * @param {Function} $0.onError           Function called when an error happens.
11388   * @param {Function} $0.onFileChange      Function called each time a file or a temporary representation of the file is available.
11389   */
11390  
11391  function mediaUpload(_ref) {
11392    let {
11393      additionalData = {},
11394      allowedTypes,
11395      filesList,
11396      maxUploadFileSize,
11397      onError = external_lodash_namespaceObject.noop,
11398      onFileChange
11399    } = _ref;
11400    const {
11401      getCurrentPostId,
11402      getEditorSettings
11403    } = (0,external_wp_data_namespaceObject.select)(store_store);
11404    const wpAllowedMimeTypes = getEditorSettings().allowedMimeTypes;
11405    maxUploadFileSize = maxUploadFileSize || getEditorSettings().maxUploadFileSize;
11406    (0,external_wp_mediaUtils_namespaceObject.uploadMedia)({
11407      allowedTypes,
11408      filesList,
11409      onFileChange,
11410      additionalData: {
11411        post: getCurrentPostId(),
11412        ...additionalData
11413      },
11414      maxUploadFileSize,
11415      onError: _ref2 => {
11416        let {
11417          message
11418        } = _ref2;
11419        return onError(message);
11420      },
11421      wpAllowedMimeTypes
11422    });
11423  }
11424  
11425  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/provider/use-block-editor-settings.js
11426  /**
11427   * External dependencies
11428   */
11429  
11430  /**
11431   * WordPress dependencies
11432   */
11433  
11434  
11435  
11436  
11437  
11438  /**
11439   * Internal dependencies
11440   */
11441  
11442  
11443  
11444  /**
11445   * React hook used to compute the block editor settings to use for the post editor.
11446   *
11447   * @param {Object}  settings    EditorProvider settings prop.
11448   * @param {boolean} hasTemplate Whether template mode is enabled.
11449   *
11450   * @return {Object} Block Editor Settings.
11451   */
11452  
11453  function useBlockEditorSettings(settings, hasTemplate) {
11454    const {
11455      reusableBlocks,
11456      hasUploadPermissions,
11457      canUseUnfilteredHTML,
11458      userCanCreatePages,
11459      pageOnFront
11460    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
11461      const {
11462        canUserUseUnfilteredHTML
11463      } = select(store_store);
11464      const isWeb = external_wp_element_namespaceObject.Platform.OS === 'web';
11465      const {
11466        canUser,
11467        getEntityRecord
11468      } = select(external_wp_coreData_namespaceObject.store);
11469      const siteSettings = getEntityRecord('root', 'site');
11470      return {
11471        canUseUnfilteredHTML: canUserUseUnfilteredHTML(),
11472        reusableBlocks: isWeb ? select(external_wp_coreData_namespaceObject.store).getEntityRecords('postType', 'wp_block', {
11473          per_page: -1
11474        }) : [],
11475        // Reusable blocks are fetched in the native version of this hook.
11476        hasUploadPermissions: (0,external_lodash_namespaceObject.defaultTo)(canUser('create', 'media'), true),
11477        userCanCreatePages: canUser('create', 'pages'),
11478        pageOnFront: siteSettings === null || siteSettings === void 0 ? void 0 : siteSettings.page_on_front
11479      };
11480    }, []);
11481    const {
11482      __experimentalBlockPatterns: settingsBlockPatterns,
11483      __experimentalBlockPatternCategories: settingsBlockPatternCategories
11484    } = settings;
11485    const {
11486      blockPatterns,
11487      blockPatternCategories
11488    } = (0,external_wp_data_namespaceObject.useSelect)(select => ({
11489      blockPatterns: settingsBlockPatterns !== null && settingsBlockPatterns !== void 0 ? settingsBlockPatterns : select(external_wp_coreData_namespaceObject.store).getBlockPatterns(),
11490      blockPatternCategories: settingsBlockPatternCategories !== null && settingsBlockPatternCategories !== void 0 ? settingsBlockPatternCategories : select(external_wp_coreData_namespaceObject.store).getBlockPatternCategories()
11491    }), [settingsBlockPatterns, settingsBlockPatternCategories]);
11492    const {
11493      undo
11494    } = (0,external_wp_data_namespaceObject.useDispatch)(store_store);
11495    const {
11496      saveEntityRecord
11497    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_coreData_namespaceObject.store);
11498    /**
11499     * Creates a Post entity.
11500     * This is utilised by the Link UI to allow for on-the-fly creation of Posts/Pages.
11501     *
11502     * @param {Object} options parameters for the post being created. These mirror those used on 3rd param of saveEntityRecord.
11503     * @return {Object} the post type object that was created.
11504     */
11505  
11506    const createPageEntity = options => {
11507      if (!userCanCreatePages) {
11508        return Promise.reject({
11509          message: (0,external_wp_i18n_namespaceObject.__)('You do not have permission to create Pages.')
11510        });
11511      }
11512  
11513      return saveEntityRecord('postType', 'page', options);
11514    };
11515  
11516    return (0,external_wp_element_namespaceObject.useMemo)(() => ({ ...(0,external_lodash_namespaceObject.pick)(settings, ['__experimentalBlockDirectory', '__experimentalDiscussionSettings', '__experimentalFeatures', '__experimentalPreferredStyleVariations', '__experimentalSetIsInserterOpened', '__unstableGalleryWithImageBlocks', 'alignWide', 'allowedBlockTypes', 'bodyPlaceholder', 'canLockBlocks', 'codeEditingEnabled', 'colors', 'disableCustomColors', 'disableCustomFontSizes', 'disableCustomGradients', 'enableCustomLineHeight', 'enableCustomSpacing', 'enableCustomUnits', 'focusMode', 'fontSizes', 'gradients', 'generateAnchors', 'hasFixedToolbar', 'hasReducedUI', 'imageDefaultSize', 'imageDimensions', 'imageEditing', 'imageSizes', 'isRTL', 'keepCaretInsideBlock', 'maxWidth', 'onUpdateDefaultBlockStyles', 'styles', 'template', 'templateLock', 'titlePlaceholder', 'supportsLayout', 'widgetTypesToHideFromLegacyWidgetBlock', '__unstableResolvedAssets']),
11517      mediaUpload: hasUploadPermissions ? mediaUpload : undefined,
11518      __experimentalReusableBlocks: reusableBlocks,
11519      __experimentalBlockPatterns: blockPatterns,
11520      __experimentalBlockPatternCategories: blockPatternCategories,
11521      __experimentalFetchLinkSuggestions: (search, searchOptions) => (0,external_wp_coreData_namespaceObject.__experimentalFetchLinkSuggestions)(search, searchOptions, settings),
11522      __experimentalFetchRichUrlData: external_wp_coreData_namespaceObject.__experimentalFetchUrlData,
11523      __experimentalCanUserUseUnfilteredHTML: canUseUnfilteredHTML,
11524      __experimentalUndo: undo,
11525      outlineMode: hasTemplate,
11526      __experimentalCreatePageEntity: createPageEntity,
11527      __experimentalUserCanCreatePages: userCanCreatePages,
11528      pageOnFront,
11529      __experimentalPreferPatternsOnRoot: hasTemplate
11530    }), [settings, hasUploadPermissions, reusableBlocks, blockPatterns, blockPatternCategories, canUseUnfilteredHTML, undo, hasTemplate, userCanCreatePages, pageOnFront]);
11531  }
11532  
11533  /* harmony default export */ var use_block_editor_settings = (useBlockEditorSettings);
11534  
11535  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/provider/index.js
11536  
11537  
11538  /**
11539   * WordPress dependencies
11540   */
11541  
11542  
11543  
11544  
11545  
11546  
11547  
11548  /**
11549   * Internal dependencies
11550   */
11551  
11552  
11553  
11554  
11555  
11556  function EditorProvider(_ref) {
11557    let {
11558      __unstableTemplate,
11559      post,
11560      settings,
11561      recovery,
11562      initialEdits,
11563      children
11564    } = _ref;
11565    const defaultBlockContext = (0,external_wp_element_namespaceObject.useMemo)(() => {
11566      if (post.type === 'wp_template') {
11567        return {};
11568      }
11569  
11570      return {
11571        postId: post.id,
11572        postType: post.type
11573      };
11574    }, [post.id, post.type]);
11575    const {
11576      selection,
11577      isReady
11578    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
11579      const {
11580        getEditorSelection,
11581        __unstableIsEditorReady
11582      } = select(store_store);
11583      return {
11584        isReady: __unstableIsEditorReady(),
11585        selection: getEditorSelection()
11586      };
11587    }, []);
11588    const {
11589      id,
11590      type
11591    } = __unstableTemplate !== null && __unstableTemplate !== void 0 ? __unstableTemplate : post;
11592    const [blocks, onInput, onChange] = (0,external_wp_coreData_namespaceObject.useEntityBlockEditor)('postType', type, {
11593      id
11594    });
11595    const editorSettings = use_block_editor_settings(settings, !!__unstableTemplate);
11596    const {
11597      updatePostLock,
11598      setupEditor,
11599      updateEditorSettings,
11600      __experimentalTearDownEditor
11601    } = (0,external_wp_data_namespaceObject.useDispatch)(store_store);
11602    const {
11603      createWarningNotice
11604    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_notices_namespaceObject.store); // Initialize and tear down the editor.
11605    // Ideally this should be synced on each change and not just something you do once.
11606  
11607    (0,external_wp_element_namespaceObject.useLayoutEffect)(() => {
11608      // Assume that we don't need to initialize in the case of an error recovery.
11609      if (recovery) {
11610        return;
11611      }
11612  
11613      updatePostLock(settings.postLock);
11614      setupEditor(post, initialEdits, settings.template);
11615  
11616      if (settings.autosave) {
11617        createWarningNotice((0,external_wp_i18n_namespaceObject.__)('There is an autosave of this post that is more recent than the version below.'), {
11618          id: 'autosave-exists',
11619          actions: [{
11620            label: (0,external_wp_i18n_namespaceObject.__)('View the autosave'),
11621            url: settings.autosave.editLink
11622          }]
11623        });
11624      }
11625  
11626      return () => {
11627        __experimentalTearDownEditor();
11628      };
11629    }, []); // Synchronize the editor settings as they change.
11630  
11631    (0,external_wp_element_namespaceObject.useEffect)(() => {
11632      updateEditorSettings(settings);
11633    }, [settings]);
11634  
11635    if (!isReady) {
11636      return null;
11637    }
11638  
11639    return (0,external_wp_element_namespaceObject.createElement)(external_wp_coreData_namespaceObject.EntityProvider, {
11640      kind: "root",
11641      type: "site"
11642    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_coreData_namespaceObject.EntityProvider, {
11643      kind: "postType",
11644      type: post.type,
11645      id: post.id
11646    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockContextProvider, {
11647      value: defaultBlockContext
11648    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockEditorProvider, {
11649      value: blocks,
11650      onChange: onChange,
11651      onInput: onInput,
11652      selection: selection,
11653      settings: editorSettings,
11654      useSubRegistry: false
11655    }, children, (0,external_wp_element_namespaceObject.createElement)(external_wp_reusableBlocks_namespaceObject.ReusableBlocksMenuItems, null)))));
11656  }
11657  
11658  /* harmony default export */ var provider = (with_registry_provider(EditorProvider));
11659  
11660  ;// CONCATENATED MODULE: external ["wp","serverSideRender"]
11661  var external_wp_serverSideRender_namespaceObject = window["wp"]["serverSideRender"];
11662  var external_wp_serverSideRender_default = /*#__PURE__*/__webpack_require__.n(external_wp_serverSideRender_namespaceObject);
11663  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/deprecated.js
11664  
11665  
11666  // Block Creation Components.
11667  
11668  /**
11669   * WordPress dependencies
11670   */
11671  
11672  
11673  
11674  
11675  
11676  function deprecateComponent(name, Wrapped) {
11677    let staticsToHoist = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : [];
11678    const Component = (0,external_wp_element_namespaceObject.forwardRef)((props, ref) => {
11679      external_wp_deprecated_default()('wp.editor.' + name, {
11680        since: '5.3',
11681        alternative: 'wp.blockEditor.' + name,
11682        version: '6.2'
11683      });
11684      return (0,external_wp_element_namespaceObject.createElement)(Wrapped, _extends({
11685        ref: ref
11686      }, props));
11687    });
11688    staticsToHoist.forEach(staticName => {
11689      Component[staticName] = deprecateComponent(name + '.' + staticName, Wrapped[staticName]);
11690    });
11691    return Component;
11692  }
11693  
11694  function deprecateFunction(name, func) {
11695    return function () {
11696      external_wp_deprecated_default()('wp.editor.' + name, {
11697        since: '5.3',
11698        alternative: 'wp.blockEditor.' + name,
11699        version: '6.2'
11700      });
11701      return func(...arguments);
11702    };
11703  }
11704  
11705  const RichText = deprecateComponent('RichText', external_wp_blockEditor_namespaceObject.RichText, ['Content']);
11706  RichText.isEmpty = deprecateFunction('RichText.isEmpty', external_wp_blockEditor_namespaceObject.RichText.isEmpty);
11707  
11708  const Autocomplete = deprecateComponent('Autocomplete', external_wp_blockEditor_namespaceObject.Autocomplete);
11709  const AlignmentToolbar = deprecateComponent('AlignmentToolbar', external_wp_blockEditor_namespaceObject.AlignmentToolbar);
11710  const BlockAlignmentToolbar = deprecateComponent('BlockAlignmentToolbar', external_wp_blockEditor_namespaceObject.BlockAlignmentToolbar);
11711  const BlockControls = deprecateComponent('BlockControls', external_wp_blockEditor_namespaceObject.BlockControls, ['Slot']);
11712  const BlockEdit = deprecateComponent('BlockEdit', external_wp_blockEditor_namespaceObject.BlockEdit);
11713  const BlockEditorKeyboardShortcuts = deprecateComponent('BlockEditorKeyboardShortcuts', external_wp_blockEditor_namespaceObject.BlockEditorKeyboardShortcuts);
11714  const BlockFormatControls = deprecateComponent('BlockFormatControls', external_wp_blockEditor_namespaceObject.BlockFormatControls, ['Slot']);
11715  const BlockIcon = deprecateComponent('BlockIcon', external_wp_blockEditor_namespaceObject.BlockIcon);
11716  const BlockInspector = deprecateComponent('BlockInspector', external_wp_blockEditor_namespaceObject.BlockInspector);
11717  const BlockList = deprecateComponent('BlockList', external_wp_blockEditor_namespaceObject.BlockList);
11718  const BlockMover = deprecateComponent('BlockMover', external_wp_blockEditor_namespaceObject.BlockMover);
11719  const BlockNavigationDropdown = deprecateComponent('BlockNavigationDropdown', external_wp_blockEditor_namespaceObject.BlockNavigationDropdown);
11720  const BlockSelectionClearer = deprecateComponent('BlockSelectionClearer', external_wp_blockEditor_namespaceObject.BlockSelectionClearer);
11721  const BlockSettingsMenu = deprecateComponent('BlockSettingsMenu', external_wp_blockEditor_namespaceObject.BlockSettingsMenu);
11722  const BlockTitle = deprecateComponent('BlockTitle', external_wp_blockEditor_namespaceObject.BlockTitle);
11723  const BlockToolbar = deprecateComponent('BlockToolbar', external_wp_blockEditor_namespaceObject.BlockToolbar);
11724  const ColorPalette = deprecateComponent('ColorPalette', external_wp_blockEditor_namespaceObject.ColorPalette);
11725  const ContrastChecker = deprecateComponent('ContrastChecker', external_wp_blockEditor_namespaceObject.ContrastChecker);
11726  const CopyHandler = deprecateComponent('CopyHandler', external_wp_blockEditor_namespaceObject.CopyHandler);
11727  const DefaultBlockAppender = deprecateComponent('DefaultBlockAppender', external_wp_blockEditor_namespaceObject.DefaultBlockAppender);
11728  const FontSizePicker = deprecateComponent('FontSizePicker', external_wp_blockEditor_namespaceObject.FontSizePicker);
11729  const Inserter = deprecateComponent('Inserter', external_wp_blockEditor_namespaceObject.Inserter);
11730  const InnerBlocks = deprecateComponent('InnerBlocks', external_wp_blockEditor_namespaceObject.InnerBlocks, ['ButtonBlockAppender', 'DefaultBlockAppender', 'Content']);
11731  const InspectorAdvancedControls = deprecateComponent('InspectorAdvancedControls', external_wp_blockEditor_namespaceObject.InspectorAdvancedControls, ['Slot']);
11732  const InspectorControls = deprecateComponent('InspectorControls', external_wp_blockEditor_namespaceObject.InspectorControls, ['Slot']);
11733  const PanelColorSettings = deprecateComponent('PanelColorSettings', external_wp_blockEditor_namespaceObject.PanelColorSettings);
11734  const PlainText = deprecateComponent('PlainText', external_wp_blockEditor_namespaceObject.PlainText);
11735  const RichTextShortcut = deprecateComponent('RichTextShortcut', external_wp_blockEditor_namespaceObject.RichTextShortcut);
11736  const RichTextToolbarButton = deprecateComponent('RichTextToolbarButton', external_wp_blockEditor_namespaceObject.RichTextToolbarButton);
11737  const __unstableRichTextInputEvent = deprecateComponent('__unstableRichTextInputEvent', external_wp_blockEditor_namespaceObject.__unstableRichTextInputEvent);
11738  const MediaPlaceholder = deprecateComponent('MediaPlaceholder', external_wp_blockEditor_namespaceObject.MediaPlaceholder);
11739  const MediaUpload = deprecateComponent('MediaUpload', external_wp_blockEditor_namespaceObject.MediaUpload);
11740  const MediaUploadCheck = deprecateComponent('MediaUploadCheck', external_wp_blockEditor_namespaceObject.MediaUploadCheck);
11741  const MultiSelectScrollIntoView = deprecateComponent('MultiSelectScrollIntoView', external_wp_blockEditor_namespaceObject.MultiSelectScrollIntoView);
11742  const NavigableToolbar = deprecateComponent('NavigableToolbar', external_wp_blockEditor_namespaceObject.NavigableToolbar);
11743  const ObserveTyping = deprecateComponent('ObserveTyping', external_wp_blockEditor_namespaceObject.ObserveTyping);
11744  const SkipToSelectedBlock = deprecateComponent('SkipToSelectedBlock', external_wp_blockEditor_namespaceObject.SkipToSelectedBlock);
11745  const URLInput = deprecateComponent('URLInput', external_wp_blockEditor_namespaceObject.URLInput);
11746  const URLInputButton = deprecateComponent('URLInputButton', external_wp_blockEditor_namespaceObject.URLInputButton);
11747  const URLPopover = deprecateComponent('URLPopover', external_wp_blockEditor_namespaceObject.URLPopover);
11748  const Warning = deprecateComponent('Warning', external_wp_blockEditor_namespaceObject.Warning);
11749  const WritingFlow = deprecateComponent('WritingFlow', external_wp_blockEditor_namespaceObject.WritingFlow);
11750  const createCustomColorsHOC = deprecateFunction('createCustomColorsHOC', external_wp_blockEditor_namespaceObject.createCustomColorsHOC);
11751  const getColorClassName = deprecateFunction('getColorClassName', external_wp_blockEditor_namespaceObject.getColorClassName);
11752  const getColorObjectByAttributeValues = deprecateFunction('getColorObjectByAttributeValues', external_wp_blockEditor_namespaceObject.getColorObjectByAttributeValues);
11753  const getColorObjectByColorValue = deprecateFunction('getColorObjectByColorValue', external_wp_blockEditor_namespaceObject.getColorObjectByColorValue);
11754  const getFontSize = deprecateFunction('getFontSize', external_wp_blockEditor_namespaceObject.getFontSize);
11755  const getFontSizeClass = deprecateFunction('getFontSizeClass', external_wp_blockEditor_namespaceObject.getFontSizeClass);
11756  const withColorContext = deprecateFunction('withColorContext', external_wp_blockEditor_namespaceObject.withColorContext);
11757  const withColors = deprecateFunction('withColors', external_wp_blockEditor_namespaceObject.withColors);
11758  const withFontSizes = deprecateFunction('withFontSizes', external_wp_blockEditor_namespaceObject.withFontSizes);
11759  
11760  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/components/index.js
11761  // Block Creation Components.
11762   // Post Related Components.
11763  
11764  
11765  
11766  
11767  
11768  
11769  
11770  
11771  
11772  
11773  
11774  
11775  
11776  
11777  
11778  
11779  
11780  
11781  
11782  
11783  
11784  
11785  
11786  
11787  
11788  
11789  
11790  
11791  
11792  
11793  
11794  
11795  
11796  
11797  
11798  
11799  
11800  
11801  
11802  
11803  
11804  
11805  
11806  
11807  
11808  
11809  
11810  
11811  
11812  
11813  
11814  
11815  
11816  
11817  
11818  
11819  
11820  
11821  
11822  
11823  
11824   // State Related Components.
11825  
11826  
11827  
11828  
11829  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/utils/url.js
11830  /**
11831   * WordPress dependencies
11832   */
11833  
11834  
11835  /**
11836   * Performs some basic cleanup of a string for use as a post slug
11837   *
11838   * This replicates some of what sanitize_title() does in WordPress core, but
11839   * is only designed to approximate what the slug will be.
11840   *
11841   * Converts Latin-1 Supplement and Latin Extended-A letters to basic Latin letters.
11842   * Removes combining diacritical marks. Converts whitespace, periods,
11843   * and forward slashes to hyphens. Removes any remaining non-word characters
11844   * except hyphens and underscores. Converts remaining string to lowercase.
11845   * It does not account for octets, HTML entities, or other encoded characters.
11846   *
11847   * @param {string} string Title or slug to be processed
11848   *
11849   * @return {string} Processed string
11850   */
11851  
11852  function cleanForSlug(string) {
11853    external_wp_deprecated_default()('wp.editor.cleanForSlug', {
11854      since: '12.7',
11855      plugin: 'Gutenberg',
11856      alternative: 'wp.url.cleanForSlug'
11857    });
11858    return (0,external_wp_url_namespaceObject.cleanForSlug)(string);
11859  }
11860  
11861  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/utils/index.js
11862  /**
11863   * Internal dependencies
11864   */
11865  
11866  
11867  
11868  
11869  
11870  ;// CONCATENATED MODULE: ./node_modules/@wordpress/editor/build-module/index.js
11871  /**
11872   * Internal dependencies
11873   */
11874  
11875  
11876  
11877  
11878  /*
11879   * Backward compatibility
11880   */
11881  
11882  
11883  
11884  }();
11885  (window.wp = window.wp || {}).editor = __webpack_exports__;
11886  /******/ })()
11887  ;


Generated: Sun Dec 22 01:00:02 2024 Cross-referenced by PHPXref 0.7.1