[ Index ]

PHP Cross Reference of WordPress

title

Body

[close]

/wp-includes/js/dist/ -> block-library.js (source)

   1  /******/ (function() { // webpackBootstrap
   2  /******/     var __webpack_modules__ = ({
   3  
   4  /***/ 3827:
   5  /***/ (function(module, exports) {
   6  
   7  var __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;/*!
   8    Copyright (c) 2018 Jed Watson.
   9    Licensed under the MIT License (MIT), see
  10    http://jedwatson.github.io/classnames
  11  */
  12  /* global define */
  13  
  14  (function () {
  15      'use strict';
  16  
  17      var classNames = (function () {
  18          // don't inherit from Object so we can skip hasOwnProperty check later
  19          // http://stackoverflow.com/questions/15518328/creating-js-object-with-object-createnull#answer-21079232
  20  		function StorageObject() {}
  21          StorageObject.prototype = Object.create(null);
  22  
  23  		function _parseArray (resultSet, array) {
  24              var length = array.length;
  25  
  26              for (var i = 0; i < length; ++i) {
  27                  _parse(resultSet, array[i]);
  28              }
  29          }
  30  
  31          var hasOwn = {}.hasOwnProperty;
  32  
  33  		function _parseNumber (resultSet, num) {
  34              resultSet[num] = true;
  35          }
  36  
  37  		function _parseObject (resultSet, object) {
  38              if (object.toString === Object.prototype.toString) {
  39                  for (var k in object) {
  40                      if (hasOwn.call(object, k)) {
  41                          // set value to false instead of deleting it to avoid changing object structure
  42                          // https://www.smashingmagazine.com/2012/11/writing-fast-memory-efficient-javascript/#de-referencing-misconceptions
  43                          resultSet[k] = !!object[k];
  44                      }
  45                  }
  46              } else {
  47                  resultSet[object.toString()] = true;
  48              }
  49          }
  50  
  51          var SPACE = /\s+/;
  52  		function _parseString (resultSet, str) {
  53              var array = str.split(SPACE);
  54              var length = array.length;
  55  
  56              for (var i = 0; i < length; ++i) {
  57                  resultSet[array[i]] = true;
  58              }
  59          }
  60  
  61  		function _parse (resultSet, arg) {
  62              if (!arg) return;
  63              var argType = typeof arg;
  64  
  65              // 'foo bar'
  66              if (argType === 'string') {
  67                  _parseString(resultSet, arg);
  68  
  69              // ['foo', 'bar', ...]
  70              } else if (Array.isArray(arg)) {
  71                  _parseArray(resultSet, arg);
  72  
  73              // { 'foo': true, ... }
  74              } else if (argType === 'object') {
  75                  _parseObject(resultSet, arg);
  76  
  77              // '130'
  78              } else if (argType === 'number') {
  79                  _parseNumber(resultSet, arg);
  80              }
  81          }
  82  
  83  		function _classNames () {
  84              // don't leak arguments
  85              // https://github.com/petkaantonov/bluebird/wiki/Optimization-killers#32-leaking-arguments
  86              var len = arguments.length;
  87              var args = Array(len);
  88              for (var i = 0; i < len; i++) {
  89                  args[i] = arguments[i];
  90              }
  91  
  92              var classSet = new StorageObject();
  93              _parseArray(classSet, args);
  94  
  95              var list = [];
  96  
  97              for (var k in classSet) {
  98                  if (classSet[k]) {
  99                      list.push(k)
 100                  }
 101              }
 102  
 103              return list.join(' ');
 104          }
 105  
 106          return _classNames;
 107      })();
 108  
 109      if ( true && module.exports) {
 110          classNames.default = classNames;
 111          module.exports = classNames;
 112      } else if (true) {
 113          // register as 'classnames', consistent with npm package name
 114          !(__WEBPACK_AMD_DEFINE_ARRAY__ = [], __WEBPACK_AMD_DEFINE_RESULT__ = (function () {
 115              return classNames;
 116          }).apply(exports, __WEBPACK_AMD_DEFINE_ARRAY__),
 117          __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__));
 118      } else {}
 119  }());
 120  
 121  
 122  /***/ }),
 123  
 124  /***/ 4403:
 125  /***/ (function(module, exports) {
 126  
 127  var __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;/*!
 128    Copyright (c) 2018 Jed Watson.
 129    Licensed under the MIT License (MIT), see
 130    http://jedwatson.github.io/classnames
 131  */
 132  /* global define */
 133  
 134  (function () {
 135      'use strict';
 136  
 137      var hasOwn = {}.hasOwnProperty;
 138  
 139  	function classNames() {
 140          var classes = [];
 141  
 142          for (var i = 0; i < arguments.length; i++) {
 143              var arg = arguments[i];
 144              if (!arg) continue;
 145  
 146              var argType = typeof arg;
 147  
 148              if (argType === 'string' || argType === 'number') {
 149                  classes.push(arg);
 150              } else if (Array.isArray(arg)) {
 151                  if (arg.length) {
 152                      var inner = classNames.apply(null, arg);
 153                      if (inner) {
 154                          classes.push(inner);
 155                      }
 156                  }
 157              } else if (argType === 'object') {
 158                  if (arg.toString === Object.prototype.toString) {
 159                      for (var key in arg) {
 160                          if (hasOwn.call(arg, key) && arg[key]) {
 161                              classes.push(key);
 162                          }
 163                      }
 164                  } else {
 165                      classes.push(arg.toString());
 166                  }
 167              }
 168          }
 169  
 170          return classes.join(' ');
 171      }
 172  
 173      if ( true && module.exports) {
 174          classNames.default = classNames;
 175          module.exports = classNames;
 176      } else if (true) {
 177          // register as 'classnames', consistent with npm package name
 178          !(__WEBPACK_AMD_DEFINE_ARRAY__ = [], __WEBPACK_AMD_DEFINE_RESULT__ = (function () {
 179              return classNames;
 180          }).apply(exports, __WEBPACK_AMD_DEFINE_ARRAY__),
 181          __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__));
 182      } else {}
 183  }());
 184  
 185  
 186  /***/ }),
 187  
 188  /***/ 5027:
 189  /***/ (function(module) {
 190  
 191  /*! Fast Average Color | © 2019 Denis Seleznev | MIT License | https://github.com/hcodes/fast-average-color/ */
 192  (function (global, factory) {
 193       true ? module.exports = factory() :
 194      0;
 195  }(this, (function () { 'use strict';
 196  
 197  function _classCallCheck(instance, Constructor) {
 198    if (!(instance instanceof Constructor)) {
 199      throw new TypeError("Cannot call a class as a function");
 200    }
 201  }
 202  
 203  function _defineProperties(target, props) {
 204    for (var i = 0; i < props.length; i++) {
 205      var descriptor = props[i];
 206      descriptor.enumerable = descriptor.enumerable || false;
 207      descriptor.configurable = true;
 208      if ("value" in descriptor) descriptor.writable = true;
 209      Object.defineProperty(target, descriptor.key, descriptor);
 210    }
 211  }
 212  
 213  function _createClass(Constructor, protoProps, staticProps) {
 214    if (protoProps) _defineProperties(Constructor.prototype, protoProps);
 215    if (staticProps) _defineProperties(Constructor, staticProps);
 216    return Constructor;
 217  }
 218  
 219  function _slicedToArray(arr, i) {
 220    return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _nonIterableRest();
 221  }
 222  
 223  function _arrayWithHoles(arr) {
 224    if (Array.isArray(arr)) return arr;
 225  }
 226  
 227  function _iterableToArrayLimit(arr, i) {
 228    var _arr = [];
 229    var _n = true;
 230    var _d = false;
 231    var _e = undefined;
 232  
 233    try {
 234      for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) {
 235        _arr.push(_s.value);
 236  
 237        if (i && _arr.length === i) break;
 238      }
 239    } catch (err) {
 240      _d = true;
 241      _e = err;
 242    } finally {
 243      try {
 244        if (!_n && _i["return"] != null) _i["return"]();
 245      } finally {
 246        if (_d) throw _e;
 247      }
 248    }
 249  
 250    return _arr;
 251  }
 252  
 253  function _nonIterableRest() {
 254    throw new TypeError("Invalid attempt to destructure non-iterable instance");
 255  }
 256  
 257  var FastAverageColor =
 258  /*#__PURE__*/
 259  function () {
 260    function FastAverageColor() {
 261      _classCallCheck(this, FastAverageColor);
 262    }
 263  
 264    _createClass(FastAverageColor, [{
 265      key: "getColorAsync",
 266  
 267      /**
 268       * Get asynchronously the average color from not loaded image.
 269       *
 270       * @param {HTMLImageElement} resource
 271       * @param {Function} callback
 272       * @param {Object|null} [options]
 273       * @param {Array}  [options.defaultColor=[255, 255, 255, 255]]
 274       * @param {*}      [options.data]
 275       * @param {string} [options.mode="speed"] "precision" or "speed"
 276       * @param {string} [options.algorithm="sqrt"] "simple", "sqrt" or "dominant"
 277       * @param {number} [options.step=1]
 278       * @param {number} [options.left=0]
 279       * @param {number} [options.top=0]
 280       * @param {number} [options.width=width of resource]
 281       * @param {number} [options.height=height of resource]
 282       */
 283      value: function getColorAsync(resource, callback, options) {
 284        if (resource.complete) {
 285          callback.call(resource, this.getColor(resource, options), options && options.data);
 286        } else {
 287          this._bindImageEvents(resource, callback, options);
 288        }
 289      }
 290      /**
 291       * Get the average color from images, videos and canvas.
 292       *
 293       * @param {HTMLImageElement|HTMLVideoElement|HTMLCanvasElement} resource
 294       * @param {Object|null} [options]
 295       * @param {Array}  [options.defaultColor=[255, 255, 255, 255]]
 296       * @param {*}      [options.data]
 297       * @param {string} [options.mode="speed"] "precision" or "speed"
 298       * @param {string} [options.algorithm="sqrt"] "simple", "sqrt" or "dominant"
 299       * @param {number} [options.step=1]
 300       * @param {number} [options.left=0]
 301       * @param {number} [options.top=0]
 302       * @param {number} [options.width=width of resource]
 303       * @param {number} [options.height=height of resource]
 304       *
 305       * @returns {Object}
 306       */
 307  
 308    }, {
 309      key: "getColor",
 310      value: function getColor(resource, options) {
 311        options = options || {};
 312  
 313        var defaultColor = this._getDefaultColor(options),
 314            originalSize = this._getOriginalSize(resource),
 315            size = this._prepareSizeAndPosition(originalSize, options);
 316  
 317        var error = null,
 318            value = defaultColor;
 319  
 320        if (!size.srcWidth || !size.srcHeight || !size.destWidth || !size.destHeight) {
 321          return this._prepareResult(defaultColor, new Error('FastAverageColor: Incorrect sizes.'));
 322        }
 323  
 324        if (!this._ctx) {
 325          this._canvas = this._makeCanvas();
 326          this._ctx = this._canvas.getContext && this._canvas.getContext('2d');
 327  
 328          if (!this._ctx) {
 329            return this._prepareResult(defaultColor, new Error('FastAverageColor: Canvas Context 2D is not supported in this browser.'));
 330          }
 331        }
 332  
 333        this._canvas.width = size.destWidth;
 334        this._canvas.height = size.destHeight;
 335  
 336        try {
 337          this._ctx.clearRect(0, 0, size.destWidth, size.destHeight);
 338  
 339          this._ctx.drawImage(resource, size.srcLeft, size.srcTop, size.srcWidth, size.srcHeight, 0, 0, size.destWidth, size.destHeight);
 340  
 341          var bitmapData = this._ctx.getImageData(0, 0, size.destWidth, size.destHeight).data;
 342  
 343          value = this.getColorFromArray4(bitmapData, options);
 344        } catch (e) {
 345          // Security error, CORS
 346          // https://developer.mozilla.org/en/docs/Web/HTML/CORS_enabled_image
 347          error = e;
 348        }
 349  
 350        return this._prepareResult(value, error);
 351      }
 352      /**
 353       * Get the average color from a array when 1 pixel is 4 bytes.
 354       *
 355       * @param {Array|Uint8Array} arr
 356       * @param {Object} [options]
 357       * @param {string} [options.algorithm="sqrt"] "simple", "sqrt" or "dominant"
 358       * @param {Array}  [options.defaultColor=[255, 255, 255, 255]]
 359       * @param {number} [options.step=1]
 360       *
 361       * @returns {Array} [red (0-255), green (0-255), blue (0-255), alpha (0-255)]
 362       */
 363  
 364    }, {
 365      key: "getColorFromArray4",
 366      value: function getColorFromArray4(arr, options) {
 367        options = options || {};
 368        var bytesPerPixel = 4,
 369            arrLength = arr.length;
 370  
 371        if (arrLength < bytesPerPixel) {
 372          return this._getDefaultColor(options);
 373        }
 374  
 375        var len = arrLength - arrLength % bytesPerPixel,
 376            preparedStep = (options.step || 1) * bytesPerPixel,
 377            algorithm = '_' + (options.algorithm || 'sqrt') + 'Algorithm';
 378  
 379        if (typeof this[algorithm] !== 'function') {
 380          throw new Error("FastAverageColor: ".concat(options.algorithm, " is unknown algorithm."));
 381        }
 382  
 383        return this[algorithm](arr, len, preparedStep);
 384      }
 385      /**
 386       * Destroy the instance.
 387       */
 388  
 389    }, {
 390      key: "destroy",
 391      value: function destroy() {
 392        delete this._canvas;
 393        delete this._ctx;
 394      }
 395    }, {
 396      key: "_getDefaultColor",
 397      value: function _getDefaultColor(options) {
 398        return this._getOption(options, 'defaultColor', [255, 255, 255, 255]);
 399      }
 400    }, {
 401      key: "_getOption",
 402      value: function _getOption(options, name, defaultValue) {
 403        return typeof options[name] === 'undefined' ? defaultValue : options[name];
 404      }
 405    }, {
 406      key: "_prepareSizeAndPosition",
 407      value: function _prepareSizeAndPosition(originalSize, options) {
 408        var srcLeft = this._getOption(options, 'left', 0),
 409            srcTop = this._getOption(options, 'top', 0),
 410            srcWidth = this._getOption(options, 'width', originalSize.width),
 411            srcHeight = this._getOption(options, 'height', originalSize.height),
 412            destWidth = srcWidth,
 413            destHeight = srcHeight;
 414  
 415        if (options.mode === 'precision') {
 416          return {
 417            srcLeft: srcLeft,
 418            srcTop: srcTop,
 419            srcWidth: srcWidth,
 420            srcHeight: srcHeight,
 421            destWidth: destWidth,
 422            destHeight: destHeight
 423          };
 424        }
 425  
 426        var maxSize = 100,
 427            minSize = 10;
 428        var factor;
 429  
 430        if (srcWidth > srcHeight) {
 431          factor = srcWidth / srcHeight;
 432          destWidth = maxSize;
 433          destHeight = Math.round(destWidth / factor);
 434        } else {
 435          factor = srcHeight / srcWidth;
 436          destHeight = maxSize;
 437          destWidth = Math.round(destHeight / factor);
 438        }
 439  
 440        if (destWidth > srcWidth || destHeight > srcHeight || destWidth < minSize || destHeight < minSize) {
 441          destWidth = srcWidth;
 442          destHeight = srcHeight;
 443        }
 444  
 445        return {
 446          srcLeft: srcLeft,
 447          srcTop: srcTop,
 448          srcWidth: srcWidth,
 449          srcHeight: srcHeight,
 450          destWidth: destWidth,
 451          destHeight: destHeight
 452        };
 453      }
 454    }, {
 455      key: "_simpleAlgorithm",
 456      value: function _simpleAlgorithm(arr, len, preparedStep) {
 457        var redTotal = 0,
 458            greenTotal = 0,
 459            blueTotal = 0,
 460            alphaTotal = 0,
 461            count = 0;
 462  
 463        for (var i = 0; i < len; i += preparedStep) {
 464          var alpha = arr[i + 3],
 465              red = arr[i] * alpha,
 466              green = arr[i + 1] * alpha,
 467              blue = arr[i + 2] * alpha;
 468          redTotal += red;
 469          greenTotal += green;
 470          blueTotal += blue;
 471          alphaTotal += alpha;
 472          count++;
 473        }
 474  
 475        return alphaTotal ? [Math.round(redTotal / alphaTotal), Math.round(greenTotal / alphaTotal), Math.round(blueTotal / alphaTotal), Math.round(alphaTotal / count)] : [0, 0, 0, 0];
 476      }
 477    }, {
 478      key: "_sqrtAlgorithm",
 479      value: function _sqrtAlgorithm(arr, len, preparedStep) {
 480        var redTotal = 0,
 481            greenTotal = 0,
 482            blueTotal = 0,
 483            alphaTotal = 0,
 484            count = 0;
 485  
 486        for (var i = 0; i < len; i += preparedStep) {
 487          var red = arr[i],
 488              green = arr[i + 1],
 489              blue = arr[i + 2],
 490              alpha = arr[i + 3];
 491          redTotal += red * red * alpha;
 492          greenTotal += green * green * alpha;
 493          blueTotal += blue * blue * alpha;
 494          alphaTotal += alpha;
 495          count++;
 496        }
 497  
 498        return alphaTotal ? [Math.round(Math.sqrt(redTotal / alphaTotal)), Math.round(Math.sqrt(greenTotal / alphaTotal)), Math.round(Math.sqrt(blueTotal / alphaTotal)), Math.round(alphaTotal / count)] : [0, 0, 0, 0];
 499      }
 500    }, {
 501      key: "_dominantAlgorithm",
 502      value: function _dominantAlgorithm(arr, len, preparedStep) {
 503        var colorHash = {},
 504            divider = 24;
 505  
 506        for (var i = 0; i < len; i += preparedStep) {
 507          var red = arr[i],
 508              green = arr[i + 1],
 509              blue = arr[i + 2],
 510              alpha = arr[i + 3],
 511              key = Math.round(red / divider) + ',' + Math.round(green / divider) + ',' + Math.round(blue / divider);
 512  
 513          if (colorHash[key]) {
 514            colorHash[key] = [colorHash[key][0] + red * alpha, colorHash[key][1] + green * alpha, colorHash[key][2] + blue * alpha, colorHash[key][3] + alpha, colorHash[key][4] + 1];
 515          } else {
 516            colorHash[key] = [red * alpha, green * alpha, blue * alpha, alpha, 1];
 517          }
 518        }
 519  
 520        var buffer = Object.keys(colorHash).map(function (key) {
 521          return colorHash[key];
 522        }).sort(function (a, b) {
 523          var countA = a[4],
 524              countB = b[4];
 525          return countA > countB ? -1 : countA === countB ? 0 : 1;
 526        });
 527  
 528        var _buffer$ = _slicedToArray(buffer[0], 5),
 529            redTotal = _buffer$[0],
 530            greenTotal = _buffer$[1],
 531            blueTotal = _buffer$[2],
 532            alphaTotal = _buffer$[3],
 533            count = _buffer$[4];
 534  
 535        return alphaTotal ? [Math.round(redTotal / alphaTotal), Math.round(greenTotal / alphaTotal), Math.round(blueTotal / alphaTotal), Math.round(alphaTotal / count)] : [0, 0, 0, 0];
 536      }
 537    }, {
 538      key: "_bindImageEvents",
 539      value: function _bindImageEvents(resource, callback, options) {
 540        var _this = this;
 541  
 542        options = options || {};
 543  
 544        var data = options && options.data,
 545            defaultColor = this._getDefaultColor(options),
 546            onload = function onload() {
 547          unbindEvents();
 548          callback.call(resource, _this.getColor(resource, options), data);
 549        },
 550            onerror = function onerror() {
 551          unbindEvents();
 552          callback.call(resource, _this._prepareResult(defaultColor, new Error('Image error')), data);
 553        },
 554            onabort = function onabort() {
 555          unbindEvents();
 556          callback.call(resource, _this._prepareResult(defaultColor, new Error('Image abort')), data);
 557        },
 558            unbindEvents = function unbindEvents() {
 559          resource.removeEventListener('load', onload);
 560          resource.removeEventListener('error', onerror);
 561          resource.removeEventListener('abort', onabort);
 562        };
 563  
 564        resource.addEventListener('load', onload);
 565        resource.addEventListener('error', onerror);
 566        resource.addEventListener('abort', onabort);
 567      }
 568    }, {
 569      key: "_prepareResult",
 570      value: function _prepareResult(value, error) {
 571        var rgb = value.slice(0, 3),
 572            rgba = [].concat(rgb, value[3] / 255),
 573            isDark = this._isDark(value);
 574  
 575        return {
 576          error: error,
 577          value: value,
 578          rgb: 'rgb(' + rgb.join(',') + ')',
 579          rgba: 'rgba(' + rgba.join(',') + ')',
 580          hex: this._arrayToHex(rgb),
 581          hexa: this._arrayToHex(value),
 582          isDark: isDark,
 583          isLight: !isDark
 584        };
 585      }
 586    }, {
 587      key: "_getOriginalSize",
 588      value: function _getOriginalSize(resource) {
 589        if (resource instanceof HTMLImageElement) {
 590          return {
 591            width: resource.naturalWidth,
 592            height: resource.naturalHeight
 593          };
 594        }
 595  
 596        if (resource instanceof HTMLVideoElement) {
 597          return {
 598            width: resource.videoWidth,
 599            height: resource.videoHeight
 600          };
 601        }
 602  
 603        return {
 604          width: resource.width,
 605          height: resource.height
 606        };
 607      }
 608    }, {
 609      key: "_toHex",
 610      value: function _toHex(num) {
 611        var str = num.toString(16);
 612        return str.length === 1 ? '0' + str : str;
 613      }
 614    }, {
 615      key: "_arrayToHex",
 616      value: function _arrayToHex(arr) {
 617        return '#' + arr.map(this._toHex).join('');
 618      }
 619    }, {
 620      key: "_isDark",
 621      value: function _isDark(color) {
 622        // http://www.w3.org/TR/AERT#color-contrast
 623        var result = (color[0] * 299 + color[1] * 587 + color[2] * 114) / 1000;
 624        return result < 128;
 625      }
 626    }, {
 627      key: "_makeCanvas",
 628      value: function _makeCanvas() {
 629        return typeof window === 'undefined' ? new OffscreenCanvas(1, 1) : document.createElement('canvas');
 630      }
 631    }]);
 632  
 633    return FastAverageColor;
 634  }();
 635  
 636  return FastAverageColor;
 637  
 638  })));
 639  
 640  
 641  /***/ }),
 642  
 643  /***/ 9756:
 644  /***/ (function(module) {
 645  
 646  /**
 647   * Memize options object.
 648   *
 649   * @typedef MemizeOptions
 650   *
 651   * @property {number} [maxSize] Maximum size of the cache.
 652   */
 653  
 654  /**
 655   * Internal cache entry.
 656   *
 657   * @typedef MemizeCacheNode
 658   *
 659   * @property {?MemizeCacheNode|undefined} [prev] Previous node.
 660   * @property {?MemizeCacheNode|undefined} [next] Next node.
 661   * @property {Array<*>}                   args   Function arguments for cache
 662   *                                               entry.
 663   * @property {*}                          val    Function result.
 664   */
 665  
 666  /**
 667   * Properties of the enhanced function for controlling cache.
 668   *
 669   * @typedef MemizeMemoizedFunction
 670   *
 671   * @property {()=>void} clear Clear the cache.
 672   */
 673  
 674  /**
 675   * Accepts a function to be memoized, and returns a new memoized function, with
 676   * optional options.
 677   *
 678   * @template {Function} F
 679   *
 680   * @param {F}             fn        Function to memoize.
 681   * @param {MemizeOptions} [options] Options object.
 682   *
 683   * @return {F & MemizeMemoizedFunction} Memoized function.
 684   */
 685  function memize( fn, options ) {
 686      var size = 0;
 687  
 688      /** @type {?MemizeCacheNode|undefined} */
 689      var head;
 690  
 691      /** @type {?MemizeCacheNode|undefined} */
 692      var tail;
 693  
 694      options = options || {};
 695  
 696  	function memoized( /* ...args */ ) {
 697          var node = head,
 698              len = arguments.length,
 699              args, i;
 700  
 701          searchCache: while ( node ) {
 702              // Perform a shallow equality test to confirm that whether the node
 703              // under test is a candidate for the arguments passed. Two arrays
 704              // are shallowly equal if their length matches and each entry is
 705              // strictly equal between the two sets. Avoid abstracting to a
 706              // function which could incur an arguments leaking deoptimization.
 707  
 708              // Check whether node arguments match arguments length
 709              if ( node.args.length !== arguments.length ) {
 710                  node = node.next;
 711                  continue;
 712              }
 713  
 714              // Check whether node arguments match arguments values
 715              for ( i = 0; i < len; i++ ) {
 716                  if ( node.args[ i ] !== arguments[ i ] ) {
 717                      node = node.next;
 718                      continue searchCache;
 719                  }
 720              }
 721  
 722              // At this point we can assume we've found a match
 723  
 724              // Surface matched node to head if not already
 725              if ( node !== head ) {
 726                  // As tail, shift to previous. Must only shift if not also
 727                  // head, since if both head and tail, there is no previous.
 728                  if ( node === tail ) {
 729                      tail = node.prev;
 730                  }
 731  
 732                  // Adjust siblings to point to each other. If node was tail,
 733                  // this also handles new tail's empty `next` assignment.
 734                  /** @type {MemizeCacheNode} */ ( node.prev ).next = node.next;
 735                  if ( node.next ) {
 736                      node.next.prev = node.prev;
 737                  }
 738  
 739                  node.next = head;
 740                  node.prev = null;
 741                  /** @type {MemizeCacheNode} */ ( head ).prev = node;
 742                  head = node;
 743              }
 744  
 745              // Return immediately
 746              return node.val;
 747          }
 748  
 749          // No cached value found. Continue to insertion phase:
 750  
 751          // Create a copy of arguments (avoid leaking deoptimization)
 752          args = new Array( len );
 753          for ( i = 0; i < len; i++ ) {
 754              args[ i ] = arguments[ i ];
 755          }
 756  
 757          node = {
 758              args: args,
 759  
 760              // Generate the result from original function
 761              val: fn.apply( null, args ),
 762          };
 763  
 764          // Don't need to check whether node is already head, since it would
 765          // have been returned above already if it was
 766  
 767          // Shift existing head down list
 768          if ( head ) {
 769              head.prev = node;
 770              node.next = head;
 771          } else {
 772              // If no head, follows that there's no tail (at initial or reset)
 773              tail = node;
 774          }
 775  
 776          // Trim tail if we're reached max size and are pending cache insertion
 777          if ( size === /** @type {MemizeOptions} */ ( options ).maxSize ) {
 778              tail = /** @type {MemizeCacheNode} */ ( tail ).prev;
 779              /** @type {MemizeCacheNode} */ ( tail ).next = null;
 780          } else {
 781              size++;
 782          }
 783  
 784          head = node;
 785  
 786          return node.val;
 787      }
 788  
 789      memoized.clear = function() {
 790          head = null;
 791          tail = null;
 792          size = 0;
 793      };
 794  
 795      if ( false ) {}
 796  
 797      // Ignore reason: There's not a clear solution to create an intersection of
 798      // the function with additional properties, where the goal is to retain the
 799      // function signature of the incoming argument and add control properties
 800      // on the return value.
 801  
 802      // @ts-ignore
 803      return memoized;
 804  }
 805  
 806  module.exports = memize;
 807  
 808  
 809  /***/ })
 810  
 811  /******/     });
 812  /************************************************************************/
 813  /******/     // The module cache
 814  /******/     var __webpack_module_cache__ = {};
 815  /******/     
 816  /******/     // The require function
 817  /******/ 	function __webpack_require__(moduleId) {
 818  /******/         // Check if module is in cache
 819  /******/         var cachedModule = __webpack_module_cache__[moduleId];
 820  /******/         if (cachedModule !== undefined) {
 821  /******/             return cachedModule.exports;
 822  /******/         }
 823  /******/         // Create a new module (and put it into the cache)
 824  /******/         var module = __webpack_module_cache__[moduleId] = {
 825  /******/             // no module.id needed
 826  /******/             // no module.loaded needed
 827  /******/             exports: {}
 828  /******/         };
 829  /******/     
 830  /******/         // Execute the module function
 831  /******/         __webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);
 832  /******/     
 833  /******/         // Return the exports of the module
 834  /******/         return module.exports;
 835  /******/     }
 836  /******/     
 837  /************************************************************************/
 838  /******/     /* webpack/runtime/compat get default export */
 839  /******/     !function() {
 840  /******/         // getDefaultExport function for compatibility with non-harmony modules
 841  /******/         __webpack_require__.n = function(module) {
 842  /******/             var getter = module && module.__esModule ?
 843  /******/                 function() { return module['default']; } :
 844  /******/                 function() { return module; };
 845  /******/             __webpack_require__.d(getter, { a: getter });
 846  /******/             return getter;
 847  /******/         };
 848  /******/     }();
 849  /******/     
 850  /******/     /* webpack/runtime/define property getters */
 851  /******/     !function() {
 852  /******/         // define getter functions for harmony exports
 853  /******/         __webpack_require__.d = function(exports, definition) {
 854  /******/             for(var key in definition) {
 855  /******/                 if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {
 856  /******/                     Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });
 857  /******/                 }
 858  /******/             }
 859  /******/         };
 860  /******/     }();
 861  /******/     
 862  /******/     /* webpack/runtime/hasOwnProperty shorthand */
 863  /******/     !function() {
 864  /******/         __webpack_require__.o = function(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); }
 865  /******/     }();
 866  /******/     
 867  /******/     /* webpack/runtime/make namespace object */
 868  /******/     !function() {
 869  /******/         // define __esModule on exports
 870  /******/         __webpack_require__.r = function(exports) {
 871  /******/             if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
 872  /******/                 Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
 873  /******/             }
 874  /******/             Object.defineProperty(exports, '__esModule', { value: true });
 875  /******/         };
 876  /******/     }();
 877  /******/     
 878  /************************************************************************/
 879  var __webpack_exports__ = {};
 880  // This entry need to be wrapped in an IIFE because it need to be in strict mode.
 881  !function() {
 882  "use strict";
 883  // ESM COMPAT FLAG
 884  __webpack_require__.r(__webpack_exports__);
 885  
 886  // EXPORTS
 887  __webpack_require__.d(__webpack_exports__, {
 888    "__experimentalGetCoreBlocks": function() { return /* binding */ __experimentalGetCoreBlocks; },
 889    "__experimentalRegisterExperimentalCoreBlocks": function() { return /* binding */ __experimentalRegisterExperimentalCoreBlocks; },
 890    "registerCoreBlocks": function() { return /* binding */ registerCoreBlocks; }
 891  });
 892  
 893  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/archives/index.js
 894  var archives_namespaceObject = {};
 895  __webpack_require__.r(archives_namespaceObject);
 896  __webpack_require__.d(archives_namespaceObject, {
 897    "metadata": function() { return metadata; },
 898    "name": function() { return archives_name; },
 899    "settings": function() { return settings; }
 900  });
 901  
 902  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/avatar/index.js
 903  var avatar_namespaceObject = {};
 904  __webpack_require__.r(avatar_namespaceObject);
 905  __webpack_require__.d(avatar_namespaceObject, {
 906    "metadata": function() { return avatar_metadata; },
 907    "name": function() { return avatar_name; },
 908    "settings": function() { return avatar_settings; }
 909  });
 910  
 911  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/audio/index.js
 912  var build_module_audio_namespaceObject = {};
 913  __webpack_require__.r(build_module_audio_namespaceObject);
 914  __webpack_require__.d(build_module_audio_namespaceObject, {
 915    "metadata": function() { return audio_metadata; },
 916    "name": function() { return audio_name; },
 917    "settings": function() { return audio_settings; }
 918  });
 919  
 920  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/button/index.js
 921  var build_module_button_namespaceObject = {};
 922  __webpack_require__.r(build_module_button_namespaceObject);
 923  __webpack_require__.d(build_module_button_namespaceObject, {
 924    "metadata": function() { return button_metadata; },
 925    "name": function() { return button_name; },
 926    "settings": function() { return button_settings; }
 927  });
 928  
 929  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/buttons/index.js
 930  var build_module_buttons_namespaceObject = {};
 931  __webpack_require__.r(build_module_buttons_namespaceObject);
 932  __webpack_require__.d(build_module_buttons_namespaceObject, {
 933    "metadata": function() { return buttons_metadata; },
 934    "name": function() { return buttons_name; },
 935    "settings": function() { return buttons_settings; }
 936  });
 937  
 938  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/calendar/index.js
 939  var build_module_calendar_namespaceObject = {};
 940  __webpack_require__.r(build_module_calendar_namespaceObject);
 941  __webpack_require__.d(build_module_calendar_namespaceObject, {
 942    "metadata": function() { return calendar_metadata; },
 943    "name": function() { return calendar_name; },
 944    "settings": function() { return calendar_settings; }
 945  });
 946  
 947  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/categories/index.js
 948  var categories_namespaceObject = {};
 949  __webpack_require__.r(categories_namespaceObject);
 950  __webpack_require__.d(categories_namespaceObject, {
 951    "metadata": function() { return categories_metadata; },
 952    "name": function() { return categories_name; },
 953    "settings": function() { return categories_settings; }
 954  });
 955  
 956  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/freeform/index.js
 957  var freeform_namespaceObject = {};
 958  __webpack_require__.r(freeform_namespaceObject);
 959  __webpack_require__.d(freeform_namespaceObject, {
 960    "metadata": function() { return freeform_metadata; },
 961    "name": function() { return freeform_name; },
 962    "settings": function() { return freeform_settings; }
 963  });
 964  
 965  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/code/index.js
 966  var build_module_code_namespaceObject = {};
 967  __webpack_require__.r(build_module_code_namespaceObject);
 968  __webpack_require__.d(build_module_code_namespaceObject, {
 969    "metadata": function() { return code_metadata; },
 970    "name": function() { return code_name; },
 971    "settings": function() { return code_settings; }
 972  });
 973  
 974  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/column/index.js
 975  var build_module_column_namespaceObject = {};
 976  __webpack_require__.r(build_module_column_namespaceObject);
 977  __webpack_require__.d(build_module_column_namespaceObject, {
 978    "metadata": function() { return column_metadata; },
 979    "name": function() { return column_name; },
 980    "settings": function() { return column_settings; }
 981  });
 982  
 983  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/columns/index.js
 984  var build_module_columns_namespaceObject = {};
 985  __webpack_require__.r(build_module_columns_namespaceObject);
 986  __webpack_require__.d(build_module_columns_namespaceObject, {
 987    "metadata": function() { return columns_metadata; },
 988    "name": function() { return columns_name; },
 989    "settings": function() { return columns_settings; }
 990  });
 991  
 992  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/comment-author-name/index.js
 993  var build_module_comment_author_name_namespaceObject = {};
 994  __webpack_require__.r(build_module_comment_author_name_namespaceObject);
 995  __webpack_require__.d(build_module_comment_author_name_namespaceObject, {
 996    "metadata": function() { return comment_author_name_metadata; },
 997    "name": function() { return comment_author_name_name; },
 998    "settings": function() { return comment_author_name_settings; }
 999  });
1000  
1001  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/comment-content/index.js
1002  var build_module_comment_content_namespaceObject = {};
1003  __webpack_require__.r(build_module_comment_content_namespaceObject);
1004  __webpack_require__.d(build_module_comment_content_namespaceObject, {
1005    "metadata": function() { return comment_content_metadata; },
1006    "name": function() { return comment_content_name; },
1007    "settings": function() { return comment_content_settings; }
1008  });
1009  
1010  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/comment-date/index.js
1011  var comment_date_namespaceObject = {};
1012  __webpack_require__.r(comment_date_namespaceObject);
1013  __webpack_require__.d(comment_date_namespaceObject, {
1014    "metadata": function() { return comment_date_metadata; },
1015    "name": function() { return comment_date_name; },
1016    "settings": function() { return comment_date_settings; }
1017  });
1018  
1019  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/comment-edit-link/index.js
1020  var build_module_comment_edit_link_namespaceObject = {};
1021  __webpack_require__.r(build_module_comment_edit_link_namespaceObject);
1022  __webpack_require__.d(build_module_comment_edit_link_namespaceObject, {
1023    "metadata": function() { return comment_edit_link_metadata; },
1024    "name": function() { return comment_edit_link_name; },
1025    "settings": function() { return comment_edit_link_settings; }
1026  });
1027  
1028  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/comment-reply-link/index.js
1029  var build_module_comment_reply_link_namespaceObject = {};
1030  __webpack_require__.r(build_module_comment_reply_link_namespaceObject);
1031  __webpack_require__.d(build_module_comment_reply_link_namespaceObject, {
1032    "metadata": function() { return comment_reply_link_metadata; },
1033    "name": function() { return comment_reply_link_name; },
1034    "settings": function() { return comment_reply_link_settings; }
1035  });
1036  
1037  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/comment-template/index.js
1038  var comment_template_namespaceObject = {};
1039  __webpack_require__.r(comment_template_namespaceObject);
1040  __webpack_require__.d(comment_template_namespaceObject, {
1041    "metadata": function() { return comment_template_metadata; },
1042    "name": function() { return comment_template_name; },
1043    "settings": function() { return comment_template_settings; }
1044  });
1045  
1046  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/comments-pagination-previous/index.js
1047  var comments_pagination_previous_namespaceObject = {};
1048  __webpack_require__.r(comments_pagination_previous_namespaceObject);
1049  __webpack_require__.d(comments_pagination_previous_namespaceObject, {
1050    "metadata": function() { return comments_pagination_previous_metadata; },
1051    "name": function() { return comments_pagination_previous_name; },
1052    "settings": function() { return comments_pagination_previous_settings; }
1053  });
1054  
1055  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/comments-query-loop/index.js
1056  var comments_query_loop_namespaceObject = {};
1057  __webpack_require__.r(comments_query_loop_namespaceObject);
1058  __webpack_require__.d(comments_query_loop_namespaceObject, {
1059    "metadata": function() { return comments_query_loop_metadata; },
1060    "name": function() { return comments_query_loop_name; },
1061    "settings": function() { return comments_query_loop_settings; }
1062  });
1063  
1064  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/comments-pagination/index.js
1065  var comments_pagination_namespaceObject = {};
1066  __webpack_require__.r(comments_pagination_namespaceObject);
1067  __webpack_require__.d(comments_pagination_namespaceObject, {
1068    "metadata": function() { return comments_pagination_metadata; },
1069    "name": function() { return comments_pagination_name; },
1070    "settings": function() { return comments_pagination_settings; }
1071  });
1072  
1073  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/comments-pagination-next/index.js
1074  var comments_pagination_next_namespaceObject = {};
1075  __webpack_require__.r(comments_pagination_next_namespaceObject);
1076  __webpack_require__.d(comments_pagination_next_namespaceObject, {
1077    "metadata": function() { return comments_pagination_next_metadata; },
1078    "name": function() { return comments_pagination_next_name; },
1079    "settings": function() { return comments_pagination_next_settings; }
1080  });
1081  
1082  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/comments-pagination-numbers/index.js
1083  var comments_pagination_numbers_namespaceObject = {};
1084  __webpack_require__.r(comments_pagination_numbers_namespaceObject);
1085  __webpack_require__.d(comments_pagination_numbers_namespaceObject, {
1086    "metadata": function() { return comments_pagination_numbers_metadata; },
1087    "name": function() { return comments_pagination_numbers_name; },
1088    "settings": function() { return comments_pagination_numbers_settings; }
1089  });
1090  
1091  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/comments-title/index.js
1092  var comments_title_namespaceObject = {};
1093  __webpack_require__.r(comments_title_namespaceObject);
1094  __webpack_require__.d(comments_title_namespaceObject, {
1095    "metadata": function() { return comments_title_metadata; },
1096    "name": function() { return comments_title_name; },
1097    "settings": function() { return comments_title_settings; }
1098  });
1099  
1100  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/cover/index.js
1101  var build_module_cover_namespaceObject = {};
1102  __webpack_require__.r(build_module_cover_namespaceObject);
1103  __webpack_require__.d(build_module_cover_namespaceObject, {
1104    "metadata": function() { return cover_metadata; },
1105    "name": function() { return cover_name; },
1106    "settings": function() { return cover_settings; }
1107  });
1108  
1109  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/embed/index.js
1110  var embed_namespaceObject = {};
1111  __webpack_require__.r(embed_namespaceObject);
1112  __webpack_require__.d(embed_namespaceObject, {
1113    "metadata": function() { return embed_metadata; },
1114    "name": function() { return embed_name; },
1115    "settings": function() { return embed_settings; }
1116  });
1117  
1118  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/file/index.js
1119  var build_module_file_namespaceObject = {};
1120  __webpack_require__.r(build_module_file_namespaceObject);
1121  __webpack_require__.d(build_module_file_namespaceObject, {
1122    "metadata": function() { return file_metadata; },
1123    "name": function() { return file_name; },
1124    "settings": function() { return file_settings; }
1125  });
1126  
1127  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/gallery/index.js
1128  var build_module_gallery_namespaceObject = {};
1129  __webpack_require__.r(build_module_gallery_namespaceObject);
1130  __webpack_require__.d(build_module_gallery_namespaceObject, {
1131    "metadata": function() { return gallery_metadata; },
1132    "name": function() { return gallery_name; },
1133    "settings": function() { return gallery_settings; }
1134  });
1135  
1136  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/group/index.js
1137  var build_module_group_namespaceObject = {};
1138  __webpack_require__.r(build_module_group_namespaceObject);
1139  __webpack_require__.d(build_module_group_namespaceObject, {
1140    "metadata": function() { return group_metadata; },
1141    "name": function() { return group_name; },
1142    "settings": function() { return group_settings; }
1143  });
1144  
1145  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/heading/index.js
1146  var build_module_heading_namespaceObject = {};
1147  __webpack_require__.r(build_module_heading_namespaceObject);
1148  __webpack_require__.d(build_module_heading_namespaceObject, {
1149    "metadata": function() { return heading_metadata; },
1150    "name": function() { return heading_name; },
1151    "settings": function() { return heading_settings; }
1152  });
1153  
1154  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/home-link/index.js
1155  var home_link_namespaceObject = {};
1156  __webpack_require__.r(home_link_namespaceObject);
1157  __webpack_require__.d(home_link_namespaceObject, {
1158    "metadata": function() { return home_link_metadata; },
1159    "name": function() { return home_link_name; },
1160    "settings": function() { return home_link_settings; }
1161  });
1162  
1163  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/html/index.js
1164  var build_module_html_namespaceObject = {};
1165  __webpack_require__.r(build_module_html_namespaceObject);
1166  __webpack_require__.d(build_module_html_namespaceObject, {
1167    "metadata": function() { return html_metadata; },
1168    "name": function() { return html_name; },
1169    "settings": function() { return html_settings; }
1170  });
1171  
1172  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/image/index.js
1173  var build_module_image_namespaceObject = {};
1174  __webpack_require__.r(build_module_image_namespaceObject);
1175  __webpack_require__.d(build_module_image_namespaceObject, {
1176    "metadata": function() { return image_metadata; },
1177    "name": function() { return image_name; },
1178    "settings": function() { return image_settings; }
1179  });
1180  
1181  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/latest-comments/index.js
1182  var latest_comments_namespaceObject = {};
1183  __webpack_require__.r(latest_comments_namespaceObject);
1184  __webpack_require__.d(latest_comments_namespaceObject, {
1185    "metadata": function() { return latest_comments_metadata; },
1186    "name": function() { return latest_comments_name; },
1187    "settings": function() { return latest_comments_settings; }
1188  });
1189  
1190  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/latest-posts/index.js
1191  var latest_posts_namespaceObject = {};
1192  __webpack_require__.r(latest_posts_namespaceObject);
1193  __webpack_require__.d(latest_posts_namespaceObject, {
1194    "metadata": function() { return latest_posts_metadata; },
1195    "name": function() { return latest_posts_name; },
1196    "settings": function() { return latest_posts_settings; }
1197  });
1198  
1199  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/list/index.js
1200  var build_module_list_namespaceObject = {};
1201  __webpack_require__.r(build_module_list_namespaceObject);
1202  __webpack_require__.d(build_module_list_namespaceObject, {
1203    "metadata": function() { return list_metadata; },
1204    "name": function() { return list_name; },
1205    "settings": function() { return list_settings; }
1206  });
1207  
1208  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/loginout/index.js
1209  var loginout_namespaceObject = {};
1210  __webpack_require__.r(loginout_namespaceObject);
1211  __webpack_require__.d(loginout_namespaceObject, {
1212    "metadata": function() { return loginout_metadata; },
1213    "name": function() { return loginout_name; },
1214    "settings": function() { return loginout_settings; }
1215  });
1216  
1217  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/media-text/index.js
1218  var media_text_namespaceObject = {};
1219  __webpack_require__.r(media_text_namespaceObject);
1220  __webpack_require__.d(media_text_namespaceObject, {
1221    "metadata": function() { return media_text_metadata; },
1222    "name": function() { return media_text_name; },
1223    "settings": function() { return media_text_settings; }
1224  });
1225  
1226  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/missing/index.js
1227  var missing_namespaceObject = {};
1228  __webpack_require__.r(missing_namespaceObject);
1229  __webpack_require__.d(missing_namespaceObject, {
1230    "metadata": function() { return missing_metadata; },
1231    "name": function() { return missing_name; },
1232    "settings": function() { return missing_settings; }
1233  });
1234  
1235  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/more/index.js
1236  var build_module_more_namespaceObject = {};
1237  __webpack_require__.r(build_module_more_namespaceObject);
1238  __webpack_require__.d(build_module_more_namespaceObject, {
1239    "metadata": function() { return more_metadata; },
1240    "name": function() { return more_name; },
1241    "settings": function() { return more_settings; }
1242  });
1243  
1244  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/navigation/index.js
1245  var build_module_navigation_namespaceObject = {};
1246  __webpack_require__.r(build_module_navigation_namespaceObject);
1247  __webpack_require__.d(build_module_navigation_namespaceObject, {
1248    "metadata": function() { return navigation_metadata; },
1249    "name": function() { return navigation_name; },
1250    "settings": function() { return navigation_settings; }
1251  });
1252  
1253  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/navigation-link/index.js
1254  var navigation_link_namespaceObject = {};
1255  __webpack_require__.r(navigation_link_namespaceObject);
1256  __webpack_require__.d(navigation_link_namespaceObject, {
1257    "metadata": function() { return navigation_link_metadata; },
1258    "name": function() { return navigation_link_name; },
1259    "settings": function() { return navigation_link_settings; }
1260  });
1261  
1262  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/navigation-submenu/index.js
1263  var navigation_submenu_namespaceObject = {};
1264  __webpack_require__.r(navigation_submenu_namespaceObject);
1265  __webpack_require__.d(navigation_submenu_namespaceObject, {
1266    "metadata": function() { return navigation_submenu_metadata; },
1267    "name": function() { return navigation_submenu_name; },
1268    "settings": function() { return navigation_submenu_settings; }
1269  });
1270  
1271  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/nextpage/index.js
1272  var nextpage_namespaceObject = {};
1273  __webpack_require__.r(nextpage_namespaceObject);
1274  __webpack_require__.d(nextpage_namespaceObject, {
1275    "metadata": function() { return nextpage_metadata; },
1276    "name": function() { return nextpage_name; },
1277    "settings": function() { return nextpage_settings; }
1278  });
1279  
1280  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/pattern/index.js
1281  var pattern_namespaceObject = {};
1282  __webpack_require__.r(pattern_namespaceObject);
1283  __webpack_require__.d(pattern_namespaceObject, {
1284    "metadata": function() { return pattern_metadata; },
1285    "name": function() { return pattern_name; },
1286    "settings": function() { return pattern_settings; }
1287  });
1288  
1289  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/page-list/index.js
1290  var page_list_namespaceObject = {};
1291  __webpack_require__.r(page_list_namespaceObject);
1292  __webpack_require__.d(page_list_namespaceObject, {
1293    "metadata": function() { return page_list_metadata; },
1294    "name": function() { return page_list_name; },
1295    "settings": function() { return page_list_settings; }
1296  });
1297  
1298  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/paragraph/index.js
1299  var build_module_paragraph_namespaceObject = {};
1300  __webpack_require__.r(build_module_paragraph_namespaceObject);
1301  __webpack_require__.d(build_module_paragraph_namespaceObject, {
1302    "metadata": function() { return paragraph_metadata; },
1303    "name": function() { return paragraph_name; },
1304    "settings": function() { return paragraph_settings; }
1305  });
1306  
1307  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/post-author/index.js
1308  var build_module_post_author_namespaceObject = {};
1309  __webpack_require__.r(build_module_post_author_namespaceObject);
1310  __webpack_require__.d(build_module_post_author_namespaceObject, {
1311    "metadata": function() { return post_author_metadata; },
1312    "name": function() { return post_author_name; },
1313    "settings": function() { return post_author_settings; }
1314  });
1315  
1316  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/post-author-biography/index.js
1317  var post_author_biography_namespaceObject = {};
1318  __webpack_require__.r(post_author_biography_namespaceObject);
1319  __webpack_require__.d(post_author_biography_namespaceObject, {
1320    "metadata": function() { return post_author_biography_metadata; },
1321    "name": function() { return post_author_biography_name; },
1322    "settings": function() { return post_author_biography_settings; }
1323  });
1324  
1325  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/post-comments/index.js
1326  var build_module_post_comments_namespaceObject = {};
1327  __webpack_require__.r(build_module_post_comments_namespaceObject);
1328  __webpack_require__.d(build_module_post_comments_namespaceObject, {
1329    "metadata": function() { return post_comments_metadata; },
1330    "name": function() { return post_comments_name; },
1331    "settings": function() { return post_comments_settings; }
1332  });
1333  
1334  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/post-comments-form/index.js
1335  var build_module_post_comments_form_namespaceObject = {};
1336  __webpack_require__.r(build_module_post_comments_form_namespaceObject);
1337  __webpack_require__.d(build_module_post_comments_form_namespaceObject, {
1338    "metadata": function() { return post_comments_form_metadata; },
1339    "name": function() { return post_comments_form_name; },
1340    "settings": function() { return post_comments_form_settings; }
1341  });
1342  
1343  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/post-content/index.js
1344  var build_module_post_content_namespaceObject = {};
1345  __webpack_require__.r(build_module_post_content_namespaceObject);
1346  __webpack_require__.d(build_module_post_content_namespaceObject, {
1347    "metadata": function() { return post_content_metadata; },
1348    "name": function() { return post_content_name; },
1349    "settings": function() { return post_content_settings; }
1350  });
1351  
1352  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/post-date/index.js
1353  var build_module_post_date_namespaceObject = {};
1354  __webpack_require__.r(build_module_post_date_namespaceObject);
1355  __webpack_require__.d(build_module_post_date_namespaceObject, {
1356    "metadata": function() { return post_date_metadata; },
1357    "name": function() { return post_date_name; },
1358    "settings": function() { return post_date_settings; }
1359  });
1360  
1361  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/post-excerpt/index.js
1362  var build_module_post_excerpt_namespaceObject = {};
1363  __webpack_require__.r(build_module_post_excerpt_namespaceObject);
1364  __webpack_require__.d(build_module_post_excerpt_namespaceObject, {
1365    "metadata": function() { return post_excerpt_metadata; },
1366    "name": function() { return post_excerpt_name; },
1367    "settings": function() { return post_excerpt_settings; }
1368  });
1369  
1370  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/post-featured-image/index.js
1371  var build_module_post_featured_image_namespaceObject = {};
1372  __webpack_require__.r(build_module_post_featured_image_namespaceObject);
1373  __webpack_require__.d(build_module_post_featured_image_namespaceObject, {
1374    "metadata": function() { return post_featured_image_metadata; },
1375    "name": function() { return post_featured_image_name; },
1376    "settings": function() { return post_featured_image_settings; }
1377  });
1378  
1379  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/post-navigation-link/index.js
1380  var post_navigation_link_namespaceObject = {};
1381  __webpack_require__.r(post_navigation_link_namespaceObject);
1382  __webpack_require__.d(post_navigation_link_namespaceObject, {
1383    "metadata": function() { return post_navigation_link_metadata; },
1384    "name": function() { return post_navigation_link_name; },
1385    "settings": function() { return post_navigation_link_settings; }
1386  });
1387  
1388  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/post-template/index.js
1389  var post_template_namespaceObject = {};
1390  __webpack_require__.r(post_template_namespaceObject);
1391  __webpack_require__.d(post_template_namespaceObject, {
1392    "metadata": function() { return post_template_metadata; },
1393    "name": function() { return post_template_name; },
1394    "settings": function() { return post_template_settings; }
1395  });
1396  
1397  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/post-terms/index.js
1398  var build_module_post_terms_namespaceObject = {};
1399  __webpack_require__.r(build_module_post_terms_namespaceObject);
1400  __webpack_require__.d(build_module_post_terms_namespaceObject, {
1401    "metadata": function() { return post_terms_metadata; },
1402    "name": function() { return post_terms_name; },
1403    "settings": function() { return post_terms_settings; }
1404  });
1405  
1406  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/post-title/index.js
1407  var build_module_post_title_namespaceObject = {};
1408  __webpack_require__.r(build_module_post_title_namespaceObject);
1409  __webpack_require__.d(build_module_post_title_namespaceObject, {
1410    "metadata": function() { return post_title_metadata; },
1411    "name": function() { return post_title_name; },
1412    "settings": function() { return post_title_settings; }
1413  });
1414  
1415  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/preformatted/index.js
1416  var build_module_preformatted_namespaceObject = {};
1417  __webpack_require__.r(build_module_preformatted_namespaceObject);
1418  __webpack_require__.d(build_module_preformatted_namespaceObject, {
1419    "metadata": function() { return preformatted_metadata; },
1420    "name": function() { return preformatted_name; },
1421    "settings": function() { return preformatted_settings; }
1422  });
1423  
1424  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/pullquote/index.js
1425  var build_module_pullquote_namespaceObject = {};
1426  __webpack_require__.r(build_module_pullquote_namespaceObject);
1427  __webpack_require__.d(build_module_pullquote_namespaceObject, {
1428    "metadata": function() { return pullquote_metadata; },
1429    "name": function() { return pullquote_name; },
1430    "settings": function() { return pullquote_settings; }
1431  });
1432  
1433  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/query/index.js
1434  var query_namespaceObject = {};
1435  __webpack_require__.r(query_namespaceObject);
1436  __webpack_require__.d(query_namespaceObject, {
1437    "metadata": function() { return query_metadata; },
1438    "name": function() { return query_name; },
1439    "settings": function() { return query_settings; }
1440  });
1441  
1442  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/query-no-results/index.js
1443  var query_no_results_namespaceObject = {};
1444  __webpack_require__.r(query_no_results_namespaceObject);
1445  __webpack_require__.d(query_no_results_namespaceObject, {
1446    "metadata": function() { return query_no_results_metadata; },
1447    "name": function() { return query_no_results_name; },
1448    "settings": function() { return query_no_results_settings; }
1449  });
1450  
1451  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/query-pagination/index.js
1452  var build_module_query_pagination_namespaceObject = {};
1453  __webpack_require__.r(build_module_query_pagination_namespaceObject);
1454  __webpack_require__.d(build_module_query_pagination_namespaceObject, {
1455    "metadata": function() { return query_pagination_metadata; },
1456    "name": function() { return query_pagination_name; },
1457    "settings": function() { return query_pagination_settings; }
1458  });
1459  
1460  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/query-pagination-next/index.js
1461  var build_module_query_pagination_next_namespaceObject = {};
1462  __webpack_require__.r(build_module_query_pagination_next_namespaceObject);
1463  __webpack_require__.d(build_module_query_pagination_next_namespaceObject, {
1464    "metadata": function() { return query_pagination_next_metadata; },
1465    "name": function() { return query_pagination_next_name; },
1466    "settings": function() { return query_pagination_next_settings; }
1467  });
1468  
1469  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/query-pagination-numbers/index.js
1470  var build_module_query_pagination_numbers_namespaceObject = {};
1471  __webpack_require__.r(build_module_query_pagination_numbers_namespaceObject);
1472  __webpack_require__.d(build_module_query_pagination_numbers_namespaceObject, {
1473    "metadata": function() { return query_pagination_numbers_metadata; },
1474    "name": function() { return query_pagination_numbers_name; },
1475    "settings": function() { return query_pagination_numbers_settings; }
1476  });
1477  
1478  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/query-pagination-previous/index.js
1479  var build_module_query_pagination_previous_namespaceObject = {};
1480  __webpack_require__.r(build_module_query_pagination_previous_namespaceObject);
1481  __webpack_require__.d(build_module_query_pagination_previous_namespaceObject, {
1482    "metadata": function() { return query_pagination_previous_metadata; },
1483    "name": function() { return query_pagination_previous_name; },
1484    "settings": function() { return query_pagination_previous_settings; }
1485  });
1486  
1487  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/query-title/index.js
1488  var build_module_query_title_namespaceObject = {};
1489  __webpack_require__.r(build_module_query_title_namespaceObject);
1490  __webpack_require__.d(build_module_query_title_namespaceObject, {
1491    "metadata": function() { return query_title_metadata; },
1492    "name": function() { return query_title_name; },
1493    "settings": function() { return query_title_settings; }
1494  });
1495  
1496  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/quote/index.js
1497  var build_module_quote_namespaceObject = {};
1498  __webpack_require__.r(build_module_quote_namespaceObject);
1499  __webpack_require__.d(build_module_quote_namespaceObject, {
1500    "metadata": function() { return quote_metadata; },
1501    "name": function() { return quote_name; },
1502    "settings": function() { return quote_settings; },
1503    "settingsV1": function() { return quote_settingsV1; }
1504  });
1505  
1506  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/block/index.js
1507  var block_namespaceObject = {};
1508  __webpack_require__.r(block_namespaceObject);
1509  __webpack_require__.d(block_namespaceObject, {
1510    "metadata": function() { return block_metadata; },
1511    "name": function() { return block_name; },
1512    "settings": function() { return block_settings; }
1513  });
1514  
1515  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/read-more/index.js
1516  var read_more_namespaceObject = {};
1517  __webpack_require__.r(read_more_namespaceObject);
1518  __webpack_require__.d(read_more_namespaceObject, {
1519    "metadata": function() { return read_more_metadata; },
1520    "name": function() { return read_more_name; },
1521    "settings": function() { return read_more_settings; }
1522  });
1523  
1524  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/rss/index.js
1525  var build_module_rss_namespaceObject = {};
1526  __webpack_require__.r(build_module_rss_namespaceObject);
1527  __webpack_require__.d(build_module_rss_namespaceObject, {
1528    "metadata": function() { return rss_metadata; },
1529    "name": function() { return rss_name; },
1530    "settings": function() { return rss_settings; }
1531  });
1532  
1533  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/search/index.js
1534  var build_module_search_namespaceObject = {};
1535  __webpack_require__.r(build_module_search_namespaceObject);
1536  __webpack_require__.d(build_module_search_namespaceObject, {
1537    "metadata": function() { return search_metadata; },
1538    "name": function() { return search_name; },
1539    "settings": function() { return search_settings; }
1540  });
1541  
1542  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/separator/index.js
1543  var build_module_separator_namespaceObject = {};
1544  __webpack_require__.r(build_module_separator_namespaceObject);
1545  __webpack_require__.d(build_module_separator_namespaceObject, {
1546    "metadata": function() { return separator_metadata; },
1547    "name": function() { return separator_name; },
1548    "settings": function() { return separator_settings; }
1549  });
1550  
1551  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/shortcode/index.js
1552  var build_module_shortcode_namespaceObject = {};
1553  __webpack_require__.r(build_module_shortcode_namespaceObject);
1554  __webpack_require__.d(build_module_shortcode_namespaceObject, {
1555    "metadata": function() { return shortcode_metadata; },
1556    "name": function() { return shortcode_name; },
1557    "settings": function() { return shortcode_settings; }
1558  });
1559  
1560  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/site-logo/index.js
1561  var build_module_site_logo_namespaceObject = {};
1562  __webpack_require__.r(build_module_site_logo_namespaceObject);
1563  __webpack_require__.d(build_module_site_logo_namespaceObject, {
1564    "metadata": function() { return site_logo_metadata; },
1565    "name": function() { return site_logo_name; },
1566    "settings": function() { return site_logo_settings; }
1567  });
1568  
1569  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/site-tagline/index.js
1570  var site_tagline_namespaceObject = {};
1571  __webpack_require__.r(site_tagline_namespaceObject);
1572  __webpack_require__.d(site_tagline_namespaceObject, {
1573    "metadata": function() { return site_tagline_metadata; },
1574    "name": function() { return site_tagline_name; },
1575    "settings": function() { return site_tagline_settings; }
1576  });
1577  
1578  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/site-title/index.js
1579  var site_title_namespaceObject = {};
1580  __webpack_require__.r(site_title_namespaceObject);
1581  __webpack_require__.d(site_title_namespaceObject, {
1582    "metadata": function() { return site_title_metadata; },
1583    "name": function() { return site_title_name; },
1584    "settings": function() { return site_title_settings; }
1585  });
1586  
1587  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/social-link/index.js
1588  var social_link_namespaceObject = {};
1589  __webpack_require__.r(social_link_namespaceObject);
1590  __webpack_require__.d(social_link_namespaceObject, {
1591    "metadata": function() { return social_link_metadata; },
1592    "name": function() { return social_link_name; },
1593    "settings": function() { return social_link_settings; }
1594  });
1595  
1596  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/social-links/index.js
1597  var social_links_namespaceObject = {};
1598  __webpack_require__.r(social_links_namespaceObject);
1599  __webpack_require__.d(social_links_namespaceObject, {
1600    "metadata": function() { return social_links_metadata; },
1601    "name": function() { return social_links_name; },
1602    "settings": function() { return social_links_settings; }
1603  });
1604  
1605  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/spacer/index.js
1606  var spacer_namespaceObject = {};
1607  __webpack_require__.r(spacer_namespaceObject);
1608  __webpack_require__.d(spacer_namespaceObject, {
1609    "metadata": function() { return spacer_metadata; },
1610    "name": function() { return spacer_name; },
1611    "settings": function() { return spacer_settings; }
1612  });
1613  
1614  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/table/index.js
1615  var build_module_table_namespaceObject = {};
1616  __webpack_require__.r(build_module_table_namespaceObject);
1617  __webpack_require__.d(build_module_table_namespaceObject, {
1618    "metadata": function() { return table_metadata; },
1619    "name": function() { return table_name; },
1620    "settings": function() { return table_settings; }
1621  });
1622  
1623  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/tag-cloud/index.js
1624  var tag_cloud_namespaceObject = {};
1625  __webpack_require__.r(tag_cloud_namespaceObject);
1626  __webpack_require__.d(tag_cloud_namespaceObject, {
1627    "metadata": function() { return tag_cloud_metadata; },
1628    "name": function() { return tag_cloud_name; },
1629    "settings": function() { return tag_cloud_settings; }
1630  });
1631  
1632  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/template-part/index.js
1633  var template_part_namespaceObject = {};
1634  __webpack_require__.r(template_part_namespaceObject);
1635  __webpack_require__.d(template_part_namespaceObject, {
1636    "metadata": function() { return template_part_metadata; },
1637    "name": function() { return template_part_name; },
1638    "settings": function() { return template_part_settings; }
1639  });
1640  
1641  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/term-description/index.js
1642  var build_module_term_description_namespaceObject = {};
1643  __webpack_require__.r(build_module_term_description_namespaceObject);
1644  __webpack_require__.d(build_module_term_description_namespaceObject, {
1645    "metadata": function() { return term_description_metadata; },
1646    "name": function() { return term_description_name; },
1647    "settings": function() { return term_description_settings; }
1648  });
1649  
1650  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/text-columns/index.js
1651  var text_columns_namespaceObject = {};
1652  __webpack_require__.r(text_columns_namespaceObject);
1653  __webpack_require__.d(text_columns_namespaceObject, {
1654    "metadata": function() { return text_columns_metadata; },
1655    "name": function() { return text_columns_name; },
1656    "settings": function() { return text_columns_settings; }
1657  });
1658  
1659  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/verse/index.js
1660  var build_module_verse_namespaceObject = {};
1661  __webpack_require__.r(build_module_verse_namespaceObject);
1662  __webpack_require__.d(build_module_verse_namespaceObject, {
1663    "metadata": function() { return verse_metadata; },
1664    "name": function() { return verse_name; },
1665    "settings": function() { return verse_settings; }
1666  });
1667  
1668  // NAMESPACE OBJECT: ./node_modules/@wordpress/block-library/build-module/video/index.js
1669  var build_module_video_namespaceObject = {};
1670  __webpack_require__.r(build_module_video_namespaceObject);
1671  __webpack_require__.d(build_module_video_namespaceObject, {
1672    "metadata": function() { return video_metadata; },
1673    "name": function() { return video_name; },
1674    "settings": function() { return video_settings; }
1675  });
1676  
1677  ;// CONCATENATED MODULE: external ["wp","blocks"]
1678  var external_wp_blocks_namespaceObject = window["wp"]["blocks"];
1679  ;// CONCATENATED MODULE: external ["wp","element"]
1680  var external_wp_element_namespaceObject = window["wp"]["element"];
1681  ;// CONCATENATED MODULE: external ["wp","primitives"]
1682  var external_wp_primitives_namespaceObject = window["wp"]["primitives"];
1683  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/archive.js
1684  
1685  
1686  /**
1687   * WordPress dependencies
1688   */
1689  
1690  const archive = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
1691    viewBox: "0 0 24 24",
1692    xmlns: "http://www.w3.org/2000/svg"
1693  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
1694    d: "M19 6.2h-5.9l-.6-1.1c-.3-.7-1-1.1-1.8-1.1H5c-1.1 0-2 .9-2 2v11.8c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V8.2c0-1.1-.9-2-2-2zm.5 11.6c0 .3-.2.5-.5.5H5c-.3 0-.5-.2-.5-.5V6c0-.3.2-.5.5-.5h5.8c.2 0 .4.1.4.3l1 2H19c.3 0 .5.2.5.5v9.5zM8 12.8h8v-1.5H8v1.5zm0 3h8v-1.5H8v1.5z"
1695  }));
1696  /* harmony default export */ var library_archive = (archive);
1697  
1698  ;// CONCATENATED MODULE: external ["wp","components"]
1699  var external_wp_components_namespaceObject = window["wp"]["components"];
1700  ;// CONCATENATED MODULE: external ["wp","i18n"]
1701  var external_wp_i18n_namespaceObject = window["wp"]["i18n"];
1702  ;// CONCATENATED MODULE: external ["wp","blockEditor"]
1703  var external_wp_blockEditor_namespaceObject = window["wp"]["blockEditor"];
1704  ;// CONCATENATED MODULE: external ["wp","serverSideRender"]
1705  var external_wp_serverSideRender_namespaceObject = window["wp"]["serverSideRender"];
1706  var external_wp_serverSideRender_default = /*#__PURE__*/__webpack_require__.n(external_wp_serverSideRender_namespaceObject);
1707  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/archives/edit.js
1708  
1709  
1710  /**
1711   * WordPress dependencies
1712   */
1713  
1714  
1715  
1716  
1717  function ArchivesEdit(_ref) {
1718    let {
1719      attributes,
1720      setAttributes
1721    } = _ref;
1722    const {
1723      showPostCounts,
1724      displayAsDropdown,
1725      type
1726    } = attributes;
1727    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
1728      title: (0,external_wp_i18n_namespaceObject.__)('Archives settings')
1729    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
1730      label: (0,external_wp_i18n_namespaceObject.__)('Display as dropdown'),
1731      checked: displayAsDropdown,
1732      onChange: () => setAttributes({
1733        displayAsDropdown: !displayAsDropdown
1734      })
1735    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
1736      label: (0,external_wp_i18n_namespaceObject.__)('Show post counts'),
1737      checked: showPostCounts,
1738      onChange: () => setAttributes({
1739        showPostCounts: !showPostCounts
1740      })
1741    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SelectControl, {
1742      label: (0,external_wp_i18n_namespaceObject.__)('Group by:'),
1743      options: [{
1744        label: (0,external_wp_i18n_namespaceObject.__)('Year'),
1745        value: 'yearly'
1746      }, {
1747        label: (0,external_wp_i18n_namespaceObject.__)('Month'),
1748        value: 'monthly'
1749      }, {
1750        label: (0,external_wp_i18n_namespaceObject.__)('Week'),
1751        value: 'weekly'
1752      }, {
1753        label: (0,external_wp_i18n_namespaceObject.__)('Day'),
1754        value: 'daily'
1755      }],
1756      value: type,
1757      onChange: value => setAttributes({
1758        type: value
1759      })
1760    }))), (0,external_wp_element_namespaceObject.createElement)("div", (0,external_wp_blockEditor_namespaceObject.useBlockProps)(), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Disabled, null, (0,external_wp_element_namespaceObject.createElement)((external_wp_serverSideRender_default()), {
1761      block: "core/archives",
1762      attributes: attributes
1763    }))));
1764  }
1765  
1766  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/archives/index.js
1767  /**
1768   * WordPress dependencies
1769   */
1770  
1771  /**
1772   * Internal dependencies
1773   */
1774  
1775  const metadata = {
1776    $schema: "https://schemas.wp.org/trunk/block.json",
1777    apiVersion: 2,
1778    name: "core/archives",
1779    title: "Archives",
1780    category: "widgets",
1781    description: "Display a date archive of your posts.",
1782    textdomain: "default",
1783    attributes: {
1784      displayAsDropdown: {
1785        type: "boolean",
1786        "default": false
1787      },
1788      showPostCounts: {
1789        type: "boolean",
1790        "default": false
1791      },
1792      type: {
1793        type: "string",
1794        "default": "monthly"
1795      }
1796    },
1797    supports: {
1798      align: true,
1799      html: false
1800    },
1801    editorStyle: "wp-block-archives-editor"
1802  };
1803  
1804  const {
1805    name: archives_name
1806  } = metadata;
1807  
1808  const settings = {
1809    icon: library_archive,
1810    example: {},
1811    edit: ArchivesEdit
1812  };
1813  
1814  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/comment-author-avatar.js
1815  
1816  
1817  /**
1818   * WordPress dependencies
1819   */
1820  
1821  const commentAuthorAvatar = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
1822    xmlns: "http://www.w3.org/2000/svg",
1823    viewBox: "0 0 24 24"
1824  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
1825    fillRule: "evenodd",
1826    d: "M7.25 16.437a6.5 6.5 0 1 1 9.5 0V16A2.75 2.75 0 0 0 14 13.25h-4A2.75 2.75 0 0 0 7.25 16v.437Zm1.5 1.193a6.47 6.47 0 0 0 3.25.87 6.47 6.47 0 0 0 3.25-.87V16c0-.69-.56-1.25-1.25-1.25h-4c-.69 0-1.25.56-1.25 1.25v1.63ZM4 12a8 8 0 1 1 16 0 8 8 0 0 1-16 0Zm10-2a2 2 0 1 1-4 0 2 2 0 0 1 4 0Z",
1827    clipRule: "evenodd"
1828  }));
1829  /* harmony default export */ var comment_author_avatar = (commentAuthorAvatar);
1830  
1831  ;// CONCATENATED MODULE: ./node_modules/@babel/runtime/helpers/esm/extends.js
1832  function _extends() {
1833    _extends = Object.assign || function (target) {
1834      for (var i = 1; i < arguments.length; i++) {
1835        var source = arguments[i];
1836  
1837        for (var key in source) {
1838          if (Object.prototype.hasOwnProperty.call(source, key)) {
1839            target[key] = source[key];
1840          }
1841        }
1842      }
1843  
1844      return target;
1845    };
1846  
1847    return _extends.apply(this, arguments);
1848  }
1849  // EXTERNAL MODULE: ./node_modules/classnames/index.js
1850  var classnames = __webpack_require__(4403);
1851  var classnames_default = /*#__PURE__*/__webpack_require__.n(classnames);
1852  ;// CONCATENATED MODULE: external ["wp","url"]
1853  var external_wp_url_namespaceObject = window["wp"]["url"];
1854  ;// CONCATENATED MODULE: external ["wp","coreData"]
1855  var external_wp_coreData_namespaceObject = window["wp"]["coreData"];
1856  ;// CONCATENATED MODULE: external ["wp","data"]
1857  var external_wp_data_namespaceObject = window["wp"]["data"];
1858  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/avatar/hooks.js
1859  /**
1860   * WordPress dependencies
1861   */
1862  
1863  
1864  
1865  
1866  
1867  function getAvatarSizes(sizes) {
1868    const minSize = sizes ? sizes[0] : 24;
1869    const maxSize = sizes ? sizes[sizes.length - 1] : 96;
1870    const maxSizeBuffer = Math.floor(maxSize * 2.5);
1871    return {
1872      minSize,
1873      maxSize: maxSizeBuffer
1874    };
1875  }
1876  
1877  function useDefaultAvatar() {
1878    const {
1879      avatarURL: defaultAvatarUrl
1880    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
1881      const {
1882        getSettings
1883      } = select(external_wp_blockEditor_namespaceObject.store);
1884      const {
1885        __experimentalDiscussionSettings
1886      } = getSettings();
1887      return __experimentalDiscussionSettings;
1888    });
1889    return defaultAvatarUrl;
1890  }
1891  
1892  function useCommentAvatar(_ref) {
1893    let {
1894      commentId
1895    } = _ref;
1896    const [avatars] = (0,external_wp_coreData_namespaceObject.useEntityProp)('root', 'comment', 'author_avatar_urls', commentId);
1897    const [authorName] = (0,external_wp_coreData_namespaceObject.useEntityProp)('root', 'comment', 'author_name', commentId);
1898    const avatarUrls = avatars ? Object.values(avatars) : null;
1899    const sizes = avatars ? Object.keys(avatars) : null;
1900    const {
1901      minSize,
1902      maxSize
1903    } = getAvatarSizes(sizes);
1904    const defaultAvatar = useDefaultAvatar();
1905    return {
1906      src: avatarUrls ? avatarUrls[avatarUrls.length - 1] : defaultAvatar,
1907      minSize,
1908      maxSize,
1909      // translators: %s is the Author name.
1910      alt: authorName ? // translators: %s is the Author name.
1911      (0,external_wp_i18n_namespaceObject.sprintf)((0,external_wp_i18n_namespaceObject.__)('%s Avatar'), authorName) : (0,external_wp_i18n_namespaceObject.__)('Default Avatar')
1912    };
1913  }
1914  function useUserAvatar(_ref2) {
1915    let {
1916      userId,
1917      postId,
1918      postType
1919    } = _ref2;
1920    const {
1921      authorDetails
1922    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
1923      var _getEditedEntityRecor;
1924  
1925      const {
1926        getEditedEntityRecord,
1927        getUser
1928      } = select(external_wp_coreData_namespaceObject.store);
1929  
1930      if (userId) {
1931        return {
1932          authorDetails: getUser(userId)
1933        };
1934      }
1935  
1936      const _authorId = (_getEditedEntityRecor = getEditedEntityRecord('postType', postType, postId)) === null || _getEditedEntityRecor === void 0 ? void 0 : _getEditedEntityRecor.author;
1937  
1938      return {
1939        authorDetails: _authorId ? getUser(_authorId) : null
1940      };
1941    }, [postType, postId, userId]);
1942    const avatarUrls = authorDetails ? Object.values(authorDetails.avatar_urls) : null;
1943    const sizes = authorDetails ? Object.keys(authorDetails.avatar_urls) : null;
1944    const {
1945      minSize,
1946      maxSize
1947    } = getAvatarSizes(sizes);
1948    const defaultAvatar = useDefaultAvatar();
1949    return {
1950      src: avatarUrls ? avatarUrls[avatarUrls.length - 1] : defaultAvatar,
1951      minSize,
1952      maxSize,
1953      alt: authorDetails ? // translators: %s is the Author name.
1954      (0,external_wp_i18n_namespaceObject.sprintf)((0,external_wp_i18n_namespaceObject.__)('%s Avatar'), authorDetails === null || authorDetails === void 0 ? void 0 : authorDetails.name) : (0,external_wp_i18n_namespaceObject.__)('Default Avatar')
1955    };
1956  }
1957  
1958  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/avatar/user-control.js
1959  
1960  
1961  /**
1962   * WordPress dependencies
1963   */
1964  
1965  
1966  
1967  
1968  
1969  const AUTHORS_QUERY = {
1970    who: 'authors',
1971    per_page: -1,
1972    _fields: 'id,name',
1973    context: 'view'
1974  };
1975  
1976  function UserControl(_ref) {
1977    let {
1978      value,
1979      onChange
1980    } = _ref;
1981    const [filteredAuthorsList, setFilteredAuthorsList] = (0,external_wp_element_namespaceObject.useState)();
1982    const authorsList = (0,external_wp_data_namespaceObject.useSelect)(select => {
1983      const {
1984        getUsers
1985      } = select(external_wp_coreData_namespaceObject.store);
1986      return getUsers(AUTHORS_QUERY);
1987    }, []);
1988  
1989    if (!authorsList) {
1990      return null;
1991    }
1992  
1993    const options = authorsList.map(author => {
1994      return {
1995        label: author.name,
1996        value: author.id
1997      };
1998    });
1999    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ComboboxControl, {
2000      label: (0,external_wp_i18n_namespaceObject.__)('User'),
2001      help: (0,external_wp_i18n_namespaceObject.__)('Select the avatar user to display, if it is blank it will use the post/page author.'),
2002      value: value,
2003      onChange: onChange,
2004      options: filteredAuthorsList || options,
2005      onFilterValueChange: inputValue => setFilteredAuthorsList(options.filter(option => option.label.toLowerCase().startsWith(inputValue.toLowerCase())))
2006    });
2007  }
2008  
2009  /* harmony default export */ var user_control = (UserControl);
2010  
2011  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/avatar/edit.js
2012  
2013  
2014  
2015  /**
2016   * External dependencies
2017   */
2018  
2019  /**
2020   * WordPress dependencies
2021   */
2022  
2023  
2024  
2025  
2026  
2027  /**
2028   * Internal dependencies
2029   */
2030  
2031  
2032  
2033  
2034  const AvatarInspectorControls = _ref => {
2035    let {
2036      setAttributes,
2037      avatar,
2038      attributes,
2039      selectUser
2040    } = _ref;
2041    return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
2042      title: (0,external_wp_i18n_namespaceObject.__)('Settings')
2043    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.RangeControl, {
2044      label: (0,external_wp_i18n_namespaceObject.__)('Image size'),
2045      onChange: newSize => setAttributes({
2046        size: newSize
2047      }),
2048      min: avatar.minSize,
2049      max: avatar.maxSize,
2050      initialPosition: attributes === null || attributes === void 0 ? void 0 : attributes.size,
2051      value: attributes === null || attributes === void 0 ? void 0 : attributes.size
2052    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
2053      label: (0,external_wp_i18n_namespaceObject.__)('Link to user profile'),
2054      onChange: () => setAttributes({
2055        isLink: !attributes.isLink
2056      }),
2057      checked: attributes.isLink
2058    }), attributes.isLink && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
2059      label: (0,external_wp_i18n_namespaceObject.__)('Open in new tab'),
2060      onChange: value => setAttributes({
2061        linkTarget: value ? '_blank' : '_self'
2062      }),
2063      checked: attributes.linkTarget === '_blank'
2064    }), selectUser && (0,external_wp_element_namespaceObject.createElement)(user_control, {
2065      value: attributes === null || attributes === void 0 ? void 0 : attributes.userId,
2066      onChange: value => {
2067        setAttributes({
2068          userId: value
2069        });
2070      }
2071    })));
2072  };
2073  
2074  const ResizableAvatar = _ref2 => {
2075    let {
2076      setAttributes,
2077      attributes,
2078      avatar,
2079      blockProps,
2080      isSelected
2081    } = _ref2;
2082    const borderProps = (0,external_wp_blockEditor_namespaceObject.__experimentalUseBorderProps)(attributes);
2083    const doubledSizedSrc = (0,external_wp_url_namespaceObject.addQueryArgs)((0,external_wp_url_namespaceObject.removeQueryArgs)(avatar === null || avatar === void 0 ? void 0 : avatar.src, ['s']), {
2084      s: (attributes === null || attributes === void 0 ? void 0 : attributes.size) * 2
2085    });
2086    return (0,external_wp_element_namespaceObject.createElement)("div", blockProps, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ResizableBox, {
2087      size: {
2088        width: attributes.size,
2089        height: attributes.size
2090      },
2091      showHandle: isSelected,
2092      onResizeStop: (event, direction, elt, delta) => {
2093        setAttributes({
2094          size: parseInt(attributes.size + (delta.height || delta.width), 10)
2095        });
2096      },
2097      lockAspectRatio: true,
2098      enable: {
2099        top: false,
2100        right: !(0,external_wp_i18n_namespaceObject.isRTL)(),
2101        bottom: true,
2102        left: (0,external_wp_i18n_namespaceObject.isRTL)()
2103      },
2104      minWidth: avatar.minSize,
2105      maxWidth: avatar.maxSize
2106    }, (0,external_wp_element_namespaceObject.createElement)("img", _extends({
2107      src: doubledSizedSrc,
2108      alt: avatar.alt
2109    }, borderProps, {
2110      className: classnames_default()('avatar', 'avatar-' + attributes.size, 'photo', 'wp-block-avatar__image', borderProps.className),
2111      style: { ...borderProps.style // Border radius, width and style.
2112  
2113      }
2114    }))));
2115  };
2116  
2117  const CommentEdit = _ref3 => {
2118    let {
2119      attributes,
2120      context,
2121      setAttributes,
2122      isSelected
2123    } = _ref3;
2124    const {
2125      commentId
2126    } = context;
2127    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)();
2128    const avatar = useCommentAvatar({
2129      commentId
2130    });
2131    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(AvatarInspectorControls, {
2132      avatar: avatar,
2133      setAttributes: setAttributes,
2134      attributes: attributes,
2135      selectUser: false
2136    }), attributes.isLink ? (0,external_wp_element_namespaceObject.createElement)("a", {
2137      href: "#avatar-pseudo-link",
2138      className: "wp-block-avatar__link",
2139      onClick: event => event.preventDefault()
2140    }, (0,external_wp_element_namespaceObject.createElement)(ResizableAvatar, {
2141      attributes: attributes,
2142      avatar: avatar,
2143      blockProps: blockProps,
2144      isSelected: isSelected,
2145      setAttributes: setAttributes
2146    })) : (0,external_wp_element_namespaceObject.createElement)(ResizableAvatar, {
2147      attributes: attributes,
2148      avatar: avatar,
2149      blockProps: blockProps,
2150      isSelected: isSelected,
2151      setAttributes: setAttributes
2152    }));
2153  };
2154  
2155  const UserEdit = _ref4 => {
2156    let {
2157      attributes,
2158      context,
2159      setAttributes,
2160      isSelected
2161    } = _ref4;
2162    const {
2163      postId,
2164      postType
2165    } = context;
2166    const avatar = useUserAvatar({
2167      userId: attributes === null || attributes === void 0 ? void 0 : attributes.userId,
2168      postId,
2169      postType
2170    });
2171    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)();
2172    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(AvatarInspectorControls, {
2173      selectUser: true,
2174      attributes: attributes,
2175      avatar: avatar,
2176      setAttributes: setAttributes
2177    }), (0,external_wp_element_namespaceObject.createElement)("div", null, attributes.isLink ? (0,external_wp_element_namespaceObject.createElement)("a", {
2178      href: "#avatar-pseudo-link",
2179      className: "wp-block-avatar__link",
2180      onClick: event => event.preventDefault()
2181    }, (0,external_wp_element_namespaceObject.createElement)(ResizableAvatar, {
2182      attributes: attributes,
2183      avatar: avatar,
2184      blockProps: blockProps,
2185      isSelected: isSelected,
2186      setAttributes: setAttributes
2187    })) : (0,external_wp_element_namespaceObject.createElement)(ResizableAvatar, {
2188      attributes: attributes,
2189      avatar: avatar,
2190      blockProps: blockProps,
2191      isSelected: isSelected,
2192      setAttributes: setAttributes
2193    })));
2194  };
2195  
2196  function Edit(props) {
2197    var _props$context, _props$context2;
2198  
2199    // Don't show the Comment Edit controls if we have a comment ID set, or if we're in the Site Editor (where it is `null`).
2200    if (props !== null && props !== void 0 && (_props$context = props.context) !== null && _props$context !== void 0 && _props$context.commentId || (props === null || props === void 0 ? void 0 : (_props$context2 = props.context) === null || _props$context2 === void 0 ? void 0 : _props$context2.commentId) === null) {
2201      return (0,external_wp_element_namespaceObject.createElement)(CommentEdit, props);
2202    }
2203  
2204    return (0,external_wp_element_namespaceObject.createElement)(UserEdit, props);
2205  }
2206  
2207  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/avatar/index.js
2208  /**
2209   * WordPress dependencies
2210   */
2211  
2212  /**
2213   * Internal dependencies
2214   */
2215  
2216  const avatar_metadata = {
2217    $schema: "https://schemas.wp.org/trunk/block.json",
2218    apiVersion: 2,
2219    name: "core/avatar",
2220    title: "Avatar",
2221    category: "theme",
2222    description: "Add a user's avatar.",
2223    textdomain: "default",
2224    attributes: {
2225      userId: {
2226        type: "number"
2227      },
2228      size: {
2229        type: "number",
2230        "default": 96
2231      },
2232      isLink: {
2233        type: "boolean",
2234        "default": false
2235      },
2236      linkTarget: {
2237        type: "string",
2238        "default": "_self"
2239      }
2240    },
2241    usesContext: ["postType", "postId", "commentId"],
2242    supports: {
2243      html: false,
2244      align: true,
2245      alignWide: false,
2246      spacing: {
2247        margin: true
2248      },
2249      __experimentalBorder: {
2250        __experimentalSkipSerialization: true,
2251        radius: true,
2252        width: true,
2253        color: true,
2254        style: true,
2255        __experimentalDefaultControls: {
2256          radius: true
2257        }
2258      },
2259      color: {
2260        text: false,
2261        background: false,
2262        __experimentalDuotone: "img"
2263      }
2264    },
2265    editorStyle: "wp-block-avatar",
2266    style: "wp-block-avatar"
2267  };
2268  
2269  const {
2270    name: avatar_name
2271  } = avatar_metadata;
2272  
2273  const avatar_settings = {
2274    icon: comment_author_avatar,
2275    edit: Edit
2276  };
2277  
2278  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/audio.js
2279  
2280  
2281  /**
2282   * WordPress dependencies
2283   */
2284  
2285  const audio = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
2286    viewBox: "0 0 24 24",
2287    xmlns: "http://www.w3.org/2000/svg"
2288  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
2289    d: "M17.7 4.3c-1.2 0-2.8 0-3.8 1-.6.6-.9 1.5-.9 2.6V14c-.6-.6-1.5-1-2.5-1C8.6 13 7 14.6 7 16.5S8.6 20 10.5 20c1.5 0 2.8-1 3.3-2.3.5-.8.7-1.8.7-2.5V7.9c0-.7.2-1.2.5-1.6.6-.6 1.8-.6 2.8-.6h.3V4.3h-.4z"
2290  }));
2291  /* harmony default export */ var library_audio = (audio);
2292  
2293  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/audio/deprecated.js
2294  
2295  
2296  /**
2297   * WordPress dependencies
2298   */
2299  
2300  /* harmony default export */ var deprecated = ([{
2301    attributes: {
2302      src: {
2303        type: 'string',
2304        source: 'attribute',
2305        selector: 'audio',
2306        attribute: 'src'
2307      },
2308      caption: {
2309        type: 'string',
2310        source: 'html',
2311        selector: 'figcaption'
2312      },
2313      id: {
2314        type: 'number'
2315      },
2316      autoplay: {
2317        type: 'boolean',
2318        source: 'attribute',
2319        selector: 'audio',
2320        attribute: 'autoplay'
2321      },
2322      loop: {
2323        type: 'boolean',
2324        source: 'attribute',
2325        selector: 'audio',
2326        attribute: 'loop'
2327      },
2328      preload: {
2329        type: 'string',
2330        source: 'attribute',
2331        selector: 'audio',
2332        attribute: 'preload'
2333      }
2334    },
2335    supports: {
2336      align: true
2337    },
2338  
2339    save(_ref) {
2340      let {
2341        attributes
2342      } = _ref;
2343      const {
2344        autoplay,
2345        caption,
2346        loop,
2347        preload,
2348        src
2349      } = attributes;
2350      return (0,external_wp_element_namespaceObject.createElement)("figure", null, (0,external_wp_element_namespaceObject.createElement)("audio", {
2351        controls: "controls",
2352        src: src,
2353        autoPlay: autoplay,
2354        loop: loop,
2355        preload: preload
2356      }), !external_wp_blockEditor_namespaceObject.RichText.isEmpty(caption) && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
2357        tagName: "figcaption",
2358        value: caption
2359      }));
2360    }
2361  
2362  }]);
2363  
2364  ;// CONCATENATED MODULE: external ["wp","blob"]
2365  var external_wp_blob_namespaceObject = window["wp"]["blob"];
2366  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/embed/constants.js
2367  const ASPECT_RATIOS = [// Common video resolutions.
2368  {
2369    ratio: '2.33',
2370    className: 'wp-embed-aspect-21-9'
2371  }, {
2372    ratio: '2.00',
2373    className: 'wp-embed-aspect-18-9'
2374  }, {
2375    ratio: '1.78',
2376    className: 'wp-embed-aspect-16-9'
2377  }, {
2378    ratio: '1.33',
2379    className: 'wp-embed-aspect-4-3'
2380  }, // Vertical video and instagram square video support.
2381  {
2382    ratio: '1.00',
2383    className: 'wp-embed-aspect-1-1'
2384  }, {
2385    ratio: '0.56',
2386    className: 'wp-embed-aspect-9-16'
2387  }, {
2388    ratio: '0.50',
2389    className: 'wp-embed-aspect-1-2'
2390  }];
2391  const WP_EMBED_TYPE = 'wp-embed';
2392  
2393  ;// CONCATENATED MODULE: external "lodash"
2394  var external_lodash_namespaceObject = window["lodash"];
2395  // EXTERNAL MODULE: ./node_modules/classnames/dedupe.js
2396  var dedupe = __webpack_require__(3827);
2397  var dedupe_default = /*#__PURE__*/__webpack_require__.n(dedupe);
2398  // EXTERNAL MODULE: ./node_modules/memize/index.js
2399  var memize = __webpack_require__(9756);
2400  var memize_default = /*#__PURE__*/__webpack_require__.n(memize);
2401  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/embed/util.js
2402  
2403  
2404  /**
2405   * Internal dependencies
2406   */
2407  
2408  /**
2409   * External dependencies
2410   */
2411  
2412  
2413  
2414  
2415  /**
2416   * WordPress dependencies
2417   */
2418  
2419  
2420  
2421  /**
2422   * Internal dependencies
2423   */
2424  
2425  const util_metadata = {
2426    $schema: "https://schemas.wp.org/trunk/block.json",
2427    apiVersion: 2,
2428    name: "core/embed",
2429    title: "Embed",
2430    category: "embed",
2431    description: "Add a block that displays content pulled from other sites, like Twitter or YouTube.",
2432    textdomain: "default",
2433    attributes: {
2434      url: {
2435        type: "string"
2436      },
2437      caption: {
2438        type: "string",
2439        source: "html",
2440        selector: "figcaption"
2441      },
2442      type: {
2443        type: "string"
2444      },
2445      providerNameSlug: {
2446        type: "string"
2447      },
2448      allowResponsive: {
2449        type: "boolean",
2450        "default": true
2451      },
2452      responsive: {
2453        type: "boolean",
2454        "default": false
2455      },
2456      previewable: {
2457        type: "boolean",
2458        "default": true
2459      }
2460    },
2461    supports: {
2462      align: true
2463    },
2464    editorStyle: "wp-block-embed-editor",
2465    style: "wp-block-embed"
2466  };
2467  const {
2468    name: DEFAULT_EMBED_BLOCK
2469  } = util_metadata;
2470  /** @typedef {import('@wordpress/blocks').WPBlockVariation} WPBlockVariation */
2471  
2472  /**
2473   * Returns the embed block's information by matching the provided service provider
2474   *
2475   * @param {string} provider The embed block's provider
2476   * @return {WPBlockVariation} The embed block's information
2477   */
2478  
2479  const getEmbedInfoByProvider = provider => {
2480    var _getBlockVariations;
2481  
2482    return (_getBlockVariations = (0,external_wp_blocks_namespaceObject.getBlockVariations)(DEFAULT_EMBED_BLOCK)) === null || _getBlockVariations === void 0 ? void 0 : _getBlockVariations.find(_ref => {
2483      let {
2484        name
2485      } = _ref;
2486      return name === provider;
2487    });
2488  };
2489  /**
2490   * Returns true if any of the regular expressions match the URL.
2491   *
2492   * @param {string} url      The URL to test.
2493   * @param {Array}  patterns The list of regular expressions to test agains.
2494   * @return {boolean} True if any of the regular expressions match the URL.
2495   */
2496  
2497  const matchesPatterns = function (url) {
2498    let patterns = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];
2499    return patterns.some(pattern => url.match(pattern));
2500  };
2501  /**
2502   * Finds the block variation that should be used for the URL,
2503   * based on the provided URL and the variation's patterns.
2504   *
2505   * @param {string} url The URL to test.
2506   * @return {WPBlockVariation} The block variation that should be used for this URL
2507   */
2508  
2509  const findMoreSuitableBlock = url => {
2510    var _getBlockVariations2;
2511  
2512    return (_getBlockVariations2 = (0,external_wp_blocks_namespaceObject.getBlockVariations)(DEFAULT_EMBED_BLOCK)) === null || _getBlockVariations2 === void 0 ? void 0 : _getBlockVariations2.find(_ref2 => {
2513      let {
2514        patterns
2515      } = _ref2;
2516      return matchesPatterns(url, patterns);
2517    });
2518  };
2519  const isFromWordPress = html => html && html.includes('class="wp-embedded-content"');
2520  const getPhotoHtml = photo => {
2521    // 100% width for the preview so it fits nicely into the document, some "thumbnails" are
2522    // actually the full size photo. If thumbnails not found, use full image.
2523    const imageUrl = photo.thumbnail_url || photo.url;
2524    const photoPreview = (0,external_wp_element_namespaceObject.createElement)("p", null, (0,external_wp_element_namespaceObject.createElement)("img", {
2525      src: imageUrl,
2526      alt: photo.title,
2527      width: "100%"
2528    }));
2529    return (0,external_wp_element_namespaceObject.renderToString)(photoPreview);
2530  };
2531  /**
2532   * Creates a more suitable embed block based on the passed in props
2533   * and attributes generated from an embed block's preview.
2534   *
2535   * We require `attributesFromPreview` to be generated from the latest attributes
2536   * and preview, and because of the way the react lifecycle operates, we can't
2537   * guarantee that the attributes contained in the block's props are the latest
2538   * versions, so we require that these are generated separately.
2539   * See `getAttributesFromPreview` in the generated embed edit component.
2540   *
2541   * @param {Object} props                   The block's props.
2542   * @param {Object} [attributesFromPreview] Attributes generated from the block's most up to date preview.
2543   * @return {Object|undefined} A more suitable embed block if one exists.
2544   */
2545  
2546  const createUpgradedEmbedBlock = function (props) {
2547    var _getBlockVariations3;
2548  
2549    let attributesFromPreview = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
2550    const {
2551      preview,
2552      attributes = {}
2553    } = props;
2554    const {
2555      url,
2556      providerNameSlug,
2557      type,
2558      ...restAttributes
2559    } = attributes;
2560    if (!url || !(0,external_wp_blocks_namespaceObject.getBlockType)(DEFAULT_EMBED_BLOCK)) return;
2561    const matchedBlock = findMoreSuitableBlock(url); // WordPress blocks can work on multiple sites, and so don't have patterns,
2562    // so if we're in a WordPress block, assume the user has chosen it for a WordPress URL.
2563  
2564    const isCurrentBlockWP = providerNameSlug === 'wordpress' || type === WP_EMBED_TYPE; // If current block is not WordPress and a more suitable block found
2565    // that is different from the current one, create the new matched block.
2566  
2567    const shouldCreateNewBlock = !isCurrentBlockWP && matchedBlock && (matchedBlock.attributes.providerNameSlug !== providerNameSlug || !providerNameSlug);
2568  
2569    if (shouldCreateNewBlock) {
2570      return (0,external_wp_blocks_namespaceObject.createBlock)(DEFAULT_EMBED_BLOCK, {
2571        url,
2572        ...restAttributes,
2573        ...matchedBlock.attributes
2574      });
2575    }
2576  
2577    const wpVariation = (_getBlockVariations3 = (0,external_wp_blocks_namespaceObject.getBlockVariations)(DEFAULT_EMBED_BLOCK)) === null || _getBlockVariations3 === void 0 ? void 0 : _getBlockVariations3.find(_ref3 => {
2578      let {
2579        name
2580      } = _ref3;
2581      return name === 'wordpress';
2582    }); // We can't match the URL for WordPress embeds, we have to check the HTML instead.
2583  
2584    if (!wpVariation || !preview || !isFromWordPress(preview.html) || isCurrentBlockWP) {
2585      return;
2586    } // This is not the WordPress embed block so transform it into one.
2587  
2588  
2589    return (0,external_wp_blocks_namespaceObject.createBlock)(DEFAULT_EMBED_BLOCK, {
2590      url,
2591      ...wpVariation.attributes,
2592      // By now we have the preview, but when the new block first renders, it
2593      // won't have had all the attributes set, and so won't get the correct
2594      // type and it won't render correctly. So, we pass through the current attributes
2595      // here so that the initial render works when we switch to the WordPress
2596      // block. This only affects the WordPress block because it can't be
2597      // rendered in the usual Sandbox (it has a sandbox of its own) and it
2598      // relies on the preview to set the correct render type.
2599      ...attributesFromPreview
2600    });
2601  };
2602  /**
2603   * Removes all previously set aspect ratio related classes and return the rest
2604   * existing class names.
2605   *
2606   * @param {string} existingClassNames Any existing class names.
2607   * @return {string} The class names without any aspect ratio related class.
2608   */
2609  
2610  const removeAspectRatioClasses = existingClassNames => {
2611    if (!existingClassNames) {
2612      // Avoids extraneous work and also, by returning the same value as
2613      // received, ensures the post is not dirtied by a change of the block
2614      // attribute from `undefined` to an emtpy string.
2615      return existingClassNames;
2616    }
2617  
2618    const aspectRatioClassNames = ASPECT_RATIOS.reduce((accumulator, _ref4) => {
2619      let {
2620        className
2621      } = _ref4;
2622      accumulator[className] = false;
2623      return accumulator;
2624    }, {
2625      'wp-has-aspect-ratio': false
2626    });
2627    return dedupe_default()(existingClassNames, aspectRatioClassNames);
2628  };
2629  /**
2630   * Returns class names with any relevant responsive aspect ratio names.
2631   *
2632   * @param {string}  html               The preview HTML that possibly contains an iframe with width and height set.
2633   * @param {string}  existingClassNames Any existing class names.
2634   * @param {boolean} allowResponsive    If the responsive class names should be added, or removed.
2635   * @return {string} Deduped class names.
2636   */
2637  
2638  function getClassNames(html, existingClassNames) {
2639    let allowResponsive = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : true;
2640  
2641    if (!allowResponsive) {
2642      return removeAspectRatioClasses(existingClassNames);
2643    }
2644  
2645    const previewDocument = document.implementation.createHTMLDocument('');
2646    previewDocument.body.innerHTML = html;
2647    const iframe = previewDocument.body.querySelector('iframe'); // If we have a fixed aspect iframe, and it's a responsive embed block.
2648  
2649    if (iframe && iframe.height && iframe.width) {
2650      const aspectRatio = (iframe.width / iframe.height).toFixed(2); // Given the actual aspect ratio, find the widest ratio to support it.
2651  
2652      for (let ratioIndex = 0; ratioIndex < ASPECT_RATIOS.length; ratioIndex++) {
2653        const potentialRatio = ASPECT_RATIOS[ratioIndex];
2654  
2655        if (aspectRatio >= potentialRatio.ratio) {
2656          // Evaluate the difference between actual aspect ratio and closest match.
2657          // If the difference is too big, do not scale the embed according to aspect ratio.
2658          const ratioDiff = aspectRatio - potentialRatio.ratio;
2659  
2660          if (ratioDiff > 0.1) {
2661            // No close aspect ratio match found.
2662            return removeAspectRatioClasses(existingClassNames);
2663          } // Close aspect ratio match found.
2664  
2665  
2666          return dedupe_default()(removeAspectRatioClasses(existingClassNames), potentialRatio.className, 'wp-has-aspect-ratio');
2667        }
2668      }
2669    }
2670  
2671    return existingClassNames;
2672  }
2673  /**
2674   * Fallback behaviour for unembeddable URLs.
2675   * Creates a paragraph block containing a link to the URL, and calls `onReplace`.
2676   *
2677   * @param {string}   url       The URL that could not be embedded.
2678   * @param {Function} onReplace Function to call with the created fallback block.
2679   */
2680  
2681  function fallback(url, onReplace) {
2682    const link = (0,external_wp_element_namespaceObject.createElement)("a", {
2683      href: url
2684    }, url);
2685    onReplace((0,external_wp_blocks_namespaceObject.createBlock)('core/paragraph', {
2686      content: (0,external_wp_element_namespaceObject.renderToString)(link)
2687    }));
2688  }
2689  /***
2690   * Gets block attributes based on the preview and responsive state.
2691   *
2692   * @param {Object} preview The preview data.
2693   * @param {string} title The block's title, e.g. Twitter.
2694   * @param {Object} currentClassNames The block's current class names.
2695   * @param {boolean} isResponsive Boolean indicating if the block supports responsive content.
2696   * @param {boolean} allowResponsive Apply responsive classes to fixed size content.
2697   * @return {Object} Attributes and values.
2698   */
2699  
2700  const getAttributesFromPreview = memize_default()(function (preview, title, currentClassNames, isResponsive) {
2701    let allowResponsive = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : true;
2702  
2703    if (!preview) {
2704      return {};
2705    }
2706  
2707    const attributes = {}; // Some plugins only return HTML with no type info, so default this to 'rich'.
2708  
2709    let {
2710      type = 'rich'
2711    } = preview; // If we got a provider name from the API, use it for the slug, otherwise we use the title,
2712    // because not all embed code gives us a provider name.
2713  
2714    const {
2715      html,
2716      provider_name: providerName
2717    } = preview;
2718    const providerNameSlug = (0,external_lodash_namespaceObject.kebabCase)((providerName || title).toLowerCase());
2719  
2720    if (isFromWordPress(html)) {
2721      type = WP_EMBED_TYPE;
2722    }
2723  
2724    if (html || 'photo' === type) {
2725      attributes.type = type;
2726      attributes.providerNameSlug = providerNameSlug;
2727    }
2728  
2729    attributes.className = getClassNames(html, currentClassNames, isResponsive && allowResponsive);
2730    return attributes;
2731  });
2732  
2733  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/audio/edit.js
2734  
2735  
2736  /**
2737   * External dependencies
2738   */
2739  
2740  /**
2741   * WordPress dependencies
2742   */
2743  
2744  
2745  
2746  
2747  
2748  
2749  
2750  
2751  
2752  /**
2753   * Internal dependencies
2754   */
2755  
2756  
2757  const ALLOWED_MEDIA_TYPES = ['audio'];
2758  
2759  function AudioEdit(_ref) {
2760    let {
2761      attributes,
2762      className,
2763      noticeOperations,
2764      setAttributes,
2765      onReplace,
2766      isSelected,
2767      noticeUI,
2768      insertBlocksAfter
2769    } = _ref;
2770    const {
2771      id,
2772      autoplay,
2773      caption,
2774      loop,
2775      preload,
2776      src
2777    } = attributes;
2778    const isTemporaryAudio = !id && (0,external_wp_blob_namespaceObject.isBlobURL)(src);
2779    const mediaUpload = (0,external_wp_data_namespaceObject.useSelect)(select => {
2780      const {
2781        getSettings
2782      } = select(external_wp_blockEditor_namespaceObject.store);
2783      return getSettings().mediaUpload;
2784    }, []);
2785    (0,external_wp_element_namespaceObject.useEffect)(() => {
2786      if (!id && (0,external_wp_blob_namespaceObject.isBlobURL)(src)) {
2787        const file = (0,external_wp_blob_namespaceObject.getBlobByURL)(src);
2788  
2789        if (file) {
2790          mediaUpload({
2791            filesList: [file],
2792            onFileChange: _ref2 => {
2793              let [{
2794                id: mediaId,
2795                url
2796              }] = _ref2;
2797              setAttributes({
2798                id: mediaId,
2799                src: url
2800              });
2801            },
2802            onError: e => {
2803              setAttributes({
2804                src: undefined,
2805                id: undefined
2806              });
2807              noticeOperations.createErrorNotice(e);
2808            },
2809            allowedTypes: ALLOWED_MEDIA_TYPES
2810          });
2811        }
2812      }
2813    }, []);
2814  
2815    function toggleAttribute(attribute) {
2816      return newValue => {
2817        setAttributes({
2818          [attribute]: newValue
2819        });
2820      };
2821    }
2822  
2823    function onSelectURL(newSrc) {
2824      // Set the block's src from the edit component's state, and switch off
2825      // the editing UI.
2826      if (newSrc !== src) {
2827        // Check if there's an embed block that handles this URL.
2828        const embedBlock = createUpgradedEmbedBlock({
2829          attributes: {
2830            url: newSrc
2831          }
2832        });
2833  
2834        if (undefined !== embedBlock && onReplace) {
2835          onReplace(embedBlock);
2836          return;
2837        }
2838  
2839        setAttributes({
2840          src: newSrc,
2841          id: undefined
2842        });
2843      }
2844    }
2845  
2846    function onUploadError(message) {
2847      noticeOperations.removeAllNotices();
2848      noticeOperations.createErrorNotice(message);
2849    }
2850  
2851    function getAutoplayHelp(checked) {
2852      return checked ? (0,external_wp_i18n_namespaceObject.__)('Autoplay may cause usability issues for some users.') : null;
2853    }
2854  
2855    function onSelectAudio(media) {
2856      if (!media || !media.url) {
2857        // In this case there was an error and we should continue in the editing state
2858        // previous attributes should be removed because they may be temporary blob urls.
2859        setAttributes({
2860          src: undefined,
2861          id: undefined
2862        });
2863        return;
2864      } // Sets the block's attribute and updates the edit component from the
2865      // selected media, then switches off the editing UI.
2866  
2867  
2868      setAttributes({
2869        src: media.url,
2870        id: media.id
2871      });
2872    }
2873  
2874    const classes = classnames_default()(className, {
2875      'is-transient': isTemporaryAudio
2876    });
2877    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
2878      className: classes
2879    });
2880  
2881    if (!src) {
2882      return (0,external_wp_element_namespaceObject.createElement)("div", blockProps, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.MediaPlaceholder, {
2883        icon: (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockIcon, {
2884          icon: library_audio
2885        }),
2886        onSelect: onSelectAudio,
2887        onSelectURL: onSelectURL,
2888        accept: "audio/*",
2889        allowedTypes: ALLOWED_MEDIA_TYPES,
2890        value: attributes,
2891        notices: noticeUI,
2892        onError: onUploadError
2893      }));
2894    }
2895  
2896    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, {
2897      group: "other"
2898    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.MediaReplaceFlow, {
2899      mediaId: id,
2900      mediaURL: src,
2901      allowedTypes: ALLOWED_MEDIA_TYPES,
2902      accept: "audio/*",
2903      onSelect: onSelectAudio,
2904      onSelectURL: onSelectURL,
2905      onError: onUploadError
2906    })), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
2907      title: (0,external_wp_i18n_namespaceObject.__)('Audio settings')
2908    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
2909      label: (0,external_wp_i18n_namespaceObject.__)('Autoplay'),
2910      onChange: toggleAttribute('autoplay'),
2911      checked: autoplay,
2912      help: getAutoplayHelp
2913    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
2914      label: (0,external_wp_i18n_namespaceObject.__)('Loop'),
2915      onChange: toggleAttribute('loop'),
2916      checked: loop
2917    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SelectControl, {
2918      label: (0,external_wp_i18n_namespaceObject._x)('Preload', 'noun; Audio block parameter'),
2919      value: preload || '' // `undefined` is required for the preload attribute to be unset.
2920      ,
2921      onChange: value => setAttributes({
2922        preload: value || undefined
2923      }),
2924      options: [{
2925        value: '',
2926        label: (0,external_wp_i18n_namespaceObject.__)('Browser default')
2927      }, {
2928        value: 'auto',
2929        label: (0,external_wp_i18n_namespaceObject.__)('Auto')
2930      }, {
2931        value: 'metadata',
2932        label: (0,external_wp_i18n_namespaceObject.__)('Metadata')
2933      }, {
2934        value: 'none',
2935        label: (0,external_wp_i18n_namespaceObject._x)('None', 'Preload value')
2936      }]
2937    }))), (0,external_wp_element_namespaceObject.createElement)("figure", blockProps, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Disabled, {
2938      isDisabled: !isSelected
2939    }, (0,external_wp_element_namespaceObject.createElement)("audio", {
2940      controls: "controls",
2941      src: src
2942    })), isTemporaryAudio && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Spinner, null), (!external_wp_blockEditor_namespaceObject.RichText.isEmpty(caption) || isSelected) && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText, {
2943      tagName: "figcaption",
2944      "aria-label": (0,external_wp_i18n_namespaceObject.__)('Audio caption text'),
2945      placeholder: (0,external_wp_i18n_namespaceObject.__)('Add caption'),
2946      value: caption,
2947      onChange: value => setAttributes({
2948        caption: value
2949      }),
2950      inlineToolbar: true,
2951      __unstableOnSplitAtEnd: () => insertBlocksAfter((0,external_wp_blocks_namespaceObject.createBlock)('core/paragraph'))
2952    })));
2953  }
2954  
2955  /* harmony default export */ var edit = ((0,external_wp_components_namespaceObject.withNotices)(AudioEdit));
2956  
2957  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/audio/save.js
2958  
2959  
2960  /**
2961   * WordPress dependencies
2962   */
2963  
2964  function save(_ref) {
2965    let {
2966      attributes
2967    } = _ref;
2968    const {
2969      autoplay,
2970      caption,
2971      loop,
2972      preload,
2973      src
2974    } = attributes;
2975    return src && (0,external_wp_element_namespaceObject.createElement)("figure", external_wp_blockEditor_namespaceObject.useBlockProps.save(), (0,external_wp_element_namespaceObject.createElement)("audio", {
2976      controls: "controls",
2977      src: src,
2978      autoPlay: autoplay,
2979      loop: loop,
2980      preload: preload
2981    }), !external_wp_blockEditor_namespaceObject.RichText.isEmpty(caption) && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
2982      tagName: "figcaption",
2983      value: caption
2984    }));
2985  }
2986  
2987  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/audio/transforms.js
2988  /**
2989   * WordPress dependencies
2990   */
2991  
2992  
2993  const transforms = {
2994    from: [{
2995      type: 'files',
2996  
2997      isMatch(files) {
2998        return files.length === 1 && files[0].type.indexOf('audio/') === 0;
2999      },
3000  
3001      transform(files) {
3002        const file = files[0]; // We don't need to upload the media directly here
3003        // It's already done as part of the `componentDidMount`
3004        // in the audio block.
3005  
3006        const block = (0,external_wp_blocks_namespaceObject.createBlock)('core/audio', {
3007          src: (0,external_wp_blob_namespaceObject.createBlobURL)(file)
3008        });
3009        return block;
3010      }
3011  
3012    }, {
3013      type: 'shortcode',
3014      tag: 'audio',
3015      attributes: {
3016        src: {
3017          type: 'string',
3018          shortcode: _ref => {
3019            let {
3020              named: {
3021                src,
3022                mp3,
3023                m4a,
3024                ogg,
3025                wav,
3026                wma
3027              }
3028            } = _ref;
3029            return src || mp3 || m4a || ogg || wav || wma;
3030          }
3031        },
3032        loop: {
3033          type: 'string',
3034          shortcode: _ref2 => {
3035            let {
3036              named: {
3037                loop
3038              }
3039            } = _ref2;
3040            return loop;
3041          }
3042        },
3043        autoplay: {
3044          type: 'string',
3045          shortcode: _ref3 => {
3046            let {
3047              named: {
3048                autoplay
3049              }
3050            } = _ref3;
3051            return autoplay;
3052          }
3053        },
3054        preload: {
3055          type: 'string',
3056          shortcode: _ref4 => {
3057            let {
3058              named: {
3059                preload
3060              }
3061            } = _ref4;
3062            return preload;
3063          }
3064        }
3065      }
3066    }]
3067  };
3068  /* harmony default export */ var audio_transforms = (transforms);
3069  
3070  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/audio/index.js
3071  /**
3072   * WordPress dependencies
3073   */
3074  
3075  /**
3076   * Internal dependencies
3077   */
3078  
3079  
3080  
3081  const audio_metadata = {
3082    $schema: "https://schemas.wp.org/trunk/block.json",
3083    apiVersion: 2,
3084    name: "core/audio",
3085    title: "Audio",
3086    category: "media",
3087    description: "Embed a simple audio player.",
3088    keywords: ["music", "sound", "podcast", "recording"],
3089    textdomain: "default",
3090    attributes: {
3091      src: {
3092        type: "string",
3093        source: "attribute",
3094        selector: "audio",
3095        attribute: "src"
3096      },
3097      caption: {
3098        type: "string",
3099        source: "html",
3100        selector: "figcaption"
3101      },
3102      id: {
3103        type: "number"
3104      },
3105      autoplay: {
3106        type: "boolean",
3107        source: "attribute",
3108        selector: "audio",
3109        attribute: "autoplay"
3110      },
3111      loop: {
3112        type: "boolean",
3113        source: "attribute",
3114        selector: "audio",
3115        attribute: "loop"
3116      },
3117      preload: {
3118        type: "string",
3119        source: "attribute",
3120        selector: "audio",
3121        attribute: "preload"
3122      }
3123    },
3124    supports: {
3125      anchor: true,
3126      align: true
3127    },
3128    editorStyle: "wp-block-audio-editor",
3129    style: "wp-block-audio"
3130  };
3131  
3132  
3133  const {
3134    name: audio_name
3135  } = audio_metadata;
3136  
3137  const audio_settings = {
3138    icon: library_audio,
3139    example: {
3140      attributes: {
3141        src: 'https://upload.wikimedia.org/wikipedia/commons/d/dd/Armstrong_Small_Step.ogg'
3142      }
3143    },
3144    transforms: audio_transforms,
3145    deprecated: deprecated,
3146    edit: edit,
3147    save: save
3148  };
3149  
3150  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/button.js
3151  
3152  
3153  /**
3154   * WordPress dependencies
3155   */
3156  
3157  const button_button = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
3158    viewBox: "0 0 24 24",
3159    xmlns: "http://www.w3.org/2000/svg"
3160  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
3161    d: "M19 6.5H5c-1.1 0-2 .9-2 2v7c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2v-7c0-1.1-.9-2-2-2zm.5 9c0 .3-.2.5-.5.5H5c-.3 0-.5-.2-.5-.5v-7c0-.3.2-.5.5-.5h14c.3 0 .5.2.5.5v7zM8 12.8h8v-1.5H8v1.5z"
3162  }));
3163  /* harmony default export */ var library_button = (button_button);
3164  
3165  ;// CONCATENATED MODULE: external ["wp","compose"]
3166  var external_wp_compose_namespaceObject = window["wp"]["compose"];
3167  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/utils/clean-empty-object.js
3168  /**
3169   * External dependencies
3170   */
3171  
3172  /**
3173   * Removed empty nodes from nested objects.
3174   *
3175   * @param {Object} object
3176   * @return {Object} Object cleaned from empty nodes.
3177   */
3178  
3179  const cleanEmptyObject = object => {
3180    if (!(0,external_lodash_namespaceObject.isObject)(object) || Array.isArray(object)) {
3181      return object;
3182    }
3183  
3184    const cleanedNestedObjects = (0,external_lodash_namespaceObject.pickBy)((0,external_lodash_namespaceObject.mapValues)(object, cleanEmptyObject), external_lodash_namespaceObject.identity);
3185    return (0,external_lodash_namespaceObject.isEmpty)(cleanedNestedObjects) ? undefined : cleanedNestedObjects;
3186  };
3187  
3188  /* harmony default export */ var clean_empty_object = (cleanEmptyObject);
3189  
3190  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/utils/migrate-font-family.js
3191  /**
3192   * External dependencies
3193   */
3194  
3195  /**
3196   * Internal dependencies
3197   */
3198  
3199  
3200  /**
3201   * Migrates the current style.typography.fontFamily attribute,
3202   * whose value was "var:preset|font-family|helvetica-arial",
3203   * to the style.fontFamily attribute, whose value will be "helvetica-arial".
3204   *
3205   * @param {Object} attributes The current attributes
3206   * @return {Object} The updated attributes.
3207   */
3208  
3209  /* harmony default export */ function migrate_font_family(attributes) {
3210    var _attributes$style, _attributes$style$typ;
3211  
3212    if (!(attributes !== null && attributes !== void 0 && (_attributes$style = attributes.style) !== null && _attributes$style !== void 0 && (_attributes$style$typ = _attributes$style.typography) !== null && _attributes$style$typ !== void 0 && _attributes$style$typ.fontFamily)) {
3213      return attributes;
3214    } // Clone first so when we delete the fontFamily
3215    // below we're not modifying the original
3216    // attributes. Because the deprecation may be discarded
3217    // we don't want to alter the original attributes.
3218  
3219  
3220    const atts = (0,external_lodash_namespaceObject.cloneDeep)(attributes);
3221    const fontFamily = atts.style.typography.fontFamily.split('|').pop();
3222    delete atts.style.typography.fontFamily;
3223    atts.style = clean_empty_object(atts.style);
3224    return { ...atts,
3225      fontFamily
3226    };
3227  }
3228  
3229  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/button/deprecated.js
3230  
3231  
3232  /**
3233   * External dependencies
3234   */
3235  
3236  
3237  /**
3238   * WordPress dependencies
3239   */
3240  
3241  
3242  
3243  /**
3244   * Internal dependencies
3245   */
3246  
3247  
3248  
3249  const migrateBorderRadius = attributes => {
3250    var _newAttributes$style, _newAttributes$style$, _newAttributes$style2;
3251  
3252    const {
3253      borderRadius,
3254      ...newAttributes
3255    } = attributes; // We have to check old property `borderRadius` and if
3256    // `styles.border.radius` is a `number`
3257  
3258    const oldBorderRadius = [borderRadius, (_newAttributes$style = newAttributes.style) === null || _newAttributes$style === void 0 ? void 0 : (_newAttributes$style$ = _newAttributes$style.border) === null || _newAttributes$style$ === void 0 ? void 0 : _newAttributes$style$.radius].find(possibleBorderRadius => {
3259      return typeof possibleBorderRadius === 'number' && possibleBorderRadius !== 0;
3260    });
3261  
3262    if (!oldBorderRadius) {
3263      return newAttributes;
3264    }
3265  
3266    return { ...newAttributes,
3267      style: { ...newAttributes.style,
3268        border: { ...((_newAttributes$style2 = newAttributes.style) === null || _newAttributes$style2 === void 0 ? void 0 : _newAttributes$style2.border),
3269          radius: `$oldBorderRadius}px`
3270        }
3271      }
3272    };
3273  };
3274  
3275  const migrateCustomColorsAndGradients = attributes => {
3276    if (!attributes.customTextColor && !attributes.customBackgroundColor && !attributes.customGradient) {
3277      return attributes;
3278    }
3279  
3280    const style = {
3281      color: {}
3282    };
3283  
3284    if (attributes.customTextColor) {
3285      style.color.text = attributes.customTextColor;
3286    }
3287  
3288    if (attributes.customBackgroundColor) {
3289      style.color.background = attributes.customBackgroundColor;
3290    }
3291  
3292    if (attributes.customGradient) {
3293      style.color.gradient = attributes.customGradient;
3294    }
3295  
3296    return { ...(0,external_lodash_namespaceObject.omit)(attributes, ['customTextColor', 'customBackgroundColor', 'customGradient']),
3297      style
3298    };
3299  };
3300  
3301  const oldColorsMigration = attributes => {
3302    return migrateCustomColorsAndGradients((0,external_lodash_namespaceObject.omit)({ ...attributes,
3303      customTextColor: attributes.textColor && '#' === attributes.textColor[0] ? attributes.textColor : undefined,
3304      customBackgroundColor: attributes.color && '#' === attributes.color[0] ? attributes.color : undefined
3305    }, ['color', 'textColor']));
3306  };
3307  
3308  const blockAttributes = {
3309    url: {
3310      type: 'string',
3311      source: 'attribute',
3312      selector: 'a',
3313      attribute: 'href'
3314    },
3315    title: {
3316      type: 'string',
3317      source: 'attribute',
3318      selector: 'a',
3319      attribute: 'title'
3320    },
3321    text: {
3322      type: 'string',
3323      source: 'html',
3324      selector: 'a'
3325    }
3326  };
3327  const v10 = {
3328    attributes: {
3329      url: {
3330        type: 'string',
3331        source: 'attribute',
3332        selector: 'a',
3333        attribute: 'href'
3334      },
3335      title: {
3336        type: 'string',
3337        source: 'attribute',
3338        selector: 'a',
3339        attribute: 'title'
3340      },
3341      text: {
3342        type: 'string',
3343        source: 'html',
3344        selector: 'a'
3345      },
3346      linkTarget: {
3347        type: 'string',
3348        source: 'attribute',
3349        selector: 'a',
3350        attribute: 'target'
3351      },
3352      rel: {
3353        type: 'string',
3354        source: 'attribute',
3355        selector: 'a',
3356        attribute: 'rel'
3357      },
3358      placeholder: {
3359        type: 'string'
3360      },
3361      backgroundColor: {
3362        type: 'string'
3363      },
3364      textColor: {
3365        type: 'string'
3366      },
3367      gradient: {
3368        type: 'string'
3369      },
3370      width: {
3371        type: 'number'
3372      }
3373    },
3374    supports: {
3375      anchor: true,
3376      align: true,
3377      alignWide: false,
3378      color: {
3379        __experimentalSkipSerialization: true,
3380        gradients: true
3381      },
3382      typography: {
3383        fontSize: true,
3384        __experimentalFontFamily: true
3385      },
3386      reusable: false,
3387      spacing: {
3388        __experimentalSkipSerialization: true,
3389        padding: ['horizontal', 'vertical'],
3390        __experimentalDefaultControls: {
3391          padding: true
3392        }
3393      },
3394      __experimentalBorder: {
3395        radius: true,
3396        __experimentalSkipSerialization: true
3397      },
3398      __experimentalSelector: '.wp-block-button__link'
3399    },
3400  
3401    save(_ref) {
3402      var _style$border, _style$typography;
3403  
3404      let {
3405        attributes,
3406        className
3407      } = _ref;
3408      const {
3409        fontSize,
3410        linkTarget,
3411        rel,
3412        style,
3413        text,
3414        title,
3415        url,
3416        width
3417      } = attributes;
3418  
3419      if (!text) {
3420        return null;
3421      }
3422  
3423      const borderProps = (0,external_wp_blockEditor_namespaceObject.__experimentalGetBorderClassesAndStyles)(attributes);
3424      const colorProps = (0,external_wp_blockEditor_namespaceObject.__experimentalGetColorClassesAndStyles)(attributes);
3425      const spacingProps = (0,external_wp_blockEditor_namespaceObject.__experimentalGetSpacingClassesAndStyles)(attributes);
3426      const buttonClasses = classnames_default()('wp-block-button__link', colorProps.className, borderProps.className, {
3427        // For backwards compatibility add style that isn't provided via
3428        // block support.
3429        'no-border-radius': (style === null || style === void 0 ? void 0 : (_style$border = style.border) === null || _style$border === void 0 ? void 0 : _style$border.radius) === 0
3430      });
3431      const buttonStyle = { ...borderProps.style,
3432        ...colorProps.style,
3433        ...spacingProps.style
3434      }; // The use of a `title` attribute here is soft-deprecated, but still applied
3435      // if it had already been assigned, for the sake of backward-compatibility.
3436      // A title will no longer be assigned for new or updated button block links.
3437  
3438      const wrapperClasses = classnames_default()(className, {
3439        [`has-custom-width wp-block-button__width-$width}`]: width,
3440        [`has-custom-font-size`]: fontSize || (style === null || style === void 0 ? void 0 : (_style$typography = style.typography) === null || _style$typography === void 0 ? void 0 : _style$typography.fontSize)
3441      });
3442      return (0,external_wp_element_namespaceObject.createElement)("div", external_wp_blockEditor_namespaceObject.useBlockProps.save({
3443        className: wrapperClasses
3444      }), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
3445        tagName: "a",
3446        className: buttonClasses,
3447        href: url,
3448        title: title,
3449        style: buttonStyle,
3450        value: text,
3451        target: linkTarget,
3452        rel: rel
3453      }));
3454    },
3455  
3456    migrate: migrate_font_family,
3457  
3458    isEligible(_ref2) {
3459      var _style$typography2;
3460  
3461      let {
3462        style
3463      } = _ref2;
3464      return style === null || style === void 0 ? void 0 : (_style$typography2 = style.typography) === null || _style$typography2 === void 0 ? void 0 : _style$typography2.fontFamily;
3465    }
3466  
3467  };
3468  const deprecated_deprecated = [v10, {
3469    supports: {
3470      anchor: true,
3471      align: true,
3472      alignWide: false,
3473      color: {
3474        __experimentalSkipSerialization: true,
3475        gradients: true
3476      },
3477      typography: {
3478        fontSize: true,
3479        __experimentalFontFamily: true
3480      },
3481      reusable: false,
3482      __experimentalSelector: '.wp-block-button__link'
3483    },
3484    attributes: { ...blockAttributes,
3485      linkTarget: {
3486        type: 'string',
3487        source: 'attribute',
3488        selector: 'a',
3489        attribute: 'target'
3490      },
3491      rel: {
3492        type: 'string',
3493        source: 'attribute',
3494        selector: 'a',
3495        attribute: 'rel'
3496      },
3497      placeholder: {
3498        type: 'string'
3499      },
3500      backgroundColor: {
3501        type: 'string'
3502      },
3503      textColor: {
3504        type: 'string'
3505      },
3506      gradient: {
3507        type: 'string'
3508      },
3509      width: {
3510        type: 'number'
3511      }
3512    },
3513  
3514    isEligible(_ref3) {
3515      var _style$border2;
3516  
3517      let {
3518        style
3519      } = _ref3;
3520      return typeof (style === null || style === void 0 ? void 0 : (_style$border2 = style.border) === null || _style$border2 === void 0 ? void 0 : _style$border2.radius) === 'number';
3521    },
3522  
3523    save(_ref4) {
3524      var _style$border3, _style$border4, _style$typography3;
3525  
3526      let {
3527        attributes,
3528        className
3529      } = _ref4;
3530      const {
3531        fontSize,
3532        linkTarget,
3533        rel,
3534        style,
3535        text,
3536        title,
3537        url,
3538        width
3539      } = attributes;
3540  
3541      if (!text) {
3542        return null;
3543      }
3544  
3545      const borderRadius = style === null || style === void 0 ? void 0 : (_style$border3 = style.border) === null || _style$border3 === void 0 ? void 0 : _style$border3.radius;
3546      const colorProps = (0,external_wp_blockEditor_namespaceObject.__experimentalGetColorClassesAndStyles)(attributes);
3547      const buttonClasses = classnames_default()('wp-block-button__link', colorProps.className, {
3548        'no-border-radius': (style === null || style === void 0 ? void 0 : (_style$border4 = style.border) === null || _style$border4 === void 0 ? void 0 : _style$border4.radius) === 0
3549      });
3550      const buttonStyle = {
3551        borderRadius: borderRadius ? borderRadius : undefined,
3552        ...colorProps.style
3553      }; // The use of a `title` attribute here is soft-deprecated, but still applied
3554      // if it had already been assigned, for the sake of backward-compatibility.
3555      // A title will no longer be assigned for new or updated button block links.
3556  
3557      const wrapperClasses = classnames_default()(className, {
3558        [`has-custom-width wp-block-button__width-$width}`]: width,
3559        [`has-custom-font-size`]: fontSize || (style === null || style === void 0 ? void 0 : (_style$typography3 = style.typography) === null || _style$typography3 === void 0 ? void 0 : _style$typography3.fontSize)
3560      });
3561      return (0,external_wp_element_namespaceObject.createElement)("div", external_wp_blockEditor_namespaceObject.useBlockProps.save({
3562        className: wrapperClasses
3563      }), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
3564        tagName: "a",
3565        className: buttonClasses,
3566        href: url,
3567        title: title,
3568        style: buttonStyle,
3569        value: text,
3570        target: linkTarget,
3571        rel: rel
3572      }));
3573    },
3574  
3575    migrate: (0,external_wp_compose_namespaceObject.compose)(migrate_font_family, migrateBorderRadius)
3576  }, {
3577    supports: {
3578      anchor: true,
3579      align: true,
3580      alignWide: false,
3581      color: {
3582        __experimentalSkipSerialization: true
3583      },
3584      reusable: false,
3585      __experimentalSelector: '.wp-block-button__link'
3586    },
3587    attributes: { ...blockAttributes,
3588      linkTarget: {
3589        type: 'string',
3590        source: 'attribute',
3591        selector: 'a',
3592        attribute: 'target'
3593      },
3594      rel: {
3595        type: 'string',
3596        source: 'attribute',
3597        selector: 'a',
3598        attribute: 'rel'
3599      },
3600      placeholder: {
3601        type: 'string'
3602      },
3603      borderRadius: {
3604        type: 'number'
3605      },
3606      backgroundColor: {
3607        type: 'string'
3608      },
3609      textColor: {
3610        type: 'string'
3611      },
3612      gradient: {
3613        type: 'string'
3614      },
3615      style: {
3616        type: 'object'
3617      },
3618      width: {
3619        type: 'number'
3620      }
3621    },
3622  
3623    save(_ref5) {
3624      let {
3625        attributes,
3626        className
3627      } = _ref5;
3628      const {
3629        borderRadius,
3630        linkTarget,
3631        rel,
3632        text,
3633        title,
3634        url,
3635        width
3636      } = attributes;
3637      const colorProps = (0,external_wp_blockEditor_namespaceObject.__experimentalGetColorClassesAndStyles)(attributes);
3638      const buttonClasses = classnames_default()('wp-block-button__link', colorProps.className, {
3639        'no-border-radius': borderRadius === 0
3640      });
3641      const buttonStyle = {
3642        borderRadius: borderRadius ? borderRadius + 'px' : undefined,
3643        ...colorProps.style
3644      }; // The use of a `title` attribute here is soft-deprecated, but still applied
3645      // if it had already been assigned, for the sake of backward-compatibility.
3646      // A title will no longer be assigned for new or updated button block links.
3647  
3648      const wrapperClasses = classnames_default()(className, {
3649        [`has-custom-width wp-block-button__width-$width}`]: width
3650      });
3651      return (0,external_wp_element_namespaceObject.createElement)("div", external_wp_blockEditor_namespaceObject.useBlockProps.save({
3652        className: wrapperClasses
3653      }), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
3654        tagName: "a",
3655        className: buttonClasses,
3656        href: url,
3657        title: title,
3658        style: buttonStyle,
3659        value: text,
3660        target: linkTarget,
3661        rel: rel
3662      }));
3663    },
3664  
3665    migrate: (0,external_wp_compose_namespaceObject.compose)(migrate_font_family, migrateBorderRadius)
3666  }, {
3667    supports: {
3668      anchor: true,
3669      align: true,
3670      alignWide: false,
3671      color: {
3672        __experimentalSkipSerialization: true
3673      },
3674      reusable: false,
3675      __experimentalSelector: '.wp-block-button__link'
3676    },
3677    attributes: { ...blockAttributes,
3678      linkTarget: {
3679        type: 'string',
3680        source: 'attribute',
3681        selector: 'a',
3682        attribute: 'target'
3683      },
3684      rel: {
3685        type: 'string',
3686        source: 'attribute',
3687        selector: 'a',
3688        attribute: 'rel'
3689      },
3690      placeholder: {
3691        type: 'string'
3692      },
3693      borderRadius: {
3694        type: 'number'
3695      },
3696      backgroundColor: {
3697        type: 'string'
3698      },
3699      textColor: {
3700        type: 'string'
3701      },
3702      gradient: {
3703        type: 'string'
3704      },
3705      style: {
3706        type: 'object'
3707      },
3708      width: {
3709        type: 'number'
3710      }
3711    },
3712  
3713    save(_ref6) {
3714      let {
3715        attributes,
3716        className
3717      } = _ref6;
3718      const {
3719        borderRadius,
3720        linkTarget,
3721        rel,
3722        text,
3723        title,
3724        url,
3725        width
3726      } = attributes;
3727      const colorProps = (0,external_wp_blockEditor_namespaceObject.__experimentalGetColorClassesAndStyles)(attributes);
3728      const buttonClasses = classnames_default()('wp-block-button__link', colorProps.className, {
3729        'no-border-radius': borderRadius === 0
3730      });
3731      const buttonStyle = {
3732        borderRadius: borderRadius ? borderRadius + 'px' : undefined,
3733        ...colorProps.style
3734      }; // The use of a `title` attribute here is soft-deprecated, but still applied
3735      // if it had already been assigned, for the sake of backward-compatibility.
3736      // A title will no longer be assigned for new or updated button block links.
3737  
3738      const wrapperClasses = classnames_default()(className, {
3739        [`has-custom-width wp-block-button__width-$width}`]: width
3740      });
3741      return (0,external_wp_element_namespaceObject.createElement)("div", external_wp_blockEditor_namespaceObject.useBlockProps.save({
3742        className: wrapperClasses
3743      }), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
3744        tagName: "a",
3745        className: buttonClasses,
3746        href: url,
3747        title: title,
3748        style: buttonStyle,
3749        value: text,
3750        target: linkTarget,
3751        rel: rel
3752      }));
3753    },
3754  
3755    migrate: (0,external_wp_compose_namespaceObject.compose)(migrate_font_family, migrateBorderRadius)
3756  }, {
3757    supports: {
3758      align: true,
3759      alignWide: false,
3760      color: {
3761        gradients: true
3762      }
3763    },
3764    attributes: { ...blockAttributes,
3765      linkTarget: {
3766        type: 'string',
3767        source: 'attribute',
3768        selector: 'a',
3769        attribute: 'target'
3770      },
3771      rel: {
3772        type: 'string',
3773        source: 'attribute',
3774        selector: 'a',
3775        attribute: 'rel'
3776      },
3777      placeholder: {
3778        type: 'string'
3779      },
3780      borderRadius: {
3781        type: 'number'
3782      },
3783      backgroundColor: {
3784        type: 'string'
3785      },
3786      textColor: {
3787        type: 'string'
3788      },
3789      gradient: {
3790        type: 'string'
3791      },
3792      style: {
3793        type: 'object'
3794      }
3795    },
3796  
3797    save(_ref7) {
3798      let {
3799        attributes
3800      } = _ref7;
3801      const {
3802        borderRadius,
3803        linkTarget,
3804        rel,
3805        text,
3806        title,
3807        url
3808      } = attributes;
3809      const buttonClasses = classnames_default()('wp-block-button__link', {
3810        'no-border-radius': borderRadius === 0
3811      });
3812      const buttonStyle = {
3813        borderRadius: borderRadius ? borderRadius + 'px' : undefined
3814      };
3815      return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
3816        tagName: "a",
3817        className: buttonClasses,
3818        href: url,
3819        title: title,
3820        style: buttonStyle,
3821        value: text,
3822        target: linkTarget,
3823        rel: rel
3824      });
3825    },
3826  
3827    migrate: migrateBorderRadius
3828  }, {
3829    supports: {
3830      align: true,
3831      alignWide: false
3832    },
3833    attributes: { ...blockAttributes,
3834      linkTarget: {
3835        type: 'string',
3836        source: 'attribute',
3837        selector: 'a',
3838        attribute: 'target'
3839      },
3840      rel: {
3841        type: 'string',
3842        source: 'attribute',
3843        selector: 'a',
3844        attribute: 'rel'
3845      },
3846      placeholder: {
3847        type: 'string'
3848      },
3849      borderRadius: {
3850        type: 'number'
3851      },
3852      backgroundColor: {
3853        type: 'string'
3854      },
3855      textColor: {
3856        type: 'string'
3857      },
3858      customBackgroundColor: {
3859        type: 'string'
3860      },
3861      customTextColor: {
3862        type: 'string'
3863      },
3864      customGradient: {
3865        type: 'string'
3866      },
3867      gradient: {
3868        type: 'string'
3869      }
3870    },
3871    isEligible: attributes => !!attributes.customTextColor || !!attributes.customBackgroundColor || !!attributes.customGradient,
3872    migrate: (0,external_wp_compose_namespaceObject.compose)(migrateBorderRadius, migrateCustomColorsAndGradients),
3873  
3874    save(_ref8) {
3875      let {
3876        attributes
3877      } = _ref8;
3878      const {
3879        backgroundColor,
3880        borderRadius,
3881        customBackgroundColor,
3882        customTextColor,
3883        customGradient,
3884        linkTarget,
3885        gradient,
3886        rel,
3887        text,
3888        textColor,
3889        title,
3890        url
3891      } = attributes;
3892      const textClass = (0,external_wp_blockEditor_namespaceObject.getColorClassName)('color', textColor);
3893      const backgroundClass = !customGradient && (0,external_wp_blockEditor_namespaceObject.getColorClassName)('background-color', backgroundColor);
3894  
3895      const gradientClass = (0,external_wp_blockEditor_namespaceObject.__experimentalGetGradientClass)(gradient);
3896  
3897      const buttonClasses = classnames_default()('wp-block-button__link', {
3898        'has-text-color': textColor || customTextColor,
3899        [textClass]: textClass,
3900        'has-background': backgroundColor || customBackgroundColor || customGradient || gradient,
3901        [backgroundClass]: backgroundClass,
3902        'no-border-radius': borderRadius === 0,
3903        [gradientClass]: gradientClass
3904      });
3905      const buttonStyle = {
3906        background: customGradient ? customGradient : undefined,
3907        backgroundColor: backgroundClass || customGradient || gradient ? undefined : customBackgroundColor,
3908        color: textClass ? undefined : customTextColor,
3909        borderRadius: borderRadius ? borderRadius + 'px' : undefined
3910      }; // The use of a `title` attribute here is soft-deprecated, but still applied
3911      // if it had already been assigned, for the sake of backward-compatibility.
3912      // A title will no longer be assigned for new or updated button block links.
3913  
3914      return (0,external_wp_element_namespaceObject.createElement)("div", null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
3915        tagName: "a",
3916        className: buttonClasses,
3917        href: url,
3918        title: title,
3919        style: buttonStyle,
3920        value: text,
3921        target: linkTarget,
3922        rel: rel
3923      }));
3924    }
3925  
3926  }, {
3927    attributes: { ...blockAttributes,
3928      align: {
3929        type: 'string',
3930        default: 'none'
3931      },
3932      backgroundColor: {
3933        type: 'string'
3934      },
3935      textColor: {
3936        type: 'string'
3937      },
3938      customBackgroundColor: {
3939        type: 'string'
3940      },
3941      customTextColor: {
3942        type: 'string'
3943      },
3944      linkTarget: {
3945        type: 'string',
3946        source: 'attribute',
3947        selector: 'a',
3948        attribute: 'target'
3949      },
3950      rel: {
3951        type: 'string',
3952        source: 'attribute',
3953        selector: 'a',
3954        attribute: 'rel'
3955      },
3956      placeholder: {
3957        type: 'string'
3958      }
3959    },
3960  
3961    isEligible(attribute) {
3962      return attribute.className && attribute.className.includes('is-style-squared');
3963    },
3964  
3965    migrate(attributes) {
3966      let newClassName = attributes.className;
3967  
3968      if (newClassName) {
3969        newClassName = newClassName.replace(/is-style-squared[\s]?/, '').trim();
3970      }
3971  
3972      return migrateBorderRadius(migrateCustomColorsAndGradients({ ...attributes,
3973        className: newClassName ? newClassName : undefined,
3974        borderRadius: 0
3975      }));
3976    },
3977  
3978    save(_ref9) {
3979      let {
3980        attributes
3981      } = _ref9;
3982      const {
3983        backgroundColor,
3984        customBackgroundColor,
3985        customTextColor,
3986        linkTarget,
3987        rel,
3988        text,
3989        textColor,
3990        title,
3991        url
3992      } = attributes;
3993      const textClass = (0,external_wp_blockEditor_namespaceObject.getColorClassName)('color', textColor);
3994      const backgroundClass = (0,external_wp_blockEditor_namespaceObject.getColorClassName)('background-color', backgroundColor);
3995      const buttonClasses = classnames_default()('wp-block-button__link', {
3996        'has-text-color': textColor || customTextColor,
3997        [textClass]: textClass,
3998        'has-background': backgroundColor || customBackgroundColor,
3999        [backgroundClass]: backgroundClass
4000      });
4001      const buttonStyle = {
4002        backgroundColor: backgroundClass ? undefined : customBackgroundColor,
4003        color: textClass ? undefined : customTextColor
4004      };
4005      return (0,external_wp_element_namespaceObject.createElement)("div", null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
4006        tagName: "a",
4007        className: buttonClasses,
4008        href: url,
4009        title: title,
4010        style: buttonStyle,
4011        value: text,
4012        target: linkTarget,
4013        rel: rel
4014      }));
4015    }
4016  
4017  }, {
4018    attributes: { ...blockAttributes,
4019      align: {
4020        type: 'string',
4021        default: 'none'
4022      },
4023      backgroundColor: {
4024        type: 'string'
4025      },
4026      textColor: {
4027        type: 'string'
4028      },
4029      customBackgroundColor: {
4030        type: 'string'
4031      },
4032      customTextColor: {
4033        type: 'string'
4034      }
4035    },
4036    migrate: oldColorsMigration,
4037  
4038    save(_ref10) {
4039      let {
4040        attributes
4041      } = _ref10;
4042      const {
4043        url,
4044        text,
4045        title,
4046        backgroundColor,
4047        textColor,
4048        customBackgroundColor,
4049        customTextColor
4050      } = attributes;
4051      const textClass = (0,external_wp_blockEditor_namespaceObject.getColorClassName)('color', textColor);
4052      const backgroundClass = (0,external_wp_blockEditor_namespaceObject.getColorClassName)('background-color', backgroundColor);
4053      const buttonClasses = classnames_default()('wp-block-button__link', {
4054        'has-text-color': textColor || customTextColor,
4055        [textClass]: textClass,
4056        'has-background': backgroundColor || customBackgroundColor,
4057        [backgroundClass]: backgroundClass
4058      });
4059      const buttonStyle = {
4060        backgroundColor: backgroundClass ? undefined : customBackgroundColor,
4061        color: textClass ? undefined : customTextColor
4062      };
4063      return (0,external_wp_element_namespaceObject.createElement)("div", null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
4064        tagName: "a",
4065        className: buttonClasses,
4066        href: url,
4067        title: title,
4068        style: buttonStyle,
4069        value: text
4070      }));
4071    }
4072  
4073  }, {
4074    attributes: { ...blockAttributes,
4075      color: {
4076        type: 'string'
4077      },
4078      textColor: {
4079        type: 'string'
4080      },
4081      align: {
4082        type: 'string',
4083        default: 'none'
4084      }
4085    },
4086  
4087    save(_ref11) {
4088      let {
4089        attributes
4090      } = _ref11;
4091      const {
4092        url,
4093        text,
4094        title,
4095        align,
4096        color,
4097        textColor
4098      } = attributes;
4099      const buttonStyle = {
4100        backgroundColor: color,
4101        color: textColor
4102      };
4103      const linkClass = 'wp-block-button__link';
4104      return (0,external_wp_element_namespaceObject.createElement)("div", {
4105        className: `align$align}`
4106      }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
4107        tagName: "a",
4108        className: linkClass,
4109        href: url,
4110        title: title,
4111        style: buttonStyle,
4112        value: text
4113      }));
4114    },
4115  
4116    migrate: oldColorsMigration
4117  }, {
4118    attributes: { ...blockAttributes,
4119      color: {
4120        type: 'string'
4121      },
4122      textColor: {
4123        type: 'string'
4124      },
4125      align: {
4126        type: 'string',
4127        default: 'none'
4128      }
4129    },
4130  
4131    save(_ref12) {
4132      let {
4133        attributes
4134      } = _ref12;
4135      const {
4136        url,
4137        text,
4138        title,
4139        align,
4140        color,
4141        textColor
4142      } = attributes;
4143      return (0,external_wp_element_namespaceObject.createElement)("div", {
4144        className: `align$align}`,
4145        style: {
4146          backgroundColor: color
4147        }
4148      }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
4149        tagName: "a",
4150        href: url,
4151        title: title,
4152        style: {
4153          color: textColor
4154        },
4155        value: text
4156      }));
4157    },
4158  
4159    migrate: oldColorsMigration
4160  }];
4161  /* harmony default export */ var button_deprecated = (deprecated_deprecated);
4162  
4163  ;// CONCATENATED MODULE: external ["wp","keycodes"]
4164  var external_wp_keycodes_namespaceObject = window["wp"]["keycodes"];
4165  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/link.js
4166  
4167  
4168  /**
4169   * WordPress dependencies
4170   */
4171  
4172  const link_link = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
4173    xmlns: "http://www.w3.org/2000/svg",
4174    viewBox: "0 0 24 24"
4175  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
4176    d: "M15.6 7.2H14v1.5h1.6c2 0 3.7 1.7 3.7 3.7s-1.7 3.7-3.7 3.7H14v1.5h1.6c2.8 0 5.2-2.3 5.2-5.2 0-2.9-2.3-5.2-5.2-5.2zM4.7 12.4c0-2 1.7-3.7 3.7-3.7H10V7.2H8.4c-2.9 0-5.2 2.3-5.2 5.2 0 2.9 2.3 5.2 5.2 5.2H10v-1.5H8.4c-2 0-3.7-1.7-3.7-3.7zm4.6.9h5.3v-1.5H9.3v1.5z"
4177  }));
4178  /* harmony default export */ var library_link = (link_link);
4179  
4180  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/link-off.js
4181  
4182  
4183  /**
4184   * WordPress dependencies
4185   */
4186  
4187  const linkOff = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
4188    xmlns: "http://www.w3.org/2000/svg",
4189    viewBox: "0 0 24 24"
4190  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
4191    d: "M15.6 7.3h-.7l1.6-3.5-.9-.4-3.9 8.5H9v1.5h2l-1.3 2.8H8.4c-2 0-3.7-1.7-3.7-3.7s1.7-3.7 3.7-3.7H10V7.3H8.4c-2.9 0-5.2 2.3-5.2 5.2 0 2.9 2.3 5.2 5.2 5.2H9l-1.4 3.2.9.4 5.7-12.5h1.4c2 0 3.7 1.7 3.7 3.7s-1.7 3.7-3.7 3.7H14v1.5h1.6c2.9 0 5.2-2.3 5.2-5.2 0-2.9-2.4-5.2-5.2-5.2z"
4192  }));
4193  /* harmony default export */ var link_off = (linkOff);
4194  
4195  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/button/edit.js
4196  
4197  
4198  
4199  /**
4200   * External dependencies
4201   */
4202  
4203  /**
4204   * WordPress dependencies
4205   */
4206  
4207  
4208  
4209  
4210  
4211  
4212  
4213  
4214  const NEW_TAB_REL = 'noreferrer noopener';
4215  
4216  function WidthPanel(_ref) {
4217    let {
4218      selectedWidth,
4219      setAttributes
4220    } = _ref;
4221  
4222    function handleChange(newWidth) {
4223      // Check if we are toggling the width off
4224      const width = selectedWidth === newWidth ? undefined : newWidth; // Update attributes.
4225  
4226      setAttributes({
4227        width
4228      });
4229    }
4230  
4231    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
4232      title: (0,external_wp_i18n_namespaceObject.__)('Width settings')
4233    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ButtonGroup, {
4234      "aria-label": (0,external_wp_i18n_namespaceObject.__)('Button width')
4235    }, [25, 50, 75, 100].map(widthValue => {
4236      return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
4237        key: widthValue,
4238        isSmall: true,
4239        variant: widthValue === selectedWidth ? 'primary' : undefined,
4240        onClick: () => handleChange(widthValue)
4241      }, widthValue, "%");
4242    })));
4243  }
4244  
4245  function ButtonEdit(props) {
4246    var _style$border;
4247  
4248    const {
4249      attributes,
4250      setAttributes,
4251      className,
4252      isSelected,
4253      onReplace,
4254      mergeBlocks
4255    } = props;
4256    const {
4257      linkTarget,
4258      placeholder,
4259      rel,
4260      style,
4261      text,
4262      url,
4263      width
4264    } = attributes;
4265    const onSetLinkRel = (0,external_wp_element_namespaceObject.useCallback)(value => {
4266      setAttributes({
4267        rel: value
4268      });
4269    }, [setAttributes]);
4270  
4271    function onToggleOpenInNewTab(value) {
4272      const newLinkTarget = value ? '_blank' : undefined;
4273      let updatedRel = rel;
4274  
4275      if (newLinkTarget && !rel) {
4276        updatedRel = NEW_TAB_REL;
4277      } else if (!newLinkTarget && rel === NEW_TAB_REL) {
4278        updatedRel = undefined;
4279      }
4280  
4281      setAttributes({
4282        linkTarget: newLinkTarget,
4283        rel: updatedRel
4284      });
4285    }
4286  
4287    function setButtonText(newText) {
4288      // Remove anchor tags from button text content.
4289      setAttributes({
4290        text: newText.replace(/<\/?a[^>]*>/g, '')
4291      });
4292    }
4293  
4294    function onKeyDown(event) {
4295      if (external_wp_keycodes_namespaceObject.isKeyboardEvent.primary(event, 'k')) {
4296        startEditing(event);
4297      } else if (external_wp_keycodes_namespaceObject.isKeyboardEvent.primaryShift(event, 'k')) {
4298        var _richTextRef$current;
4299  
4300        unlink();
4301        (_richTextRef$current = richTextRef.current) === null || _richTextRef$current === void 0 ? void 0 : _richTextRef$current.focus();
4302      }
4303    }
4304  
4305    const borderProps = (0,external_wp_blockEditor_namespaceObject.__experimentalUseBorderProps)(attributes);
4306    const colorProps = (0,external_wp_blockEditor_namespaceObject.__experimentalUseColorProps)(attributes);
4307    const spacingProps = (0,external_wp_blockEditor_namespaceObject.__experimentalGetSpacingClassesAndStyles)(attributes);
4308    const ref = (0,external_wp_element_namespaceObject.useRef)();
4309    const richTextRef = (0,external_wp_element_namespaceObject.useRef)();
4310    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
4311      ref,
4312      onKeyDown
4313    });
4314    const [isEditingURL, setIsEditingURL] = (0,external_wp_element_namespaceObject.useState)(false);
4315    const isURLSet = !!url;
4316    const opensInNewTab = linkTarget === '_blank';
4317  
4318    function startEditing(event) {
4319      event.preventDefault();
4320      setIsEditingURL(true);
4321    }
4322  
4323    function unlink() {
4324      setAttributes({
4325        url: undefined,
4326        linkTarget: undefined,
4327        rel: undefined
4328      });
4329      setIsEditingURL(false);
4330    }
4331  
4332    (0,external_wp_element_namespaceObject.useEffect)(() => {
4333      if (!isSelected) {
4334        setIsEditingURL(false);
4335      }
4336    }, [isSelected]);
4337    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)("div", _extends({}, blockProps, {
4338      className: classnames_default()(blockProps.className, {
4339        [`has-custom-width wp-block-button__width-$width}`]: width,
4340        [`has-custom-font-size`]: blockProps.style.fontSize
4341      })
4342    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText, {
4343      ref: richTextRef,
4344      "aria-label": (0,external_wp_i18n_namespaceObject.__)('Button text'),
4345      placeholder: placeholder || (0,external_wp_i18n_namespaceObject.__)('Add text…'),
4346      value: text,
4347      onChange: value => setButtonText(value),
4348      withoutInteractiveFormatting: true,
4349      className: classnames_default()(className, 'wp-block-button__link', colorProps.className, borderProps.className, {
4350        // For backwards compatibility add style that isn't
4351        // provided via block support.
4352        'no-border-radius': (style === null || style === void 0 ? void 0 : (_style$border = style.border) === null || _style$border === void 0 ? void 0 : _style$border.radius) === 0
4353      }),
4354      style: { ...borderProps.style,
4355        ...colorProps.style,
4356        ...spacingProps.style
4357      },
4358      onSplit: value => (0,external_wp_blocks_namespaceObject.createBlock)('core/button', { ...attributes,
4359        text: value
4360      }),
4361      onReplace: onReplace,
4362      onMerge: mergeBlocks,
4363      identifier: "text"
4364    })), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, {
4365      group: "block"
4366    }, !isURLSet && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, {
4367      name: "link",
4368      icon: library_link,
4369      title: (0,external_wp_i18n_namespaceObject.__)('Link'),
4370      shortcut: external_wp_keycodes_namespaceObject.displayShortcut.primary('k'),
4371      onClick: startEditing
4372    }), isURLSet && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, {
4373      name: "link",
4374      icon: link_off,
4375      title: (0,external_wp_i18n_namespaceObject.__)('Unlink'),
4376      shortcut: external_wp_keycodes_namespaceObject.displayShortcut.primaryShift('k'),
4377      onClick: unlink,
4378      isActive: true
4379    })), isSelected && (isEditingURL || isURLSet) && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Popover, {
4380      position: "bottom center",
4381      onClose: () => {
4382        var _richTextRef$current2;
4383  
4384        setIsEditingURL(false);
4385        (_richTextRef$current2 = richTextRef.current) === null || _richTextRef$current2 === void 0 ? void 0 : _richTextRef$current2.focus();
4386      },
4387      anchorRef: ref === null || ref === void 0 ? void 0 : ref.current,
4388      focusOnMount: isEditingURL ? 'firstElement' : false,
4389      __unstableSlotName: '__unstable-block-tools-after'
4390    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.__experimentalLinkControl, {
4391      className: "wp-block-navigation-link__inline-link-input",
4392      value: {
4393        url,
4394        opensInNewTab
4395      },
4396      onChange: _ref2 => {
4397        let {
4398          url: newURL = '',
4399          opensInNewTab: newOpensInNewTab
4400        } = _ref2;
4401        setAttributes({
4402          url: newURL
4403        });
4404  
4405        if (opensInNewTab !== newOpensInNewTab) {
4406          onToggleOpenInNewTab(newOpensInNewTab);
4407        }
4408      },
4409      onRemove: () => {
4410        var _richTextRef$current3;
4411  
4412        unlink();
4413        (_richTextRef$current3 = richTextRef.current) === null || _richTextRef$current3 === void 0 ? void 0 : _richTextRef$current3.focus();
4414      },
4415      forceIsEditingLink: isEditingURL
4416    })), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, (0,external_wp_element_namespaceObject.createElement)(WidthPanel, {
4417      selectedWidth: width,
4418      setAttributes: setAttributes
4419    })), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, {
4420      __experimentalGroup: "advanced"
4421    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TextControl, {
4422      label: (0,external_wp_i18n_namespaceObject.__)('Link rel'),
4423      value: rel || '',
4424      onChange: onSetLinkRel
4425    })));
4426  }
4427  
4428  /* harmony default export */ var button_edit = (ButtonEdit);
4429  
4430  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/button/save.js
4431  
4432  
4433  /**
4434   * External dependencies
4435   */
4436  
4437  /**
4438   * WordPress dependencies
4439   */
4440  
4441  
4442  function save_save(_ref) {
4443    var _style$border, _style$typography;
4444  
4445    let {
4446      attributes,
4447      className
4448    } = _ref;
4449    const {
4450      fontSize,
4451      linkTarget,
4452      rel,
4453      style,
4454      text,
4455      title,
4456      url,
4457      width
4458    } = attributes;
4459  
4460    if (!text) {
4461      return null;
4462    }
4463  
4464    const borderProps = (0,external_wp_blockEditor_namespaceObject.__experimentalGetBorderClassesAndStyles)(attributes);
4465    const colorProps = (0,external_wp_blockEditor_namespaceObject.__experimentalGetColorClassesAndStyles)(attributes);
4466    const spacingProps = (0,external_wp_blockEditor_namespaceObject.__experimentalGetSpacingClassesAndStyles)(attributes);
4467    const buttonClasses = classnames_default()('wp-block-button__link', colorProps.className, borderProps.className, {
4468      // For backwards compatibility add style that isn't provided via
4469      // block support.
4470      'no-border-radius': (style === null || style === void 0 ? void 0 : (_style$border = style.border) === null || _style$border === void 0 ? void 0 : _style$border.radius) === 0
4471    });
4472    const buttonStyle = { ...borderProps.style,
4473      ...colorProps.style,
4474      ...spacingProps.style
4475    }; // The use of a `title` attribute here is soft-deprecated, but still applied
4476    // if it had already been assigned, for the sake of backward-compatibility.
4477    // A title will no longer be assigned for new or updated button block links.
4478  
4479    const wrapperClasses = classnames_default()(className, {
4480      [`has-custom-width wp-block-button__width-$width}`]: width,
4481      [`has-custom-font-size`]: fontSize || (style === null || style === void 0 ? void 0 : (_style$typography = style.typography) === null || _style$typography === void 0 ? void 0 : _style$typography.fontSize)
4482    });
4483    return (0,external_wp_element_namespaceObject.createElement)("div", external_wp_blockEditor_namespaceObject.useBlockProps.save({
4484      className: wrapperClasses
4485    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
4486      tagName: "a",
4487      className: buttonClasses,
4488      href: url,
4489      title: title,
4490      style: buttonStyle,
4491      value: text,
4492      target: linkTarget,
4493      rel: rel
4494    }));
4495  }
4496  
4497  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/button/index.js
4498  /**
4499   * WordPress dependencies
4500   */
4501  
4502  
4503  /**
4504   * Internal dependencies
4505   */
4506  
4507  
4508  
4509  const button_metadata = {
4510    $schema: "https://schemas.wp.org/trunk/block.json",
4511    apiVersion: 2,
4512    name: "core/button",
4513    title: "Button",
4514    category: "design",
4515    parent: ["core/buttons"],
4516    description: "Prompt visitors to take action with a button-style link.",
4517    keywords: ["link"],
4518    textdomain: "default",
4519    attributes: {
4520      url: {
4521        type: "string",
4522        source: "attribute",
4523        selector: "a",
4524        attribute: "href"
4525      },
4526      title: {
4527        type: "string",
4528        source: "attribute",
4529        selector: "a",
4530        attribute: "title"
4531      },
4532      text: {
4533        type: "string",
4534        source: "html",
4535        selector: "a"
4536      },
4537      linkTarget: {
4538        type: "string",
4539        source: "attribute",
4540        selector: "a",
4541        attribute: "target"
4542      },
4543      rel: {
4544        type: "string",
4545        source: "attribute",
4546        selector: "a",
4547        attribute: "rel"
4548      },
4549      placeholder: {
4550        type: "string"
4551      },
4552      backgroundColor: {
4553        type: "string"
4554      },
4555      textColor: {
4556        type: "string"
4557      },
4558      gradient: {
4559        type: "string"
4560      },
4561      width: {
4562        type: "number"
4563      }
4564    },
4565    supports: {
4566      anchor: true,
4567      align: true,
4568      alignWide: false,
4569      color: {
4570        __experimentalSkipSerialization: true,
4571        gradients: true,
4572        __experimentalDefaultControls: {
4573          background: true,
4574          text: true
4575        }
4576      },
4577      typography: {
4578        fontSize: true,
4579        __experimentalFontFamily: true,
4580        __experimentalDefaultControls: {
4581          fontSize: true
4582        }
4583      },
4584      reusable: false,
4585      spacing: {
4586        __experimentalSkipSerialization: true,
4587        padding: ["horizontal", "vertical"],
4588        __experimentalDefaultControls: {
4589          padding: true
4590        }
4591      },
4592      __experimentalBorder: {
4593        radius: true,
4594        __experimentalSkipSerialization: true,
4595        __experimentalDefaultControls: {
4596          radius: true
4597        }
4598      },
4599      __experimentalSelector: ".wp-block-button__link"
4600    },
4601    styles: [{
4602      name: "fill",
4603      label: "Fill",
4604      isDefault: true
4605    }, {
4606      name: "outline",
4607      label: "Outline"
4608    }],
4609    editorStyle: "wp-block-button-editor",
4610    style: "wp-block-button"
4611  };
4612  
4613  const {
4614    name: button_name
4615  } = button_metadata;
4616  
4617  const button_settings = {
4618    icon: library_button,
4619    example: {
4620      attributes: {
4621        className: 'is-style-fill',
4622        text: (0,external_wp_i18n_namespaceObject.__)('Call to Action')
4623      }
4624    },
4625    edit: button_edit,
4626    save: save_save,
4627    deprecated: button_deprecated,
4628    merge: (a, _ref) => {
4629      let {
4630        text = ''
4631      } = _ref;
4632      return { ...a,
4633        text: (a.text || '') + text
4634      };
4635    }
4636  };
4637  
4638  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/buttons.js
4639  
4640  
4641  /**
4642   * WordPress dependencies
4643   */
4644  
4645  const buttons = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
4646    viewBox: "0 0 24 24",
4647    xmlns: "http://www.w3.org/2000/svg"
4648  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
4649    d: "M17 3H7c-1.1 0-2 .9-2 2v4c0 1.1.9 2 2 2h10c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm.5 6c0 .3-.2.5-.5.5H7c-.3 0-.5-.2-.5-.5V5c0-.3.2-.5.5-.5h10c.3 0 .5.2.5.5v4zm-8-1.2h5V6.2h-5v1.6zM17 13H7c-1.1 0-2 .9-2 2v4c0 1.1.9 2 2 2h10c1.1 0 2-.9 2-2v-4c0-1.1-.9-2-2-2zm.5 6c0 .3-.2.5-.5.5H7c-.3 0-.5-.2-.5-.5v-4c0-.3.2-.5.5-.5h10c.3 0 .5.2.5.5v4zm-8-1.2h5v-1.5h-5v1.5z"
4650  }));
4651  /* harmony default export */ var library_buttons = (buttons);
4652  
4653  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/buttons/deprecated.js
4654  
4655  
4656  /**
4657   * External dependencies
4658   */
4659  
4660  /**
4661   * WordPress dependencies
4662   */
4663  
4664  
4665  /**
4666   * @param {Object} attributes Block's attributes.
4667   */
4668  
4669  const migrateWithLayout = attributes => {
4670    if (!!attributes.layout) {
4671      return attributes;
4672    }
4673  
4674    const {
4675      contentJustification,
4676      orientation,
4677      ...updatedAttributes
4678    } = attributes;
4679  
4680    if (contentJustification || orientation) {
4681      Object.assign(updatedAttributes, {
4682        layout: {
4683          type: 'flex',
4684          ...(contentJustification && {
4685            justifyContent: contentJustification
4686          }),
4687          ...(orientation && {
4688            orientation
4689          })
4690        }
4691      });
4692    }
4693  
4694    return updatedAttributes;
4695  };
4696  
4697  const buttons_deprecated_deprecated = [{
4698    attributes: {
4699      contentJustification: {
4700        type: 'string'
4701      },
4702      orientation: {
4703        type: 'string',
4704        default: 'horizontal'
4705      }
4706    },
4707    supports: {
4708      anchor: true,
4709      align: ['wide', 'full'],
4710      __experimentalExposeControlsToChildren: true,
4711      spacing: {
4712        blockGap: true,
4713        margin: ['top', 'bottom'],
4714        __experimentalDefaultControls: {
4715          blockGap: true
4716        }
4717      }
4718    },
4719    isEligible: _ref => {
4720      let {
4721        contentJustification,
4722        orientation
4723      } = _ref;
4724      return !!contentJustification || !!orientation;
4725    },
4726    migrate: migrateWithLayout,
4727  
4728    save(_ref2) {
4729      let {
4730        attributes: {
4731          contentJustification,
4732          orientation
4733        }
4734      } = _ref2;
4735      return (0,external_wp_element_namespaceObject.createElement)("div", external_wp_blockEditor_namespaceObject.useBlockProps.save({
4736        className: classnames_default()({
4737          [`is-content-justification-$contentJustification}`]: contentJustification,
4738          'is-vertical': orientation === 'vertical'
4739        })
4740      }), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InnerBlocks.Content, null));
4741    }
4742  
4743  }, {
4744    supports: {
4745      align: ['center', 'left', 'right'],
4746      anchor: true
4747    },
4748  
4749    save() {
4750      return (0,external_wp_element_namespaceObject.createElement)("div", null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InnerBlocks.Content, null));
4751    },
4752  
4753    isEligible(_ref3) {
4754      let {
4755        align
4756      } = _ref3;
4757      return align && ['center', 'left', 'right'].includes(align);
4758    },
4759  
4760    migrate(attributes) {
4761      return migrateWithLayout({ ...attributes,
4762        align: undefined,
4763        // Floating Buttons blocks shouldn't have been supported in the
4764        // first place. Most users using them probably expected them to
4765        // act like content justification controls, so these blocks are
4766        // migrated to use content justification.
4767        // As for center-aligned Buttons blocks, the content justification
4768        // equivalent will create an identical end result in most cases.
4769        contentJustification: attributes.align
4770      });
4771    }
4772  
4773  }];
4774  /* harmony default export */ var buttons_deprecated = (buttons_deprecated_deprecated);
4775  
4776  ;// CONCATENATED MODULE: external ["wp","richText"]
4777  var external_wp_richText_namespaceObject = window["wp"]["richText"];
4778  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/buttons/transforms.js
4779  /**
4780   * WordPress dependencies
4781   */
4782  
4783  
4784  /**
4785   * Internal dependencies
4786   */
4787  
4788  const {
4789    name: transforms_name
4790  } = {
4791    $schema: "https://schemas.wp.org/trunk/block.json",
4792    apiVersion: 2,
4793    name: "core/buttons",
4794    title: "Buttons",
4795    category: "design",
4796    description: "Prompt visitors to take action with a group of button-style links.",
4797    keywords: ["link"],
4798    textdomain: "default",
4799    supports: {
4800      anchor: true,
4801      align: ["wide", "full"],
4802      __experimentalExposeControlsToChildren: true,
4803      spacing: {
4804        blockGap: true,
4805        margin: ["top", "bottom"],
4806        __experimentalDefaultControls: {
4807          blockGap: true
4808        }
4809      },
4810      __experimentalLayout: {
4811        allowSwitching: false,
4812        allowInheriting: false,
4813        "default": {
4814          type: "flex"
4815        }
4816      }
4817    },
4818    editorStyle: "wp-block-buttons-editor",
4819    style: "wp-block-buttons"
4820  };
4821  const transforms_transforms = {
4822    from: [{
4823      type: 'block',
4824      isMultiBlock: true,
4825      blocks: ['core/button'],
4826      transform: buttons => // Creates the buttons block.
4827      (0,external_wp_blocks_namespaceObject.createBlock)(transforms_name, {}, // Loop the selected buttons.
4828      buttons.map(attributes => // Create singular button in the buttons block.
4829      (0,external_wp_blocks_namespaceObject.createBlock)('core/button', attributes)))
4830    }, {
4831      type: 'block',
4832      isMultiBlock: true,
4833      blocks: ['core/paragraph'],
4834      transform: buttons => // Creates the buttons block.
4835      (0,external_wp_blocks_namespaceObject.createBlock)(transforms_name, {}, // Loop the selected buttons.
4836      buttons.map(attributes => {
4837        const element = (0,external_wp_richText_namespaceObject.__unstableCreateElement)(document, attributes.content); // Remove any HTML tags.
4838  
4839        const text = element.innerText || ''; // Get first url.
4840  
4841        const link = element.querySelector('a');
4842        const url = link === null || link === void 0 ? void 0 : link.getAttribute('href'); // Create singular button in the buttons block.
4843  
4844        return (0,external_wp_blocks_namespaceObject.createBlock)('core/button', {
4845          text,
4846          url
4847        });
4848      })),
4849      isMatch: paragraphs => {
4850        return paragraphs.every(attributes => {
4851          const element = (0,external_wp_richText_namespaceObject.__unstableCreateElement)(document, attributes.content);
4852          const text = element.innerText || '';
4853          const links = element.querySelectorAll('a');
4854          return text.length <= 30 && links.length <= 1;
4855        });
4856      }
4857    }]
4858  };
4859  /* harmony default export */ var buttons_transforms = (transforms_transforms);
4860  
4861  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/buttons/edit.js
4862  
4863  
4864  /**
4865   * WordPress dependencies
4866   */
4867  
4868  
4869  /**
4870   * Internal dependencies
4871   */
4872  
4873  
4874  const ALLOWED_BLOCKS = [button_name];
4875  const DEFAULT_BLOCK = {
4876    name: button_name,
4877    attributesToCopy: ['backgroundColor', 'border', 'className', 'fontFamily', 'fontSize', 'gradient', 'style', 'textColor', 'width']
4878  };
4879  
4880  function ButtonsEdit(_ref) {
4881    let {
4882      attributes: {
4883        layout = {}
4884      }
4885    } = _ref;
4886    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)();
4887    const preferredStyle = (0,external_wp_data_namespaceObject.useSelect)(select => {
4888      var _preferredStyleVariat;
4889  
4890      const preferredStyleVariations = select(external_wp_blockEditor_namespaceObject.store).getSettings().__experimentalPreferredStyleVariations;
4891  
4892      return preferredStyleVariations === null || preferredStyleVariations === void 0 ? void 0 : (_preferredStyleVariat = preferredStyleVariations.value) === null || _preferredStyleVariat === void 0 ? void 0 : _preferredStyleVariat[button_name];
4893    }, []);
4894    const innerBlocksProps = (0,external_wp_blockEditor_namespaceObject.useInnerBlocksProps)(blockProps, {
4895      allowedBlocks: ALLOWED_BLOCKS,
4896      __experimentalDefaultBlock: DEFAULT_BLOCK,
4897      __experimentalDirectInsert: true,
4898      template: [[button_name, {
4899        className: preferredStyle && `is-style-$preferredStyle}`
4900      }]],
4901      __experimentalLayout: layout,
4902      templateInsertUpdatesSelection: true
4903    });
4904    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)("div", innerBlocksProps));
4905  }
4906  
4907  /* harmony default export */ var buttons_edit = (ButtonsEdit);
4908  
4909  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/buttons/save.js
4910  
4911  
4912  /**
4913   * WordPress dependencies
4914   */
4915  
4916  function buttons_save_save() {
4917    const innerBlocksProps = external_wp_blockEditor_namespaceObject.useInnerBlocksProps.save(external_wp_blockEditor_namespaceObject.useBlockProps.save());
4918    return (0,external_wp_element_namespaceObject.createElement)("div", innerBlocksProps);
4919  }
4920  
4921  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/buttons/index.js
4922  /**
4923   * WordPress dependencies
4924   */
4925  
4926  
4927  /**
4928   * Internal dependencies
4929   */
4930  
4931  
4932  
4933  
4934  const buttons_metadata = {
4935    $schema: "https://schemas.wp.org/trunk/block.json",
4936    apiVersion: 2,
4937    name: "core/buttons",
4938    title: "Buttons",
4939    category: "design",
4940    description: "Prompt visitors to take action with a group of button-style links.",
4941    keywords: ["link"],
4942    textdomain: "default",
4943    supports: {
4944      anchor: true,
4945      align: ["wide", "full"],
4946      __experimentalExposeControlsToChildren: true,
4947      spacing: {
4948        blockGap: true,
4949        margin: ["top", "bottom"],
4950        __experimentalDefaultControls: {
4951          blockGap: true
4952        }
4953      },
4954      __experimentalLayout: {
4955        allowSwitching: false,
4956        allowInheriting: false,
4957        "default": {
4958          type: "flex"
4959        }
4960      }
4961    },
4962    editorStyle: "wp-block-buttons-editor",
4963    style: "wp-block-buttons"
4964  };
4965  
4966  const {
4967    name: buttons_name
4968  } = buttons_metadata;
4969  
4970  const buttons_settings = {
4971    icon: library_buttons,
4972    example: {
4973      innerBlocks: [{
4974        name: 'core/button',
4975        attributes: {
4976          text: (0,external_wp_i18n_namespaceObject.__)('Find out more')
4977        }
4978      }, {
4979        name: 'core/button',
4980        attributes: {
4981          text: (0,external_wp_i18n_namespaceObject.__)('Contact us')
4982        }
4983      }]
4984    },
4985    deprecated: buttons_deprecated,
4986    transforms: buttons_transforms,
4987    edit: buttons_edit,
4988    save: buttons_save_save
4989  };
4990  
4991  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/calendar.js
4992  
4993  
4994  /**
4995   * WordPress dependencies
4996   */
4997  
4998  const calendar = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
4999    viewBox: "0 0 24 24",
5000    xmlns: "http://www.w3.org/2000/svg"
5001  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
5002    d: "M19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm.5 16c0 .3-.2.5-.5.5H5c-.3 0-.5-.2-.5-.5V7h15v12zM9 10H7v2h2v-2zm0 4H7v2h2v-2zm4-4h-2v2h2v-2zm4 0h-2v2h2v-2zm-4 4h-2v2h2v-2zm4 0h-2v2h2v-2z"
5003  }));
5004  /* harmony default export */ var library_calendar = (calendar);
5005  
5006  ;// CONCATENATED MODULE: external "moment"
5007  var external_moment_namespaceObject = window["moment"];
5008  var external_moment_default = /*#__PURE__*/__webpack_require__.n(external_moment_namespaceObject);
5009  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/calendar/edit.js
5010  
5011  
5012  /**
5013   * External dependencies
5014   */
5015  
5016  
5017  /**
5018   * WordPress dependencies
5019   */
5020  
5021  
5022  
5023  
5024  
5025  
5026  
5027  
5028  const getYearMonth = memize_default()(date => {
5029    if (!date) {
5030      return {};
5031    }
5032  
5033    const momentDate = external_moment_default()(date);
5034    return {
5035      year: momentDate.year(),
5036      month: momentDate.month() + 1
5037    };
5038  });
5039  function CalendarEdit(_ref) {
5040    let {
5041      attributes
5042    } = _ref;
5043    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)();
5044    const {
5045      date,
5046      hasPosts,
5047      hasPostsResolved
5048    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
5049      const {
5050        getEntityRecords,
5051        hasFinishedResolution
5052      } = select(external_wp_coreData_namespaceObject.store);
5053      const singlePublishedPostQuery = {
5054        status: 'publish',
5055        per_page: 1
5056      };
5057      const posts = getEntityRecords('postType', 'post', singlePublishedPostQuery);
5058      const postsResolved = hasFinishedResolution('getEntityRecords', ['postType', 'post', singlePublishedPostQuery]);
5059  
5060      let _date; // FIXME: @wordpress/block-library should not depend on @wordpress/editor.
5061      // Blocks can be loaded into a *non-post* block editor.
5062      // eslint-disable-next-line @wordpress/data-no-store-string-literals
5063  
5064  
5065      const editorSelectors = select('core/editor');
5066  
5067      if (editorSelectors) {
5068        const postType = editorSelectors.getEditedPostAttribute('type'); // Dates are used to overwrite year and month used on the calendar.
5069        // This overwrite should only happen for 'post' post types.
5070        // For other post types the calendar always displays the current month.
5071  
5072        if (postType === 'post') {
5073          _date = editorSelectors.getEditedPostAttribute('date');
5074        }
5075      }
5076  
5077      return {
5078        date: _date,
5079        hasPostsResolved: postsResolved,
5080        hasPosts: postsResolved && (posts === null || posts === void 0 ? void 0 : posts.length) === 1
5081      };
5082    }, []);
5083  
5084    if (!hasPosts) {
5085      return (0,external_wp_element_namespaceObject.createElement)("div", blockProps, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Placeholder, {
5086        icon: library_calendar,
5087        label: (0,external_wp_i18n_namespaceObject.__)('Calendar')
5088      }, !hasPostsResolved ? (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Spinner, null) : (0,external_wp_i18n_namespaceObject.__)('No published posts found.')));
5089    }
5090  
5091    return (0,external_wp_element_namespaceObject.createElement)("div", blockProps, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Disabled, null, (0,external_wp_element_namespaceObject.createElement)((external_wp_serverSideRender_default()), {
5092      block: "core/calendar",
5093      attributes: { ...attributes,
5094        ...getYearMonth(date)
5095      }
5096    })));
5097  }
5098  
5099  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/calendar/transforms.js
5100  /**
5101   * WordPress dependencies
5102   */
5103  
5104  const calendar_transforms_transforms = {
5105    from: [{
5106      type: 'block',
5107      blocks: ['core/archives'],
5108      transform: () => (0,external_wp_blocks_namespaceObject.createBlock)('core/calendar')
5109    }],
5110    to: [{
5111      type: 'block',
5112      blocks: ['core/archives'],
5113      transform: () => (0,external_wp_blocks_namespaceObject.createBlock)('core/archives')
5114    }]
5115  };
5116  /* harmony default export */ var calendar_transforms = (calendar_transforms_transforms);
5117  
5118  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/calendar/index.js
5119  /**
5120   * WordPress dependencies
5121   */
5122  
5123  /**
5124   * Internal dependencies
5125   */
5126  
5127  const calendar_metadata = {
5128    $schema: "https://schemas.wp.org/trunk/block.json",
5129    apiVersion: 2,
5130    name: "core/calendar",
5131    title: "Calendar",
5132    category: "widgets",
5133    description: "A calendar of your site\u2019s posts.",
5134    keywords: ["posts", "archive"],
5135    textdomain: "default",
5136    attributes: {
5137      month: {
5138        type: "integer"
5139      },
5140      year: {
5141        type: "integer"
5142      }
5143    },
5144    supports: {
5145      align: true
5146    },
5147    style: "wp-block-calendar"
5148  };
5149  
5150  
5151  const {
5152    name: calendar_name
5153  } = calendar_metadata;
5154  
5155  const calendar_settings = {
5156    icon: library_calendar,
5157    example: {},
5158    edit: CalendarEdit,
5159    transforms: calendar_transforms
5160  };
5161  
5162  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/category.js
5163  
5164  
5165  /**
5166   * WordPress dependencies
5167   */
5168  
5169  const category = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
5170    viewBox: "0 0 24 24",
5171    xmlns: "http://www.w3.org/2000/svg"
5172  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
5173    d: "M6 5.5h3a.5.5 0 01.5.5v3a.5.5 0 01-.5.5H6a.5.5 0 01-.5-.5V6a.5.5 0 01.5-.5zM4 6a2 2 0 012-2h3a2 2 0 012 2v3a2 2 0 01-2 2H6a2 2 0 01-2-2V6zm11-.5h3a.5.5 0 01.5.5v3a.5.5 0 01-.5.5h-3a.5.5 0 01-.5-.5V6a.5.5 0 01.5-.5zM13 6a2 2 0 012-2h3a2 2 0 012 2v3a2 2 0 01-2 2h-3a2 2 0 01-2-2V6zm5 8.5h-3a.5.5 0 00-.5.5v3a.5.5 0 00.5.5h3a.5.5 0 00.5-.5v-3a.5.5 0 00-.5-.5zM15 13a2 2 0 00-2 2v3a2 2 0 002 2h3a2 2 0 002-2v-3a2 2 0 00-2-2h-3zm-9 1.5h3a.5.5 0 01.5.5v3a.5.5 0 01-.5.5H6a.5.5 0 01-.5-.5v-3a.5.5 0 01.5-.5zM4 15a2 2 0 012-2h3a2 2 0 012 2v3a2 2 0 01-2 2H6a2 2 0 01-2-2v-3z",
5174    fillRule: "evenodd",
5175    clipRule: "evenodd"
5176  }));
5177  /* harmony default export */ var library_category = (category);
5178  
5179  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/pin.js
5180  
5181  
5182  /**
5183   * WordPress dependencies
5184   */
5185  
5186  const pin = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
5187    xmlns: "http://www.w3.org/2000/svg",
5188    viewBox: "0 0 24 24"
5189  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
5190    d: "m21.5 9.1-6.6-6.6-4.2 5.6c-1.2-.1-2.4.1-3.6.7-.1 0-.1.1-.2.1-.5.3-.9.6-1.2.9l3.7 3.7-5.7 5.7v1.1h1.1l5.7-5.7 3.7 3.7c.4-.4.7-.8.9-1.2.1-.1.1-.2.2-.3.6-1.1.8-2.4.6-3.6l5.6-4.1zm-7.3 3.5.1.9c.1.9 0 1.8-.4 2.6l-6-6c.8-.4 1.7-.5 2.6-.4l.9.1L15 4.9 19.1 9l-4.9 3.6z"
5191  }));
5192  /* harmony default export */ var library_pin = (pin);
5193  
5194  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/categories/edit.js
5195  
5196  
5197  /**
5198   * External dependencies
5199   */
5200  
5201  /**
5202   * WordPress dependencies
5203   */
5204  
5205  
5206  
5207  
5208  
5209  
5210  
5211  function CategoriesEdit(_ref) {
5212    let {
5213      attributes: {
5214        displayAsDropdown,
5215        showHierarchy,
5216        showPostCounts,
5217        showOnlyTopLevel
5218      },
5219      setAttributes
5220    } = _ref;
5221    const selectId = (0,external_wp_compose_namespaceObject.useInstanceId)(CategoriesEdit, 'blocks-category-select');
5222    const query = {
5223      per_page: -1,
5224      hide_empty: true,
5225      context: 'view'
5226    };
5227  
5228    if (showOnlyTopLevel) {
5229      query.parent = 0;
5230    }
5231  
5232    const {
5233      records: categories,
5234      isResolving
5235    } = (0,external_wp_coreData_namespaceObject.__experimentalUseEntityRecords)('taxonomy', 'category', query);
5236  
5237    const getCategoriesList = parentId => {
5238      if (!(categories !== null && categories !== void 0 && categories.length)) {
5239        return [];
5240      }
5241  
5242      if (parentId === null) {
5243        return categories;
5244      }
5245  
5246      return categories.filter(_ref2 => {
5247        let {
5248          parent
5249        } = _ref2;
5250        return parent === parentId;
5251      });
5252    };
5253  
5254    const getCategoryListClassName = level => {
5255      return `wp-block-categories__list wp-block-categories__list-level-$level}`;
5256    };
5257  
5258    const toggleAttribute = attributeName => newValue => setAttributes({
5259      [attributeName]: newValue
5260    });
5261  
5262    const renderCategoryName = name => !name ? (0,external_wp_i18n_namespaceObject.__)('(Untitled)') : (0,external_lodash_namespaceObject.unescape)(name).trim();
5263  
5264    const renderCategoryList = () => {
5265      const parentId = showHierarchy ? 0 : null;
5266      const categoriesList = getCategoriesList(parentId);
5267      return (0,external_wp_element_namespaceObject.createElement)("ul", {
5268        className: getCategoryListClassName(0)
5269      }, categoriesList.map(category => renderCategoryListItem(category, 0)));
5270    };
5271  
5272    const renderCategoryListItem = (category, level) => {
5273      const childCategories = getCategoriesList(category.id);
5274      const {
5275        id,
5276        link,
5277        count,
5278        name
5279      } = category;
5280      return (0,external_wp_element_namespaceObject.createElement)("li", {
5281        key: id
5282      }, (0,external_wp_element_namespaceObject.createElement)("a", {
5283        href: link,
5284        target: "_blank",
5285        rel: "noreferrer noopener"
5286      }, renderCategoryName(name)), showPostCounts && (0,external_wp_element_namespaceObject.createElement)("span", {
5287        className: "wp-block-categories__post-count"
5288      }, ` ($count})`), showHierarchy && !!childCategories.length && (0,external_wp_element_namespaceObject.createElement)("ul", {
5289        className: getCategoryListClassName(level + 1)
5290      }, childCategories.map(childCategory => renderCategoryListItem(childCategory, level + 1))));
5291    };
5292  
5293    const renderCategoryDropdown = () => {
5294      const parentId = showHierarchy ? 0 : null;
5295      const categoriesList = getCategoriesList(parentId);
5296      return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.VisuallyHidden, {
5297        as: "label",
5298        htmlFor: selectId
5299      }, (0,external_wp_i18n_namespaceObject.__)('Categories')), (0,external_wp_element_namespaceObject.createElement)("select", {
5300        id: selectId,
5301        className: "wp-block-categories__dropdown"
5302      }, categoriesList.map(category => renderCategoryDropdownItem(category, 0))));
5303    };
5304  
5305    const renderCategoryDropdownItem = (category, level) => {
5306      const {
5307        id,
5308        count,
5309        name
5310      } = category;
5311      const childCategories = getCategoriesList(id);
5312      return [(0,external_wp_element_namespaceObject.createElement)("option", {
5313        key: id
5314      }, (0,external_lodash_namespaceObject.times)(level * 3, () => '\xa0'), renderCategoryName(name), showPostCounts && ` ($count})`), showHierarchy && !!childCategories.length && childCategories.map(childCategory => renderCategoryDropdownItem(childCategory, level + 1))];
5315    };
5316  
5317    return (0,external_wp_element_namespaceObject.createElement)("div", (0,external_wp_blockEditor_namespaceObject.useBlockProps)(), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
5318      title: (0,external_wp_i18n_namespaceObject.__)('Categories settings')
5319    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
5320      label: (0,external_wp_i18n_namespaceObject.__)('Display as dropdown'),
5321      checked: displayAsDropdown,
5322      onChange: toggleAttribute('displayAsDropdown')
5323    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
5324      label: (0,external_wp_i18n_namespaceObject.__)('Show post counts'),
5325      checked: showPostCounts,
5326      onChange: toggleAttribute('showPostCounts')
5327    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
5328      label: (0,external_wp_i18n_namespaceObject.__)('Show only top level categories'),
5329      checked: showOnlyTopLevel,
5330      onChange: toggleAttribute('showOnlyTopLevel')
5331    }), !showOnlyTopLevel && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
5332      label: (0,external_wp_i18n_namespaceObject.__)('Show hierarchy'),
5333      checked: showHierarchy,
5334      onChange: toggleAttribute('showHierarchy')
5335    }))), isResolving && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Placeholder, {
5336      icon: library_pin,
5337      label: (0,external_wp_i18n_namespaceObject.__)('Categories')
5338    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Spinner, null)), !isResolving && (categories === null || categories === void 0 ? void 0 : categories.length) === 0 && (0,external_wp_element_namespaceObject.createElement)("p", null, (0,external_wp_i18n_namespaceObject.__)('Your site does not have any posts, so there is nothing to display here at the moment.')), !isResolving && (categories === null || categories === void 0 ? void 0 : categories.length) > 0 && (displayAsDropdown ? renderCategoryDropdown() : renderCategoryList()));
5339  }
5340  
5341  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/categories/index.js
5342  /**
5343   * WordPress dependencies
5344   */
5345  
5346  /**
5347   * Internal dependencies
5348   */
5349  
5350  const categories_metadata = {
5351    $schema: "https://schemas.wp.org/trunk/block.json",
5352    apiVersion: 2,
5353    name: "core/categories",
5354    title: "Categories",
5355    category: "widgets",
5356    description: "Display a list of all categories.",
5357    textdomain: "default",
5358    attributes: {
5359      displayAsDropdown: {
5360        type: "boolean",
5361        "default": false
5362      },
5363      showHierarchy: {
5364        type: "boolean",
5365        "default": false
5366      },
5367      showPostCounts: {
5368        type: "boolean",
5369        "default": false
5370      },
5371      showOnlyTopLevel: {
5372        type: "boolean",
5373        "default": false
5374      }
5375    },
5376    supports: {
5377      align: true,
5378      html: false
5379    },
5380    editorStyle: "wp-block-categories-editor",
5381    style: "wp-block-categories"
5382  };
5383  
5384  const {
5385    name: categories_name
5386  } = categories_metadata;
5387  
5388  const categories_settings = {
5389    icon: library_category,
5390    example: {},
5391    edit: CategoriesEdit
5392  };
5393  
5394  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/classic.js
5395  
5396  
5397  /**
5398   * WordPress dependencies
5399   */
5400  
5401  const classic = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
5402    viewBox: "0 0 24 24",
5403    xmlns: "http://www.w3.org/2000/svg"
5404  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
5405    d: "M20 6H4c-1.1 0-2 .9-2 2v9c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V8c0-1.1-.9-2-2-2zm.5 11c0 .3-.2.5-.5.5H4c-.3 0-.5-.2-.5-.5V8c0-.3.2-.5.5-.5h16c.3 0 .5.2.5.5v9zM10 10H8v2h2v-2zm-5 2h2v-2H5v2zm8-2h-2v2h2v-2zm-5 6h8v-2H8v2zm6-4h2v-2h-2v2zm3 0h2v-2h-2v2zm0 4h2v-2h-2v2zM5 16h2v-2H5v2z"
5406  }));
5407  /* harmony default export */ var library_classic = (classic);
5408  
5409  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/freeform/convert-to-blocks-button.js
5410  
5411  
5412  /**
5413   * WordPress dependencies
5414   */
5415  
5416  
5417  
5418  
5419  
5420  
5421  const ConvertToBlocksButton = _ref => {
5422    let {
5423      clientId
5424    } = _ref;
5425    const {
5426      replaceBlocks
5427    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_blockEditor_namespaceObject.store);
5428    const block = (0,external_wp_data_namespaceObject.useSelect)(select => {
5429      return select(external_wp_blockEditor_namespaceObject.store).getBlock(clientId);
5430    }, [clientId]);
5431    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, {
5432      onClick: () => replaceBlocks(block.clientId, (0,external_wp_blocks_namespaceObject.rawHandler)({
5433        HTML: (0,external_wp_blocks_namespaceObject.serialize)(block)
5434      }))
5435    }, (0,external_wp_i18n_namespaceObject.__)('Convert to blocks'));
5436  };
5437  
5438  /* harmony default export */ var convert_to_blocks_button = (ConvertToBlocksButton);
5439  
5440  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/freeform/edit.js
5441  
5442  
5443  /**
5444   * External dependencies
5445   */
5446  
5447  /**
5448   * WordPress dependencies
5449   */
5450  
5451  
5452  
5453  
5454  
5455  
5456  
5457  /**
5458   * Internal dependencies
5459   */
5460  
5461  
5462  const {
5463    wp: edit_wp
5464  } = window;
5465  
5466  function isTmceEmpty(editor) {
5467    // When tinyMce is empty the content seems to be:
5468    // <p><br data-mce-bogus="1"></p>
5469    // avoid expensive checks for large documents
5470    const body = editor.getBody();
5471  
5472    if (body.childNodes.length > 1) {
5473      return false;
5474    } else if (body.childNodes.length === 0) {
5475      return true;
5476    }
5477  
5478    if (body.childNodes[0].childNodes.length > 1) {
5479      return false;
5480    }
5481  
5482    return /^\n?$/.test(body.innerText || body.textContent);
5483  }
5484  
5485  function ClassicEdit(_ref) {
5486    let {
5487      clientId,
5488      attributes: {
5489        content
5490      },
5491      setAttributes,
5492      onReplace
5493    } = _ref;
5494    const {
5495      getMultiSelectedBlockClientIds
5496    } = (0,external_wp_data_namespaceObject.useSelect)(external_wp_blockEditor_namespaceObject.store);
5497    const didMount = (0,external_wp_element_namespaceObject.useRef)(false);
5498    (0,external_wp_element_namespaceObject.useEffect)(() => {
5499      if (!didMount.current) {
5500        return;
5501      }
5502  
5503      const editor = window.tinymce.get(`editor-$clientId}`);
5504      const currentContent = editor === null || editor === void 0 ? void 0 : editor.getContent();
5505  
5506      if (currentContent !== content) {
5507        editor.setContent(content || '');
5508      }
5509    }, [content]);
5510    (0,external_wp_element_namespaceObject.useEffect)(() => {
5511      const {
5512        baseURL,
5513        suffix
5514      } = window.wpEditorL10n.tinymce;
5515      didMount.current = true;
5516      window.tinymce.EditorManager.overrideDefaults({
5517        base_url: baseURL,
5518        suffix
5519      });
5520  
5521      function onSetup(editor) {
5522        let bookmark;
5523  
5524        if (content) {
5525          editor.on('loadContent', () => editor.setContent(content));
5526        }
5527  
5528        editor.on('blur', () => {
5529          var _getMultiSelectedBloc;
5530  
5531          bookmark = editor.selection.getBookmark(2, true); // There is an issue with Chrome and the editor.focus call in core at https://core.trac.wordpress.org/browser/trunk/src/js/_enqueues/lib/link.js#L451.
5532          // This causes a scroll to the top of editor content on return from some content updating dialogs so tracking
5533          // scroll position until this is fixed in core.
5534  
5535          const scrollContainer = document.querySelector('.interface-interface-skeleton__content');
5536          const scrollPosition = scrollContainer.scrollTop; // Only update attributes if we aren't multi-selecting blocks.
5537          // Updating during multi-selection can overwrite attributes of other blocks.
5538  
5539          if (!((_getMultiSelectedBloc = getMultiSelectedBlockClientIds()) !== null && _getMultiSelectedBloc !== void 0 && _getMultiSelectedBloc.length)) {
5540            setAttributes({
5541              content: editor.getContent()
5542            });
5543          }
5544  
5545          editor.once('focus', () => {
5546            if (bookmark) {
5547              editor.selection.moveToBookmark(bookmark);
5548  
5549              if (scrollContainer.scrollTop !== scrollPosition) {
5550                scrollContainer.scrollTop = scrollPosition;
5551              }
5552            }
5553          });
5554          return false;
5555        });
5556        editor.on('mousedown touchstart', () => {
5557          bookmark = null;
5558        });
5559        const debouncedOnChange = (0,external_lodash_namespaceObject.debounce)(() => {
5560          const value = editor.getContent();
5561  
5562          if (value !== editor._lastChange) {
5563            editor._lastChange = value;
5564            setAttributes({
5565              content: value
5566            });
5567          }
5568        }, 250);
5569        editor.on('Paste Change input Undo Redo', debouncedOnChange); // We need to cancel the debounce call because when we remove
5570        // the editor (onUnmount) this callback is executed in
5571        // another tick. This results in setting the content to empty.
5572  
5573        editor.on('remove', debouncedOnChange.cancel);
5574        editor.on('keydown', event => {
5575          if (external_wp_keycodes_namespaceObject.isKeyboardEvent.primary(event, 'z')) {
5576            // Prevent the gutenberg undo kicking in so TinyMCE undo stack works as expected.
5577            event.stopPropagation();
5578          }
5579  
5580          if ((event.keyCode === external_wp_keycodes_namespaceObject.BACKSPACE || event.keyCode === external_wp_keycodes_namespaceObject.DELETE) && isTmceEmpty(editor)) {
5581            // Delete the block.
5582            onReplace([]);
5583            event.preventDefault();
5584            event.stopImmediatePropagation();
5585          }
5586  
5587          const {
5588            altKey
5589          } = event;
5590          /*
5591           * Prevent Mousetrap from kicking in: TinyMCE already uses its own
5592           * `alt+f10` shortcut to focus its toolbar.
5593           */
5594  
5595          if (altKey && event.keyCode === external_wp_keycodes_namespaceObject.F10) {
5596            event.stopPropagation();
5597          }
5598        });
5599        editor.on('init', () => {
5600          const rootNode = editor.getBody(); // Create the toolbar by refocussing the editor.
5601  
5602          if (rootNode.ownerDocument.activeElement === rootNode) {
5603            rootNode.blur();
5604            editor.focus();
5605          }
5606        });
5607      }
5608  
5609      function initialize() {
5610        const {
5611          settings
5612        } = window.wpEditorL10n.tinymce;
5613        edit_wp.oldEditor.initialize(`editor-$clientId}`, {
5614          tinymce: { ...settings,
5615            inline: true,
5616            content_css: false,
5617            fixed_toolbar_container: `#toolbar-$clientId}`,
5618            setup: onSetup
5619          }
5620        });
5621      }
5622  
5623      function onReadyStateChange() {
5624        if (document.readyState === 'complete') {
5625          initialize();
5626        }
5627      }
5628  
5629      if (document.readyState === 'complete') {
5630        initialize();
5631      } else {
5632        document.addEventListener('readystatechange', onReadyStateChange);
5633      }
5634  
5635      return () => {
5636        document.removeEventListener('readystatechange', onReadyStateChange);
5637        edit_wp.oldEditor.remove(`editor-$clientId}`);
5638      };
5639    }, []);
5640  
5641    function focus() {
5642      const editor = window.tinymce.get(`editor-$clientId}`);
5643  
5644      if (editor) {
5645        editor.focus();
5646      }
5647    }
5648  
5649    function onToolbarKeyDown(event) {
5650      // Prevent WritingFlow from kicking in and allow arrows navigation on the toolbar.
5651      event.stopPropagation(); // Prevent Mousetrap from moving focus to the top toolbar when pressing `alt+f10` on this block toolbar.
5652  
5653      event.nativeEvent.stopImmediatePropagation();
5654    } // Disable reasons:
5655    //
5656    // jsx-a11y/no-static-element-interactions
5657    //  - the toolbar itself is non-interactive, but must capture events
5658    //    from the KeyboardShortcuts component to stop their propagation.
5659  
5660    /* eslint-disable jsx-a11y/no-static-element-interactions */
5661  
5662  
5663    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarGroup, null, (0,external_wp_element_namespaceObject.createElement)(convert_to_blocks_button, {
5664      clientId: clientId
5665    }))), (0,external_wp_element_namespaceObject.createElement)("div", (0,external_wp_blockEditor_namespaceObject.useBlockProps)(), (0,external_wp_element_namespaceObject.createElement)("div", {
5666      key: "toolbar",
5667      id: `toolbar-$clientId}`,
5668      className: "block-library-classic__toolbar",
5669      onClick: focus,
5670      "data-placeholder": (0,external_wp_i18n_namespaceObject.__)('Classic'),
5671      onKeyDown: onToolbarKeyDown
5672    }), (0,external_wp_element_namespaceObject.createElement)("div", {
5673      key: "editor",
5674      id: `editor-$clientId}`,
5675      className: "wp-block-freeform block-library-rich-text__tinymce"
5676    })));
5677    /* eslint-enable jsx-a11y/no-static-element-interactions */
5678  }
5679  
5680  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/freeform/save.js
5681  
5682  
5683  /**
5684   * WordPress dependencies
5685   */
5686  
5687  function freeform_save_save(_ref) {
5688    let {
5689      attributes
5690    } = _ref;
5691    const {
5692      content
5693    } = attributes;
5694    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.RawHTML, null, content);
5695  }
5696  
5697  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/freeform/index.js
5698  /**
5699   * WordPress dependencies
5700   */
5701  
5702  /**
5703   * Internal dependencies
5704   */
5705  
5706  
5707  const freeform_metadata = {
5708    $schema: "https://schemas.wp.org/trunk/block.json",
5709    apiVersion: 2,
5710    name: "core/freeform",
5711    title: "Classic",
5712    category: "text",
5713    description: "Use the classic WordPress editor.",
5714    textdomain: "default",
5715    attributes: {
5716      content: {
5717        type: "string",
5718        source: "html"
5719      }
5720    },
5721    supports: {
5722      className: false,
5723      customClassName: false,
5724      reusable: false
5725    },
5726    editorStyle: "wp-block-freeform-editor"
5727  };
5728  
5729  const {
5730    name: freeform_name
5731  } = freeform_metadata;
5732  
5733  const freeform_settings = {
5734    icon: library_classic,
5735    edit: ClassicEdit,
5736    save: freeform_save_save
5737  };
5738  
5739  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/code.js
5740  
5741  
5742  /**
5743   * WordPress dependencies
5744   */
5745  
5746  const code = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
5747    viewBox: "0 0 24 24",
5748    xmlns: "http://www.w3.org/2000/svg"
5749  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
5750    d: "M20.8 10.7l-4.3-4.3-1.1 1.1 4.3 4.3c.1.1.1.3 0 .4l-4.3 4.3 1.1 1.1 4.3-4.3c.7-.8.7-1.9 0-2.6zM4.2 11.8l4.3-4.3-1-1-4.3 4.3c-.7.7-.7 1.8 0 2.5l4.3 4.3 1.1-1.1-4.3-4.3c-.2-.1-.2-.3-.1-.4z"
5751  }));
5752  /* harmony default export */ var library_code = (code);
5753  
5754  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/code/edit.js
5755  
5756  
5757  /**
5758   * WordPress dependencies
5759   */
5760  
5761  
5762  function CodeEdit(_ref) {
5763    let {
5764      attributes,
5765      setAttributes,
5766      onRemove
5767    } = _ref;
5768    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)();
5769    return (0,external_wp_element_namespaceObject.createElement)("pre", blockProps, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText, {
5770      tagName: "code",
5771      value: attributes.content,
5772      onChange: content => setAttributes({
5773        content
5774      }),
5775      onRemove: onRemove,
5776      placeholder: (0,external_wp_i18n_namespaceObject.__)('Write code…'),
5777      "aria-label": (0,external_wp_i18n_namespaceObject.__)('Code'),
5778      preserveWhiteSpace: true,
5779      __unstablePastePlainText: true
5780    }));
5781  }
5782  
5783  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/code/utils.js
5784  /**
5785   * External dependencies
5786   */
5787  
5788  /**
5789   * Escapes ampersands, shortcodes, and links.
5790   *
5791   * @param {string} content The content of a code block.
5792   * @return {string} The given content with some characters escaped.
5793   */
5794  
5795  function utils_escape(content) {
5796    return (0,external_lodash_namespaceObject.flow)(escapeOpeningSquareBrackets, escapeProtocolInIsolatedUrls)(content || '');
5797  }
5798  /**
5799   * Returns the given content with all opening shortcode characters converted
5800   * into their HTML entity counterpart (i.e. [ => &#91;). For instance, a
5801   * shortcode like [embed] becomes &#91;embed]
5802   *
5803   * This function replicates the escaping of HTML tags, where a tag like
5804   * <strong> becomes &lt;strong>.
5805   *
5806   * @param {string} content The content of a code block.
5807   * @return {string} The given content with its opening shortcode characters
5808   *                  converted into their HTML entity counterpart
5809   *                  (i.e. [ => &#91;)
5810   */
5811  
5812  function escapeOpeningSquareBrackets(content) {
5813    return content.replace(/\[/g, '&#91;');
5814  }
5815  /**
5816   * Converts the first two forward slashes of any isolated URL into their HTML
5817   * counterparts (i.e. // => &#47;&#47;). For instance, https://youtube.com/watch?x
5818   * becomes https:&#47;&#47;youtube.com/watch?x.
5819   *
5820   * An isolated URL is a URL that sits in its own line, surrounded only by spacing
5821   * characters.
5822   *
5823   * See https://github.com/WordPress/wordpress-develop/blob/5.1.1/src/wp-includes/class-wp-embed.php#L403
5824   *
5825   * @param {string} content The content of a code block.
5826   * @return {string} The given content with its ampersands converted into
5827   *                  their HTML entity counterpart (i.e. & => &amp;)
5828   */
5829  
5830  
5831  function escapeProtocolInIsolatedUrls(content) {
5832    return content.replace(/^(\s*https?:)\/\/([^\s<>"]+\s*)$/m, '$1&#47;&#47;$2');
5833  }
5834  
5835  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/code/save.js
5836  
5837  
5838  /**
5839   * WordPress dependencies
5840   */
5841  
5842  /**
5843   * Internal dependencies
5844   */
5845  
5846  
5847  function code_save_save(_ref) {
5848    let {
5849      attributes
5850    } = _ref;
5851    return (0,external_wp_element_namespaceObject.createElement)("pre", external_wp_blockEditor_namespaceObject.useBlockProps.save(), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
5852      tagName: "code",
5853      value: utils_escape(attributes.content)
5854    }));
5855  }
5856  
5857  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/code/transforms.js
5858  /**
5859   * WordPress dependencies
5860   */
5861  
5862  const code_transforms_transforms = {
5863    from: [{
5864      type: 'enter',
5865      regExp: /^```$/,
5866      transform: () => (0,external_wp_blocks_namespaceObject.createBlock)('core/code')
5867    }, {
5868      type: 'block',
5869      blocks: ['core/html', 'core/paragraph'],
5870      transform: _ref => {
5871        let {
5872          content
5873        } = _ref;
5874        return (0,external_wp_blocks_namespaceObject.createBlock)('core/code', {
5875          content
5876        });
5877      }
5878    }, {
5879      type: 'raw',
5880      isMatch: node => node.nodeName === 'PRE' && node.children.length === 1 && node.firstChild.nodeName === 'CODE',
5881      schema: {
5882        pre: {
5883          children: {
5884            code: {
5885              children: {
5886                '#text': {}
5887              }
5888            }
5889          }
5890        }
5891      }
5892    }]
5893  };
5894  /* harmony default export */ var code_transforms = (code_transforms_transforms);
5895  
5896  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/code/index.js
5897  /**
5898   * WordPress dependencies
5899   */
5900  
5901  
5902  /**
5903   * Internal dependencies
5904   */
5905  
5906  
5907  const code_metadata = {
5908    $schema: "https://schemas.wp.org/trunk/block.json",
5909    apiVersion: 2,
5910    name: "core/code",
5911    title: "Code",
5912    category: "text",
5913    description: "Display code snippets that respect your spacing and tabs.",
5914    textdomain: "default",
5915    attributes: {
5916      content: {
5917        type: "string",
5918        source: "html",
5919        selector: "code"
5920      }
5921    },
5922    supports: {
5923      anchor: true,
5924      typography: {
5925        fontSize: true,
5926        lineHeight: true,
5927        __experimentalFontStyle: true,
5928        __experimentalFontWeight: true,
5929        __experimentalLetterSpacing: true,
5930        __experimentalTextTransform: true,
5931        __experimentalDefaultControls: {
5932          fontSize: true
5933        }
5934      },
5935      spacing: {
5936        margin: ["top", "bottom"],
5937        padding: true
5938      },
5939      __experimentalBorder: {
5940        radius: true,
5941        color: true,
5942        width: true,
5943        style: true,
5944        __experimentalDefaultControls: {
5945          width: true,
5946          color: true
5947        }
5948      },
5949      color: {
5950        text: true,
5951        background: true,
5952        gradients: true,
5953        __experimentalDefaultControls: {
5954          background: true,
5955          text: true
5956        }
5957      }
5958    },
5959    style: "wp-block-code"
5960  };
5961  
5962  
5963  const {
5964    name: code_name
5965  } = code_metadata;
5966  
5967  const code_settings = {
5968    icon: library_code,
5969    example: {
5970      attributes: {
5971        /* eslint-disable @wordpress/i18n-no-collapsible-whitespace */
5972        // translators: Preserve \n markers for line breaks
5973        content: (0,external_wp_i18n_namespaceObject.__)('// A "block" is the abstract term used\n// to describe units of markup that\n// when composed together, form the\n// content or layout of a page.\nregisterBlockType( name, settings );')
5974        /* eslint-enable @wordpress/i18n-no-collapsible-whitespace */
5975  
5976      }
5977    },
5978    transforms: code_transforms,
5979    edit: CodeEdit,
5980    save: code_save_save
5981  };
5982  
5983  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/column.js
5984  
5985  
5986  /**
5987   * WordPress dependencies
5988   */
5989  
5990  const column = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
5991    xmlns: "http://www.w3.org/2000/svg",
5992    viewBox: "0 0 24 24"
5993  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
5994    d: "M19 6H6c-1.1 0-2 .9-2 2v9c0 1.1.9 2 2 2h13c1.1 0 2-.9 2-2V8c0-1.1-.9-2-2-2zM6 17.5c-.3 0-.5-.2-.5-.5V8c0-.3.2-.5.5-.5h3v10H6zm13.5-.5c0 .3-.2.5-.5.5h-3v-10h3c.3 0 .5.2.5.5v9z"
5995  }));
5996  /* harmony default export */ var library_column = (column);
5997  
5998  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/column/deprecated.js
5999  
6000  
6001  /**
6002   * External dependencies
6003   */
6004  
6005  /**
6006   * WordPress dependencies
6007   */
6008  
6009  
6010  const column_deprecated_deprecated = [{
6011    attributes: {
6012      verticalAlignment: {
6013        type: 'string'
6014      },
6015      width: {
6016        type: 'number',
6017        min: 0,
6018        max: 100
6019      }
6020    },
6021  
6022    isEligible(_ref) {
6023      let {
6024        width
6025      } = _ref;
6026      return isFinite(width);
6027    },
6028  
6029    migrate(attributes) {
6030      return { ...attributes,
6031        width: `$attributes.width}%`
6032      };
6033    },
6034  
6035    save(_ref2) {
6036      let {
6037        attributes
6038      } = _ref2;
6039      const {
6040        verticalAlignment,
6041        width
6042      } = attributes;
6043      const wrapperClasses = classnames_default()({
6044        [`is-vertically-aligned-$verticalAlignment}`]: verticalAlignment
6045      });
6046      const style = {
6047        flexBasis: width + '%'
6048      };
6049      return (0,external_wp_element_namespaceObject.createElement)("div", {
6050        className: wrapperClasses,
6051        style: style
6052      }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InnerBlocks.Content, null));
6053    }
6054  
6055  }];
6056  /* harmony default export */ var column_deprecated = (column_deprecated_deprecated);
6057  
6058  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/column/edit.js
6059  
6060  
6061  /**
6062   * External dependencies
6063   */
6064  
6065  /**
6066   * WordPress dependencies
6067   */
6068  
6069  
6070  
6071  
6072  
6073  
6074  function ColumnEdit(_ref) {
6075    let {
6076      attributes: {
6077        verticalAlignment,
6078        width,
6079        templateLock = false,
6080        allowedBlocks
6081      },
6082      setAttributes,
6083      clientId
6084    } = _ref;
6085    const classes = classnames_default()('block-core-columns', {
6086      [`is-vertically-aligned-$verticalAlignment}`]: verticalAlignment
6087    });
6088    const units = (0,external_wp_components_namespaceObject.__experimentalUseCustomUnits)({
6089      availableUnits: (0,external_wp_blockEditor_namespaceObject.useSetting)('spacing.units') || ['%', 'px', 'em', 'rem', 'vw']
6090    });
6091    const {
6092      columnsIds,
6093      hasChildBlocks,
6094      rootClientId
6095    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
6096      const {
6097        getBlockOrder,
6098        getBlockRootClientId
6099      } = select(external_wp_blockEditor_namespaceObject.store);
6100      const rootId = getBlockRootClientId(clientId);
6101      return {
6102        hasChildBlocks: getBlockOrder(clientId).length > 0,
6103        rootClientId: rootId,
6104        columnsIds: getBlockOrder(rootId)
6105      };
6106    }, [clientId]);
6107    const {
6108      updateBlockAttributes
6109    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_blockEditor_namespaceObject.store);
6110  
6111    const updateAlignment = value => {
6112      // Update own alignment.
6113      setAttributes({
6114        verticalAlignment: value
6115      }); // Reset parent Columns block.
6116  
6117      updateBlockAttributes(rootClientId, {
6118        verticalAlignment: null
6119      });
6120    };
6121  
6122    const widthWithUnit = Number.isFinite(width) ? width + '%' : width;
6123    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
6124      className: classes,
6125      style: widthWithUnit ? {
6126        flexBasis: widthWithUnit
6127      } : undefined
6128    });
6129    const columnsCount = columnsIds.length;
6130    const currentColumnPosition = columnsIds.indexOf(clientId) + 1;
6131    const label = (0,external_wp_i18n_namespaceObject.sprintf)(
6132    /* translators: 1: Block label (i.e. "Block: Column"), 2: Position of the selected block, 3: Total number of sibling blocks of the same type */
6133    (0,external_wp_i18n_namespaceObject.__)('%1$s (%2$d of %3$d)'), blockProps['aria-label'], currentColumnPosition, columnsCount);
6134    const innerBlocksProps = (0,external_wp_blockEditor_namespaceObject.useInnerBlocksProps)({ ...blockProps,
6135      'aria-label': label
6136    }, {
6137      templateLock,
6138      allowedBlocks,
6139      renderAppender: hasChildBlocks ? undefined : external_wp_blockEditor_namespaceObject.InnerBlocks.ButtonBlockAppender
6140    });
6141    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockVerticalAlignmentToolbar, {
6142      onChange: updateAlignment,
6143      value: verticalAlignment
6144    })), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
6145      title: (0,external_wp_i18n_namespaceObject.__)('Column settings')
6146    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalUnitControl, {
6147      label: (0,external_wp_i18n_namespaceObject.__)('Width'),
6148      labelPosition: "edge",
6149      __unstableInputWidth: "80px",
6150      value: width || '',
6151      onChange: nextWidth => {
6152        nextWidth = 0 > parseFloat(nextWidth) ? '0' : nextWidth;
6153        setAttributes({
6154          width: nextWidth
6155        });
6156      },
6157      units: units
6158    }))), (0,external_wp_element_namespaceObject.createElement)("div", innerBlocksProps));
6159  }
6160  
6161  /* harmony default export */ var column_edit = (ColumnEdit);
6162  
6163  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/column/save.js
6164  
6165  
6166  /**
6167   * External dependencies
6168   */
6169  
6170  /**
6171   * WordPress dependencies
6172   */
6173  
6174  
6175  function column_save_save(_ref) {
6176    let {
6177      attributes
6178    } = _ref;
6179    const {
6180      verticalAlignment,
6181      width
6182    } = attributes;
6183    const wrapperClasses = classnames_default()({
6184      [`is-vertically-aligned-$verticalAlignment}`]: verticalAlignment
6185    });
6186    let style;
6187  
6188    if (width && /\d/.test(width)) {
6189      // Numbers are handled for backward compatibility as they can be still provided with templates.
6190      let flexBasis = Number.isFinite(width) ? width + '%' : width; // In some cases we need to round the width to a shorter float.
6191  
6192      if (!Number.isFinite(width) && width !== null && width !== void 0 && width.endsWith('%')) {
6193        const multiplier = 1000000000000; // Shrink the number back to a reasonable float.
6194  
6195        flexBasis = Math.round(Number.parseFloat(width) * multiplier) / multiplier + '%';
6196      }
6197  
6198      style = {
6199        flexBasis
6200      };
6201    }
6202  
6203    const blockProps = external_wp_blockEditor_namespaceObject.useBlockProps.save({
6204      className: wrapperClasses,
6205      style
6206    });
6207    const innerBlocksProps = external_wp_blockEditor_namespaceObject.useInnerBlocksProps.save(blockProps);
6208    return (0,external_wp_element_namespaceObject.createElement)("div", innerBlocksProps);
6209  }
6210  
6211  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/column/index.js
6212  /**
6213   * WordPress dependencies
6214   */
6215  
6216  /**
6217   * Internal dependencies
6218   */
6219  
6220  
6221  
6222  const column_metadata = {
6223    $schema: "https://schemas.wp.org/trunk/block.json",
6224    apiVersion: 2,
6225    name: "core/column",
6226    title: "Column",
6227    category: "text",
6228    parent: ["core/columns"],
6229    description: "A single column within a columns block.",
6230    textdomain: "default",
6231    attributes: {
6232      verticalAlignment: {
6233        type: "string"
6234      },
6235      width: {
6236        type: "string"
6237      },
6238      allowedBlocks: {
6239        type: "array"
6240      },
6241      templateLock: {
6242        type: ["string", "boolean"],
6243        "enum": ["all", "insert", false]
6244      }
6245    },
6246    supports: {
6247      anchor: true,
6248      reusable: false,
6249      html: false,
6250      color: {
6251        gradients: true,
6252        link: true,
6253        __experimentalDefaultControls: {
6254          background: true,
6255          text: true
6256        }
6257      },
6258      spacing: {
6259        blockGap: true,
6260        padding: true,
6261        __experimentalDefaultControls: {
6262          padding: true
6263        }
6264      },
6265      __experimentalLayout: true
6266    }
6267  };
6268  
6269  const {
6270    name: column_name
6271  } = column_metadata;
6272  
6273  const column_settings = {
6274    icon: library_column,
6275    edit: column_edit,
6276    save: column_save_save,
6277    deprecated: column_deprecated
6278  };
6279  
6280  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/columns.js
6281  
6282  
6283  /**
6284   * WordPress dependencies
6285   */
6286  
6287  const columns = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
6288    viewBox: "0 0 24 24",
6289    xmlns: "http://www.w3.org/2000/svg"
6290  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
6291    d: "M19 6H6c-1.1 0-2 .9-2 2v9c0 1.1.9 2 2 2h13c1.1 0 2-.9 2-2V8c0-1.1-.9-2-2-2zm-4.1 1.5v10H10v-10h4.9zM5.5 17V8c0-.3.2-.5.5-.5h2.5v10H6c-.3 0-.5-.2-.5-.5zm14 0c0 .3-.2.5-.5.5h-2.6v-10H19c.3 0 .5.2.5.5v9z"
6292  }));
6293  /* harmony default export */ var library_columns = (columns);
6294  
6295  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/columns/deprecated.js
6296  
6297  
6298  /**
6299   * External dependencies
6300   */
6301  
6302  
6303  /**
6304   * WordPress dependencies
6305   */
6306  
6307  
6308  
6309  /**
6310   * Given an HTML string for a deprecated columns inner block, returns the
6311   * column index to which the migrated inner block should be assigned. Returns
6312   * undefined if the inner block was not assigned to a column.
6313   *
6314   * @param {string} originalContent Deprecated Columns inner block HTML.
6315   *
6316   * @return {?number} Column to which inner block is to be assigned.
6317   */
6318  
6319  function getDeprecatedLayoutColumn(originalContent) {
6320    let {
6321      doc
6322    } = getDeprecatedLayoutColumn;
6323  
6324    if (!doc) {
6325      doc = document.implementation.createHTMLDocument('');
6326      getDeprecatedLayoutColumn.doc = doc;
6327    }
6328  
6329    let columnMatch;
6330    doc.body.innerHTML = originalContent;
6331  
6332    for (const classListItem of doc.body.firstChild.classList) {
6333      if (columnMatch = classListItem.match(/^layout-column-(\d+)$/)) {
6334        return Number(columnMatch[1]) - 1;
6335      }
6336    }
6337  }
6338  
6339  const migrateCustomColors = attributes => {
6340    if (!attributes.customTextColor && !attributes.customBackgroundColor) {
6341      return attributes;
6342    }
6343  
6344    const style = {
6345      color: {}
6346    };
6347  
6348    if (attributes.customTextColor) {
6349      style.color.text = attributes.customTextColor;
6350    }
6351  
6352    if (attributes.customBackgroundColor) {
6353      style.color.background = attributes.customBackgroundColor;
6354    }
6355  
6356    return { ...(0,external_lodash_namespaceObject.omit)(attributes, ['customTextColor', 'customBackgroundColor']),
6357      style,
6358      isStackedOnMobile: true
6359    };
6360  };
6361  
6362  /* harmony default export */ var columns_deprecated = ([{
6363    attributes: {
6364      verticalAlignment: {
6365        type: 'string'
6366      },
6367      backgroundColor: {
6368        type: 'string'
6369      },
6370      customBackgroundColor: {
6371        type: 'string'
6372      },
6373      customTextColor: {
6374        type: 'string'
6375      },
6376      textColor: {
6377        type: 'string'
6378      }
6379    },
6380    migrate: migrateCustomColors,
6381  
6382    save(_ref) {
6383      let {
6384        attributes
6385      } = _ref;
6386      const {
6387        verticalAlignment,
6388        backgroundColor,
6389        customBackgroundColor,
6390        textColor,
6391        customTextColor
6392      } = attributes;
6393      const backgroundClass = (0,external_wp_blockEditor_namespaceObject.getColorClassName)('background-color', backgroundColor);
6394      const textClass = (0,external_wp_blockEditor_namespaceObject.getColorClassName)('color', textColor);
6395      const className = classnames_default()({
6396        'has-background': backgroundColor || customBackgroundColor,
6397        'has-text-color': textColor || customTextColor,
6398        [backgroundClass]: backgroundClass,
6399        [textClass]: textClass,
6400        [`are-vertically-aligned-$verticalAlignment}`]: verticalAlignment
6401      });
6402      const style = {
6403        backgroundColor: backgroundClass ? undefined : customBackgroundColor,
6404        color: textClass ? undefined : customTextColor
6405      };
6406      return (0,external_wp_element_namespaceObject.createElement)("div", {
6407        className: className ? className : undefined,
6408        style: style
6409      }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InnerBlocks.Content, null));
6410    }
6411  
6412  }, {
6413    attributes: {
6414      columns: {
6415        type: 'number',
6416        default: 2
6417      }
6418    },
6419  
6420    isEligible(attributes, innerBlocks) {
6421      // Since isEligible is called on every valid instance of the
6422      // Columns block and a deprecation is the unlikely case due to
6423      // its subsequent migration, optimize for the `false` condition
6424      // by performing a naive, inaccurate pass at inner blocks.
6425      const isFastPassEligible = innerBlocks.some(innerBlock => /layout-column-\d+/.test(innerBlock.originalContent));
6426  
6427      if (!isFastPassEligible) {
6428        return false;
6429      } // Only if the fast pass is considered eligible is the more
6430      // accurate, durable, slower condition performed.
6431  
6432  
6433      return innerBlocks.some(innerBlock => getDeprecatedLayoutColumn(innerBlock.originalContent) !== undefined);
6434    },
6435  
6436    migrate(attributes, innerBlocks) {
6437      const columns = innerBlocks.reduce((accumulator, innerBlock) => {
6438        const {
6439          originalContent
6440        } = innerBlock;
6441        let columnIndex = getDeprecatedLayoutColumn(originalContent);
6442  
6443        if (columnIndex === undefined) {
6444          columnIndex = 0;
6445        }
6446  
6447        if (!accumulator[columnIndex]) {
6448          accumulator[columnIndex] = [];
6449        }
6450  
6451        accumulator[columnIndex].push(innerBlock);
6452        return accumulator;
6453      }, []);
6454      const migratedInnerBlocks = columns.map(columnBlocks => (0,external_wp_blocks_namespaceObject.createBlock)('core/column', {}, columnBlocks));
6455      return [{ ...(0,external_lodash_namespaceObject.omit)(attributes, ['columns']),
6456        isStackedOnMobile: true
6457      }, migratedInnerBlocks];
6458    },
6459  
6460    save(_ref2) {
6461      let {
6462        attributes
6463      } = _ref2;
6464      const {
6465        columns
6466      } = attributes;
6467      return (0,external_wp_element_namespaceObject.createElement)("div", {
6468        className: `has-$columns}-columns`
6469      }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InnerBlocks.Content, null));
6470    }
6471  
6472  }, {
6473    attributes: {
6474      columns: {
6475        type: 'number',
6476        default: 2
6477      }
6478    },
6479  
6480    migrate(attributes, innerBlocks) {
6481      attributes = { ...(0,external_lodash_namespaceObject.omit)(attributes, ['columns']),
6482        isStackedOnMobile: true
6483      };
6484      return [attributes, innerBlocks];
6485    },
6486  
6487    save(_ref3) {
6488      let {
6489        attributes
6490      } = _ref3;
6491      const {
6492        verticalAlignment,
6493        columns
6494      } = attributes;
6495      const wrapperClasses = classnames_default()(`has-$columns}-columns`, {
6496        [`are-vertically-aligned-$verticalAlignment}`]: verticalAlignment
6497      });
6498      return (0,external_wp_element_namespaceObject.createElement)("div", {
6499        className: wrapperClasses
6500      }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InnerBlocks.Content, null));
6501    }
6502  
6503  }]);
6504  
6505  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/columns/utils.js
6506  /**
6507   * External dependencies
6508   */
6509  
6510  /**
6511   * Returns a column width attribute value rounded to standard precision.
6512   * Returns `undefined` if the value is not a valid finite number.
6513   *
6514   * @param {?number} value Raw value.
6515   *
6516   * @return {number} Value rounded to standard precision.
6517   */
6518  
6519  const toWidthPrecision = value => {
6520    const unitlessValue = parseFloat(value);
6521    return Number.isFinite(unitlessValue) ? parseFloat(unitlessValue.toFixed(2)) : undefined;
6522  };
6523  /**
6524   * Returns an effective width for a given block. An effective width is equal to
6525   * its attribute value if set, or a computed value assuming equal distribution.
6526   *
6527   * @param {WPBlock} block           Block object.
6528   * @param {number}  totalBlockCount Total number of blocks in Columns.
6529   *
6530   * @return {number} Effective column width.
6531   */
6532  
6533  function getEffectiveColumnWidth(block, totalBlockCount) {
6534    const {
6535      width = 100 / totalBlockCount
6536    } = block.attributes;
6537    return toWidthPrecision(width);
6538  }
6539  /**
6540   * Returns the total width occupied by the given set of column blocks.
6541   *
6542   * @param {WPBlock[]} blocks          Block objects.
6543   * @param {?number}   totalBlockCount Total number of blocks in Columns.
6544   *                                    Defaults to number of blocks passed.
6545   *
6546   * @return {number} Total width occupied by blocks.
6547   */
6548  
6549  function getTotalColumnsWidth(blocks) {
6550    let totalBlockCount = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : blocks.length;
6551    return (0,external_lodash_namespaceObject.sumBy)(blocks, block => getEffectiveColumnWidth(block, totalBlockCount));
6552  }
6553  /**
6554   * Returns an object of `clientId` → `width` of effective column widths.
6555   *
6556   * @param {WPBlock[]} blocks          Block objects.
6557   * @param {?number}   totalBlockCount Total number of blocks in Columns.
6558   *                                    Defaults to number of blocks passed.
6559   *
6560   * @return {Object<string,number>} Column widths.
6561   */
6562  
6563  function getColumnWidths(blocks) {
6564    let totalBlockCount = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : blocks.length;
6565    return blocks.reduce((accumulator, block) => {
6566      const width = getEffectiveColumnWidth(block, totalBlockCount);
6567      return Object.assign(accumulator, {
6568        [block.clientId]: width
6569      });
6570    }, {});
6571  }
6572  /**
6573   * Returns an object of `clientId` → `width` of column widths as redistributed
6574   * proportional to their current widths, constrained or expanded to fit within
6575   * the given available width.
6576   *
6577   * @param {WPBlock[]} blocks          Block objects.
6578   * @param {number}    availableWidth  Maximum width to fit within.
6579   * @param {?number}   totalBlockCount Total number of blocks in Columns.
6580   *                                    Defaults to number of blocks passed.
6581   *
6582   * @return {Object<string,number>} Redistributed column widths.
6583   */
6584  
6585  function getRedistributedColumnWidths(blocks, availableWidth) {
6586    let totalBlockCount = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : blocks.length;
6587    const totalWidth = getTotalColumnsWidth(blocks, totalBlockCount);
6588    return (0,external_lodash_namespaceObject.mapValues)(getColumnWidths(blocks, totalBlockCount), width => {
6589      const newWidth = availableWidth * width / totalWidth;
6590      return toWidthPrecision(newWidth);
6591    });
6592  }
6593  /**
6594   * Returns true if column blocks within the provided set are assigned with
6595   * explicit widths, or false otherwise.
6596   *
6597   * @param {WPBlock[]} blocks Block objects.
6598   *
6599   * @return {boolean} Whether columns have explicit widths.
6600   */
6601  
6602  function hasExplicitPercentColumnWidths(blocks) {
6603    return blocks.every(block => {
6604      var _blockWidth$endsWith;
6605  
6606      const blockWidth = block.attributes.width;
6607      return Number.isFinite(blockWidth !== null && blockWidth !== void 0 && (_blockWidth$endsWith = blockWidth.endsWith) !== null && _blockWidth$endsWith !== void 0 && _blockWidth$endsWith.call(blockWidth, '%') ? parseFloat(blockWidth) : blockWidth);
6608    });
6609  }
6610  /**
6611   * Returns a copy of the given set of blocks with new widths assigned from the
6612   * provided object of redistributed column widths.
6613   *
6614   * @param {WPBlock[]}             blocks Block objects.
6615   * @param {Object<string,number>} widths Redistributed column widths.
6616   *
6617   * @return {WPBlock[]} blocks Mapped block objects.
6618   */
6619  
6620  function getMappedColumnWidths(blocks, widths) {
6621    return blocks.map(block => (0,external_lodash_namespaceObject.merge)({}, block, {
6622      attributes: {
6623        width: `$widths[block.clientId]}%`
6624      }
6625    }));
6626  }
6627  /**
6628   * Returns an array with columns widths values, parsed or no depends on `withParsing` flag.
6629   *
6630   * @param {WPBlock[]} blocks      Block objects.
6631   * @param {?boolean}  withParsing Whether value has to be parsed.
6632   *
6633   * @return {Array<number,string>} Column widths.
6634   */
6635  
6636  function getWidths(blocks) {
6637    let withParsing = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;
6638    return blocks.map(innerColumn => {
6639      const innerColumnWidth = innerColumn.attributes.width || 100 / blocks.length;
6640      return withParsing ? parseFloat(innerColumnWidth) : innerColumnWidth;
6641    });
6642  }
6643  /**
6644   * Returns a column width with unit.
6645   *
6646   * @param {string} width Column width.
6647   * @param {string} unit  Column width unit.
6648   *
6649   * @return {string} Column width with unit.
6650   */
6651  
6652  function getWidthWithUnit(width, unit) {
6653    width = 0 > parseFloat(width) ? '0' : width;
6654  
6655    if (isPercentageUnit(unit)) {
6656      width = Math.min(width, 100);
6657    }
6658  
6659    return `$width}$unit}`;
6660  }
6661  /**
6662   * Returns a boolean whether passed unit is percentage
6663   *
6664   * @param {string} unit Column width unit.
6665   *
6666   * @return {boolean}     Whether unit is '%'.
6667   */
6668  
6669  function isPercentageUnit(unit) {
6670    return unit === '%';
6671  }
6672  
6673  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/columns/edit.js
6674  
6675  
6676  /**
6677   * External dependencies
6678   */
6679  
6680  
6681  /**
6682   * WordPress dependencies
6683   */
6684  
6685  
6686  
6687  
6688  
6689  
6690  /**
6691   * Internal dependencies
6692   */
6693  
6694  
6695  /**
6696   * Allowed blocks constant is passed to InnerBlocks precisely as specified here.
6697   * The contents of the array should never change.
6698   * The array should contain the name of each block that is allowed.
6699   * In columns block, the only block we allow is 'core/column'.
6700   *
6701   * @constant
6702   * @type {string[]}
6703   */
6704  
6705  const edit_ALLOWED_BLOCKS = ['core/column'];
6706  
6707  function ColumnsEditContainer(_ref) {
6708    let {
6709      attributes,
6710      setAttributes,
6711      updateAlignment,
6712      updateColumns,
6713      clientId
6714    } = _ref;
6715    const {
6716      isStackedOnMobile,
6717      verticalAlignment
6718    } = attributes;
6719    const {
6720      count
6721    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
6722      return {
6723        count: select(external_wp_blockEditor_namespaceObject.store).getBlockCount(clientId)
6724      };
6725    }, [clientId]);
6726    const classes = classnames_default()({
6727      [`are-vertically-aligned-$verticalAlignment}`]: verticalAlignment,
6728      [`is-not-stacked-on-mobile`]: !isStackedOnMobile
6729    });
6730    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
6731      className: classes
6732    });
6733    const innerBlocksProps = (0,external_wp_blockEditor_namespaceObject.useInnerBlocksProps)(blockProps, {
6734      allowedBlocks: edit_ALLOWED_BLOCKS,
6735      orientation: 'horizontal',
6736      renderAppender: false
6737    });
6738    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockVerticalAlignmentToolbar, {
6739      onChange: updateAlignment,
6740      value: verticalAlignment
6741    })), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.RangeControl, {
6742      label: (0,external_wp_i18n_namespaceObject.__)('Columns'),
6743      value: count,
6744      onChange: value => updateColumns(count, value),
6745      min: 1,
6746      max: Math.max(6, count)
6747    }), count > 6 && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Notice, {
6748      status: "warning",
6749      isDismissible: false
6750    }, (0,external_wp_i18n_namespaceObject.__)('This column count exceeds the recommended amount and may cause visual breakage.')), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
6751      label: (0,external_wp_i18n_namespaceObject.__)('Stack on mobile'),
6752      checked: isStackedOnMobile,
6753      onChange: () => setAttributes({
6754        isStackedOnMobile: !isStackedOnMobile
6755      })
6756    }))), (0,external_wp_element_namespaceObject.createElement)("div", innerBlocksProps));
6757  }
6758  
6759  const ColumnsEditContainerWrapper = (0,external_wp_data_namespaceObject.withDispatch)((dispatch, ownProps, registry) => ({
6760    /**
6761     * Update all child Column blocks with a new vertical alignment setting
6762     * based on whatever alignment is passed in. This allows change to parent
6763     * to overide anything set on a individual column basis.
6764     *
6765     * @param {string} verticalAlignment the vertical alignment setting
6766     */
6767    updateAlignment(verticalAlignment) {
6768      const {
6769        clientId,
6770        setAttributes
6771      } = ownProps;
6772      const {
6773        updateBlockAttributes
6774      } = dispatch(external_wp_blockEditor_namespaceObject.store);
6775      const {
6776        getBlockOrder
6777      } = registry.select(external_wp_blockEditor_namespaceObject.store); // Update own alignment.
6778  
6779      setAttributes({
6780        verticalAlignment
6781      }); // Update all child Column Blocks to match.
6782  
6783      const innerBlockClientIds = getBlockOrder(clientId);
6784      innerBlockClientIds.forEach(innerBlockClientId => {
6785        updateBlockAttributes(innerBlockClientId, {
6786          verticalAlignment
6787        });
6788      });
6789    },
6790  
6791    /**
6792     * Updates the column count, including necessary revisions to child Column
6793     * blocks to grant required or redistribute available space.
6794     *
6795     * @param {number} previousColumns Previous column count.
6796     * @param {number} newColumns      New column count.
6797     */
6798    updateColumns(previousColumns, newColumns) {
6799      const {
6800        clientId
6801      } = ownProps;
6802      const {
6803        replaceInnerBlocks
6804      } = dispatch(external_wp_blockEditor_namespaceObject.store);
6805      const {
6806        getBlocks
6807      } = registry.select(external_wp_blockEditor_namespaceObject.store);
6808      let innerBlocks = getBlocks(clientId);
6809      const hasExplicitWidths = hasExplicitPercentColumnWidths(innerBlocks); // Redistribute available width for existing inner blocks.
6810  
6811      const isAddingColumn = newColumns > previousColumns;
6812  
6813      if (isAddingColumn && hasExplicitWidths) {
6814        // If adding a new column, assign width to the new column equal to
6815        // as if it were `1 / columns` of the total available space.
6816        const newColumnWidth = toWidthPrecision(100 / newColumns); // Redistribute in consideration of pending block insertion as
6817        // constraining the available working width.
6818  
6819        const widths = getRedistributedColumnWidths(innerBlocks, 100 - newColumnWidth);
6820        innerBlocks = [...getMappedColumnWidths(innerBlocks, widths), ...(0,external_lodash_namespaceObject.times)(newColumns - previousColumns, () => {
6821          return (0,external_wp_blocks_namespaceObject.createBlock)('core/column', {
6822            width: `$newColumnWidth}%`
6823          });
6824        })];
6825      } else if (isAddingColumn) {
6826        innerBlocks = [...innerBlocks, ...(0,external_lodash_namespaceObject.times)(newColumns - previousColumns, () => {
6827          return (0,external_wp_blocks_namespaceObject.createBlock)('core/column');
6828        })];
6829      } else {
6830        // The removed column will be the last of the inner blocks.
6831        innerBlocks = (0,external_lodash_namespaceObject.dropRight)(innerBlocks, previousColumns - newColumns);
6832  
6833        if (hasExplicitWidths) {
6834          // Redistribute as if block is already removed.
6835          const widths = getRedistributedColumnWidths(innerBlocks, 100);
6836          innerBlocks = getMappedColumnWidths(innerBlocks, widths);
6837        }
6838      }
6839  
6840      replaceInnerBlocks(clientId, innerBlocks);
6841    }
6842  
6843  }))(ColumnsEditContainer);
6844  
6845  function Placeholder(_ref2) {
6846    let {
6847      clientId,
6848      name,
6849      setAttributes
6850    } = _ref2;
6851    const {
6852      blockType,
6853      defaultVariation,
6854      variations
6855    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
6856      const {
6857        getBlockVariations,
6858        getBlockType,
6859        getDefaultBlockVariation
6860      } = select(external_wp_blocks_namespaceObject.store);
6861      return {
6862        blockType: getBlockType(name),
6863        defaultVariation: getDefaultBlockVariation(name, 'block'),
6864        variations: getBlockVariations(name, 'block')
6865      };
6866    }, [name]);
6867    const {
6868      replaceInnerBlocks
6869    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_blockEditor_namespaceObject.store);
6870    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)();
6871    return (0,external_wp_element_namespaceObject.createElement)("div", blockProps, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.__experimentalBlockVariationPicker, {
6872      icon: (0,external_lodash_namespaceObject.get)(blockType, ['icon', 'src']),
6873      label: (0,external_lodash_namespaceObject.get)(blockType, ['title']),
6874      variations: variations,
6875      onSelect: function () {
6876        let nextVariation = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : defaultVariation;
6877  
6878        if (nextVariation.attributes) {
6879          setAttributes(nextVariation.attributes);
6880        }
6881  
6882        if (nextVariation.innerBlocks) {
6883          replaceInnerBlocks(clientId, (0,external_wp_blocks_namespaceObject.createBlocksFromInnerBlocksTemplate)(nextVariation.innerBlocks), true);
6884        }
6885      },
6886      allowSkip: true
6887    }));
6888  }
6889  
6890  const ColumnsEdit = props => {
6891    const {
6892      clientId
6893    } = props;
6894    const hasInnerBlocks = (0,external_wp_data_namespaceObject.useSelect)(select => select(external_wp_blockEditor_namespaceObject.store).getBlocks(clientId).length > 0, [clientId]);
6895    const Component = hasInnerBlocks ? ColumnsEditContainerWrapper : Placeholder;
6896    return (0,external_wp_element_namespaceObject.createElement)(Component, props);
6897  };
6898  
6899  /* harmony default export */ var columns_edit = (ColumnsEdit);
6900  
6901  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/columns/save.js
6902  
6903  
6904  /**
6905   * External dependencies
6906   */
6907  
6908  /**
6909   * WordPress dependencies
6910   */
6911  
6912  
6913  function columns_save_save(_ref) {
6914    let {
6915      attributes
6916    } = _ref;
6917    const {
6918      isStackedOnMobile,
6919      verticalAlignment
6920    } = attributes;
6921    const className = classnames_default()({
6922      [`are-vertically-aligned-$verticalAlignment}`]: verticalAlignment,
6923      [`is-not-stacked-on-mobile`]: !isStackedOnMobile
6924    });
6925    const blockProps = external_wp_blockEditor_namespaceObject.useBlockProps.save({
6926      className
6927    });
6928    const innerBlocksProps = external_wp_blockEditor_namespaceObject.useInnerBlocksProps.save(blockProps);
6929    return (0,external_wp_element_namespaceObject.createElement)("div", innerBlocksProps);
6930  }
6931  
6932  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/columns/variations.js
6933  
6934  
6935  /**
6936   * WordPress dependencies
6937   */
6938  
6939  
6940  /** @typedef {import('@wordpress/blocks').WPBlockVariation} WPBlockVariation */
6941  
6942  /**
6943   * Template option choices for predefined columns layouts.
6944   *
6945   * @type {WPBlockVariation[]}
6946   */
6947  
6948  const variations = [{
6949    name: 'one-column-full',
6950    title: (0,external_wp_i18n_namespaceObject.__)('100'),
6951    description: (0,external_wp_i18n_namespaceObject.__)('One column'),
6952    icon: (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, {
6953      width: "48",
6954      height: "48",
6955      viewBox: "0 0 48 48",
6956      xmlns: "http://www.w3.org/2000/svg"
6957    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
6958      fillRule: "evenodd",
6959      clipRule: "evenodd",
6960      d: "m39.0625 14h-30.0625v20.0938h30.0625zm-30.0625-2c-1.10457 0-2 .8954-2 2v20.0938c0 1.1045.89543 2 2 2h30.0625c1.1046 0 2-.8955 2-2v-20.0938c0-1.1046-.8954-2-2-2z"
6961    })),
6962    innerBlocks: [['core/column']],
6963    scope: ['block']
6964  }, {
6965    name: 'two-columns-equal',
6966    title: (0,external_wp_i18n_namespaceObject.__)('50 / 50'),
6967    description: (0,external_wp_i18n_namespaceObject.__)('Two columns; equal split'),
6968    icon: (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, {
6969      width: "48",
6970      height: "48",
6971      viewBox: "0 0 48 48",
6972      xmlns: "http://www.w3.org/2000/svg"
6973    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
6974      fillRule: "evenodd",
6975      clipRule: "evenodd",
6976      d: "M39 12C40.1046 12 41 12.8954 41 14V34C41 35.1046 40.1046 36 39 36H9C7.89543 36 7 35.1046 7 34V14C7 12.8954 7.89543 12 9 12H39ZM39 34V14H25V34H39ZM23 34H9V14H23V34Z"
6977    })),
6978    isDefault: true,
6979    innerBlocks: [['core/column'], ['core/column']],
6980    scope: ['block']
6981  }, {
6982    name: 'two-columns-one-third-two-thirds',
6983    title: (0,external_wp_i18n_namespaceObject.__)('30 / 70'),
6984    description: (0,external_wp_i18n_namespaceObject.__)('Two columns; one-third, two-thirds split'),
6985    icon: (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, {
6986      width: "48",
6987      height: "48",
6988      viewBox: "0 0 48 48",
6989      xmlns: "http://www.w3.org/2000/svg"
6990    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
6991      fillRule: "evenodd",
6992      clipRule: "evenodd",
6993      d: "M39 12C40.1046 12 41 12.8954 41 14V34C41 35.1046 40.1046 36 39 36H9C7.89543 36 7 35.1046 7 34V14C7 12.8954 7.89543 12 9 12H39ZM39 34V14H20V34H39ZM18 34H9V14H18V34Z"
6994    })),
6995    innerBlocks: [['core/column', {
6996      width: '33.33%'
6997    }], ['core/column', {
6998      width: '66.66%'
6999    }]],
7000    scope: ['block']
7001  }, {
7002    name: 'two-columns-two-thirds-one-third',
7003    title: (0,external_wp_i18n_namespaceObject.__)('70 / 30'),
7004    description: (0,external_wp_i18n_namespaceObject.__)('Two columns; two-thirds, one-third split'),
7005    icon: (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, {
7006      width: "48",
7007      height: "48",
7008      viewBox: "0 0 48 48",
7009      xmlns: "http://www.w3.org/2000/svg"
7010    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
7011      fillRule: "evenodd",
7012      clipRule: "evenodd",
7013      d: "M39 12C40.1046 12 41 12.8954 41 14V34C41 35.1046 40.1046 36 39 36H9C7.89543 36 7 35.1046 7 34V14C7 12.8954 7.89543 12 9 12H39ZM39 34V14H30V34H39ZM28 34H9V14H28V34Z"
7014    })),
7015    innerBlocks: [['core/column', {
7016      width: '66.66%'
7017    }], ['core/column', {
7018      width: '33.33%'
7019    }]],
7020    scope: ['block']
7021  }, {
7022    name: 'three-columns-equal',
7023    title: (0,external_wp_i18n_namespaceObject.__)('33 / 33 / 33'),
7024    description: (0,external_wp_i18n_namespaceObject.__)('Three columns; equal split'),
7025    icon: (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, {
7026      width: "48",
7027      height: "48",
7028      viewBox: "0 0 48 48",
7029      xmlns: "http://www.w3.org/2000/svg"
7030    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
7031      fillRule: "evenodd",
7032      d: "M41 14a2 2 0 0 0-2-2H9a2 2 0 0 0-2 2v20a2 2 0 0 0 2 2h30a2 2 0 0 0 2-2V14zM28.5 34h-9V14h9v20zm2 0V14H39v20h-8.5zm-13 0H9V14h8.5v20z"
7033    })),
7034    innerBlocks: [['core/column'], ['core/column'], ['core/column']],
7035    scope: ['block']
7036  }, {
7037    name: 'three-columns-wider-center',
7038    title: (0,external_wp_i18n_namespaceObject.__)('25 / 50 / 25'),
7039    description: (0,external_wp_i18n_namespaceObject.__)('Three columns; wide center column'),
7040    icon: (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, {
7041      width: "48",
7042      height: "48",
7043      viewBox: "0 0 48 48",
7044      xmlns: "http://www.w3.org/2000/svg"
7045    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
7046      fillRule: "evenodd",
7047      d: "M41 14a2 2 0 0 0-2-2H9a2 2 0 0 0-2 2v20a2 2 0 0 0 2 2h30a2 2 0 0 0 2-2V14zM31 34H17V14h14v20zm2 0V14h6v20h-6zm-18 0H9V14h6v20z"
7048    })),
7049    innerBlocks: [['core/column', {
7050      width: '25%'
7051    }], ['core/column', {
7052      width: '50%'
7053    }], ['core/column', {
7054      width: '25%'
7055    }]],
7056    scope: ['block']
7057  }];
7058  /* harmony default export */ var columns_variations = (variations);
7059  
7060  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/columns/transforms.js
7061  /**
7062   * WordPress dependencies
7063   */
7064  
7065  const MAXIMUM_SELECTED_BLOCKS = 6;
7066  const columns_transforms_transforms = {
7067    from: [{
7068      type: 'block',
7069      isMultiBlock: true,
7070      blocks: ['*'],
7071      __experimentalConvert: blocks => {
7072        const columnWidth = +(100 / blocks.length).toFixed(2);
7073        const innerBlocksTemplate = blocks.map(_ref => {
7074          let {
7075            name,
7076            attributes,
7077            innerBlocks
7078          } = _ref;
7079          return ['core/column', {
7080            width: `$columnWidth}%`
7081          }, [[name, { ...attributes
7082          }, innerBlocks]]];
7083        });
7084        return (0,external_wp_blocks_namespaceObject.createBlock)('core/columns', {}, (0,external_wp_blocks_namespaceObject.createBlocksFromInnerBlocksTemplate)(innerBlocksTemplate));
7085      },
7086      isMatch: _ref2 => {
7087        let {
7088          length: selectedBlocksLength
7089        } = _ref2;
7090        return selectedBlocksLength && selectedBlocksLength <= MAXIMUM_SELECTED_BLOCKS;
7091      }
7092    }, {
7093      type: 'block',
7094      blocks: ['core/media-text'],
7095      priority: 1,
7096      transform: (attributes, innerBlocks) => {
7097        const {
7098          align,
7099          backgroundColor,
7100          textColor,
7101          style,
7102          mediaAlt: alt,
7103          mediaId: id,
7104          mediaPosition,
7105          mediaSizeSlug: sizeSlug,
7106          mediaType,
7107          mediaUrl: url,
7108          mediaWidth,
7109          verticalAlignment
7110        } = attributes;
7111        let media;
7112  
7113        if (mediaType === 'image' || !mediaType) {
7114          const imageAttrs = {
7115            id,
7116            alt,
7117            url,
7118            sizeSlug
7119          };
7120          const linkAttrs = {
7121            href: attributes.href,
7122            linkClass: attributes.linkClass,
7123            linkDestination: attributes.linkDestination,
7124            linkTarget: attributes.linkTarget,
7125            rel: attributes.rel
7126          };
7127          media = ['core/image', { ...imageAttrs,
7128            ...linkAttrs
7129          }];
7130        } else {
7131          media = ['core/video', {
7132            id,
7133            src: url
7134          }];
7135        }
7136  
7137        const innerBlocksTemplate = [['core/column', {
7138          width: `$mediaWidth}%`
7139        }, [media]], ['core/column', {
7140          width: `$100 - mediaWidth}%`
7141        }, innerBlocks]];
7142  
7143        if (mediaPosition === 'right') {
7144          innerBlocksTemplate.reverse();
7145        }
7146  
7147        return (0,external_wp_blocks_namespaceObject.createBlock)('core/columns', {
7148          align,
7149          backgroundColor,
7150          textColor,
7151          style,
7152          verticalAlignment
7153        }, (0,external_wp_blocks_namespaceObject.createBlocksFromInnerBlocksTemplate)(innerBlocksTemplate));
7154      }
7155    }]
7156  };
7157  /* harmony default export */ var columns_transforms = (columns_transforms_transforms);
7158  
7159  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/columns/index.js
7160  /**
7161   * WordPress dependencies
7162   */
7163  
7164  
7165  /**
7166   * Internal dependencies
7167   */
7168  
7169  
7170  
7171  const columns_metadata = {
7172    $schema: "https://schemas.wp.org/trunk/block.json",
7173    apiVersion: 2,
7174    name: "core/columns",
7175    title: "Columns",
7176    category: "design",
7177    description: "Display content in multiple columns, with blocks added to each column.",
7178    textdomain: "default",
7179    attributes: {
7180      verticalAlignment: {
7181        type: "string"
7182      },
7183      isStackedOnMobile: {
7184        type: "boolean",
7185        "default": true
7186      }
7187    },
7188    supports: {
7189      anchor: true,
7190      align: ["wide", "full"],
7191      html: false,
7192      color: {
7193        gradients: true,
7194        link: true,
7195        __experimentalDefaultControls: {
7196          background: true,
7197          text: true
7198        }
7199      },
7200      spacing: {
7201        blockGap: true,
7202        margin: ["top", "bottom"],
7203        padding: true,
7204        __experimentalDefaultControls: {
7205          padding: true
7206        }
7207      },
7208      __experimentalLayout: {
7209        allowSwitching: false,
7210        allowInheriting: false,
7211        allowEditing: false,
7212        "default": {
7213          type: "flex",
7214          flexWrap: "nowrap"
7215        }
7216      },
7217      __experimentalBorder: {
7218        color: true,
7219        radius: true,
7220        style: true,
7221        width: true,
7222        __experimentalDefaultControls: {
7223          color: true,
7224          radius: true,
7225          style: true,
7226          width: true
7227        }
7228      }
7229    },
7230    editorStyle: "wp-block-columns-editor",
7231    style: "wp-block-columns"
7232  };
7233  
7234  
7235  
7236  const {
7237    name: columns_name
7238  } = columns_metadata;
7239  
7240  const columns_settings = {
7241    icon: library_columns,
7242    variations: columns_variations,
7243    example: {
7244      viewportWidth: 600,
7245      // Columns collapse "@media (max-width: 599px)".
7246      innerBlocks: [{
7247        name: 'core/column',
7248        innerBlocks: [{
7249          name: 'core/paragraph',
7250          attributes: {
7251            /* translators: example text. */
7252            content: (0,external_wp_i18n_namespaceObject.__)('Lorem ipsum dolor sit amet, consectetur adipiscing elit. Praesent et eros eu felis.')
7253          }
7254        }, {
7255          name: 'core/image',
7256          attributes: {
7257            url: 'https://s.w.org/images/core/5.3/Windbuchencom.jpg'
7258          }
7259        }, {
7260          name: 'core/paragraph',
7261          attributes: {
7262            /* translators: example text. */
7263            content: (0,external_wp_i18n_namespaceObject.__)('Suspendisse commodo neque lacus, a dictum orci interdum et.')
7264          }
7265        }]
7266      }, {
7267        name: 'core/column',
7268        innerBlocks: [{
7269          name: 'core/paragraph',
7270          attributes: {
7271            /* translators: example text. */
7272            content: (0,external_wp_i18n_namespaceObject.__)('Etiam et egestas lorem. Vivamus sagittis sit amet dolor quis lobortis. Integer sed fermentum arcu, id vulputate lacus. Etiam fermentum sem eu quam hendrerit.')
7273          }
7274        }, {
7275          name: 'core/paragraph',
7276          attributes: {
7277            /* translators: example text. */
7278            content: (0,external_wp_i18n_namespaceObject.__)('Nam risus massa, ullamcorper consectetur eros fermentum, porta aliquet ligula. Sed vel mauris nec enim.')
7279          }
7280        }]
7281      }]
7282    },
7283    deprecated: columns_deprecated,
7284    edit: columns_edit,
7285    save: columns_save_save,
7286    transforms: columns_transforms
7287  };
7288  
7289  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/comment-author-name.js
7290  
7291  
7292  /**
7293   * WordPress dependencies
7294   */
7295  
7296  const commentAuthorName = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
7297    viewBox: "0 0 24 24",
7298    xmlns: "http://www.w3.org/2000/svg"
7299  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
7300    d: "M18 4H6c-1.1 0-2 .9-2 2v12.9c0 .6.5 1.1 1.1 1.1.3 0 .5-.1.8-.3L8.5 17H18c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zm.5 11c0 .3-.2.5-.5.5H7.9l-2.4 2.4V6c0-.3.2-.5.5-.5h12c.3 0 .5.2.5.5v9z",
7301    fillRule: "evenodd",
7302    clipRule: "evenodd"
7303  }), (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
7304    d: "M15 15V15C15 13.8954 14.1046 13 13 13L11 13C9.89543 13 9 13.8954 9 15V15",
7305    fillRule: "evenodd",
7306    clipRule: "evenodd"
7307  }), (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Circle, {
7308    cx: "12",
7309    cy: "9",
7310    r: "2",
7311    fillRule: "evenodd",
7312    clipRule: "evenodd"
7313  }));
7314  /* harmony default export */ var comment_author_name = (commentAuthorName);
7315  
7316  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/comment-author-name/edit.js
7317  
7318  
7319  /**
7320   * External dependencies
7321   */
7322  
7323  /**
7324   * WordPress dependencies
7325   */
7326  
7327  
7328  
7329  
7330  
7331  
7332  /**
7333   * Renders the `core/comment-author-name` block on the editor.
7334   *
7335   * @param {Object} props                       React props.
7336   * @param {Object} props.setAttributes         Callback for updating block attributes.
7337   * @param {Object} props.attributes            Block attributes.
7338   * @param {string} props.attributes.isLink     Whether the author name should be linked.
7339   * @param {string} props.attributes.linkTarget Target of the link.
7340   * @param {string} props.attributes.textAlign  Text alignment.
7341   * @param {Object} props.context               Inherited context.
7342   * @param {string} props.context.commentId     The comment ID.
7343   *
7344   * @return {JSX.Element} React element.
7345   */
7346  
7347  function edit_Edit(_ref) {
7348    let {
7349      attributes: {
7350        isLink,
7351        linkTarget,
7352        textAlign
7353      },
7354      context: {
7355        commentId
7356      },
7357      setAttributes
7358    } = _ref;
7359    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
7360      className: classnames_default()({
7361        [`has-text-align-$textAlign}`]: textAlign
7362      })
7363    });
7364    const displayName = (0,external_wp_data_namespaceObject.useSelect)(select => {
7365      const {
7366        getEntityRecord
7367      } = select(external_wp_coreData_namespaceObject.store);
7368      const comment = getEntityRecord('root', 'comment', commentId);
7369      const authorName = comment === null || comment === void 0 ? void 0 : comment.author_name; // eslint-disable-line camelcase
7370  
7371      if (comment && !authorName) {
7372        var _user$name;
7373  
7374        const user = getEntityRecord('root', 'user', comment.author);
7375        return (_user$name = user === null || user === void 0 ? void 0 : user.name) !== null && _user$name !== void 0 ? _user$name : (0,external_wp_i18n_namespaceObject.__)('Anonymous');
7376      }
7377  
7378      return authorName !== null && authorName !== void 0 ? authorName : '';
7379    }, [commentId]);
7380    const blockControls = (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, {
7381      group: "block"
7382    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.AlignmentControl, {
7383      value: textAlign,
7384      onChange: newAlign => setAttributes({
7385        textAlign: newAlign
7386      })
7387    }));
7388    const inspectorControls = (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
7389      title: (0,external_wp_i18n_namespaceObject.__)('Link settings')
7390    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
7391      label: (0,external_wp_i18n_namespaceObject.__)('Link to authors URL'),
7392      onChange: () => setAttributes({
7393        isLink: !isLink
7394      }),
7395      checked: isLink
7396    }), isLink && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
7397      label: (0,external_wp_i18n_namespaceObject.__)('Open in new tab'),
7398      onChange: value => setAttributes({
7399        linkTarget: value ? '_blank' : '_self'
7400      }),
7401      checked: linkTarget === '_blank'
7402    })));
7403  
7404    if (!commentId || !displayName) {
7405      return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, inspectorControls, blockControls, (0,external_wp_element_namespaceObject.createElement)("div", blockProps, (0,external_wp_element_namespaceObject.createElement)("p", null, (0,external_wp_i18n_namespaceObject._x)('Comment Author', 'block title'))));
7406    }
7407  
7408    const displayAuthor = isLink ? (0,external_wp_element_namespaceObject.createElement)("a", {
7409      href: "#comment-author-pseudo-link",
7410      onClick: event => event.preventDefault()
7411    }, displayName) : (0,external_wp_element_namespaceObject.createElement)("p", null, displayName);
7412    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, inspectorControls, blockControls, (0,external_wp_element_namespaceObject.createElement)("div", blockProps, displayAuthor));
7413  }
7414  
7415  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/comment-author-name/deprecated.js
7416  /**
7417   * Internal dependencies
7418   */
7419  
7420  const v1 = {
7421    attributes: {
7422      isLink: {
7423        type: 'boolean',
7424        default: false
7425      },
7426      linkTarget: {
7427        type: 'string',
7428        default: '_self'
7429      }
7430    },
7431    supports: {
7432      html: false,
7433      color: {
7434        gradients: true,
7435        link: true
7436      },
7437      typography: {
7438        fontSize: true,
7439        lineHeight: true,
7440        __experimentalFontFamily: true,
7441        __experimentalFontWeight: true,
7442        __experimentalFontStyle: true,
7443        __experimentalTextTransform: true,
7444        __experimentalLetterSpacing: true
7445      }
7446    },
7447  
7448    save() {
7449      return null;
7450    },
7451  
7452    migrate: migrate_font_family,
7453  
7454    isEligible(_ref) {
7455      var _style$typography;
7456  
7457      let {
7458        style
7459      } = _ref;
7460      return style === null || style === void 0 ? void 0 : (_style$typography = style.typography) === null || _style$typography === void 0 ? void 0 : _style$typography.fontFamily;
7461    }
7462  
7463  };
7464  /**
7465   * New deprecations need to be placed first
7466   * for them to have higher priority.
7467   *
7468   * Old deprecations may need to be updated as well.
7469   *
7470   * See block-deprecation.md
7471   */
7472  
7473  /* harmony default export */ var comment_author_name_deprecated = ([v1]);
7474  
7475  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/comment-author-name/index.js
7476  /**
7477   * WordPress dependencies
7478   */
7479  
7480  /**
7481   * Internal dependencies
7482   */
7483  
7484  const comment_author_name_metadata = {
7485    $schema: "https://schemas.wp.org/trunk/block.json",
7486    apiVersion: 2,
7487    name: "core/comment-author-name",
7488    title: "Comment Author Name",
7489    category: "theme",
7490    ancestor: ["core/comment-template"],
7491    description: "Displays the name of the author of the comment.",
7492    textdomain: "default",
7493    attributes: {
7494      isLink: {
7495        type: "boolean",
7496        "default": true
7497      },
7498      linkTarget: {
7499        type: "string",
7500        "default": "_self"
7501      },
7502      textAlign: {
7503        type: "string"
7504      },
7505      fontSize: {
7506        type: "string",
7507        "default": "small"
7508      }
7509    },
7510    usesContext: ["commentId"],
7511    supports: {
7512      html: false,
7513      spacing: {
7514        margin: true,
7515        padding: true
7516      },
7517      color: {
7518        gradients: true,
7519        link: true,
7520        __experimentalDefaultControls: {
7521          background: true,
7522          text: true,
7523          link: true
7524        }
7525      },
7526      typography: {
7527        fontSize: true,
7528        lineHeight: true,
7529        __experimentalFontFamily: true,
7530        __experimentalFontWeight: true,
7531        __experimentalFontStyle: true,
7532        __experimentalTextTransform: true,
7533        __experimentalLetterSpacing: true
7534      }
7535    }
7536  };
7537  
7538  
7539  const {
7540    name: comment_author_name_name
7541  } = comment_author_name_metadata;
7542  
7543  const comment_author_name_settings = {
7544    icon: comment_author_name,
7545    edit: edit_Edit,
7546    deprecated: comment_author_name_deprecated
7547  };
7548  
7549  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/comment-content.js
7550  
7551  
7552  /**
7553   * WordPress dependencies
7554   */
7555  
7556  const commentContent = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
7557    viewBox: "0 0 24 24",
7558    xmlns: "http://www.w3.org/2000/svg"
7559  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
7560    fillRule: "evenodd",
7561    clipRule: "evenodd",
7562    d: "M6.68822 16.625L5.5 17.8145L5.5 5.5L18.5 5.5L18.5 16.625L6.68822 16.625ZM7.31 18.125L19 18.125C19.5523 18.125 20 17.6773 20 17.125L20 5C20 4.44772 19.5523 4 19 4H5C4.44772 4 4 4.44772 4 5V19.5247C4 19.8173 4.16123 20.086 4.41935 20.2237C4.72711 20.3878 5.10601 20.3313 5.35252 20.0845L7.31 18.125ZM16 9.99997H8V8.49997H16V9.99997ZM8 14H13V12.5H8V14Z"
7563  }));
7564  /* harmony default export */ var comment_content = (commentContent);
7565  
7566  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/comment-content/edit.js
7567  
7568  
7569  /**
7570   * External dependencies
7571   */
7572  
7573  /**
7574   * WordPress dependencies
7575   */
7576  
7577  
7578  
7579  
7580  
7581  
7582  /**
7583   * Renders the `core/comment-content` block on the editor.
7584   *
7585   * @param {Object} props                      React props.
7586   * @param {Object} props.setAttributes        Callback for updating block attributes.
7587   * @param {Object} props.attributes           Block attributes.
7588   * @param {string} props.attributes.textAlign The `textAlign` attribute.
7589   * @param {Object} props.context              Inherited context.
7590   * @param {string} props.context.commentId    The comment ID.
7591   *
7592   * @return {JSX.Element} React element.
7593   */
7594  
7595  function comment_content_edit_Edit(_ref) {
7596    let {
7597      setAttributes,
7598      attributes: {
7599        textAlign
7600      },
7601      context: {
7602        commentId
7603      }
7604    } = _ref;
7605    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
7606      className: classnames_default()({
7607        [`has-text-align-$textAlign}`]: textAlign
7608      })
7609    });
7610    const [content] = (0,external_wp_coreData_namespaceObject.useEntityProp)('root', 'comment', 'content', commentId);
7611    const blockControls = (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, {
7612      group: "block"
7613    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.AlignmentControl, {
7614      value: textAlign,
7615      onChange: newAlign => setAttributes({
7616        textAlign: newAlign
7617      })
7618    }));
7619  
7620    if (!commentId || !content) {
7621      return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, blockControls, (0,external_wp_element_namespaceObject.createElement)("div", blockProps, (0,external_wp_element_namespaceObject.createElement)("p", null, (0,external_wp_i18n_namespaceObject._x)('Comment Content', 'block title'))));
7622    }
7623  
7624    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, blockControls, (0,external_wp_element_namespaceObject.createElement)("div", blockProps, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Disabled, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.RawHTML, {
7625      key: "html"
7626    }, content.rendered))));
7627  }
7628  
7629  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/comment-content/index.js
7630  /**
7631   * WordPress dependencies
7632   */
7633  
7634  /**
7635   * Internal dependencies
7636   */
7637  
7638  const comment_content_metadata = {
7639    $schema: "https://schemas.wp.org/trunk/block.json",
7640    apiVersion: 2,
7641    name: "core/comment-content",
7642    title: "Comment Content",
7643    category: "theme",
7644    ancestor: ["core/comment-template"],
7645    description: "Displays the contents of a comment.",
7646    textdomain: "default",
7647    usesContext: ["commentId"],
7648    attributes: {
7649      textAlign: {
7650        type: "string"
7651      }
7652    },
7653    supports: {
7654      color: {
7655        gradients: true,
7656        link: true,
7657        __experimentalDefaultControls: {
7658          background: true,
7659          text: true
7660        }
7661      },
7662      typography: {
7663        fontSize: true,
7664        lineHeight: true,
7665        __experimentalFontFamily: true,
7666        __experimentalFontWeight: true,
7667        __experimentalFontStyle: true,
7668        __experimentalTextTransform: true,
7669        __experimentalLetterSpacing: true
7670      },
7671      spacing: {
7672        padding: ["horizontal", "vertical"],
7673        __experimentalDefaultControls: {
7674          padding: true
7675        }
7676      },
7677      html: false
7678    }
7679  };
7680  
7681  const {
7682    name: comment_content_name
7683  } = comment_content_metadata;
7684  
7685  const comment_content_settings = {
7686    icon: comment_content,
7687    edit: comment_content_edit_Edit
7688  };
7689  
7690  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/post-date.js
7691  
7692  
7693  /**
7694   * WordPress dependencies
7695   */
7696  
7697  const postDate = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
7698    xmlns: "http://www.w3.org/2000/svg",
7699    viewBox: "0 0 24 24"
7700  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
7701    d: "M11.696 13.972c.356-.546.599-.958.728-1.235a1.79 1.79 0 00.203-.783c0-.264-.077-.47-.23-.618-.148-.153-.354-.23-.618-.23-.295 0-.569.07-.82.212a3.413 3.413 0 00-.738.571l-.147-1.188c.289-.234.59-.41.903-.526.313-.117.66-.175 1.041-.175.375 0 .695.08.959.24.264.153.46.362.59.626.135.265.203.556.203.876 0 .362-.08.734-.24 1.115-.154.381-.427.87-.82 1.466l-.756 1.152H14v1.106h-4l1.696-2.609z"
7702  }), (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
7703    d: "M19.5 7h-15v12a.5.5 0 00.5.5h14a.5.5 0 00.5-.5V7zM3 7V5a2 2 0 012-2h14a2 2 0 012 2v14a2 2 0 01-2 2H5a2 2 0 01-2-2V7z"
7704  }));
7705  /* harmony default export */ var post_date = (postDate);
7706  
7707  ;// CONCATENATED MODULE: external ["wp","date"]
7708  var external_wp_date_namespaceObject = window["wp"]["date"];
7709  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/comment-date/edit.js
7710  
7711  
7712  /**
7713   * WordPress dependencies
7714   */
7715  
7716  
7717  
7718  
7719  
7720  /**
7721   * Renders the `core/comment-date` block on the editor.
7722   *
7723   * @param {Object} props                   React props.
7724   * @param {Object} props.setAttributes     Callback for updating block attributes.
7725   * @param {Object} props.attributes        Block attributes.
7726   * @param {string} props.attributes.format Format of the date.
7727   * @param {string} props.attributes.isLink Whether the author name should be linked.
7728   * @param {Object} props.context           Inherited context.
7729   * @param {string} props.context.commentId The comment ID.
7730   *
7731   * @return {JSX.Element} React element.
7732   */
7733  
7734  function comment_date_edit_Edit(_ref) {
7735    let {
7736      attributes: {
7737        format,
7738        isLink
7739      },
7740      context: {
7741        commentId
7742      },
7743      setAttributes
7744    } = _ref;
7745    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)();
7746    const [date] = (0,external_wp_coreData_namespaceObject.useEntityProp)('root', 'comment', 'date', commentId);
7747    const [siteFormat = (0,external_wp_date_namespaceObject.__experimentalGetSettings)().formats.date] = (0,external_wp_coreData_namespaceObject.useEntityProp)('root', 'site', 'date_format');
7748    const inspectorControls = (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
7749      title: (0,external_wp_i18n_namespaceObject.__)('Settings')
7750    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.__experimentalDateFormatPicker, {
7751      format: format,
7752      defaultFormat: siteFormat,
7753      onChange: nextFormat => setAttributes({
7754        format: nextFormat
7755      })
7756    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
7757      label: (0,external_wp_i18n_namespaceObject.__)('Link to comment'),
7758      onChange: () => setAttributes({
7759        isLink: !isLink
7760      }),
7761      checked: isLink
7762    })));
7763  
7764    if (!commentId || !date) {
7765      return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, inspectorControls, (0,external_wp_element_namespaceObject.createElement)("div", blockProps, (0,external_wp_element_namespaceObject.createElement)("p", null, (0,external_wp_i18n_namespaceObject._x)('Comment Date', 'block title'))));
7766    }
7767  
7768    let commentDate = (0,external_wp_element_namespaceObject.createElement)("time", {
7769      dateTime: (0,external_wp_date_namespaceObject.dateI18n)('c', date)
7770    }, (0,external_wp_date_namespaceObject.dateI18n)(format || siteFormat, date));
7771  
7772    if (isLink) {
7773      commentDate = (0,external_wp_element_namespaceObject.createElement)("a", {
7774        href: "#comment-date-pseudo-link",
7775        onClick: event => event.preventDefault()
7776      }, commentDate);
7777    }
7778  
7779    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, inspectorControls, (0,external_wp_element_namespaceObject.createElement)("div", blockProps, commentDate));
7780  }
7781  
7782  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/comment-date/deprecated.js
7783  /**
7784   * Internal dependencies
7785   */
7786  
7787  const deprecated_v1 = {
7788    attributes: {
7789      format: {
7790        type: 'string'
7791      },
7792      isLink: {
7793        type: 'boolean',
7794        default: false
7795      }
7796    },
7797    supports: {
7798      html: false,
7799      color: {
7800        gradients: true,
7801        link: true
7802      },
7803      typography: {
7804        fontSize: true,
7805        lineHeight: true,
7806        __experimentalFontFamily: true,
7807        __experimentalFontWeight: true,
7808        __experimentalFontStyle: true,
7809        __experimentalTextTransform: true,
7810        __experimentalLetterSpacing: true
7811      }
7812    },
7813  
7814    save() {
7815      return null;
7816    },
7817  
7818    migrate: migrate_font_family,
7819  
7820    isEligible(_ref) {
7821      var _style$typography;
7822  
7823      let {
7824        style
7825      } = _ref;
7826      return style === null || style === void 0 ? void 0 : (_style$typography = style.typography) === null || _style$typography === void 0 ? void 0 : _style$typography.fontFamily;
7827    }
7828  
7829  };
7830  /**
7831   * New deprecations need to be placed first
7832   * for them to have higher priority.
7833   *
7834   * Old deprecations may need to be updated as well.
7835   *
7836   * See block-deprecation.md
7837   */
7838  
7839  /* harmony default export */ var comment_date_deprecated = ([deprecated_v1]);
7840  
7841  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/comment-date/index.js
7842  /**
7843   * WordPress dependencies
7844   */
7845  
7846  /**
7847   * Internal dependencies
7848   */
7849  
7850  const comment_date_metadata = {
7851    $schema: "https://schemas.wp.org/trunk/block.json",
7852    apiVersion: 2,
7853    name: "core/comment-date",
7854    title: "Comment Date",
7855    category: "theme",
7856    ancestor: ["core/comment-template"],
7857    description: "Displays the date on which the comment was posted.",
7858    textdomain: "default",
7859    attributes: {
7860      format: {
7861        type: "string"
7862      },
7863      isLink: {
7864        type: "boolean",
7865        "default": true
7866      },
7867      fontSize: {
7868        type: "string",
7869        "default": "small"
7870      }
7871    },
7872    usesContext: ["commentId"],
7873    supports: {
7874      html: false,
7875      color: {
7876        gradients: true,
7877        link: true,
7878        __experimentalDefaultControls: {
7879          background: true,
7880          text: true,
7881          link: true
7882        }
7883      },
7884      typography: {
7885        fontSize: true,
7886        lineHeight: true,
7887        __experimentalFontFamily: true,
7888        __experimentalFontWeight: true,
7889        __experimentalFontStyle: true,
7890        __experimentalTextTransform: true,
7891        __experimentalLetterSpacing: true,
7892        __experimentalDefaultControls: {
7893          fontSize: true
7894        }
7895      }
7896    }
7897  };
7898  
7899  
7900  const {
7901    name: comment_date_name
7902  } = comment_date_metadata;
7903  
7904  const comment_date_settings = {
7905    icon: post_date,
7906    edit: comment_date_edit_Edit,
7907    deprecated: comment_date_deprecated
7908  };
7909  
7910  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/comment-edit-link.js
7911  
7912  
7913  /**
7914   * WordPress dependencies
7915   */
7916  
7917  const commentEditLink = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
7918    width: "24",
7919    height: "24",
7920    viewBox: "0 0 24 24",
7921    xmlns: "http://www.w3.org/2000/svg"
7922  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
7923    d: "m6.249 11.065.44-.44h3.186l-1.5 1.5H7.31l-1.957 1.96A.792.792 0 0 1 4 13.524V5a1 1 0 0 1 1-1h8a1 1 0 0 1 1 1v1.5L12.5 8V5.5h-7v6.315l.749-.75ZM20 19.75H7v-1.5h13v1.5Zm0-12.653-8.967 9.064L8 17l.867-2.935L17.833 5 20 7.097Z"
7924  }));
7925  /* harmony default export */ var comment_edit_link = (commentEditLink);
7926  
7927  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/comment-edit-link/edit.js
7928  
7929  
7930  /**
7931   * External dependencies
7932   */
7933  
7934  /**
7935   * WordPress dependencies
7936   */
7937  
7938  
7939  
7940  
7941  function comment_edit_link_edit_Edit(_ref) {
7942    let {
7943      attributes: {
7944        linkTarget,
7945        textAlign
7946      },
7947      setAttributes
7948    } = _ref;
7949    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
7950      className: classnames_default()({
7951        [`has-text-align-$textAlign}`]: textAlign
7952      })
7953    });
7954    const blockControls = (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, {
7955      group: "block"
7956    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.AlignmentControl, {
7957      value: textAlign,
7958      onChange: newAlign => setAttributes({
7959        textAlign: newAlign
7960      })
7961    }));
7962    const inspectorControls = (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
7963      title: (0,external_wp_i18n_namespaceObject.__)('Link settings')
7964    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
7965      label: (0,external_wp_i18n_namespaceObject.__)('Open in new tab'),
7966      onChange: value => setAttributes({
7967        linkTarget: value ? '_blank' : '_self'
7968      }),
7969      checked: linkTarget === '_blank'
7970    })));
7971    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, blockControls, inspectorControls, (0,external_wp_element_namespaceObject.createElement)("div", blockProps, (0,external_wp_element_namespaceObject.createElement)("a", {
7972      href: "#edit-comment-pseudo-link",
7973      onClick: event => event.preventDefault()
7974    }, (0,external_wp_i18n_namespaceObject.__)('Edit'))));
7975  }
7976  
7977  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/comment-edit-link/index.js
7978  /**
7979   * WordPress dependencies
7980   */
7981  
7982  /**
7983   * Internal dependencies
7984   */
7985  
7986  const comment_edit_link_metadata = {
7987    $schema: "https://schemas.wp.org/trunk/block.json",
7988    apiVersion: 2,
7989    name: "core/comment-edit-link",
7990    title: "Comment Edit Link",
7991    category: "theme",
7992    ancestor: ["core/comment-template"],
7993    description: "Displays a link to edit the comment in the WordPress Dashboard. This link is only visible to users with the edit comment capability.",
7994    textdomain: "default",
7995    usesContext: ["commentId"],
7996    attributes: {
7997      linkTarget: {
7998        type: "string",
7999        "default": "_self"
8000      },
8001      textAlign: {
8002        type: "string"
8003      },
8004      fontSize: {
8005        type: "string",
8006        "default": "small"
8007      }
8008    },
8009    supports: {
8010      html: false,
8011      color: {
8012        link: true,
8013        gradients: true,
8014        text: false,
8015        __experimentalDefaultControls: {
8016          background: true,
8017          link: true
8018        }
8019      },
8020      typography: {
8021        fontSize: true,
8022        lineHeight: true,
8023        __experimentalFontFamily: true,
8024        __experimentalFontWeight: true,
8025        __experimentalFontStyle: true,
8026        __experimentalTextTransform: true,
8027        __experimentalLetterSpacing: true
8028      }
8029    }
8030  };
8031  
8032  const {
8033    name: comment_edit_link_name
8034  } = comment_edit_link_metadata;
8035  
8036  const comment_edit_link_settings = {
8037    icon: comment_edit_link,
8038    edit: comment_edit_link_edit_Edit
8039  };
8040  
8041  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/comment-reply-link.js
8042  
8043  
8044  /**
8045   * WordPress dependencies
8046   */
8047  
8048  const commentReplyLink = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
8049    width: "24",
8050    height: "24",
8051    viewBox: "0 0 24 24",
8052    xmlns: "http://www.w3.org/2000/svg"
8053  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
8054    d: "M6.68822 10.625L6.24878 11.0649L5.5 11.8145L5.5 5.5L12.5 5.5V8L14 6.5V5C14 4.44772 13.5523 4 13 4H5C4.44772 4 4 4.44771 4 5V13.5247C4 13.8173 4.16123 14.086 4.41935 14.2237C4.72711 14.3878 5.10601 14.3313 5.35252 14.0845L7.31 12.125H8.375L9.875 10.625H7.31H6.68822ZM14.5605 10.4983L11.6701 13.75H16.9975C17.9963 13.75 18.7796 14.1104 19.3553 14.7048C19.9095 15.2771 20.2299 16.0224 20.4224 16.7443C20.7645 18.0276 20.7543 19.4618 20.7487 20.2544C20.7481 20.345 20.7475 20.4272 20.7475 20.4999L19.2475 20.5001C19.2475 20.4191 19.248 20.3319 19.2484 20.2394V20.2394C19.2526 19.4274 19.259 18.2035 18.973 17.1307C18.8156 16.5401 18.586 16.0666 18.2778 15.7483C17.9909 15.4521 17.5991 15.25 16.9975 15.25H11.8106L14.5303 17.9697L13.4696 19.0303L8.96956 14.5303L13.4394 9.50171L14.5605 10.4983Z"
8055  }));
8056  /* harmony default export */ var comment_reply_link = (commentReplyLink);
8057  
8058  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/comment-reply-link/edit.js
8059  
8060  
8061  /**
8062   * External dependencies
8063   */
8064  
8065  /**
8066   * WordPress dependencies
8067   */
8068  
8069  
8070  
8071  /**
8072   * Renders the `core/comment-reply-link` block on the editor.
8073   *
8074   * @param {Object} props                      React props.
8075   * @param {Object} props.setAttributes        Callback for updating block attributes.
8076   * @param {Object} props.attributes           Block attributes.
8077   * @param {string} props.attributes.textAlign The `textAlign` attribute.
8078   *
8079   * @return {JSX.Element} React element.
8080   */
8081  
8082  function comment_reply_link_edit_Edit(_ref) {
8083    let {
8084      setAttributes,
8085      attributes: {
8086        textAlign
8087      }
8088    } = _ref;
8089    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
8090      className: classnames_default()({
8091        [`has-text-align-$textAlign}`]: textAlign
8092      })
8093    });
8094    const blockControls = (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, {
8095      group: "block"
8096    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.AlignmentControl, {
8097      value: textAlign,
8098      onChange: newAlign => setAttributes({
8099        textAlign: newAlign
8100      })
8101    }));
8102    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, blockControls, (0,external_wp_element_namespaceObject.createElement)("div", blockProps, (0,external_wp_element_namespaceObject.createElement)("a", {
8103      href: "#comment-reply-pseudo-link",
8104      onClick: event => event.preventDefault()
8105    }, (0,external_wp_i18n_namespaceObject.__)('Reply'))));
8106  }
8107  
8108  /* harmony default export */ var comment_reply_link_edit = (comment_reply_link_edit_Edit);
8109  
8110  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/comment-reply-link/index.js
8111  /**
8112   * WordPress dependencies
8113   */
8114  
8115  /**
8116   * Internal dependencies
8117   */
8118  
8119  const comment_reply_link_metadata = {
8120    $schema: "https://schemas.wp.org/trunk/block.json",
8121    apiVersion: 2,
8122    name: "core/comment-reply-link",
8123    title: "Comment Reply Link",
8124    category: "theme",
8125    ancestor: ["core/comment-template"],
8126    description: "Displays a link to reply to a comment.",
8127    textdomain: "default",
8128    usesContext: ["commentId"],
8129    attributes: {
8130      textAlign: {
8131        type: "string"
8132      },
8133      fontSize: {
8134        type: "string",
8135        "default": "small"
8136      }
8137    },
8138    supports: {
8139      color: {
8140        gradients: true,
8141        link: true,
8142        text: false,
8143        __experimentalDefaultControls: {
8144          background: true,
8145          link: true
8146        }
8147      },
8148      typography: {
8149        fontSize: true,
8150        lineHeight: true,
8151        __experimentalFontFamily: true,
8152        __experimentalFontWeight: true,
8153        __experimentalFontStyle: true,
8154        __experimentalTextTransform: true,
8155        __experimentalLetterSpacing: true
8156      },
8157      html: false
8158    }
8159  };
8160  
8161  const {
8162    name: comment_reply_link_name
8163  } = comment_reply_link_metadata;
8164  
8165  const comment_reply_link_settings = {
8166    edit: comment_reply_link_edit,
8167    icon: comment_reply_link
8168  };
8169  
8170  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/layout.js
8171  
8172  
8173  /**
8174   * WordPress dependencies
8175   */
8176  
8177  const layout = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
8178    xmlns: "http://www.w3.org/2000/svg",
8179    viewBox: "0 0 24 24"
8180  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
8181    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"
8182  }));
8183  /* harmony default export */ var library_layout = (layout);
8184  
8185  ;// CONCATENATED MODULE: external ["wp","apiFetch"]
8186  var external_wp_apiFetch_namespaceObject = window["wp"]["apiFetch"];
8187  var external_wp_apiFetch_default = /*#__PURE__*/__webpack_require__.n(external_wp_apiFetch_namespaceObject);
8188  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/comment-template/hooks.js
8189  /**
8190   * WordPress dependencies
8191   */
8192  
8193  
8194  
8195  
8196   // This is limited by WP REST API
8197  
8198  const MAX_COMMENTS_PER_PAGE = 100;
8199  /**
8200   * Return an object with the query args needed to fetch the default page of
8201   * comments.
8202   *
8203   * @param {Object} props        Hook props.
8204   * @param {number} props.postId ID of the post that contains the comments.
8205   *                              discussion settings.
8206   *
8207   * @return {Object} Query args to retrieve the comments.
8208   */
8209  
8210  const useCommentQueryArgs = _ref => {
8211    let {
8212      postId
8213    } = _ref;
8214    // Initialize the query args that are not going to change.
8215    const queryArgs = {
8216      status: 'approve',
8217      order: 'asc',
8218      context: 'embed',
8219      parent: 0,
8220      _embed: 'children'
8221    }; // Get the Discussion settings that may be needed to query the comments.
8222  
8223    const {
8224      pageComments,
8225      commentsPerPage,
8226      defaultCommentsPage: defaultPage
8227    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
8228      const {
8229        getSettings
8230      } = select(external_wp_blockEditor_namespaceObject.store);
8231      const {
8232        __experimentalDiscussionSettings
8233      } = getSettings();
8234      return __experimentalDiscussionSettings;
8235    }); // WP REST API doesn't allow fetching more than max items limit set per single page of data.
8236    // As for the editor performance is more important than completeness of data and fetching only the
8237    // max allowed for single page should be enough for the purpose of design and laying out the page.
8238    // Fetching over the limit would return an error here but would work with backend query.
8239  
8240    const perPage = pageComments ? Math.min(commentsPerPage, MAX_COMMENTS_PER_PAGE) : MAX_COMMENTS_PER_PAGE; // Get the number of the default page.
8241  
8242    const page = useDefaultPageIndex({
8243      defaultPage,
8244      postId,
8245      perPage,
8246      queryArgs
8247    }); // Merge, memoize and return all query arguments, unless the default page's
8248    // number is not known yet.
8249  
8250    return (0,external_wp_element_namespaceObject.useMemo)(() => {
8251      return page ? { ...queryArgs,
8252        post: postId,
8253        per_page: perPage,
8254        page
8255      } : null;
8256    }, [postId, perPage, page]);
8257  };
8258  /**
8259   * Return the index of the default page, depending on whether `defaultPage` is
8260   * `newest` or `oldest`. In the first case, the only way to know the page's
8261   * index is by using the `X-WP-TotalPages` header, which forces to make an
8262   * additional request.
8263   *
8264   * @param {Object} props             Hook props.
8265   * @param {string} props.defaultPage Page shown by default (newest/oldest).
8266   * @param {number} props.postId      ID of the post that contains the comments.
8267   * @param {number} props.perPage     The number of comments included per page.
8268   * @param {Object} props.queryArgs   Other query args.
8269   *
8270   * @return {number} Index of the default comments page.
8271   */
8272  
8273  const useDefaultPageIndex = _ref2 => {
8274    let {
8275      defaultPage,
8276      postId,
8277      perPage,
8278      queryArgs
8279    } = _ref2;
8280    // Store the default page indices.
8281    const [defaultPages, setDefaultPages] = (0,external_wp_element_namespaceObject.useState)({});
8282    const key = `$postId}_$perPage}`;
8283    const page = defaultPages[key] || 0;
8284    (0,external_wp_element_namespaceObject.useEffect)(() => {
8285      // Do nothing if the page is already known or not the newest page.
8286      if (page || defaultPage !== 'newest') {
8287        return;
8288      } // We need to fetch comments to know the index. Use HEAD and limit
8289      // fields just to ID, to make this call as light as possible.
8290  
8291  
8292      external_wp_apiFetch_default()({
8293        path: (0,external_wp_url_namespaceObject.addQueryArgs)('/wp/v2/comments', { ...queryArgs,
8294          post: postId,
8295          per_page: perPage,
8296          _fields: 'id'
8297        }),
8298        method: 'HEAD',
8299        parse: false
8300      }).then(res => {
8301        const pages = parseInt(res.headers.get('X-WP-TotalPages'));
8302        setDefaultPages({ ...defaultPages,
8303          [key]: pages <= 1 ? 1 : pages // If there are 0 pages, it means that there are no comments, but there is no 0th page.
8304  
8305        });
8306      });
8307    }, [defaultPage, postId, perPage, setDefaultPages]); // The oldest one is always the first one.
8308  
8309    return defaultPage === 'newest' ? page : 1;
8310  };
8311  /**
8312   * Generate a tree structure of comment IDs from a list of comment entities. The
8313   * children of each comment are obtained from `_embedded`.
8314   *
8315   * @typedef {{ commentId: number, children: CommentNode }} CommentNode
8316   *
8317   * @param {Object[]} topLevelComments List of comment entities.
8318   * @return {{ commentTree: CommentNode[]}} Tree of comment IDs.
8319   */
8320  
8321  
8322  const useCommentTree = topLevelComments => {
8323    const commentTree = (0,external_wp_element_namespaceObject.useMemo)(() => topLevelComments === null || topLevelComments === void 0 ? void 0 : topLevelComments.map(_ref3 => {
8324      let {
8325        id,
8326        _embedded
8327      } = _ref3;
8328      const [children] = (_embedded === null || _embedded === void 0 ? void 0 : _embedded.children) || [[]];
8329      return {
8330        commentId: id,
8331        children: children.map(child => ({
8332          commentId: child.id
8333        }))
8334      };
8335    }), [topLevelComments]);
8336    return commentTree;
8337  };
8338  
8339  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/comment-template/edit.js
8340  
8341  
8342  
8343  /**
8344   * WordPress dependencies
8345   */
8346  
8347  
8348  
8349  
8350  
8351  
8352  /**
8353   * Internal dependencies
8354   */
8355  
8356  
8357  const TEMPLATE = [['core/avatar'], ['core/comment-author-name'], ['core/comment-date'], ['core/comment-content'], ['core/comment-reply-link'], ['core/comment-edit-link']];
8358  /**
8359   * Function that returns a comment structure that will be rendered with default placehoders.
8360   *
8361   * Each comment has a `commentId` property that is always a negative number in
8362   * case of the placeholders. This is to ensure that the comment does not
8363   * conflict with the actual (real) comments.
8364   *
8365   * @param {Object}  settings                       Discussion Settings.
8366   * @param {number}  [settings.perPage]             - Comments per page setting or block attribute.
8367   * @param {boolean} [settings.threadComments]      - Enable threaded (nested) comments setting.
8368   * @param {number}  [settings.threadCommentsDepth] - Level deep of threaded comments.
8369   *
8370   * @typedef {{id: null, children: EmptyComment[]}} EmptyComment
8371   * @return {EmptyComment[]}                         Inner blocks of the Comment Template
8372   */
8373  
8374  const getCommentsPlaceholder = _ref => {
8375    let {
8376      perPage,
8377      threadComments,
8378      threadCommentsDepth
8379    } = _ref;
8380    // In case that `threadCommentsDepth` is falsy, we default to a somewhat
8381    // arbitrary value of 3.
8382    // In case that the value is set but larger than 3 we truncate it to 3.
8383    const commentsDepth = Math.min(threadCommentsDepth || 3, 3); // We set a limit in order not to overload the editor of empty comments.
8384  
8385    const defaultCommentsToShow = perPage <= commentsDepth ? perPage : commentsDepth;
8386  
8387    if (!threadComments || defaultCommentsToShow === 1) {
8388      // If displaying threaded comments is disabled, we only show one comment
8389      // A commentId is negative in order to avoid conflicts with the actual comments.
8390      return [{
8391        commentId: -1,
8392        children: []
8393      }];
8394    } else if (defaultCommentsToShow === 2) {
8395      return [{
8396        commentId: -1,
8397        children: [{
8398          commentId: -2,
8399          children: []
8400        }]
8401      }];
8402    } // In case that the value is set but larger than 3 we truncate it to 3.
8403  
8404  
8405    return [{
8406      commentId: -1,
8407      children: [{
8408        commentId: -2,
8409        children: [{
8410          commentId: -3,
8411          children: []
8412        }]
8413      }]
8414    }];
8415  };
8416  /**
8417   * Component which renders the inner blocks of the Comment Template.
8418   *
8419   * @param {Object} props                      Component props.
8420   * @param {Array}  [props.comment]            - A comment object.
8421   * @param {Array}  [props.activeCommentId]    - The ID of the comment that is currently active.
8422   * @param {Array}  [props.setActiveCommentId] - The setter for activeCommentId.
8423   * @param {Array}  [props.firstCommentId]     - ID of the first comment in the array.
8424   * @param {Array}  [props.blocks]             - Array of blocks returned from
8425   *                                            getBlocks() in parent .
8426   * @return {WPElement}                         Inner blocks of the Comment Template
8427   */
8428  
8429  
8430  function CommentTemplateInnerBlocks(_ref2) {
8431    var _comment$children;
8432  
8433    let {
8434      comment,
8435      activeCommentId,
8436      setActiveCommentId,
8437      firstCommentId,
8438      blocks
8439    } = _ref2;
8440    const {
8441      children,
8442      ...innerBlocksProps
8443    } = (0,external_wp_blockEditor_namespaceObject.useInnerBlocksProps)({}, {
8444      template: TEMPLATE
8445    });
8446    return (0,external_wp_element_namespaceObject.createElement)("li", innerBlocksProps, comment.commentId === (activeCommentId || firstCommentId) ? children : null, (0,external_wp_element_namespaceObject.createElement)(MemoizedCommentTemplatePreview, {
8447      blocks: blocks,
8448      commentId: comment.commentId,
8449      setActiveCommentId: setActiveCommentId,
8450      isHidden: comment.commentId === (activeCommentId || firstCommentId)
8451    }), (comment === null || comment === void 0 ? void 0 : (_comment$children = comment.children) === null || _comment$children === void 0 ? void 0 : _comment$children.length) > 0 ? (0,external_wp_element_namespaceObject.createElement)(CommentsList, {
8452      comments: comment.children,
8453      activeCommentId: activeCommentId,
8454      setActiveCommentId: setActiveCommentId,
8455      blocks: blocks,
8456      firstCommentId: firstCommentId
8457    }) : null);
8458  }
8459  
8460  const CommentTemplatePreview = _ref3 => {
8461    let {
8462      blocks,
8463      commentId,
8464      setActiveCommentId,
8465      isHidden
8466    } = _ref3;
8467    const blockPreviewProps = (0,external_wp_blockEditor_namespaceObject.__experimentalUseBlockPreview)({
8468      blocks
8469    });
8470  
8471    const handleOnClick = () => {
8472      setActiveCommentId(commentId);
8473    }; // We have to hide the preview block if the `comment` props points to
8474    // the curently active block!
8475    // Or, to put it differently, every preview block is visible unless it is the
8476    // currently active block - in this case we render its inner blocks.
8477  
8478  
8479    const style = {
8480      display: isHidden ? 'none' : undefined
8481    };
8482    return (0,external_wp_element_namespaceObject.createElement)("div", _extends({}, blockPreviewProps, {
8483      tabIndex: 0,
8484      role: "button",
8485      style: style // eslint-disable-next-line jsx-a11y/no-noninteractive-element-to-interactive-role
8486      ,
8487      onClick: handleOnClick,
8488      onKeyPress: handleOnClick
8489    }));
8490  };
8491  
8492  const MemoizedCommentTemplatePreview = (0,external_wp_element_namespaceObject.memo)(CommentTemplatePreview);
8493  /**
8494   * Component that renders a list of (nested) comments. It is called recursively.
8495   *
8496   * @param {Object} props                      Component props.
8497   * @param {Array}  [props.comments]           - Array of comment objects.
8498   * @param {Array}  [props.blockProps]         - Props from parent's `useBlockProps()`.
8499   * @param {Array}  [props.activeCommentId]    - The ID of the comment that is currently active.
8500   * @param {Array}  [props.setActiveCommentId] - The setter for activeCommentId.
8501   * @param {Array}  [props.blocks]             - Array of blocks returned from getBlocks() in parent.
8502   * @param {Object} [props.firstCommentId]     - The ID of the first comment in the array of
8503   *                                            comment objects.
8504   * @return {WPElement}                         List of comments.
8505   */
8506  
8507  const CommentsList = _ref4 => {
8508    let {
8509      comments,
8510      blockProps,
8511      activeCommentId,
8512      setActiveCommentId,
8513      blocks,
8514      firstCommentId
8515    } = _ref4;
8516    return (0,external_wp_element_namespaceObject.createElement)("ol", blockProps, comments && comments.map((_ref5, index) => {
8517      let {
8518        commentId,
8519        ...comment
8520      } = _ref5;
8521      return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockContextProvider, {
8522        key: comment.commentId || index,
8523        value: {
8524          // If the commentId is negative it means that this comment is a
8525          // "placeholder" and that the block is most likely being used in the
8526          // site editor. In this case, we have to set the commentId to `null`
8527          // because otherwise the (non-existent) comment with a negative ID
8528          // would be reqested from the REST API.
8529          commentId: commentId < 0 ? null : commentId
8530        }
8531      }, (0,external_wp_element_namespaceObject.createElement)(CommentTemplateInnerBlocks, {
8532        comment: {
8533          commentId,
8534          ...comment
8535        },
8536        activeCommentId: activeCommentId,
8537        setActiveCommentId: setActiveCommentId,
8538        blocks: blocks,
8539        firstCommentId: firstCommentId
8540      }));
8541    }));
8542  };
8543  
8544  function CommentTemplateEdit(_ref6) {
8545    var _commentTree$;
8546  
8547    let {
8548      clientId,
8549      context: {
8550        postId
8551      }
8552    } = _ref6;
8553    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)();
8554    const [activeCommentId, setActiveCommentId] = (0,external_wp_element_namespaceObject.useState)();
8555    const {
8556      commentOrder,
8557      threadCommentsDepth,
8558      threadComments,
8559      commentsPerPage
8560    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
8561      const {
8562        getSettings
8563      } = select(external_wp_blockEditor_namespaceObject.store);
8564      return getSettings().__experimentalDiscussionSettings;
8565    });
8566    const commentQuery = useCommentQueryArgs({
8567      postId
8568    });
8569    const {
8570      topLevelComments,
8571      blocks
8572    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
8573      const {
8574        getEntityRecords
8575      } = select(external_wp_coreData_namespaceObject.store);
8576      const {
8577        getBlocks
8578      } = select(external_wp_blockEditor_namespaceObject.store);
8579      return {
8580        // Request only top-level comments. Replies are embedded.
8581        topLevelComments: commentQuery ? getEntityRecords('root', 'comment', commentQuery) : null,
8582        blocks: getBlocks(clientId)
8583      };
8584    }, [clientId, commentQuery]); // Generate a tree structure of comment IDs.
8585  
8586    let commentTree = useCommentTree( // Reverse the order of top comments if needed.
8587    commentOrder === 'desc' && topLevelComments ? [...topLevelComments].reverse() : topLevelComments);
8588  
8589    if (!topLevelComments) {
8590      return (0,external_wp_element_namespaceObject.createElement)("p", blockProps, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Spinner, null));
8591    }
8592  
8593    if (!postId) {
8594      commentTree = getCommentsPlaceholder({
8595        perPage: commentsPerPage,
8596        threadComments,
8597        threadCommentsDepth
8598      });
8599    }
8600  
8601    if (!commentTree.length) {
8602      return (0,external_wp_element_namespaceObject.createElement)("p", _extends({}, blockProps, {
8603        "data-testid": "noresults"
8604      }), (0,external_wp_i18n_namespaceObject.__)('No results found.'));
8605    }
8606  
8607    return (0,external_wp_element_namespaceObject.createElement)(CommentsList, {
8608      comments: commentTree,
8609      blockProps: blockProps,
8610      blocks: blocks,
8611      activeCommentId: activeCommentId,
8612      setActiveCommentId: setActiveCommentId,
8613      firstCommentId: (_commentTree$ = commentTree[0]) === null || _commentTree$ === void 0 ? void 0 : _commentTree$.commentId
8614    });
8615  }
8616  
8617  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/comment-template/save.js
8618  
8619  
8620  /**
8621   * WordPress dependencies
8622   */
8623  
8624  function CommentTemplateSave() {
8625    return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InnerBlocks.Content, null);
8626  }
8627  
8628  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/comment-template/index.js
8629  /**
8630   * WordPress dependencies
8631   */
8632  
8633  /**
8634   * Internal dependencies
8635   */
8636  
8637  const comment_template_metadata = {
8638    $schema: "https://schemas.wp.org/trunk/block.json",
8639    apiVersion: 2,
8640    name: "core/comment-template",
8641    title: "Comment Template",
8642    category: "design",
8643    parent: ["core/comments-query-loop"],
8644    description: "Contains the block elements used to display a comment, like the title, date, author, avatar and more.",
8645    textdomain: "default",
8646    usesContext: ["postId"],
8647    supports: {
8648      reusable: false,
8649      html: false,
8650      align: true
8651    },
8652    style: "wp-block-comment-template"
8653  };
8654  
8655  
8656  const {
8657    name: comment_template_name
8658  } = comment_template_metadata;
8659  
8660  const comment_template_settings = {
8661    icon: library_layout,
8662    edit: CommentTemplateEdit,
8663    save: CommentTemplateSave
8664  };
8665  
8666  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/query-pagination-previous.js
8667  
8668  
8669  /**
8670   * WordPress dependencies
8671   */
8672  
8673  const queryPaginationPrevious = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
8674    xmlns: "http://www.w3.org/2000/svg",
8675    viewBox: "0 0 24 24"
8676  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
8677    d: "M16 10.5v3h3v-3h-3zm-5 3h3v-3h-3v3zM7 9l-3 3 3 3 1-1-2-2 2-2-1-1z"
8678  }));
8679  /* harmony default export */ var query_pagination_previous = (queryPaginationPrevious);
8680  
8681  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/comments-pagination-previous/edit.js
8682  
8683  
8684  
8685  /**
8686   * WordPress dependencies
8687   */
8688  
8689  
8690  const arrowMap = {
8691    none: '',
8692    arrow: '←',
8693    chevron: '«'
8694  };
8695  function CommentsPaginationPreviousEdit(_ref) {
8696    let {
8697      attributes: {
8698        label
8699      },
8700      setAttributes,
8701      context: {
8702        'comments/paginationArrow': paginationArrow
8703      }
8704    } = _ref;
8705    const displayArrow = arrowMap[paginationArrow];
8706    return (0,external_wp_element_namespaceObject.createElement)("a", _extends({
8707      href: "#comments-pagination-previous-pseudo-link",
8708      onClick: event => event.preventDefault()
8709    }, (0,external_wp_blockEditor_namespaceObject.useBlockProps)()), displayArrow && (0,external_wp_element_namespaceObject.createElement)("span", {
8710      className: `wp-block-comments-pagination-previous-arrow is-arrow-$paginationArrow}`
8711    }, displayArrow), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.PlainText, {
8712      __experimentalVersion: 2,
8713      tagName: "span",
8714      "aria-label": (0,external_wp_i18n_namespaceObject.__)('Older comments page link'),
8715      placeholder: (0,external_wp_i18n_namespaceObject.__)('Older Comments'),
8716      value: label,
8717      onChange: newLabel => setAttributes({
8718        label: newLabel
8719      })
8720    }));
8721  }
8722  
8723  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/comments-pagination-previous/index.js
8724  /**
8725   * WordPress dependencies
8726   */
8727  
8728  /**
8729   * Internal dependencies
8730   */
8731  
8732  const comments_pagination_previous_metadata = {
8733    $schema: "https://schemas.wp.org/trunk/block.json",
8734    apiVersion: 2,
8735    name: "core/comments-pagination-previous",
8736    title: "Previous Page",
8737    category: "theme",
8738    parent: ["core/comments-pagination"],
8739    description: "Displays the previous comment's page link.",
8740    textdomain: "default",
8741    attributes: {
8742      label: {
8743        type: "string"
8744      }
8745    },
8746    usesContext: ["postId", "comments/paginationArrow"],
8747    supports: {
8748      reusable: false,
8749      html: false,
8750      color: {
8751        gradients: true,
8752        text: false,
8753        __experimentalDefaultControls: {
8754          background: true
8755        }
8756      },
8757      typography: {
8758        fontSize: true,
8759        lineHeight: true,
8760        __experimentalFontStyle: true,
8761        __experimentalFontWeight: true,
8762        __experimentalLetterSpacing: true,
8763        __experimentalTextTransform: true,
8764        __experimentalDefaultControls: {
8765          fontSize: true
8766        }
8767      }
8768    }
8769  };
8770  
8771  const {
8772    name: comments_pagination_previous_name
8773  } = comments_pagination_previous_metadata;
8774  
8775  const comments_pagination_previous_settings = {
8776    icon: query_pagination_previous,
8777    edit: CommentsPaginationPreviousEdit
8778  };
8779  
8780  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/post-comments.js
8781  
8782  
8783  /**
8784   * WordPress dependencies
8785   */
8786  
8787  const postComments = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
8788    xmlns: "http://www.w3.org/2000/svg",
8789    viewBox: "0 0 24 24"
8790  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
8791    d: "M14 10.1V4c0-.6-.4-1-1-1H5c-.6 0-1 .4-1 1v8.3c0 .3.2.7.6.8.1.1.2.1.3.1.2 0 .5-.1.6-.3l1.8-1.8H13c.6 0 1-.4 1-1zm-1.5-.5H6.7l-1.2 1.2V4.5h7v5.1zM19 12h-8c-.6 0-1 .4-1 1v6.1c0 .6.4 1 1 1h5.7l1.8 1.8c.1.2.4.3.6.3.1 0 .2 0 .3-.1.4-.1.6-.5.6-.8V13c0-.6-.4-1-1-1zm-.5 7.8l-1.2-1.2h-5.8v-5.1h7v6.3z"
8792  }));
8793  /* harmony default export */ var post_comments = (postComments);
8794  
8795  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/comments-query-loop/edit/comments-inspector-controls.js
8796  
8797  
8798  /**
8799   * WordPress dependencies
8800   */
8801  
8802  
8803  
8804  function CommentsInspectorControls(_ref) {
8805    let {
8806      attributes: {
8807        TagName
8808      },
8809      setAttributes
8810    } = _ref;
8811    return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, {
8812      __experimentalGroup: "advanced"
8813    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SelectControl, {
8814      label: (0,external_wp_i18n_namespaceObject.__)('HTML element'),
8815      options: [{
8816        label: (0,external_wp_i18n_namespaceObject.__)('Default (<div>)'),
8817        value: 'div'
8818      }, {
8819        label: '<section>',
8820        value: 'section'
8821      }, {
8822        label: '<aside>',
8823        value: 'aside'
8824      }],
8825      value: TagName,
8826      onChange: value => setAttributes({
8827        tagName: value
8828      })
8829    })));
8830  }
8831  
8832  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/comments-query-loop/edit.js
8833  
8834  
8835  /**
8836   * WordPress dependencies
8837   */
8838  
8839  /**
8840   * Internal dependencies
8841   */
8842  
8843  
8844  const edit_TEMPLATE = [['core/comments-title'], ['core/comment-template', {}, [['core/columns', {}, [['core/column', {
8845    width: '40px'
8846  }, [['core/avatar', {
8847    size: 40,
8848    style: {
8849      border: {
8850        radius: '20px'
8851      }
8852    }
8853  }]]], ['core/column', {}, [['core/comment-author-name'], ['core/group', {
8854    layout: {
8855      type: 'flex'
8856    },
8857    style: {
8858      spacing: {
8859        margin: {
8860          top: '0px',
8861          bottom: '0px'
8862        }
8863      }
8864    }
8865  }, [['core/comment-date'], ['core/comment-edit-link']]], ['core/comment-content'], ['core/comment-reply-link']]]]]]], ['core/comments-pagination'], ['core/post-comments-form']];
8866  function CommentsQueryLoopEdit(_ref) {
8867    let {
8868      attributes,
8869      setAttributes
8870    } = _ref;
8871    const {
8872      tagName: TagName
8873    } = attributes;
8874    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)();
8875    const innerBlocksProps = (0,external_wp_blockEditor_namespaceObject.useInnerBlocksProps)(blockProps, {
8876      template: edit_TEMPLATE
8877    });
8878    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(CommentsInspectorControls, {
8879      attributes: attributes,
8880      setAttributes: setAttributes
8881    }), (0,external_wp_element_namespaceObject.createElement)(TagName, innerBlocksProps));
8882  }
8883  
8884  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/comments-query-loop/save.js
8885  
8886  
8887  /**
8888   * WordPress dependencies
8889   */
8890  
8891  function CommentsQueryLoopSave(_ref) {
8892    let {
8893      attributes: {
8894        tagName: Tag
8895      }
8896    } = _ref;
8897    return (0,external_wp_element_namespaceObject.createElement)(Tag, external_wp_blockEditor_namespaceObject.useBlockProps.save(), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InnerBlocks.Content, null));
8898  }
8899  
8900  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/comments-query-loop/index.js
8901  /**
8902   * WordPress dependencies
8903   */
8904  
8905  /**
8906   * Internal dependencies
8907   */
8908  
8909  const comments_query_loop_metadata = {
8910    $schema: "https://schemas.wp.org/trunk/block.json",
8911    apiVersion: 2,
8912    name: "core/comments-query-loop",
8913    title: "Comments Query Loop",
8914    category: "theme",
8915    description: "An advanced block that allows displaying post comments using different visual configurations.",
8916    textdomain: "default",
8917    attributes: {
8918      tagName: {
8919        type: "string",
8920        "default": "div"
8921      }
8922    },
8923    supports: {
8924      align: ["wide", "full"],
8925      html: false,
8926      color: {
8927        gradients: true,
8928        link: true,
8929        __experimentalDefaultControls: {
8930          background: true,
8931          text: true,
8932          link: true
8933        }
8934      }
8935    },
8936    editorStyle: "wp-block-comments-editor"
8937  };
8938  
8939  
8940  const {
8941    name: comments_query_loop_name
8942  } = comments_query_loop_metadata;
8943  
8944  const comments_query_loop_settings = {
8945    icon: post_comments,
8946    edit: CommentsQueryLoopEdit,
8947    save: CommentsQueryLoopSave
8948  };
8949  
8950  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/query-pagination.js
8951  
8952  
8953  /**
8954   * WordPress dependencies
8955   */
8956  
8957  const queryPagination = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
8958    xmlns: "http://www.w3.org/2000/svg",
8959    viewBox: "0 0 24 24"
8960  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
8961    d: "M4 13.5h6v-3H4v3zm8 0h3v-3h-3v3zm5-3v3h3v-3h-3z"
8962  }));
8963  /* harmony default export */ var query_pagination = (queryPagination);
8964  
8965  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/comments-pagination/comments-pagination-arrow-controls.js
8966  
8967  
8968  /**
8969   * WordPress dependencies
8970   */
8971  
8972  
8973  function CommentsPaginationArrowControls(_ref) {
8974    let {
8975      value,
8976      onChange
8977    } = _ref;
8978    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalToggleGroupControl, {
8979      label: (0,external_wp_i18n_namespaceObject.__)('Arrow'),
8980      value: value,
8981      onChange: onChange,
8982      help: (0,external_wp_i18n_namespaceObject.__)('A decorative arrow appended to the next and previous comments link.'),
8983      isBlock: true
8984    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalToggleGroupControlOption, {
8985      value: "none",
8986      label: (0,external_wp_i18n_namespaceObject._x)('None', 'Arrow option for Comments Pagination Next/Previous blocks')
8987    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalToggleGroupControlOption, {
8988      value: "arrow",
8989      label: (0,external_wp_i18n_namespaceObject._x)('Arrow', 'Arrow option for Comments Pagination Next/Previous blocks')
8990    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalToggleGroupControlOption, {
8991      value: "chevron",
8992      label: (0,external_wp_i18n_namespaceObject._x)('Chevron', 'Arrow option for Comments Pagination Next/Previous blocks')
8993    }));
8994  }
8995  
8996  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/comments-pagination/edit.js
8997  
8998  
8999  /**
9000   * WordPress dependencies
9001   */
9002  
9003  
9004  
9005  
9006  
9007  /**
9008   * Internal dependencies
9009   */
9010  
9011  
9012  const comments_pagination_edit_TEMPLATE = [['core/comments-pagination-previous'], ['core/comments-pagination-numbers'], ['core/comments-pagination-next']];
9013  
9014  const getDefaultBlockLayout = blockTypeOrName => {
9015    const layoutBlockSupportConfig = (0,external_wp_blocks_namespaceObject.getBlockSupport)(blockTypeOrName, '__experimentalLayout');
9016    return layoutBlockSupportConfig === null || layoutBlockSupportConfig === void 0 ? void 0 : layoutBlockSupportConfig.default;
9017  };
9018  
9019  function QueryPaginationEdit(_ref) {
9020    let {
9021      attributes: {
9022        paginationArrow,
9023        layout
9024      },
9025      setAttributes,
9026      clientId,
9027      name
9028    } = _ref;
9029    const usedLayout = layout || getDefaultBlockLayout(name);
9030    const hasNextPreviousBlocks = (0,external_wp_data_namespaceObject.useSelect)(select => {
9031      const {
9032        getBlocks
9033      } = select(external_wp_blockEditor_namespaceObject.store);
9034      const innerBlocks = getBlocks(clientId);
9035      /**
9036       * Show the `paginationArrow` control only if a
9037       * Comments Pagination Next or Comments Pagination Previous
9038       * block exists.
9039       */
9040  
9041      return innerBlocks === null || innerBlocks === void 0 ? void 0 : innerBlocks.find(innerBlock => {
9042        return ['core/comments-pagination-previous', 'core/comments-pagination-next'].includes(innerBlock.name);
9043      });
9044    }, []);
9045    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)();
9046    const innerBlocksProps = (0,external_wp_blockEditor_namespaceObject.useInnerBlocksProps)(blockProps, {
9047      template: comments_pagination_edit_TEMPLATE,
9048      allowedBlocks: ['core/comments-pagination-previous', 'core/comments-pagination-numbers', 'core/comments-pagination-next'],
9049      __experimentalLayout: usedLayout
9050    }); // Get the Discussion settings
9051  
9052    const pageComments = (0,external_wp_data_namespaceObject.useSelect)(select => {
9053      const {
9054        getSettings
9055      } = select(external_wp_blockEditor_namespaceObject.store);
9056      const {
9057        __experimentalDiscussionSettings
9058      } = getSettings();
9059      return __experimentalDiscussionSettings === null || __experimentalDiscussionSettings === void 0 ? void 0 : __experimentalDiscussionSettings.pageComments;
9060    }, []); // If paging comments is not enabled in the Discussion Settings then hide the pagination
9061    // controls. We don't want to remove them from the template so that when the user enables
9062    // paging comments, the controls will be visible.
9063  
9064    if (!pageComments) {
9065      return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.Warning, null, (0,external_wp_i18n_namespaceObject.__)('Comments Pagination block: paging comments is disabled in the Discussion Settings'));
9066    }
9067  
9068    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, hasNextPreviousBlocks && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
9069      title: (0,external_wp_i18n_namespaceObject.__)('Settings')
9070    }, (0,external_wp_element_namespaceObject.createElement)(CommentsPaginationArrowControls, {
9071      value: paginationArrow,
9072      onChange: value => {
9073        setAttributes({
9074          paginationArrow: value
9075        });
9076      }
9077    }))), (0,external_wp_element_namespaceObject.createElement)("div", innerBlocksProps));
9078  }
9079  
9080  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/comments-pagination/save.js
9081  
9082  
9083  /**
9084   * WordPress dependencies
9085   */
9086  
9087  function comments_pagination_save_save() {
9088    return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InnerBlocks.Content, null);
9089  }
9090  
9091  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/comments-pagination/index.js
9092  /**
9093   * WordPress dependencies
9094   */
9095  
9096  /**
9097   * Internal dependencies
9098   */
9099  
9100  const comments_pagination_metadata = {
9101    $schema: "https://schemas.wp.org/trunk/block.json",
9102    apiVersion: 2,
9103    name: "core/comments-pagination",
9104    title: "Comments Pagination",
9105    category: "theme",
9106    parent: ["core/comments-query-loop"],
9107    description: "Displays a paginated navigation to next/previous set of comments, when applicable.",
9108    textdomain: "default",
9109    attributes: {
9110      paginationArrow: {
9111        type: "string",
9112        "default": "none"
9113      }
9114    },
9115    providesContext: {
9116      "comments/paginationArrow": "paginationArrow"
9117    },
9118    supports: {
9119      align: true,
9120      reusable: false,
9121      html: false,
9122      color: {
9123        gradients: true,
9124        link: true,
9125        __experimentalDefaultControls: {
9126          background: true,
9127          text: true,
9128          link: true
9129        }
9130      },
9131      __experimentalLayout: {
9132        allowSwitching: false,
9133        allowInheriting: false,
9134        "default": {
9135          type: "flex"
9136        }
9137      }
9138    },
9139    editorStyle: "wp-block-comments-pagination-editor",
9140    style: "wp-block-comments-pagination"
9141  };
9142  
9143  
9144  const {
9145    name: comments_pagination_name
9146  } = comments_pagination_metadata;
9147  
9148  const comments_pagination_settings = {
9149    icon: query_pagination,
9150    edit: QueryPaginationEdit,
9151    save: comments_pagination_save_save
9152  };
9153  
9154  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/query-pagination-next.js
9155  
9156  
9157  /**
9158   * WordPress dependencies
9159   */
9160  
9161  const queryPaginationNext = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
9162    xmlns: "http://www.w3.org/2000/svg",
9163    viewBox: "0 0 24 24"
9164  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
9165    d: "M5 13.5h3v-3H5v3zm5 0h3v-3h-3v3zM17 9l-1 1 2 2-2 2 1 1 3-3-3-3z"
9166  }));
9167  /* harmony default export */ var query_pagination_next = (queryPaginationNext);
9168  
9169  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/comments-pagination-next/edit.js
9170  
9171  
9172  
9173  /**
9174   * WordPress dependencies
9175   */
9176  
9177  
9178  const edit_arrowMap = {
9179    none: '',
9180    arrow: '→',
9181    chevron: '»'
9182  };
9183  function CommentsPaginationNextEdit(_ref) {
9184    let {
9185      attributes: {
9186        label
9187      },
9188      setAttributes,
9189      context: {
9190        'comments/paginationArrow': paginationArrow
9191      }
9192    } = _ref;
9193    const displayArrow = edit_arrowMap[paginationArrow];
9194    return (0,external_wp_element_namespaceObject.createElement)("a", _extends({
9195      href: "#comments-pagination-next-pseudo-link",
9196      onClick: event => event.preventDefault()
9197    }, (0,external_wp_blockEditor_namespaceObject.useBlockProps)()), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.PlainText, {
9198      __experimentalVersion: 2,
9199      tagName: "span",
9200      "aria-label": (0,external_wp_i18n_namespaceObject.__)('Newer comments page link'),
9201      placeholder: (0,external_wp_i18n_namespaceObject.__)('Newer Comments'),
9202      value: label,
9203      onChange: newLabel => setAttributes({
9204        label: newLabel
9205      })
9206    }), displayArrow && (0,external_wp_element_namespaceObject.createElement)("span", {
9207      className: `wp-block-comments-pagination-next-arrow is-arrow-$paginationArrow}`
9208    }, displayArrow));
9209  }
9210  
9211  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/comments-pagination-next/index.js
9212  /**
9213   * WordPress dependencies
9214   */
9215  
9216  /**
9217   * Internal dependencies
9218   */
9219  
9220  const comments_pagination_next_metadata = {
9221    $schema: "https://schemas.wp.org/trunk/block.json",
9222    apiVersion: 2,
9223    name: "core/comments-pagination-next",
9224    title: "Next Page",
9225    category: "theme",
9226    parent: ["core/comments-pagination"],
9227    description: "Displays the next comment's page link.",
9228    textdomain: "default",
9229    attributes: {
9230      label: {
9231        type: "string"
9232      }
9233    },
9234    usesContext: ["postId", "comments/paginationArrow"],
9235    supports: {
9236      reusable: false,
9237      html: false,
9238      color: {
9239        gradients: true,
9240        text: false,
9241        __experimentalDefaultControls: {
9242          background: true
9243        }
9244      },
9245      typography: {
9246        fontSize: true,
9247        lineHeight: true,
9248        __experimentalFontStyle: true,
9249        __experimentalFontWeight: true,
9250        __experimentalLetterSpacing: true,
9251        __experimentalTextTransform: true,
9252        __experimentalDefaultControls: {
9253          fontSize: true
9254        }
9255      }
9256    }
9257  };
9258  
9259  const {
9260    name: comments_pagination_next_name
9261  } = comments_pagination_next_metadata;
9262  
9263  const comments_pagination_next_settings = {
9264    icon: query_pagination_next,
9265    edit: CommentsPaginationNextEdit
9266  };
9267  
9268  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/query-pagination-numbers.js
9269  
9270  
9271  /**
9272   * WordPress dependencies
9273   */
9274  
9275  const queryPaginationNumbers = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
9276    xmlns: "http://www.w3.org/2000/svg",
9277    viewBox: "0 0 24 24"
9278  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
9279    d: "M4 13.5h6v-3H4v3zm8.2-2.5.8-.3V14h1V9.3l-2.2.7.4 1zm7.1-1.2c-.5-.6-1.2-.5-1.7-.4-.3.1-.5.2-.7.3l.1 1.1c.2-.2.5-.4.8-.5.3-.1.6 0 .7.1.2.3 0 .8-.2 1.1-.5.8-.9 1.6-1.4 2.5h2.7v-1h-.9c.3-.6.8-1.4.9-2.1 0-.3-.1-.8-.3-1.1z"
9280  }));
9281  /* harmony default export */ var query_pagination_numbers = (queryPaginationNumbers);
9282  
9283  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/comments-pagination-numbers/edit.js
9284  
9285  
9286  /**
9287   * WordPress dependencies
9288   */
9289  
9290  
9291  const PaginationItem = _ref => {
9292    let {
9293      content,
9294      tag: Tag = 'a',
9295      extraClass = ''
9296    } = _ref;
9297    return (0,external_wp_element_namespaceObject.createElement)(Tag, {
9298      className: `page-numbers $extraClass}`
9299    }, content);
9300  };
9301  
9302  function CommentsPaginationNumbersEdit() {
9303    return (0,external_wp_element_namespaceObject.createElement)("div", (0,external_wp_blockEditor_namespaceObject.useBlockProps)(), (0,external_wp_element_namespaceObject.createElement)(PaginationItem, {
9304      content: "1"
9305    }), (0,external_wp_element_namespaceObject.createElement)(PaginationItem, {
9306      content: "2"
9307    }), (0,external_wp_element_namespaceObject.createElement)(PaginationItem, {
9308      content: "3",
9309      tag: "span",
9310      extraClass: "current"
9311    }), (0,external_wp_element_namespaceObject.createElement)(PaginationItem, {
9312      content: "4"
9313    }), (0,external_wp_element_namespaceObject.createElement)(PaginationItem, {
9314      content: "5"
9315    }), (0,external_wp_element_namespaceObject.createElement)(PaginationItem, {
9316      content: "...",
9317      tag: "span",
9318      extraClass: "dots"
9319    }), (0,external_wp_element_namespaceObject.createElement)(PaginationItem, {
9320      content: "8"
9321    }));
9322  }
9323  
9324  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/comments-pagination-numbers/index.js
9325  /**
9326   * WordPress dependencies
9327   */
9328  
9329  /**
9330   * Internal dependencies
9331   */
9332  
9333  const comments_pagination_numbers_metadata = {
9334    $schema: "https://schemas.wp.org/trunk/block.json",
9335    apiVersion: 2,
9336    name: "core/comments-pagination-numbers",
9337    title: "Page Numbers",
9338    category: "theme",
9339    parent: ["core/comments-pagination"],
9340    description: "Displays a list of page numbers for comments pagination.",
9341    textdomain: "default",
9342    usesContext: ["postId"],
9343    supports: {
9344      reusable: false,
9345      html: false
9346    }
9347  };
9348  
9349  const {
9350    name: comments_pagination_numbers_name
9351  } = comments_pagination_numbers_metadata;
9352  
9353  const comments_pagination_numbers_settings = {
9354    icon: query_pagination_numbers,
9355    edit: CommentsPaginationNumbersEdit
9356  };
9357  
9358  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/comment-title.js
9359  
9360  
9361  /**
9362   * WordPress dependencies
9363   */
9364  
9365  const commentTitle = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
9366    xmlns: "http://www.w3.org/2000/svg",
9367    viewBox: "0 0 24 24"
9368  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
9369    d: "M6 11.9c.6.3 1.3.5 2.1.5.4 0 .8 0 1.2-.1.4-.1.7-.2 1-.3l-.1-1.3c-.3.1-.6.3-.9.3-.3.1-.7.1-1.1.1-.6 0-1.1-.1-1.5-.4-.4-.3-.7-.6-.9-1-.2-.5-.3-1-.3-1.5 0-.6.1-1.1.3-1.5.2-.4.5-.8.9-1 .4-.3.9-.4 1.5-.4.4 0 .7 0 1.1.1l.9.3.1-1.3c-.3-.1-.6-.2-1-.3C9 4 8.6 4 8.2 4c-.9 0-1.6.2-2.2.5-.6.4-1.1.8-1.5 1.5-.3.6-.5 1.3-.5 2.2s.2 1.6.5 2.2c.4.6.9 1.1 1.5 1.5zm-2 2.6V16h16v-1.5H4zM4 20h9v-1.5H4V20z"
9370  }));
9371  /* harmony default export */ var comment_title = (commentTitle);
9372  
9373  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/heading/heading-level-icon.js
9374  
9375  
9376  /**
9377   * WordPress dependencies
9378   */
9379  
9380  /** @typedef {import('@wordpress/element').WPComponent} WPComponent */
9381  
9382  /**
9383   * HeadingLevelIcon props.
9384   *
9385   * @typedef WPHeadingLevelIconProps
9386   *
9387   * @property {number}   level     The heading level to show an icon for.
9388   * @property {?boolean} isPressed Whether or not the icon should appear pressed; default: false.
9389   */
9390  
9391  /**
9392   * Heading level icon.
9393   *
9394   * @param {WPHeadingLevelIconProps} props Component props.
9395   *
9396   * @return {?WPComponent} The icon.
9397   */
9398  
9399  function HeadingLevelIcon(_ref) {
9400    let {
9401      level,
9402      isPressed = false
9403    } = _ref;
9404    const levelToPath = {
9405      1: 'M9 5h2v10H9v-4H5v4H3V5h2v4h4V5zm6.6 0c-.6.9-1.5 1.7-2.6 2v1h2v7h2V5h-1.4z',
9406      2: 'M7 5h2v10H7v-4H3v4H1V5h2v4h4V5zm8 8c.5-.4.6-.6 1.1-1.1.4-.4.8-.8 1.2-1.3.3-.4.6-.8.9-1.3.2-.4.3-.8.3-1.3 0-.4-.1-.9-.3-1.3-.2-.4-.4-.7-.8-1-.3-.3-.7-.5-1.2-.6-.5-.2-1-.2-1.5-.2-.4 0-.7 0-1.1.1-.3.1-.7.2-1 .3-.3.1-.6.3-.9.5-.3.2-.6.4-.8.7l1.2 1.2c.3-.3.6-.5 1-.7.4-.2.7-.3 1.2-.3s.9.1 1.3.4c.3.3.5.7.5 1.1 0 .4-.1.8-.4 1.1-.3.5-.6.9-1 1.2-.4.4-1 .9-1.6 1.4-.6.5-1.4 1.1-2.2 1.6V15h8v-2H15z',
9407      3: 'M12.1 12.2c.4.3.8.5 1.2.7.4.2.9.3 1.4.3.5 0 1-.1 1.4-.3.3-.1.5-.5.5-.8 0-.2 0-.4-.1-.6-.1-.2-.3-.3-.5-.4-.3-.1-.7-.2-1-.3-.5-.1-1-.1-1.5-.1V9.1c.7.1 1.5-.1 2.2-.4.4-.2.6-.5.6-.9 0-.3-.1-.6-.4-.8-.3-.2-.7-.3-1.1-.3-.4 0-.8.1-1.1.3-.4.2-.7.4-1.1.6l-1.2-1.4c.5-.4 1.1-.7 1.6-.9.5-.2 1.2-.3 1.8-.3.5 0 1 .1 1.6.2.4.1.8.3 1.2.5.3.2.6.5.8.8.2.3.3.7.3 1.1 0 .5-.2.9-.5 1.3-.4.4-.9.7-1.5.9v.1c.6.1 1.2.4 1.6.8.4.4.7.9.7 1.5 0 .4-.1.8-.3 1.2-.2.4-.5.7-.9.9-.4.3-.9.4-1.3.5-.5.1-1 .2-1.6.2-.8 0-1.6-.1-2.3-.4-.6-.2-1.1-.6-1.6-1l1.1-1.4zM7 9H3V5H1v10h2v-4h4v4h2V5H7v4z',
9408      4: 'M9 15H7v-4H3v4H1V5h2v4h4V5h2v10zm10-2h-1v2h-2v-2h-5v-2l4-6h3v6h1v2zm-3-2V7l-2.8 4H16z',
9409      5: 'M12.1 12.2c.4.3.7.5 1.1.7.4.2.9.3 1.3.3.5 0 1-.1 1.4-.4.4-.3.6-.7.6-1.1 0-.4-.2-.9-.6-1.1-.4-.3-.9-.4-1.4-.4H14c-.1 0-.3 0-.4.1l-.4.1-.5.2-1-.6.3-5h6.4v1.9h-4.3L14 8.8c.2-.1.5-.1.7-.2.2 0 .5-.1.7-.1.5 0 .9.1 1.4.2.4.1.8.3 1.1.6.3.2.6.6.8.9.2.4.3.9.3 1.4 0 .5-.1 1-.3 1.4-.2.4-.5.8-.9 1.1-.4.3-.8.5-1.3.7-.5.2-1 .3-1.5.3-.8 0-1.6-.1-2.3-.4-.6-.2-1.1-.6-1.6-1-.1-.1 1-1.5 1-1.5zM9 15H7v-4H3v4H1V5h2v4h4V5h2v10z',
9410      6: 'M9 15H7v-4H3v4H1V5h2v4h4V5h2v10zm8.6-7.5c-.2-.2-.5-.4-.8-.5-.6-.2-1.3-.2-1.9 0-.3.1-.6.3-.8.5l-.6.9c-.2.5-.2.9-.2 1.4.4-.3.8-.6 1.2-.8.4-.2.8-.3 1.3-.3.4 0 .8 0 1.2.2.4.1.7.3 1 .6.3.3.5.6.7.9.2.4.3.8.3 1.3s-.1.9-.3 1.4c-.2.4-.5.7-.8 1-.4.3-.8.5-1.2.6-1 .3-2 .3-3 0-.5-.2-1-.5-1.4-.9-.4-.4-.8-.9-1-1.5-.2-.6-.3-1.3-.3-2.1s.1-1.6.4-2.3c.2-.6.6-1.2 1-1.6.4-.4.9-.7 1.4-.9.6-.3 1.1-.4 1.7-.4.7 0 1.4.1 2 .3.5.2 1 .5 1.4.8 0 .1-1.3 1.4-1.3 1.4zm-2.4 5.8c.2 0 .4 0 .6-.1.2 0 .4-.1.5-.2.1-.1.3-.3.4-.5.1-.2.1-.5.1-.7 0-.4-.1-.8-.4-1.1-.3-.2-.7-.3-1.1-.3-.3 0-.7.1-1 .2-.4.2-.7.4-1 .7 0 .3.1.7.3 1 .1.2.3.4.4.6.2.1.3.3.5.3.2.1.5.2.7.1z'
9411    };
9412  
9413    if (!levelToPath.hasOwnProperty(level)) {
9414      return null;
9415    }
9416  
9417    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, {
9418      width: "24",
9419      height: "24",
9420      viewBox: "0 0 20 20",
9421      xmlns: "http://www.w3.org/2000/svg",
9422      isPressed: isPressed
9423    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
9424      d: levelToPath[level]
9425    }));
9426  }
9427  
9428  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/heading/heading-level-dropdown.js
9429  
9430  
9431  /**
9432   * WordPress dependencies
9433   */
9434  
9435  
9436  /**
9437   * Internal dependencies
9438   */
9439  
9440  
9441  const HEADING_LEVELS = [1, 2, 3, 4, 5, 6];
9442  const POPOVER_PROPS = {
9443    className: 'block-library-heading-level-dropdown'
9444  };
9445  /** @typedef {import('@wordpress/element').WPComponent} WPComponent */
9446  
9447  /**
9448   * HeadingLevelDropdown props.
9449   *
9450   * @typedef WPHeadingLevelDropdownProps
9451   *
9452   * @property {number}                 selectedLevel The chosen heading level.
9453   * @property {(newValue:number)=>any} onChange      Callback to run when
9454   *                                                  toolbar value is changed.
9455   */
9456  
9457  /**
9458   * Dropdown for selecting a heading level (1 through 6).
9459   *
9460   * @param {WPHeadingLevelDropdownProps} props Component props.
9461   *
9462   * @return {WPComponent} The toolbar.
9463   */
9464  
9465  function HeadingLevelDropdown(_ref) {
9466    let {
9467      selectedLevel,
9468      onChange
9469    } = _ref;
9470    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarDropdownMenu, {
9471      popoverProps: POPOVER_PROPS,
9472      icon: (0,external_wp_element_namespaceObject.createElement)(HeadingLevelIcon, {
9473        level: selectedLevel
9474      }),
9475      label: (0,external_wp_i18n_namespaceObject.__)('Change heading level'),
9476      controls: HEADING_LEVELS.map(targetLevel => {
9477        {
9478          const isActive = targetLevel === selectedLevel;
9479          return {
9480            icon: (0,external_wp_element_namespaceObject.createElement)(HeadingLevelIcon, {
9481              level: targetLevel,
9482              isPressed: isActive
9483            }),
9484            label: (0,external_wp_i18n_namespaceObject.sprintf)( // translators: %s: heading level e.g: "1", "2", "3"
9485            (0,external_wp_i18n_namespaceObject.__)('Heading %d'), targetLevel),
9486            isActive,
9487  
9488            onClick() {
9489              onChange(targetLevel);
9490            }
9491  
9492          };
9493        }
9494      })
9495    });
9496  }
9497  
9498  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/comments-title/edit.js
9499  
9500  
9501  /**
9502   * External dependencies
9503   */
9504  
9505  /**
9506   * WordPress dependencies
9507   */
9508  
9509  
9510  
9511  
9512  
9513  
9514  
9515  
9516  /**
9517   * Internal dependencies
9518   */
9519  
9520  
9521  function comments_title_edit_Edit(_ref) {
9522    let {
9523      attributes: {
9524        textAlign,
9525        singleCommentLabel,
9526        multipleCommentsLabel,
9527        showPostTitle,
9528        showCommentsCount,
9529        level
9530      },
9531      setAttributes,
9532      context: {
9533        postType,
9534        postId
9535      }
9536    } = _ref;
9537    const TagName = 'h' + level;
9538    const [commentsCount, setCommentsCount] = (0,external_wp_element_namespaceObject.useState)();
9539    const [editingMode, setEditingMode] = (0,external_wp_element_namespaceObject.useState)('plural');
9540    const [rawTitle] = (0,external_wp_coreData_namespaceObject.useEntityProp)('postType', postType, 'title', postId);
9541    const isSiteEditor = typeof postId === 'undefined';
9542    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
9543      className: classnames_default()({
9544        [`has-text-align-$textAlign}`]: textAlign
9545      })
9546    });
9547    (0,external_wp_element_namespaceObject.useEffect)(() => {
9548      if (isSiteEditor) {
9549        setCommentsCount(3);
9550        return;
9551      }
9552  
9553      const currentPostId = postId;
9554      external_wp_apiFetch_default()({
9555        path: (0,external_wp_url_namespaceObject.addQueryArgs)('/wp/v2/comments', {
9556          post: postId,
9557          _fields: 'id'
9558        }),
9559        method: 'HEAD',
9560        parse: false
9561      }).then(res => {
9562        // Stale requests will have the `currentPostId` of an older closure.
9563        if (currentPostId === postId) {
9564          setCommentsCount(parseInt(res.headers.get('X-WP-Total')));
9565        }
9566      }).catch(() => {
9567        setCommentsCount(0);
9568      });
9569    }, [postId]);
9570    const blockControls = (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, {
9571      group: "block"
9572    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.AlignmentControl, {
9573      value: textAlign,
9574      onChange: newAlign => setAttributes({
9575        textAlign: newAlign
9576      })
9577    }), (0,external_wp_element_namespaceObject.createElement)(HeadingLevelDropdown, {
9578      selectedLevel: level,
9579      onChange: newLevel => setAttributes({
9580        level: newLevel
9581      })
9582    }));
9583    const inspectorControls = (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
9584      title: (0,external_wp_i18n_namespaceObject.__)('Settings')
9585    }, isSiteEditor && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalToggleGroupControl, {
9586      label: (0,external_wp_i18n_namespaceObject.__)('Editing mode'),
9587      onChange: setEditingMode,
9588      value: editingMode
9589    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalToggleGroupControlOption, {
9590      label: (0,external_wp_i18n_namespaceObject.__)('Singular'),
9591      value: "singular"
9592    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalToggleGroupControlOption, {
9593      label: (0,external_wp_i18n_namespaceObject.__)('Plural'),
9594      value: "plural"
9595    })), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
9596      label: (0,external_wp_i18n_namespaceObject.__)('Show post title'),
9597      checked: showPostTitle,
9598      onChange: value => setAttributes({
9599        showPostTitle: value
9600      })
9601    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
9602      label: (0,external_wp_i18n_namespaceObject.__)('Show comments count'),
9603      checked: showCommentsCount,
9604      onChange: value => setAttributes({
9605        showCommentsCount: value
9606      })
9607    })));
9608    const postTitle = isSiteEditor ? (0,external_wp_i18n_namespaceObject.__)('"Post Title"') : `"$rawTitle}"`;
9609    const singlePlaceholder = showPostTitle ? (0,external_wp_i18n_namespaceObject.__)('One response to ') : (0,external_wp_i18n_namespaceObject.__)('One response');
9610    const singlePlaceholderNoCount = showPostTitle ? (0,external_wp_i18n_namespaceObject.__)('Response to ') : (0,external_wp_i18n_namespaceObject.__)('Response');
9611    const multiplePlaceholder = showPostTitle ? (0,external_wp_i18n_namespaceObject.__)('responses to ') : (0,external_wp_i18n_namespaceObject.__)('responses');
9612    const multiplePlaceholderNoCount = showPostTitle ? (0,external_wp_i18n_namespaceObject.__)('Responses to ') : (0,external_wp_i18n_namespaceObject.__)('Responses');
9613    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, blockControls, inspectorControls, (0,external_wp_element_namespaceObject.createElement)(TagName, blockProps, editingMode === 'singular' || commentsCount === 1 ? (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.PlainText, {
9614      __experimentalVersion: 2,
9615      tagName: "span",
9616      "aria-label": showCommentsCount ? singlePlaceholder : singlePlaceholderNoCount,
9617      placeholder: showCommentsCount ? singlePlaceholder : singlePlaceholderNoCount,
9618      value: singleCommentLabel,
9619      onChange: newLabel => setAttributes({
9620        singleCommentLabel: newLabel
9621      })
9622    }), showPostTitle ? postTitle : null) : (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, showCommentsCount ? commentsCount : null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.PlainText, {
9623      __experimentalVersion: 2,
9624      tagName: "span",
9625      "aria-label": showCommentsCount ? ` $multiplePlaceholder}` : multiplePlaceholderNoCount,
9626      placeholder: showCommentsCount ? ` $multiplePlaceholder}` : multiplePlaceholderNoCount,
9627      value: multipleCommentsLabel,
9628      onChange: newLabel => setAttributes({
9629        multipleCommentsLabel: newLabel
9630      })
9631    }), showPostTitle ? postTitle : null)));
9632  }
9633  
9634  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/comments-title/index.js
9635  /**
9636   * WordPress dependencies
9637   */
9638  
9639  /**
9640   * Internal dependencies
9641   */
9642  
9643  const comments_title_metadata = {
9644    $schema: "https://schemas.wp.org/trunk/block.json",
9645    apiVersion: 2,
9646    name: "core/comments-title",
9647    title: "Comments Title",
9648    category: "theme",
9649    ancestor: ["core/comments-query-loop"],
9650    description: "Displays a title with the number of comments",
9651    textdomain: "default",
9652    usesContext: ["postId", "postType"],
9653    attributes: {
9654      textAlign: {
9655        type: "string"
9656      },
9657      singleCommentLabel: {
9658        type: "string"
9659      },
9660      multipleCommentsLabel: {
9661        type: "string"
9662      },
9663      showPostTitle: {
9664        type: "boolean",
9665        "default": true
9666      },
9667      showCommentsCount: {
9668        type: "boolean",
9669        "default": true
9670      },
9671      level: {
9672        type: "number",
9673        "default": 2
9674      }
9675    },
9676    supports: {
9677      anchor: false,
9678      align: true,
9679      html: false,
9680      __experimentalBorder: {
9681        radius: true,
9682        color: true,
9683        width: true,
9684        style: true
9685      },
9686      color: {
9687        gradients: true,
9688        __experimentalDefaultControls: {
9689          background: true,
9690          text: true
9691        }
9692      },
9693      spacing: {
9694        margin: true,
9695        padding: true
9696      },
9697      typography: {
9698        fontSize: true,
9699        lineHeight: true,
9700        __experimentalFontStyle: true,
9701        __experimentalFontWeight: true,
9702        __experimentalFontFamily: true,
9703        __experimentalTextTransform: true,
9704        __experimentalDefaultControls: {
9705          fontSize: true,
9706          __experimentalFontFamily: true,
9707          __experimentalFontStyle: true,
9708          __experimentalFontWeight: true
9709        }
9710      }
9711    }
9712  };
9713  
9714  const {
9715    name: comments_title_name
9716  } = comments_title_metadata;
9717  
9718  const comments_title_settings = {
9719    icon: comment_title,
9720    edit: comments_title_edit_Edit
9721  };
9722  
9723  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/cover.js
9724  
9725  
9726  /**
9727   * WordPress dependencies
9728   */
9729  
9730  const cover = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
9731    xmlns: "http://www.w3.org/2000/svg",
9732    viewBox: "0 0 24 24"
9733  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
9734    d: "M18.7 3H5.3C4 3 3 4 3 5.3v13.4C3 20 4 21 5.3 21h13.4c1.3 0 2.3-1 2.3-2.3V5.3C21 4 20 3 18.7 3zm.8 15.7c0 .4-.4.8-.8.8H5.3c-.4 0-.8-.4-.8-.8V5.3c0-.4.4-.8.8-.8h6.2v8.9l2.5-3.1 2.5 3.1V4.5h2.2c.4 0 .8.4.8.8v13.4z"
9735  }));
9736  /* harmony default export */ var library_cover = (cover);
9737  
9738  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/cover/shared.js
9739  /**
9740   * WordPress dependencies
9741   */
9742  
9743  const POSITION_CLASSNAMES = {
9744    'top left': 'is-position-top-left',
9745    'top center': 'is-position-top-center',
9746    'top right': 'is-position-top-right',
9747    'center left': 'is-position-center-left',
9748    'center center': 'is-position-center-center',
9749    center: 'is-position-center-center',
9750    'center right': 'is-position-center-right',
9751    'bottom left': 'is-position-bottom-left',
9752    'bottom center': 'is-position-bottom-center',
9753    'bottom right': 'is-position-bottom-right'
9754  };
9755  const IMAGE_BACKGROUND_TYPE = 'image';
9756  const VIDEO_BACKGROUND_TYPE = 'video';
9757  const COVER_MIN_HEIGHT = 50;
9758  const COVER_MAX_HEIGHT = 1000;
9759  const COVER_DEFAULT_HEIGHT = 300;
9760  function backgroundImageStyles(url) {
9761    return url ? {
9762      backgroundImage: `url($url})`
9763    } : {};
9764  }
9765  const shared_ALLOWED_MEDIA_TYPES = ['image', 'video'];
9766  function dimRatioToClass(ratio) {
9767    return ratio === 50 || !ratio === undefined ? null : 'has-background-dim-' + 10 * Math.round(ratio / 10);
9768  }
9769  function attributesFromMedia(setAttributes, dimRatio) {
9770    return media => {
9771      if (!media || !media.url) {
9772        setAttributes({
9773          url: undefined,
9774          id: undefined
9775        });
9776        return;
9777      }
9778  
9779      if ((0,external_wp_blob_namespaceObject.isBlobURL)(media.url)) {
9780        media.type = (0,external_wp_blob_namespaceObject.getBlobTypeByURL)(media.url);
9781      }
9782  
9783      let mediaType; // For media selections originated from a file upload.
9784  
9785      if (media.media_type) {
9786        if (media.media_type === IMAGE_BACKGROUND_TYPE) {
9787          mediaType = IMAGE_BACKGROUND_TYPE;
9788        } else {
9789          // only images and videos are accepted so if the media_type is not an image we can assume it is a video.
9790          // Videos contain the media type of 'file' in the object returned from the rest api.
9791          mediaType = VIDEO_BACKGROUND_TYPE;
9792        }
9793      } else {
9794        // For media selections originated from existing files in the media library.
9795        if (media.type !== IMAGE_BACKGROUND_TYPE && media.type !== VIDEO_BACKGROUND_TYPE) {
9796          return;
9797        }
9798  
9799        mediaType = media.type;
9800      }
9801  
9802      setAttributes({
9803        dimRatio: dimRatio === 100 ? 50 : dimRatio,
9804        url: media.url,
9805        id: media.id,
9806        alt: media === null || media === void 0 ? void 0 : media.alt,
9807        backgroundType: mediaType,
9808        ...(mediaType === VIDEO_BACKGROUND_TYPE ? {
9809          focalPoint: undefined,
9810          hasParallax: undefined
9811        } : {})
9812      });
9813    };
9814  }
9815  /**
9816   * Checks of the contentPosition is the center (default) position.
9817   *
9818   * @param {string} contentPosition The current content position.
9819   * @return {boolean} Whether the contentPosition is center.
9820   */
9821  
9822  function isContentPositionCenter(contentPosition) {
9823    return !contentPosition || contentPosition === 'center center' || contentPosition === 'center';
9824  }
9825  /**
9826   * Retrieves the className for the current contentPosition.
9827   * The default position (center) will not have a className.
9828   *
9829   * @param {string} contentPosition The current content position.
9830   * @return {string} The className assigned to the contentPosition.
9831   */
9832  
9833  function getPositionClassName(contentPosition) {
9834    /*
9835     * Only render a className if the contentPosition is not center (the default).
9836     */
9837    if (isContentPositionCenter(contentPosition)) return '';
9838    return POSITION_CLASSNAMES[contentPosition];
9839  }
9840  
9841  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/cover/deprecated.js
9842  
9843  
9844  /**
9845   * External dependencies
9846   */
9847  
9848  
9849  /**
9850   * WordPress dependencies
9851   */
9852  
9853  
9854  
9855  
9856  /**
9857   * Internal dependencies
9858   */
9859  
9860  
9861  /**
9862   * Original function to determine the background opacity classname
9863   *
9864   * Used in deprecations: v1-7.
9865   *
9866   * @param {number} ratio ratio to use for opacity.
9867   * @return {string}       background opacity class   .
9868   */
9869  
9870  function dimRatioToClassV1(ratio) {
9871    return ratio === 0 || ratio === 50 || !ratio ? null : 'has-background-dim-' + 10 * Math.round(ratio / 10);
9872  }
9873  
9874  function migrateDimRatio(attributes) {
9875    return { ...attributes,
9876      dimRatio: !attributes.url ? 100 : attributes.dimRatio
9877    };
9878  }
9879  
9880  const deprecated_blockAttributes = {
9881    url: {
9882      type: 'string'
9883    },
9884    id: {
9885      type: 'number'
9886    },
9887    hasParallax: {
9888      type: 'boolean',
9889      default: false
9890    },
9891    dimRatio: {
9892      type: 'number',
9893      default: 50
9894    },
9895    overlayColor: {
9896      type: 'string'
9897    },
9898    customOverlayColor: {
9899      type: 'string'
9900    },
9901    backgroundType: {
9902      type: 'string',
9903      default: 'image'
9904    },
9905    focalPoint: {
9906      type: 'object'
9907    }
9908  }; // Deprecation for blocks with `minHeightUnit` set but no `minHeight`.
9909  
9910  const v9 = {
9911    attributes: {
9912      url: {
9913        type: 'string'
9914      },
9915      id: {
9916        type: 'number'
9917      },
9918      alt: {
9919        type: 'string',
9920        source: 'attribute',
9921        selector: 'img',
9922        attribute: 'alt',
9923        default: ''
9924      },
9925      hasParallax: {
9926        type: 'boolean',
9927        default: false
9928      },
9929      isRepeated: {
9930        type: 'boolean',
9931        default: false
9932      },
9933      dimRatio: {
9934        type: 'number',
9935        default: 100
9936      },
9937      overlayColor: {
9938        type: 'string'
9939      },
9940      customOverlayColor: {
9941        type: 'string'
9942      },
9943      backgroundType: {
9944        type: 'string',
9945        default: 'image'
9946      },
9947      focalPoint: {
9948        type: 'object'
9949      },
9950      minHeight: {
9951        type: 'number'
9952      },
9953      minHeightUnit: {
9954        type: 'string'
9955      },
9956      gradient: {
9957        type: 'string'
9958      },
9959      customGradient: {
9960        type: 'string'
9961      },
9962      contentPosition: {
9963        type: 'string'
9964      },
9965      isDark: {
9966        type: 'boolean',
9967        default: true
9968      },
9969      allowedBlocks: {
9970        type: 'array'
9971      },
9972      templateLock: {
9973        type: ['string', 'boolean'],
9974        enum: ['all', 'insert', false]
9975      }
9976    },
9977    supports: {
9978      anchor: true,
9979      align: true,
9980      html: false,
9981      spacing: {
9982        padding: true,
9983        __experimentalDefaultControls: {
9984          padding: true
9985        }
9986      },
9987      color: {
9988        __experimentalDuotone: '> .wp-block-cover__image-background, > .wp-block-cover__video-background',
9989        text: false,
9990        background: false
9991      }
9992    },
9993  
9994    save(_ref) {
9995      let {
9996        attributes
9997      } = _ref;
9998      const {
9999        backgroundType,
10000        gradient,
10001        contentPosition,
10002        customGradient,
10003        customOverlayColor,
10004        dimRatio,
10005        focalPoint,
10006        hasParallax,
10007        isDark,
10008        isRepeated,
10009        overlayColor,
10010        url,
10011        alt,
10012        id,
10013        minHeight: minHeightProp,
10014        minHeightUnit
10015      } = attributes;
10016      const overlayColorClass = (0,external_wp_blockEditor_namespaceObject.getColorClassName)('background-color', overlayColor);
10017  
10018      const gradientClass = (0,external_wp_blockEditor_namespaceObject.__experimentalGetGradientClass)(gradient);
10019  
10020      const minHeight = minHeightUnit ? `$minHeightProp}$minHeightUnit}` : minHeightProp;
10021      const isImageBackground = IMAGE_BACKGROUND_TYPE === backgroundType;
10022      const isVideoBackground = VIDEO_BACKGROUND_TYPE === backgroundType;
10023      const isImgElement = !(hasParallax || isRepeated);
10024      const style = { ...(isImageBackground && !isImgElement ? backgroundImageStyles(url) : {}),
10025        minHeight: minHeight || undefined
10026      };
10027      const bgStyle = {
10028        backgroundColor: !overlayColorClass ? customOverlayColor : undefined,
10029        background: customGradient ? customGradient : undefined
10030      };
10031      const objectPosition = // prettier-ignore
10032      focalPoint && isImgElement ? `$Math.round(focalPoint.x * 100)}% $Math.round(focalPoint.y * 100)}%` : undefined;
10033      const classes = classnames_default()({
10034        'is-light': !isDark,
10035        'has-parallax': hasParallax,
10036        'is-repeated': isRepeated,
10037        'has-custom-content-position': !isContentPositionCenter(contentPosition)
10038      }, getPositionClassName(contentPosition));
10039      const gradientValue = gradient || customGradient;
10040      return (0,external_wp_element_namespaceObject.createElement)("div", external_wp_blockEditor_namespaceObject.useBlockProps.save({
10041        className: classes,
10042        style
10043      }), (0,external_wp_element_namespaceObject.createElement)("span", {
10044        "aria-hidden": "true",
10045        className: classnames_default()('wp-block-cover__background', overlayColorClass, dimRatioToClass(dimRatio), {
10046          'has-background-dim': dimRatio !== undefined,
10047          // For backwards compatibility. Former versions of the Cover Block applied
10048          // `.wp-block-cover__gradient-background` in the presence of
10049          // media, a gradient and a dim.
10050          'wp-block-cover__gradient-background': url && gradientValue && dimRatio !== 0,
10051          'has-background-gradient': gradientValue,
10052          [gradientClass]: gradientClass
10053        }),
10054        style: bgStyle
10055      }), isImageBackground && isImgElement && url && (0,external_wp_element_namespaceObject.createElement)("img", {
10056        className: classnames_default()('wp-block-cover__image-background', id ? `wp-image-$id}` : null),
10057        alt: alt,
10058        src: url,
10059        style: {
10060          objectPosition
10061        },
10062        "data-object-fit": "cover",
10063        "data-object-position": objectPosition
10064      }), isVideoBackground && url && (0,external_wp_element_namespaceObject.createElement)("video", {
10065        className: classnames_default()('wp-block-cover__video-background', 'intrinsic-ignore'),
10066        autoPlay: true,
10067        muted: true,
10068        loop: true,
10069        playsInline: true,
10070        src: url,
10071        style: {
10072          objectPosition
10073        },
10074        "data-object-fit": "cover",
10075        "data-object-position": objectPosition
10076      }), (0,external_wp_element_namespaceObject.createElement)("div", external_wp_blockEditor_namespaceObject.useInnerBlocksProps.save({
10077        className: 'wp-block-cover__inner-container'
10078      })));
10079    }
10080  
10081  }; // v8: deprecated to remove duplicated gradient classes and swap `wp-block-cover__gradient-background` for `wp-block-cover__background`.
10082  
10083  const v8 = {
10084    attributes: {
10085      url: {
10086        type: 'string'
10087      },
10088      id: {
10089        type: 'number'
10090      },
10091      alt: {
10092        type: 'string',
10093        source: 'attribute',
10094        selector: 'img',
10095        attribute: 'alt',
10096        default: ''
10097      },
10098      hasParallax: {
10099        type: 'boolean',
10100        default: false
10101      },
10102      isRepeated: {
10103        type: 'boolean',
10104        default: false
10105      },
10106      dimRatio: {
10107        type: 'number',
10108        default: 100
10109      },
10110      overlayColor: {
10111        type: 'string'
10112      },
10113      customOverlayColor: {
10114        type: 'string'
10115      },
10116      backgroundType: {
10117        type: 'string',
10118        default: 'image'
10119      },
10120      focalPoint: {
10121        type: 'object'
10122      },
10123      minHeight: {
10124        type: 'number'
10125      },
10126      minHeightUnit: {
10127        type: 'string'
10128      },
10129      gradient: {
10130        type: 'string'
10131      },
10132      customGradient: {
10133        type: 'string'
10134      },
10135      contentPosition: {
10136        type: 'string'
10137      },
10138      isDark: {
10139        type: 'boolean',
10140        default: true
10141      },
10142      allowedBlocks: {
10143        type: 'array'
10144      },
10145      templateLock: {
10146        type: ['string', 'boolean'],
10147        enum: ['all', 'insert', false]
10148      }
10149    },
10150    supports: {
10151      anchor: true,
10152      align: true,
10153      html: false,
10154      spacing: {
10155        padding: true,
10156        __experimentalDefaultControls: {
10157          padding: true
10158        }
10159      },
10160      color: {
10161        __experimentalDuotone: '> .wp-block-cover__image-background, > .wp-block-cover__video-background',
10162        text: false,
10163        background: false
10164      }
10165    },
10166  
10167    save(_ref2) {
10168      let {
10169        attributes
10170      } = _ref2;
10171      const {
10172        backgroundType,
10173        gradient,
10174        contentPosition,
10175        customGradient,
10176        customOverlayColor,
10177        dimRatio,
10178        focalPoint,
10179        hasParallax,
10180        isDark,
10181        isRepeated,
10182        overlayColor,
10183        url,
10184        alt,
10185        id,
10186        minHeight: minHeightProp,
10187        minHeightUnit
10188      } = attributes;
10189      const overlayColorClass = (0,external_wp_blockEditor_namespaceObject.getColorClassName)('background-color', overlayColor);
10190  
10191      const gradientClass = (0,external_wp_blockEditor_namespaceObject.__experimentalGetGradientClass)(gradient);
10192  
10193      const minHeight = minHeightUnit ? `$minHeightProp}$minHeightUnit}` : minHeightProp;
10194      const isImageBackground = IMAGE_BACKGROUND_TYPE === backgroundType;
10195      const isVideoBackground = VIDEO_BACKGROUND_TYPE === backgroundType;
10196      const isImgElement = !(hasParallax || isRepeated);
10197      const style = { ...(isImageBackground && !isImgElement ? backgroundImageStyles(url) : {}),
10198        minHeight: minHeight || undefined
10199      };
10200      const bgStyle = {
10201        backgroundColor: !overlayColorClass ? customOverlayColor : undefined,
10202        background: customGradient ? customGradient : undefined
10203      };
10204      const objectPosition = // prettier-ignore
10205      focalPoint && isImgElement ? `$Math.round(focalPoint.x * 100)}% $Math.round(focalPoint.y * 100)}%` : undefined;
10206      const classes = classnames_default()({
10207        'is-light': !isDark,
10208        'has-parallax': hasParallax,
10209        'is-repeated': isRepeated,
10210        'has-custom-content-position': !isContentPositionCenter(contentPosition)
10211      }, getPositionClassName(contentPosition));
10212      return (0,external_wp_element_namespaceObject.createElement)("div", external_wp_blockEditor_namespaceObject.useBlockProps.save({
10213        className: classes,
10214        style
10215      }), (0,external_wp_element_namespaceObject.createElement)("span", {
10216        "aria-hidden": "true",
10217        className: classnames_default()(overlayColorClass, dimRatioToClass(dimRatio), 'wp-block-cover__gradient-background', gradientClass, {
10218          'has-background-dim': dimRatio !== undefined,
10219          'has-background-gradient': gradient || customGradient,
10220          [gradientClass]: !url && gradientClass
10221        }),
10222        style: bgStyle
10223      }), isImageBackground && isImgElement && url && (0,external_wp_element_namespaceObject.createElement)("img", {
10224        className: classnames_default()('wp-block-cover__image-background', id ? `wp-image-$id}` : null),
10225        alt: alt,
10226        src: url,
10227        style: {
10228          objectPosition
10229        },
10230        "data-object-fit": "cover",
10231        "data-object-position": objectPosition
10232      }), isVideoBackground && url && (0,external_wp_element_namespaceObject.createElement)("video", {
10233        className: classnames_default()('wp-block-cover__video-background', 'intrinsic-ignore'),
10234        autoPlay: true,
10235        muted: true,
10236        loop: true,
10237        playsInline: true,
10238        src: url,
10239        style: {
10240          objectPosition
10241        },
10242        "data-object-fit": "cover",
10243        "data-object-position": objectPosition
10244      }), (0,external_wp_element_namespaceObject.createElement)("div", external_wp_blockEditor_namespaceObject.useInnerBlocksProps.save({
10245        className: 'wp-block-cover__inner-container'
10246      })));
10247    }
10248  
10249  };
10250  const v7 = {
10251    attributes: { ...deprecated_blockAttributes,
10252      isRepeated: {
10253        type: 'boolean',
10254        default: false
10255      },
10256      minHeight: {
10257        type: 'number'
10258      },
10259      minHeightUnit: {
10260        type: 'string'
10261      },
10262      gradient: {
10263        type: 'string'
10264      },
10265      customGradient: {
10266        type: 'string'
10267      },
10268      contentPosition: {
10269        type: 'string'
10270      },
10271      alt: {
10272        type: 'string',
10273        source: 'attribute',
10274        selector: 'img',
10275        attribute: 'alt',
10276        default: ''
10277      }
10278    },
10279    supports: {
10280      anchor: true,
10281      align: true,
10282      html: false,
10283      spacing: {
10284        padding: true,
10285        __experimentalDefaultControls: {
10286          padding: true
10287        }
10288      },
10289      color: {
10290        __experimentalDuotone: '> .wp-block-cover__image-background, > .wp-block-cover__video-background',
10291        text: false,
10292        background: false
10293      }
10294    },
10295  
10296    save(_ref3) {
10297      let {
10298        attributes
10299      } = _ref3;
10300      const {
10301        backgroundType,
10302        gradient,
10303        contentPosition,
10304        customGradient,
10305        customOverlayColor,
10306        dimRatio,
10307        focalPoint,
10308        hasParallax,
10309        isRepeated,
10310        overlayColor,
10311        url,
10312        alt,
10313        id,
10314        minHeight: minHeightProp,
10315        minHeightUnit
10316      } = attributes;
10317      const overlayColorClass = (0,external_wp_blockEditor_namespaceObject.getColorClassName)('background-color', overlayColor);
10318  
10319      const gradientClass = (0,external_wp_blockEditor_namespaceObject.__experimentalGetGradientClass)(gradient);
10320  
10321      const minHeight = minHeightUnit ? `$minHeightProp}$minHeightUnit}` : minHeightProp;
10322      const isImageBackground = IMAGE_BACKGROUND_TYPE === backgroundType;
10323      const isVideoBackground = VIDEO_BACKGROUND_TYPE === backgroundType;
10324      const isImgElement = !(hasParallax || isRepeated);
10325      const style = { ...(isImageBackground && !isImgElement ? backgroundImageStyles(url) : {}),
10326        backgroundColor: !overlayColorClass ? customOverlayColor : undefined,
10327        background: customGradient && !url ? customGradient : undefined,
10328        minHeight: minHeight || undefined
10329      };
10330      const objectPosition = // prettier-ignore
10331      focalPoint && isImgElement ? `$Math.round(focalPoint.x * 100)}% $Math.round(focalPoint.y * 100)}%` : undefined;
10332      const classes = classnames_default()(dimRatioToClassV1(dimRatio), overlayColorClass, {
10333        'has-background-dim': dimRatio !== 0,
10334        'has-parallax': hasParallax,
10335        'is-repeated': isRepeated,
10336        'has-background-gradient': gradient || customGradient,
10337        [gradientClass]: !url && gradientClass,
10338        'has-custom-content-position': !isContentPositionCenter(contentPosition)
10339      }, getPositionClassName(contentPosition));
10340      return (0,external_wp_element_namespaceObject.createElement)("div", external_wp_blockEditor_namespaceObject.useBlockProps.save({
10341        className: classes,
10342        style
10343      }), url && (gradient || customGradient) && dimRatio !== 0 && (0,external_wp_element_namespaceObject.createElement)("span", {
10344        "aria-hidden": "true",
10345        className: classnames_default()('wp-block-cover__gradient-background', gradientClass),
10346        style: customGradient ? {
10347          background: customGradient
10348        } : undefined
10349      }), isImageBackground && isImgElement && url && (0,external_wp_element_namespaceObject.createElement)("img", {
10350        className: classnames_default()('wp-block-cover__image-background', id ? `wp-image-$id}` : null),
10351        alt: alt,
10352        src: url,
10353        style: {
10354          objectPosition
10355        },
10356        "data-object-fit": "cover",
10357        "data-object-position": objectPosition
10358      }), isVideoBackground && url && (0,external_wp_element_namespaceObject.createElement)("video", {
10359        className: classnames_default()('wp-block-cover__video-background', 'intrinsic-ignore'),
10360        autoPlay: true,
10361        muted: true,
10362        loop: true,
10363        playsInline: true,
10364        src: url,
10365        style: {
10366          objectPosition
10367        },
10368        "data-object-fit": "cover",
10369        "data-object-position": objectPosition
10370      }), (0,external_wp_element_namespaceObject.createElement)("div", {
10371        className: "wp-block-cover__inner-container"
10372      }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InnerBlocks.Content, null)));
10373    },
10374  
10375    migrate: migrateDimRatio
10376  };
10377  const v6 = {
10378    attributes: { ...deprecated_blockAttributes,
10379      isRepeated: {
10380        type: 'boolean',
10381        default: false
10382      },
10383      minHeight: {
10384        type: 'number'
10385      },
10386      minHeightUnit: {
10387        type: 'string'
10388      },
10389      gradient: {
10390        type: 'string'
10391      },
10392      customGradient: {
10393        type: 'string'
10394      },
10395      contentPosition: {
10396        type: 'string'
10397      }
10398    },
10399    supports: {
10400      align: true
10401    },
10402  
10403    save(_ref4) {
10404      let {
10405        attributes
10406      } = _ref4;
10407      const {
10408        backgroundType,
10409        gradient,
10410        contentPosition,
10411        customGradient,
10412        customOverlayColor,
10413        dimRatio,
10414        focalPoint,
10415        hasParallax,
10416        isRepeated,
10417        overlayColor,
10418        url,
10419        minHeight: minHeightProp,
10420        minHeightUnit
10421      } = attributes;
10422      const overlayColorClass = (0,external_wp_blockEditor_namespaceObject.getColorClassName)('background-color', overlayColor);
10423  
10424      const gradientClass = (0,external_wp_blockEditor_namespaceObject.__experimentalGetGradientClass)(gradient);
10425  
10426      const minHeight = minHeightUnit ? `$minHeightProp}$minHeightUnit}` : minHeightProp;
10427      const isImageBackground = IMAGE_BACKGROUND_TYPE === backgroundType;
10428      const isVideoBackground = VIDEO_BACKGROUND_TYPE === backgroundType;
10429      const style = isImageBackground ? backgroundImageStyles(url) : {};
10430      const videoStyle = {};
10431  
10432      if (!overlayColorClass) {
10433        style.backgroundColor = customOverlayColor;
10434      }
10435  
10436      if (customGradient && !url) {
10437        style.background = customGradient;
10438      }
10439  
10440      style.minHeight = minHeight || undefined;
10441      let positionValue;
10442  
10443      if (focalPoint) {
10444        positionValue = `$Math.round(focalPoint.x * 100)}% $Math.round(focalPoint.y * 100)}%`;
10445  
10446        if (isImageBackground && !hasParallax) {
10447          style.backgroundPosition = positionValue;
10448        }
10449  
10450        if (isVideoBackground) {
10451          videoStyle.objectPosition = positionValue;
10452        }
10453      }
10454  
10455      const classes = classnames_default()(dimRatioToClassV1(dimRatio), overlayColorClass, {
10456        'has-background-dim': dimRatio !== 0,
10457        'has-parallax': hasParallax,
10458        'is-repeated': isRepeated,
10459        'has-background-gradient': gradient || customGradient,
10460        [gradientClass]: !url && gradientClass,
10461        'has-custom-content-position': !isContentPositionCenter(contentPosition)
10462      }, getPositionClassName(contentPosition));
10463      return (0,external_wp_element_namespaceObject.createElement)("div", external_wp_blockEditor_namespaceObject.useBlockProps.save({
10464        className: classes,
10465        style
10466      }), url && (gradient || customGradient) && dimRatio !== 0 && (0,external_wp_element_namespaceObject.createElement)("span", {
10467        "aria-hidden": "true",
10468        className: classnames_default()('wp-block-cover__gradient-background', gradientClass),
10469        style: customGradient ? {
10470          background: customGradient
10471        } : undefined
10472      }), isVideoBackground && url && (0,external_wp_element_namespaceObject.createElement)("video", {
10473        className: "wp-block-cover__video-background",
10474        autoPlay: true,
10475        muted: true,
10476        loop: true,
10477        playsInline: true,
10478        src: url,
10479        style: videoStyle
10480      }), (0,external_wp_element_namespaceObject.createElement)("div", {
10481        className: "wp-block-cover__inner-container"
10482      }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InnerBlocks.Content, null)));
10483    },
10484  
10485    migrate: migrateDimRatio
10486  };
10487  const v5 = {
10488    attributes: { ...deprecated_blockAttributes,
10489      minHeight: {
10490        type: 'number'
10491      },
10492      gradient: {
10493        type: 'string'
10494      },
10495      customGradient: {
10496        type: 'string'
10497      }
10498    },
10499    supports: {
10500      align: true
10501    },
10502  
10503    save(_ref5) {
10504      let {
10505        attributes
10506      } = _ref5;
10507      const {
10508        backgroundType,
10509        gradient,
10510        customGradient,
10511        customOverlayColor,
10512        dimRatio,
10513        focalPoint,
10514        hasParallax,
10515        overlayColor,
10516        url,
10517        minHeight
10518      } = attributes;
10519      const overlayColorClass = (0,external_wp_blockEditor_namespaceObject.getColorClassName)('background-color', overlayColor);
10520  
10521      const gradientClass = (0,external_wp_blockEditor_namespaceObject.__experimentalGetGradientClass)(gradient);
10522  
10523      const style = backgroundType === IMAGE_BACKGROUND_TYPE ? backgroundImageStyles(url) : {};
10524  
10525      if (!overlayColorClass) {
10526        style.backgroundColor = customOverlayColor;
10527      }
10528  
10529      if (focalPoint && !hasParallax) {
10530        style.backgroundPosition = `$Math.round(focalPoint.x * 100)}% $Math.round(focalPoint.y * 100)}%`;
10531      }
10532  
10533      if (customGradient && !url) {
10534        style.background = customGradient;
10535      }
10536  
10537      style.minHeight = minHeight || undefined;
10538      const classes = classnames_default()(dimRatioToClassV1(dimRatio), overlayColorClass, {
10539        'has-background-dim': dimRatio !== 0,
10540        'has-parallax': hasParallax,
10541        'has-background-gradient': customGradient,
10542        [gradientClass]: !url && gradientClass
10543      });
10544      return (0,external_wp_element_namespaceObject.createElement)("div", {
10545        className: classes,
10546        style: style
10547      }, url && (gradient || customGradient) && dimRatio !== 0 && (0,external_wp_element_namespaceObject.createElement)("span", {
10548        "aria-hidden": "true",
10549        className: classnames_default()('wp-block-cover__gradient-background', gradientClass),
10550        style: customGradient ? {
10551          background: customGradient
10552        } : undefined
10553      }), VIDEO_BACKGROUND_TYPE === backgroundType && url && (0,external_wp_element_namespaceObject.createElement)("video", {
10554        className: "wp-block-cover__video-background",
10555        autoPlay: true,
10556        muted: true,
10557        loop: true,
10558        src: url
10559      }), (0,external_wp_element_namespaceObject.createElement)("div", {
10560        className: "wp-block-cover__inner-container"
10561      }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InnerBlocks.Content, null)));
10562    },
10563  
10564    migrate: migrateDimRatio
10565  };
10566  const v4 = {
10567    attributes: { ...deprecated_blockAttributes,
10568      minHeight: {
10569        type: 'number'
10570      },
10571      gradient: {
10572        type: 'string'
10573      },
10574      customGradient: {
10575        type: 'string'
10576      }
10577    },
10578    supports: {
10579      align: true
10580    },
10581  
10582    save(_ref6) {
10583      let {
10584        attributes
10585      } = _ref6;
10586      const {
10587        backgroundType,
10588        gradient,
10589        customGradient,
10590        customOverlayColor,
10591        dimRatio,
10592        focalPoint,
10593        hasParallax,
10594        overlayColor,
10595        url,
10596        minHeight
10597      } = attributes;
10598      const overlayColorClass = (0,external_wp_blockEditor_namespaceObject.getColorClassName)('background-color', overlayColor);
10599  
10600      const gradientClass = (0,external_wp_blockEditor_namespaceObject.__experimentalGetGradientClass)(gradient);
10601  
10602      const style = backgroundType === IMAGE_BACKGROUND_TYPE ? backgroundImageStyles(url) : {};
10603  
10604      if (!overlayColorClass) {
10605        style.backgroundColor = customOverlayColor;
10606      }
10607  
10608      if (focalPoint && !hasParallax) {
10609        style.backgroundPosition = `$focalPoint.x * 100}% $focalPoint.y * 100}%`;
10610      }
10611  
10612      if (customGradient && !url) {
10613        style.background = customGradient;
10614      }
10615  
10616      style.minHeight = minHeight || undefined;
10617      const classes = classnames_default()(dimRatioToClassV1(dimRatio), overlayColorClass, {
10618        'has-background-dim': dimRatio !== 0,
10619        'has-parallax': hasParallax,
10620        'has-background-gradient': customGradient,
10621        [gradientClass]: !url && gradientClass
10622      });
10623      return (0,external_wp_element_namespaceObject.createElement)("div", {
10624        className: classes,
10625        style: style
10626      }, url && (gradient || customGradient) && dimRatio !== 0 && (0,external_wp_element_namespaceObject.createElement)("span", {
10627        "aria-hidden": "true",
10628        className: classnames_default()('wp-block-cover__gradient-background', gradientClass),
10629        style: customGradient ? {
10630          background: customGradient
10631        } : undefined
10632      }), VIDEO_BACKGROUND_TYPE === backgroundType && url && (0,external_wp_element_namespaceObject.createElement)("video", {
10633        className: "wp-block-cover__video-background",
10634        autoPlay: true,
10635        muted: true,
10636        loop: true,
10637        src: url
10638      }), (0,external_wp_element_namespaceObject.createElement)("div", {
10639        className: "wp-block-cover__inner-container"
10640      }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InnerBlocks.Content, null)));
10641    },
10642  
10643    migrate: migrateDimRatio
10644  };
10645  const v3 = {
10646    attributes: { ...deprecated_blockAttributes,
10647      title: {
10648        type: 'string',
10649        source: 'html',
10650        selector: 'p'
10651      },
10652      contentAlign: {
10653        type: 'string',
10654        default: 'center'
10655      }
10656    },
10657    supports: {
10658      align: true
10659    },
10660  
10661    save(_ref7) {
10662      let {
10663        attributes
10664      } = _ref7;
10665      const {
10666        backgroundType,
10667        contentAlign,
10668        customOverlayColor,
10669        dimRatio,
10670        focalPoint,
10671        hasParallax,
10672        overlayColor,
10673        title,
10674        url
10675      } = attributes;
10676      const overlayColorClass = (0,external_wp_blockEditor_namespaceObject.getColorClassName)('background-color', overlayColor);
10677      const style = backgroundType === IMAGE_BACKGROUND_TYPE ? backgroundImageStyles(url) : {};
10678  
10679      if (!overlayColorClass) {
10680        style.backgroundColor = customOverlayColor;
10681      }
10682  
10683      if (focalPoint && !hasParallax) {
10684        style.backgroundPosition = `$focalPoint.x * 100}% $focalPoint.y * 100}%`;
10685      }
10686  
10687      const classes = classnames_default()(dimRatioToClassV1(dimRatio), overlayColorClass, {
10688        'has-background-dim': dimRatio !== 0,
10689        'has-parallax': hasParallax,
10690        [`has-$contentAlign}-content`]: contentAlign !== 'center'
10691      });
10692      return (0,external_wp_element_namespaceObject.createElement)("div", {
10693        className: classes,
10694        style: style
10695      }, VIDEO_BACKGROUND_TYPE === backgroundType && url && (0,external_wp_element_namespaceObject.createElement)("video", {
10696        className: "wp-block-cover__video-background",
10697        autoPlay: true,
10698        muted: true,
10699        loop: true,
10700        src: url
10701      }), !external_wp_blockEditor_namespaceObject.RichText.isEmpty(title) && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
10702        tagName: "p",
10703        className: "wp-block-cover-text",
10704        value: title
10705      }));
10706    },
10707  
10708    migrate(attributes) {
10709      const newAttribs = { ...attributes,
10710        dimRatio: !attributes.url ? 100 : attributes.dimRatio
10711      };
10712      return [(0,external_lodash_namespaceObject.omit)(newAttribs, ['title', 'contentAlign']), [(0,external_wp_blocks_namespaceObject.createBlock)('core/paragraph', {
10713        content: attributes.title,
10714        align: attributes.contentAlign,
10715        fontSize: 'large',
10716        placeholder: (0,external_wp_i18n_namespaceObject.__)('Write title…')
10717      })]];
10718    }
10719  
10720  };
10721  const v2 = {
10722    attributes: { ...deprecated_blockAttributes,
10723      title: {
10724        type: 'string',
10725        source: 'html',
10726        selector: 'p'
10727      },
10728      contentAlign: {
10729        type: 'string',
10730        default: 'center'
10731      },
10732      align: {
10733        type: 'string'
10734      }
10735    },
10736    supports: {
10737      className: false
10738    },
10739  
10740    save(_ref8) {
10741      let {
10742        attributes
10743      } = _ref8;
10744      const {
10745        url,
10746        title,
10747        hasParallax,
10748        dimRatio,
10749        align,
10750        contentAlign,
10751        overlayColor,
10752        customOverlayColor
10753      } = attributes;
10754      const overlayColorClass = (0,external_wp_blockEditor_namespaceObject.getColorClassName)('background-color', overlayColor);
10755      const style = backgroundImageStyles(url);
10756  
10757      if (!overlayColorClass) {
10758        style.backgroundColor = customOverlayColor;
10759      }
10760  
10761      const classes = classnames_default()('wp-block-cover-image', dimRatioToClassV1(dimRatio), overlayColorClass, {
10762        'has-background-dim': dimRatio !== 0,
10763        'has-parallax': hasParallax,
10764        [`has-$contentAlign}-content`]: contentAlign !== 'center'
10765      }, align ? `align$align}` : null);
10766      return (0,external_wp_element_namespaceObject.createElement)("div", {
10767        className: classes,
10768        style: style
10769      }, !external_wp_blockEditor_namespaceObject.RichText.isEmpty(title) && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
10770        tagName: "p",
10771        className: "wp-block-cover-image-text",
10772        value: title
10773      }));
10774    },
10775  
10776    migrate(attributes) {
10777      const newAttribs = { ...attributes,
10778        dimRatio: !attributes.url ? 100 : attributes.dimRatio
10779      };
10780      return [(0,external_lodash_namespaceObject.omit)(newAttribs, ['title', 'contentAlign', 'align']), [(0,external_wp_blocks_namespaceObject.createBlock)('core/paragraph', {
10781        content: attributes.title,
10782        align: attributes.contentAlign,
10783        fontSize: 'large',
10784        placeholder: (0,external_wp_i18n_namespaceObject.__)('Write title…')
10785      })]];
10786    }
10787  
10788  };
10789  const cover_deprecated_v1 = {
10790    attributes: { ...deprecated_blockAttributes,
10791      title: {
10792        type: 'string',
10793        source: 'html',
10794        selector: 'h2'
10795      },
10796      align: {
10797        type: 'string'
10798      },
10799      contentAlign: {
10800        type: 'string',
10801        default: 'center'
10802      }
10803    },
10804    supports: {
10805      className: false
10806    },
10807  
10808    save(_ref9) {
10809      let {
10810        attributes
10811      } = _ref9;
10812      const {
10813        url,
10814        title,
10815        hasParallax,
10816        dimRatio,
10817        align
10818      } = attributes;
10819      const style = backgroundImageStyles(url);
10820      const classes = classnames_default()('wp-block-cover-image', dimRatioToClassV1(dimRatio), {
10821        'has-background-dim': dimRatio !== 0,
10822        'has-parallax': hasParallax
10823      }, align ? `align$align}` : null);
10824      return (0,external_wp_element_namespaceObject.createElement)("section", {
10825        className: classes,
10826        style: style
10827      }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
10828        tagName: "h2",
10829        value: title
10830      }));
10831    },
10832  
10833    migrate(attributes) {
10834      const newAttribs = { ...attributes,
10835        dimRatio: !attributes.url ? 100 : attributes.dimRatio
10836      };
10837      return [(0,external_lodash_namespaceObject.omit)(newAttribs, ['title', 'contentAlign', 'align']), [(0,external_wp_blocks_namespaceObject.createBlock)('core/paragraph', {
10838        content: attributes.title,
10839        align: attributes.contentAlign,
10840        fontSize: 'large',
10841        placeholder: (0,external_wp_i18n_namespaceObject.__)('Write title…')
10842      })]];
10843    }
10844  
10845  };
10846  /* harmony default export */ var cover_deprecated = ([v9, v8, v7, v6, v5, v4, v3, v2, cover_deprecated_v1]);
10847  
10848  // EXTERNAL MODULE: ./node_modules/fast-average-color/dist/index.js
10849  var dist = __webpack_require__(5027);
10850  var dist_default = /*#__PURE__*/__webpack_require__.n(dist);
10851  ;// CONCATENATED MODULE: ./node_modules/colord/index.mjs
10852  var r={grad:.9,turn:360,rad:360/(2*Math.PI)},t=function(r){return"string"==typeof r?r.length>0:"number"==typeof r},n=function(r,t,n){return void 0===t&&(t=0),void 0===n&&(n=Math.pow(10,t)),Math.round(n*r)/n+0},e=function(r,t,n){return void 0===t&&(t=0),void 0===n&&(n=1),r>n?n:r>t?r:t},u=function(r){return(r=isFinite(r)?r%360:0)>0?r:r+360},a=function(r){return{r:e(r.r,0,255),g:e(r.g,0,255),b:e(r.b,0,255),a:e(r.a)}},o=function(r){return{r:n(r.r),g:n(r.g),b:n(r.b),a:n(r.a,3)}},i=/^#([0-9a-f]{3,8})$/i,s=function(r){var t=r.toString(16);return t.length<2?"0"+t:t},h=function(r){var t=r.r,n=r.g,e=r.b,u=r.a,a=Math.max(t,n,e),o=a-Math.min(t,n,e),i=o?a===t?(n-e)/o:a===n?2+(e-t)/o:4+(t-n)/o:0;return{h:60*(i<0?i+6:i),s:a?o/a*100:0,v:a/255*100,a:u}},b=function(r){var t=r.h,n=r.s,e=r.v,u=r.a;t=t/360*6,n/=100,e/=100;var a=Math.floor(t),o=e*(1-n),i=e*(1-(t-a)*n),s=e*(1-(1-t+a)*n),h=a%6;return{r:255*[e,i,o,o,s,e][h],g:255*[s,e,e,i,o,o][h],b:255*[o,o,s,e,e,i][h],a:u}},g=function(r){return{h:u(r.h),s:e(r.s,0,100),l:e(r.l,0,100),a:e(r.a)}},d=function(r){return{h:n(r.h),s:n(r.s),l:n(r.l),a:n(r.a,3)}},f=function(r){return b((n=(t=r).s,{h:t.h,s:(n*=((e=t.l)<50?e:100-e)/100)>0?2*n/(e+n)*100:0,v:e+n,a:t.a}));var t,n,e},c=function(r){return{h:(t=h(r)).h,s:(u=(200-(n=t.s))*(e=t.v)/100)>0&&u<200?n*e/100/(u<=100?u:200-u)*100:0,l:u/2,a:t.a};var t,n,e,u},l=/^hsla?\(\s*([+-]?\d*\.?\d+)(deg|rad|grad|turn)?\s*,\s*([+-]?\d*\.?\d+)%\s*,\s*([+-]?\d*\.?\d+)%\s*(?:,\s*([+-]?\d*\.?\d+)(%)?\s*)?\)$/i,p=/^hsla?\(\s*([+-]?\d*\.?\d+)(deg|rad|grad|turn)?\s+([+-]?\d*\.?\d+)%\s+([+-]?\d*\.?\d+)%\s*(?:\/\s*([+-]?\d*\.?\d+)(%)?\s*)?\)$/i,v=/^rgba?\(\s*([+-]?\d*\.?\d+)(%)?\s*,\s*([+-]?\d*\.?\d+)(%)?\s*,\s*([+-]?\d*\.?\d+)(%)?\s*(?:,\s*([+-]?\d*\.?\d+)(%)?\s*)?\)$/i,m=/^rgba?\(\s*([+-]?\d*\.?\d+)(%)?\s+([+-]?\d*\.?\d+)(%)?\s+([+-]?\d*\.?\d+)(%)?\s*(?:\/\s*([+-]?\d*\.?\d+)(%)?\s*)?\)$/i,y={string:[[function(r){var t=i.exec(r);return t?(r=t[1]).length<=4?{r:parseInt(r[0]+r[0],16),g:parseInt(r[1]+r[1],16),b:parseInt(r[2]+r[2],16),a:4===r.length?n(parseInt(r[3]+r[3],16)/255,2):1}:6===r.length||8===r.length?{r:parseInt(r.substr(0,2),16),g:parseInt(r.substr(2,2),16),b:parseInt(r.substr(4,2),16),a:8===r.length?n(parseInt(r.substr(6,2),16)/255,2):1}:null:null},"hex"],[function(r){var t=v.exec(r)||m.exec(r);return t?t[2]!==t[4]||t[4]!==t[6]?null:a({r:Number(t[1])/(t[2]?100/255:1),g:Number(t[3])/(t[4]?100/255:1),b:Number(t[5])/(t[6]?100/255:1),a:void 0===t[7]?1:Number(t[7])/(t[8]?100:1)}):null},"rgb"],[function(t){var n=l.exec(t)||p.exec(t);if(!n)return null;var e,u,a=g({h:(e=n[1],u=n[2],void 0===u&&(u="deg"),Number(e)*(r[u]||1)),s:Number(n[3]),l:Number(n[4]),a:void 0===n[5]?1:Number(n[5])/(n[6]?100:1)});return f(a)},"hsl"]],object:[[function(r){var n=r.r,e=r.g,u=r.b,o=r.a,i=void 0===o?1:o;return t(n)&&t(e)&&t(u)?a({r:Number(n),g:Number(e),b:Number(u),a:Number(i)}):null},"rgb"],[function(r){var n=r.h,e=r.s,u=r.l,a=r.a,o=void 0===a?1:a;if(!t(n)||!t(e)||!t(u))return null;var i=g({h:Number(n),s:Number(e),l:Number(u),a:Number(o)});return f(i)},"hsl"],[function(r){var n=r.h,a=r.s,o=r.v,i=r.a,s=void 0===i?1:i;if(!t(n)||!t(a)||!t(o))return null;var h=function(r){return{h:u(r.h),s:e(r.s,0,100),v:e(r.v,0,100),a:e(r.a)}}({h:Number(n),s:Number(a),v:Number(o),a:Number(s)});return b(h)},"hsv"]]},N=function(r,t){for(var n=0;n<t.length;n++){var e=t[n][0](r);if(e)return[e,t[n][1]]}return[null,void 0]},x=function(r){return"string"==typeof r?N(r.trim(),y.string):"object"==typeof r&&null!==r?N(r,y.object):[null,void 0]},I=function(r){return x(r)[1]},M=function(r,t){var n=c(r);return{h:n.h,s:e(n.s+100*t,0,100),l:n.l,a:n.a}},H=function(r){return(299*r.r+587*r.g+114*r.b)/1e3/255},$=function(r,t){var n=c(r);return{h:n.h,s:n.s,l:e(n.l+100*t,0,100),a:n.a}},j=function(){function r(r){this.parsed=x(r)[0],this.rgba=this.parsed||{r:0,g:0,b:0,a:1}}return r.prototype.isValid=function(){return null!==this.parsed},r.prototype.brightness=function(){return n(H(this.rgba),2)},r.prototype.isDark=function(){return H(this.rgba)<.5},r.prototype.isLight=function(){return H(this.rgba)>=.5},r.prototype.toHex=function(){return r=o(this.rgba),t=r.r,e=r.g,u=r.b,i=(a=r.a)<1?s(n(255*a)):"","#"+s(t)+s(e)+s(u)+i;var r,t,e,u,a,i},r.prototype.toRgb=function(){return o(this.rgba)},r.prototype.toRgbString=function(){return r=o(this.rgba),t=r.r,n=r.g,e=r.b,(u=r.a)<1?"rgba("+t+", "+n+", "+e+", "+u+")":"rgb("+t+", "+n+", "+e+")";var r,t,n,e,u},r.prototype.toHsl=function(){return d(c(this.rgba))},r.prototype.toHslString=function(){return r=d(c(this.rgba)),t=r.h,n=r.s,e=r.l,(u=r.a)<1?"hsla("+t+", "+n+"%, "+e+"%, "+u+")":"hsl("+t+", "+n+"%, "+e+"%)";var r,t,n,e,u},r.prototype.toHsv=function(){return r=h(this.rgba),{h:n(r.h),s:n(r.s),v:n(r.v),a:n(r.a,3)};var r},r.prototype.invert=function(){return w({r:255-(r=this.rgba).r,g:255-r.g,b:255-r.b,a:r.a});var r},r.prototype.saturate=function(r){return void 0===r&&(r=.1),w(M(this.rgba,r))},r.prototype.desaturate=function(r){return void 0===r&&(r=.1),w(M(this.rgba,-r))},r.prototype.grayscale=function(){return w(M(this.rgba,-1))},r.prototype.lighten=function(r){return void 0===r&&(r=.1),w($(this.rgba,r))},r.prototype.darken=function(r){return void 0===r&&(r=.1),w($(this.rgba,-r))},r.prototype.rotate=function(r){return void 0===r&&(r=15),this.hue(this.hue()+r)},r.prototype.alpha=function(r){return"number"==typeof r?w({r:(t=this.rgba).r,g:t.g,b:t.b,a:r}):n(this.rgba.a,3);var t},r.prototype.hue=function(r){var t=c(this.rgba);return"number"==typeof r?w({h:r,s:t.s,l:t.l,a:t.a}):n(t.h)},r.prototype.isEqual=function(r){return this.toHex()===w(r).toHex()},r}(),w=function(r){return r instanceof j?r:new j(r)},S=[],k=function(r){r.forEach(function(r){S.indexOf(r)<0&&(r(j,y),S.push(r))})},E=function(){return new j({r:255*Math.random(),g:255*Math.random(),b:255*Math.random()})};
10853  
10854  ;// CONCATENATED MODULE: ./node_modules/colord/plugins/names.mjs
10855  /* harmony default export */ function names(e,f){var a={white:"#ffffff",bisque:"#ffe4c4",blue:"#0000ff",cadetblue:"#5f9ea0",chartreuse:"#7fff00",chocolate:"#d2691e",coral:"#ff7f50",antiquewhite:"#faebd7",aqua:"#00ffff",azure:"#f0ffff",whitesmoke:"#f5f5f5",papayawhip:"#ffefd5",plum:"#dda0dd",blanchedalmond:"#ffebcd",black:"#000000",gold:"#ffd700",goldenrod:"#daa520",gainsboro:"#dcdcdc",cornsilk:"#fff8dc",cornflowerblue:"#6495ed",burlywood:"#deb887",aquamarine:"#7fffd4",beige:"#f5f5dc",crimson:"#dc143c",cyan:"#00ffff",darkblue:"#00008b",darkcyan:"#008b8b",darkgoldenrod:"#b8860b",darkkhaki:"#bdb76b",darkgray:"#a9a9a9",darkgreen:"#006400",darkgrey:"#a9a9a9",peachpuff:"#ffdab9",darkmagenta:"#8b008b",darkred:"#8b0000",darkorchid:"#9932cc",darkorange:"#ff8c00",darkslateblue:"#483d8b",gray:"#808080",darkslategray:"#2f4f4f",darkslategrey:"#2f4f4f",deeppink:"#ff1493",deepskyblue:"#00bfff",wheat:"#f5deb3",firebrick:"#b22222",floralwhite:"#fffaf0",ghostwhite:"#f8f8ff",darkviolet:"#9400d3",magenta:"#ff00ff",green:"#008000",dodgerblue:"#1e90ff",grey:"#808080",honeydew:"#f0fff0",hotpink:"#ff69b4",blueviolet:"#8a2be2",forestgreen:"#228b22",lawngreen:"#7cfc00",indianred:"#cd5c5c",indigo:"#4b0082",fuchsia:"#ff00ff",brown:"#a52a2a",maroon:"#800000",mediumblue:"#0000cd",lightcoral:"#f08080",darkturquoise:"#00ced1",lightcyan:"#e0ffff",ivory:"#fffff0",lightyellow:"#ffffe0",lightsalmon:"#ffa07a",lightseagreen:"#20b2aa",linen:"#faf0e6",mediumaquamarine:"#66cdaa",lemonchiffon:"#fffacd",lime:"#00ff00",khaki:"#f0e68c",mediumseagreen:"#3cb371",limegreen:"#32cd32",mediumspringgreen:"#00fa9a",lightskyblue:"#87cefa",lightblue:"#add8e6",midnightblue:"#191970",lightpink:"#ffb6c1",mistyrose:"#ffe4e1",moccasin:"#ffe4b5",mintcream:"#f5fffa",lightslategray:"#778899",lightslategrey:"#778899",navajowhite:"#ffdead",navy:"#000080",mediumvioletred:"#c71585",powderblue:"#b0e0e6",palegoldenrod:"#eee8aa",oldlace:"#fdf5e6",paleturquoise:"#afeeee",mediumturquoise:"#48d1cc",mediumorchid:"#ba55d3",rebeccapurple:"#663399",lightsteelblue:"#b0c4de",mediumslateblue:"#7b68ee",thistle:"#d8bfd8",tan:"#d2b48c",orchid:"#da70d6",mediumpurple:"#9370db",purple:"#800080",pink:"#ffc0cb",skyblue:"#87ceeb",springgreen:"#00ff7f",palegreen:"#98fb98",red:"#ff0000",yellow:"#ffff00",slateblue:"#6a5acd",lavenderblush:"#fff0f5",peru:"#cd853f",palevioletred:"#db7093",violet:"#ee82ee",teal:"#008080",slategray:"#708090",slategrey:"#708090",aliceblue:"#f0f8ff",darkseagreen:"#8fbc8f",darkolivegreen:"#556b2f",greenyellow:"#adff2f",seagreen:"#2e8b57",seashell:"#fff5ee",tomato:"#ff6347",silver:"#c0c0c0",sienna:"#a0522d",lavender:"#e6e6fa",lightgreen:"#90ee90",orange:"#ffa500",orangered:"#ff4500",steelblue:"#4682b4",royalblue:"#4169e1",turquoise:"#40e0d0",yellowgreen:"#9acd32",salmon:"#fa8072",saddlebrown:"#8b4513",sandybrown:"#f4a460",rosybrown:"#bc8f8f",darksalmon:"#e9967a",lightgoldenrodyellow:"#fafad2",snow:"#fffafa",lightgrey:"#d3d3d3",lightgray:"#d3d3d3",dimgray:"#696969",dimgrey:"#696969",olivedrab:"#6b8e23",olive:"#808000"},r={};for(var d in a)r[a[d]]=d;var l={};e.prototype.toName=function(f){if(!(this.rgba.a||this.rgba.r||this.rgba.g||this.rgba.b))return"transparent";var d,i,n=r[this.toHex()];if(n)return n;if(null==f?void 0:f.closest){var o=this.toRgb(),t=1/0,b="black";if(!l.length)for(var c in a)l[c]=new e(a[c]).toRgb();for(var g in a){var u=(d=o,i=l[g],Math.pow(d.r-i.r,2)+Math.pow(d.g-i.g,2)+Math.pow(d.b-i.b,2));u<t&&(t=u,b=g)}return b}};f.string.push([function(f){var r=f.toLowerCase(),d="transparent"===r?"#0000":a[r];return d?new e(d).toRgb():null},"name"])}
10856  
10857  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/post-featured-image.js
10858  
10859  
10860  /**
10861   * WordPress dependencies
10862   */
10863  
10864  const postFeaturedImage = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
10865    xmlns: "http://www.w3.org/2000/svg",
10866    viewBox: "0 0 24 24"
10867  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
10868    d: "M19 3H5c-.6 0-1 .4-1 1v7c0 .5.4 1 1 1h14c.5 0 1-.4 1-1V4c0-.6-.4-1-1-1zM5.5 10.5v-.4l1.8-1.3 1.3.8c.3.2.7.2.9-.1L11 8.1l2.4 2.4H5.5zm13 0h-2.9l-4-4c-.3-.3-.8-.3-1.1 0L8.9 8l-1.2-.8c-.3-.2-.6-.2-.9 0l-1.3 1V4.5h13v6zM4 20h9v-1.5H4V20zm0-4h16v-1.5H4V16z"
10869  }));
10870  /* harmony default export */ var post_featured_image = (postFeaturedImage);
10871  
10872  ;// CONCATENATED MODULE: external ["wp","notices"]
10873  var external_wp_notices_namespaceObject = window["wp"]["notices"];
10874  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/cover/edit.js
10875  
10876  
10877  
10878  /**
10879   * External dependencies
10880   */
10881  
10882  
10883  
10884  
10885  /**
10886   * WordPress dependencies
10887   */
10888  
10889  
10890  
10891  
10892  
10893  
10894  
10895  
10896  
10897  
10898  
10899  /**
10900   * Internal dependencies
10901   */
10902  
10903  
10904  k([names]);
10905  const {
10906    __Visualizer: BoxControlVisualizer
10907  } = external_wp_components_namespaceObject.__experimentalBoxControl;
10908  
10909  function getInnerBlocksTemplate(attributes) {
10910    return [['core/paragraph', {
10911      align: 'center',
10912      placeholder: (0,external_wp_i18n_namespaceObject.__)('Write title…'),
10913      ...attributes
10914    }]];
10915  }
10916  
10917  function retrieveFastAverageColor() {
10918    if (!retrieveFastAverageColor.fastAverageColor) {
10919      retrieveFastAverageColor.fastAverageColor = new (dist_default())();
10920    }
10921  
10922    return retrieveFastAverageColor.fastAverageColor;
10923  }
10924  
10925  function CoverHeightInput(_ref) {
10926    let {
10927      onChange,
10928      onUnitChange,
10929      unit = 'px',
10930      value = ''
10931    } = _ref;
10932    const instanceId = (0,external_wp_compose_namespaceObject.useInstanceId)(external_wp_components_namespaceObject.__experimentalUnitControl);
10933    const inputId = `block-cover-height-input-$instanceId}`;
10934    const isPx = unit === 'px';
10935    const units = (0,external_wp_components_namespaceObject.__experimentalUseCustomUnits)({
10936      availableUnits: (0,external_wp_blockEditor_namespaceObject.useSetting)('spacing.units') || ['px', 'em', 'rem', 'vw', 'vh'],
10937      defaultValues: {
10938        px: 430,
10939        '%': 20,
10940        em: 20,
10941        rem: 20,
10942        vw: 20,
10943        vh: 50
10944      }
10945    });
10946  
10947    const handleOnChange = unprocessedValue => {
10948      const inputValue = unprocessedValue !== '' ? parseFloat(unprocessedValue) : undefined;
10949  
10950      if (isNaN(inputValue) && inputValue !== undefined) {
10951        return;
10952      }
10953  
10954      onChange(inputValue);
10955    };
10956  
10957    const computedValue = (0,external_wp_element_namespaceObject.useMemo)(() => {
10958      const [parsedQuantity] = (0,external_wp_components_namespaceObject.__experimentalParseQuantityAndUnitFromRawValue)(value);
10959      return [parsedQuantity, unit].join('');
10960    }, [unit, value]);
10961    const min = isPx ? COVER_MIN_HEIGHT : 0;
10962    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.BaseControl, {
10963      label: (0,external_wp_i18n_namespaceObject.__)('Minimum height of cover'),
10964      id: inputId
10965    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalUnitControl, {
10966      id: inputId,
10967      isResetValueOnUnitChange: true,
10968      min: min,
10969      onChange: handleOnChange,
10970      onUnitChange: onUnitChange,
10971      style: {
10972        maxWidth: 80
10973      },
10974      units: units,
10975      value: computedValue
10976    }));
10977  }
10978  
10979  const RESIZABLE_BOX_ENABLE_OPTION = {
10980    top: false,
10981    right: false,
10982    bottom: true,
10983    left: false,
10984    topRight: false,
10985    bottomRight: false,
10986    bottomLeft: false,
10987    topLeft: false
10988  };
10989  
10990  function ResizableCover(_ref2) {
10991    let {
10992      className,
10993      onResizeStart,
10994      onResize,
10995      onResizeStop,
10996      ...props
10997    } = _ref2;
10998    const [isResizing, setIsResizing] = (0,external_wp_element_namespaceObject.useState)(false);
10999    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ResizableBox, _extends({
11000      className: classnames_default()(className, {
11001        'is-resizing': isResizing
11002      }),
11003      enable: RESIZABLE_BOX_ENABLE_OPTION,
11004      onResizeStart: (_event, _direction, elt) => {
11005        onResizeStart(elt.clientHeight);
11006        onResize(elt.clientHeight);
11007      },
11008      onResize: (_event, _direction, elt) => {
11009        onResize(elt.clientHeight);
11010  
11011        if (!isResizing) {
11012          setIsResizing(true);
11013        }
11014      },
11015      onResizeStop: (_event, _direction, elt) => {
11016        onResizeStop(elt.clientHeight);
11017        setIsResizing(false);
11018      }
11019    }, props));
11020  }
11021  /**
11022   * useCoverIsDark is a hook that returns a boolean variable specifying if the cover
11023   * background is dark or not.
11024   *
11025   * @param {?string} url          Url of the media background.
11026   * @param {?number} dimRatio     Transparency of the overlay color. If an image and
11027   *                               color are set, dimRatio is used to decide what is used
11028   *                               for background darkness checking purposes.
11029   * @param {?string} overlayColor String containing the overlay color value if one exists.
11030   * @param {?Object} elementRef   If a media background is set, elementRef should contain a reference to a
11031   *                               dom element that renders that media.
11032   *
11033   * @return {boolean} True if the cover background is considered "dark" and false otherwise.
11034   */
11035  
11036  
11037  function useCoverIsDark(url) {
11038    let dimRatio = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 50;
11039    let overlayColor = arguments.length > 2 ? arguments[2] : undefined;
11040    let elementRef = arguments.length > 3 ? arguments[3] : undefined;
11041    const [isDark, setIsDark] = (0,external_wp_element_namespaceObject.useState)(false);
11042    (0,external_wp_element_namespaceObject.useEffect)(() => {
11043      // If opacity is lower than 50 the dominant color is the image or video color,
11044      // so use that color for the dark mode computation.
11045      if (url && dimRatio <= 50 && elementRef.current) {
11046        retrieveFastAverageColor().getColorAsync(elementRef.current, color => {
11047          setIsDark(color.isDark);
11048        });
11049      }
11050    }, [url, url && dimRatio <= 50 && elementRef.current, setIsDark]);
11051    (0,external_wp_element_namespaceObject.useEffect)(() => {
11052      // If opacity is greater than 50 the dominant color is the overlay color,
11053      // so use that color for the dark mode computation.
11054      if (dimRatio > 50 || !url) {
11055        if (!overlayColor) {
11056          // If no overlay color exists the overlay color is black (isDark )
11057          setIsDark(true);
11058          return;
11059        }
11060  
11061        setIsDark(w(overlayColor).isDark());
11062      }
11063    }, [overlayColor, dimRatio > 50 || !url, setIsDark]);
11064    (0,external_wp_element_namespaceObject.useEffect)(() => {
11065      if (!url && !overlayColor) {
11066        // Reset isDark.
11067        setIsDark(false);
11068      }
11069    }, [!url && !overlayColor, setIsDark]);
11070    return isDark;
11071  }
11072  
11073  function mediaPosition(_ref3) {
11074    let {
11075      x,
11076      y
11077    } = _ref3;
11078    return `$Math.round(x * 100)}% $Math.round(y * 100)}%`;
11079  }
11080  /**
11081   * Is the URL a temporary blob URL? A blob URL is one that is used temporarily while
11082   * the media (image or video) is being uploaded and will not have an id allocated yet.
11083   *
11084   * @param {number} id  The id of the media.
11085   * @param {string} url The url of the media.
11086   *
11087   * @return {boolean} Is the URL a Blob URL.
11088   */
11089  
11090  
11091  const isTemporaryMedia = (id, url) => !id && (0,external_wp_blob_namespaceObject.isBlobURL)(url);
11092  
11093  function CoverPlaceholder(_ref4) {
11094    let {
11095      disableMediaButtons = false,
11096      children,
11097      onSelectMedia,
11098      onError,
11099      style
11100    } = _ref4;
11101    return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.MediaPlaceholder, {
11102      icon: (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockIcon, {
11103        icon: library_cover
11104      }),
11105      labels: {
11106        title: (0,external_wp_i18n_namespaceObject.__)('Cover'),
11107        instructions: (0,external_wp_i18n_namespaceObject.__)('Drag and drop onto this block, upload, or select existing media from your library.')
11108      },
11109      onSelect: onSelectMedia,
11110      accept: "image/*,video/*",
11111      allowedTypes: shared_ALLOWED_MEDIA_TYPES,
11112      disableMediaButtons: disableMediaButtons,
11113      onError: onError,
11114      style: style
11115    }, children);
11116  }
11117  
11118  function CoverEdit(_ref5) {
11119    var _useSetting, _styleAttribute$spaci, _styleAttribute$visua;
11120  
11121    let {
11122      attributes,
11123      clientId,
11124      isSelected,
11125      overlayColor,
11126      setAttributes,
11127      setOverlayColor,
11128      toggleSelection,
11129      context: {
11130        postId,
11131        postType
11132      }
11133    } = _ref5;
11134    const {
11135      contentPosition,
11136      id,
11137      useFeaturedImage,
11138      dimRatio,
11139      focalPoint,
11140      hasParallax,
11141      isDark,
11142      isRepeated,
11143      minHeight,
11144      minHeightUnit,
11145      style: styleAttribute,
11146      alt,
11147      allowedBlocks,
11148      templateLock
11149    } = attributes;
11150    const [featuredImage] = (0,external_wp_coreData_namespaceObject.useEntityProp)('postType', postType, 'featured_media', postId);
11151    const media = (0,external_wp_data_namespaceObject.useSelect)(select => featuredImage && select(external_wp_coreData_namespaceObject.store).getMedia(featuredImage, {
11152      context: 'view'
11153    }), [featuredImage]);
11154    const mediaUrl = media === null || media === void 0 ? void 0 : media.source_url; // instead of destructuring the attributes
11155    // we define the url and background type
11156    // depending on the value of the useFeaturedImage flag
11157    // to preview in edit the dynamic featured image
11158  
11159    const url = useFeaturedImage ? mediaUrl : attributes.url;
11160    const backgroundType = useFeaturedImage ? IMAGE_BACKGROUND_TYPE : attributes.backgroundType;
11161    const {
11162      __unstableMarkNextChangeAsNotPersistent
11163    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_blockEditor_namespaceObject.store);
11164    const {
11165      createErrorNotice
11166    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_notices_namespaceObject.store);
11167  
11168    const {
11169      gradientClass,
11170      gradientValue,
11171      setGradient
11172    } = (0,external_wp_blockEditor_namespaceObject.__experimentalUseGradient)();
11173  
11174    const onSelectMedia = attributesFromMedia(setAttributes, dimRatio);
11175    const isUploadingMedia = isTemporaryMedia(id, url);
11176    const [prevMinHeightValue, setPrevMinHeightValue] = (0,external_wp_element_namespaceObject.useState)(minHeight);
11177    const [prevMinHeightUnit, setPrevMinHeightUnit] = (0,external_wp_element_namespaceObject.useState)(minHeightUnit);
11178    const isMinFullHeight = minHeightUnit === 'vh' && minHeight === 100;
11179  
11180    const toggleMinFullHeight = () => {
11181      if (isMinFullHeight) {
11182        // If there aren't previous values, take the default ones.
11183        if (prevMinHeightUnit === 'vh' && prevMinHeightValue === 100) {
11184          return setAttributes({
11185            minHeight: undefined,
11186            minHeightUnit: undefined
11187          });
11188        } // Set the previous values of height.
11189  
11190  
11191        return setAttributes({
11192          minHeight: prevMinHeightValue,
11193          minHeightUnit: prevMinHeightUnit
11194        });
11195      }
11196  
11197      setPrevMinHeightValue(minHeight);
11198      setPrevMinHeightUnit(minHeightUnit); // Set full height.
11199  
11200      return setAttributes({
11201        minHeight: 100,
11202        minHeightUnit: 'vh'
11203      });
11204    };
11205  
11206    const toggleParallax = () => {
11207      setAttributes({
11208        hasParallax: !hasParallax,
11209        ...(!hasParallax ? {
11210          focalPoint: undefined
11211        } : {})
11212      });
11213    };
11214  
11215    const toggleIsRepeated = () => {
11216      setAttributes({
11217        isRepeated: !isRepeated
11218      });
11219    };
11220  
11221    const toggleUseFeaturedImage = () => {
11222      setAttributes({
11223        useFeaturedImage: !useFeaturedImage,
11224        dimRatio: dimRatio === 100 ? 50 : dimRatio
11225      });
11226    };
11227  
11228    const onUploadError = message => {
11229      createErrorNotice(Array.isArray(message) ? message[2] : message, {
11230        type: 'snackbar'
11231      });
11232    };
11233  
11234    const isDarkElement = (0,external_wp_element_namespaceObject.useRef)();
11235    const isCoverDark = useCoverIsDark(url, dimRatio, overlayColor.color, isDarkElement);
11236    (0,external_wp_element_namespaceObject.useEffect)(() => {
11237      // This side-effect should not create an undo level.
11238      __unstableMarkNextChangeAsNotPersistent();
11239  
11240      setAttributes({
11241        isDark: isCoverDark
11242      });
11243    }, [isCoverDark]);
11244    const isImageBackground = IMAGE_BACKGROUND_TYPE === backgroundType;
11245    const isVideoBackground = VIDEO_BACKGROUND_TYPE === backgroundType;
11246    const minHeightWithUnit = minHeight && minHeightUnit ? `${minHeight}${minHeightUnit}` : minHeight;
11247    const isImgElement = !(hasParallax || isRepeated);
11248    const style = { ...(isImageBackground && !isImgElement ? backgroundImageStyles(url) : undefined),
11249      minHeight: minHeightWithUnit || undefined
11250    };
11251    const bgStyle = {
11252      backgroundColor: overlayColor.color
11253    };
11254    const mediaStyle = {
11255      objectPosition: focalPoint && isImgElement ? mediaPosition(focalPoint) : undefined
11256    };
11257    const hasBackground = !!(url || overlayColor.color || gradientValue);
11258    const showFocalPointPicker = isVideoBackground || isImageBackground && (!hasParallax || isRepeated);
11259  
11260    const imperativeFocalPointPreview = value => {
11261      const [styleOfRef, property] = isDarkElement.current ? [isDarkElement.current.style, 'objectPosition'] : [ref.current.style, 'backgroundPosition'];
11262      styleOfRef[property] = mediaPosition(value);
11263    };
11264  
11265    const hasInnerBlocks = (0,external_wp_data_namespaceObject.useSelect)(select => select(external_wp_blockEditor_namespaceObject.store).getBlock(clientId).innerBlocks.length > 0, [clientId]);
11266    const controls = (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, {
11267      group: "block"
11268    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.__experimentalBlockAlignmentMatrixControl, {
11269      label: (0,external_wp_i18n_namespaceObject.__)('Change content position'),
11270      value: contentPosition,
11271      onChange: nextPosition => setAttributes({
11272        contentPosition: nextPosition
11273      }),
11274      isDisabled: !hasInnerBlocks
11275    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.__experimentalBlockFullHeightAligmentControl, {
11276      isActive: isMinFullHeight,
11277      onToggle: toggleMinFullHeight,
11278      isDisabled: !hasInnerBlocks
11279    })), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, {
11280      group: "other"
11281    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, {
11282      icon: post_featured_image,
11283      label: (0,external_wp_i18n_namespaceObject.__)('Use featured image'),
11284      isPressed: useFeaturedImage,
11285      onClick: toggleUseFeaturedImage
11286    }), !useFeaturedImage && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.MediaReplaceFlow, {
11287      mediaId: id,
11288      mediaURL: url,
11289      allowedTypes: shared_ALLOWED_MEDIA_TYPES,
11290      accept: "image/*,video/*",
11291      onSelect: onSelectMedia,
11292      name: !url ? (0,external_wp_i18n_namespaceObject.__)('Add Media') : (0,external_wp_i18n_namespaceObject.__)('Replace')
11293    })), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, !!url && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
11294      title: (0,external_wp_i18n_namespaceObject.__)('Media settings')
11295    }, isImageBackground && (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
11296      label: (0,external_wp_i18n_namespaceObject.__)('Fixed background'),
11297      checked: hasParallax,
11298      onChange: toggleParallax
11299    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
11300      label: (0,external_wp_i18n_namespaceObject.__)('Repeated background'),
11301      checked: isRepeated,
11302      onChange: toggleIsRepeated
11303    })), showFocalPointPicker && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.FocalPointPicker, {
11304      label: (0,external_wp_i18n_namespaceObject.__)('Focal point picker'),
11305      url: url,
11306      value: focalPoint,
11307      onDragStart: imperativeFocalPointPreview,
11308      onDrag: imperativeFocalPointPreview,
11309      onChange: newFocalPoint => setAttributes({
11310        focalPoint: newFocalPoint
11311      })
11312    }), !useFeaturedImage && url && isImageBackground && isImgElement && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TextareaControl, {
11313      label: (0,external_wp_i18n_namespaceObject.__)('Alt text (alternative text)'),
11314      value: alt,
11315      onChange: newAlt => setAttributes({
11316        alt: newAlt
11317      }),
11318      help: (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ExternalLink, {
11319        href: "https://www.w3.org/WAI/tutorials/images/decision-tree"
11320      }, (0,external_wp_i18n_namespaceObject.__)('Describe the purpose of the image')), (0,external_wp_i18n_namespaceObject.__)('Leave empty if the image is purely decorative.'))
11321    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelRow, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
11322      variant: "secondary",
11323      isSmall: true,
11324      className: "block-library-cover__reset-button",
11325      onClick: () => setAttributes({
11326        url: undefined,
11327        id: undefined,
11328        backgroundType: undefined,
11329        focalPoint: undefined,
11330        hasParallax: undefined,
11331        isRepeated: undefined,
11332        useFeaturedImage: false
11333      })
11334    }, (0,external_wp_i18n_namespaceObject.__)('Clear Media')))), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.__experimentalPanelColorGradientSettings, {
11335      __experimentalHasMultipleOrigins: true,
11336      __experimentalIsRenderedInSidebar: true,
11337      title: (0,external_wp_i18n_namespaceObject.__)('Overlay'),
11338      initialOpen: true,
11339      settings: [{
11340        colorValue: overlayColor.color,
11341        gradientValue,
11342        onColorChange: setOverlayColor,
11343        onGradientChange: setGradient,
11344        label: (0,external_wp_i18n_namespaceObject.__)('Color')
11345      }]
11346    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.RangeControl, {
11347      label: (0,external_wp_i18n_namespaceObject.__)('Opacity'),
11348      value: dimRatio,
11349      onChange: newDimRation => setAttributes({
11350        dimRatio: newDimRation
11351      }),
11352      min: 0,
11353      max: 100,
11354      step: 10,
11355      required: true
11356    }))), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, {
11357      __experimentalGroup: "dimensions"
11358    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalToolsPanelItem, {
11359      hasValue: () => !!minHeight,
11360      label: (0,external_wp_i18n_namespaceObject.__)('Minimum height'),
11361      onDeselect: () => setAttributes({
11362        minHeight: undefined,
11363        minHeightUnit: undefined
11364      }),
11365      resetAllFilter: () => ({
11366        minHeight: undefined,
11367        minHeightUnit: undefined
11368      }),
11369      isShownByDefault: true,
11370      panelId: clientId
11371    }, (0,external_wp_element_namespaceObject.createElement)(CoverHeightInput, {
11372      value: minHeight,
11373      unit: minHeightUnit,
11374      onChange: newMinHeight => setAttributes({
11375        minHeight: newMinHeight
11376      }),
11377      onUnitChange: nextUnit => setAttributes({
11378        minHeightUnit: nextUnit
11379      })
11380    }))));
11381    const ref = (0,external_wp_element_namespaceObject.useRef)();
11382    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
11383      ref
11384    }); // Check for fontSize support before we pass a fontSize attribute to the innerBlocks.
11385  
11386    const hasFontSizes = !!((_useSetting = (0,external_wp_blockEditor_namespaceObject.useSetting)('typography.fontSizes')) !== null && _useSetting !== void 0 && _useSetting.length);
11387    const innerBlocksTemplate = getInnerBlocksTemplate({
11388      fontSize: hasFontSizes ? 'large' : undefined
11389    });
11390    const innerBlocksProps = (0,external_wp_blockEditor_namespaceObject.useInnerBlocksProps)({
11391      className: 'wp-block-cover__inner-container'
11392    }, {
11393      template: innerBlocksTemplate,
11394      templateInsertUpdatesSelection: true,
11395      allowedBlocks,
11396      templateLock
11397    });
11398  
11399    if (!hasInnerBlocks && !hasBackground) {
11400      return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, controls, (0,external_wp_element_namespaceObject.createElement)("div", _extends({}, blockProps, {
11401        className: classnames_default()('is-placeholder', blockProps.className)
11402      }), (0,external_wp_element_namespaceObject.createElement)(CoverPlaceholder, {
11403        onSelectMedia: onSelectMedia,
11404        onError: onUploadError,
11405        style: {
11406          minHeight: minHeightWithUnit || undefined
11407        }
11408      }, (0,external_wp_element_namespaceObject.createElement)("div", {
11409        className: "wp-block-cover__placeholder-background-options"
11410      }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.ColorPalette, {
11411        disableCustomColors: true,
11412        value: overlayColor.color,
11413        onChange: setOverlayColor,
11414        clearable: false
11415      }))), (0,external_wp_element_namespaceObject.createElement)(ResizableCover, {
11416        className: "block-library-cover__resize-container",
11417        onResizeStart: () => {
11418          setAttributes({
11419            minHeightUnit: 'px'
11420          });
11421          toggleSelection(false);
11422        },
11423        onResize: value => {
11424          setAttributes({
11425            minHeight: value
11426          });
11427        },
11428        onResizeStop: newMinHeight => {
11429          toggleSelection(true);
11430          setAttributes({
11431            minHeight: newMinHeight
11432          });
11433        },
11434        showHandle: isSelected
11435      })));
11436    }
11437  
11438    const classes = classnames_default()({
11439      'is-dark-theme': isDark,
11440      'is-light': !isDark,
11441      'is-transient': isUploadingMedia,
11442      'has-parallax': hasParallax,
11443      'is-repeated': isRepeated,
11444      'has-custom-content-position': !isContentPositionCenter(contentPosition)
11445    }, getPositionClassName(contentPosition));
11446    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, controls, (0,external_wp_element_namespaceObject.createElement)("div", _extends({}, blockProps, {
11447      className: classnames_default()(classes, blockProps.className),
11448      style: { ...style,
11449        ...blockProps.style
11450      },
11451      "data-url": url
11452    }), (0,external_wp_element_namespaceObject.createElement)(BoxControlVisualizer, {
11453      values: styleAttribute === null || styleAttribute === void 0 ? void 0 : (_styleAttribute$spaci = styleAttribute.spacing) === null || _styleAttribute$spaci === void 0 ? void 0 : _styleAttribute$spaci.padding,
11454      showValues: styleAttribute === null || styleAttribute === void 0 ? void 0 : (_styleAttribute$visua = styleAttribute.visualizers) === null || _styleAttribute$visua === void 0 ? void 0 : _styleAttribute$visua.padding,
11455      className: "block-library-cover__padding-visualizer"
11456    }), (0,external_wp_element_namespaceObject.createElement)(ResizableCover, {
11457      className: "block-library-cover__resize-container",
11458      onResizeStart: () => {
11459        setAttributes({
11460          minHeightUnit: 'px'
11461        });
11462        toggleSelection(false);
11463      },
11464      onResize: value => {
11465        setAttributes({
11466          minHeight: value
11467        });
11468      },
11469      onResizeStop: newMinHeight => {
11470        toggleSelection(true);
11471        setAttributes({
11472          minHeight: newMinHeight
11473        });
11474      },
11475      showHandle: isSelected
11476    }), (0,external_wp_element_namespaceObject.createElement)("span", {
11477      "aria-hidden": "true",
11478      className: classnames_default()('wp-block-cover__background', dimRatioToClass(dimRatio), {
11479        [overlayColor.class]: overlayColor.class,
11480        'has-background-dim': dimRatio !== undefined,
11481        // For backwards compatibility. Former versions of the Cover Block applied
11482        // `.wp-block-cover__gradient-background` in the presence of
11483        // media, a gradient and a dim.
11484        'wp-block-cover__gradient-background': url && gradientValue && dimRatio !== 0,
11485        'has-background-gradient': gradientValue,
11486        [gradientClass]: gradientClass
11487      }),
11488      style: {
11489        backgroundImage: gradientValue,
11490        ...bgStyle
11491      }
11492    }), url && isImageBackground && isImgElement && (0,external_wp_element_namespaceObject.createElement)("img", {
11493      ref: isDarkElement,
11494      className: "wp-block-cover__image-background",
11495      alt: alt,
11496      src: url,
11497      style: mediaStyle
11498    }), url && isVideoBackground && (0,external_wp_element_namespaceObject.createElement)("video", {
11499      ref: isDarkElement,
11500      className: "wp-block-cover__video-background",
11501      autoPlay: true,
11502      muted: true,
11503      loop: true,
11504      src: url,
11505      style: mediaStyle
11506    }), isUploadingMedia && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Spinner, null), (0,external_wp_element_namespaceObject.createElement)(CoverPlaceholder, {
11507      disableMediaButtons: true,
11508      onSelectMedia: onSelectMedia,
11509      onError: onUploadError
11510    }), (0,external_wp_element_namespaceObject.createElement)("div", innerBlocksProps)));
11511  }
11512  
11513  /* harmony default export */ var cover_edit = ((0,external_wp_compose_namespaceObject.compose)([(0,external_wp_blockEditor_namespaceObject.withColors)({
11514    overlayColor: 'background-color'
11515  })])(CoverEdit));
11516  
11517  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/cover/save.js
11518  
11519  
11520  /**
11521   * External dependencies
11522   */
11523  
11524  /**
11525   * WordPress dependencies
11526   */
11527  
11528  
11529  /**
11530   * Internal dependencies
11531   */
11532  
11533  
11534  function cover_save_save(_ref) {
11535    let {
11536      attributes
11537    } = _ref;
11538    const {
11539      backgroundType,
11540      gradient,
11541      contentPosition,
11542      customGradient,
11543      customOverlayColor,
11544      dimRatio,
11545      focalPoint,
11546      useFeaturedImage,
11547      hasParallax,
11548      isDark,
11549      isRepeated,
11550      overlayColor,
11551      url,
11552      alt,
11553      id,
11554      minHeight: minHeightProp,
11555      minHeightUnit
11556    } = attributes;
11557    const overlayColorClass = (0,external_wp_blockEditor_namespaceObject.getColorClassName)('background-color', overlayColor);
11558  
11559    const gradientClass = (0,external_wp_blockEditor_namespaceObject.__experimentalGetGradientClass)(gradient);
11560  
11561    const minHeight = minHeightProp && minHeightUnit ? `$minHeightProp}$minHeightUnit}` : minHeightProp;
11562    const isImageBackground = IMAGE_BACKGROUND_TYPE === backgroundType;
11563    const isVideoBackground = VIDEO_BACKGROUND_TYPE === backgroundType;
11564    const isImgElement = !(hasParallax || isRepeated);
11565    const style = { ...(isImageBackground && !isImgElement && !useFeaturedImage ? backgroundImageStyles(url) : {}),
11566      minHeight: minHeight || undefined
11567    };
11568    const bgStyle = {
11569      backgroundColor: !overlayColorClass ? customOverlayColor : undefined,
11570      background: customGradient ? customGradient : undefined
11571    };
11572    const objectPosition = // prettier-ignore
11573    focalPoint && isImgElement ? `$Math.round(focalPoint.x * 100)}% $Math.round(focalPoint.y * 100)}%` : undefined;
11574    const classes = classnames_default()({
11575      'is-light': !isDark,
11576      'has-parallax': hasParallax,
11577      'is-repeated': isRepeated,
11578      'has-custom-content-position': !isContentPositionCenter(contentPosition)
11579    }, getPositionClassName(contentPosition));
11580    const gradientValue = gradient || customGradient;
11581    return (0,external_wp_element_namespaceObject.createElement)("div", external_wp_blockEditor_namespaceObject.useBlockProps.save({
11582      className: classes,
11583      style
11584    }), (0,external_wp_element_namespaceObject.createElement)("span", {
11585      "aria-hidden": "true",
11586      className: classnames_default()('wp-block-cover__background', overlayColorClass, dimRatioToClass(dimRatio), {
11587        'has-background-dim': dimRatio !== undefined,
11588        // For backwards compatibility. Former versions of the Cover Block applied
11589        // `.wp-block-cover__gradient-background` in the presence of
11590        // media, a gradient and a dim.
11591        'wp-block-cover__gradient-background': url && gradientValue && dimRatio !== 0,
11592        'has-background-gradient': gradientValue,
11593        [gradientClass]: gradientClass
11594      }),
11595      style: bgStyle
11596    }), !useFeaturedImage && isImageBackground && isImgElement && url && (0,external_wp_element_namespaceObject.createElement)("img", {
11597      className: classnames_default()('wp-block-cover__image-background', id ? `wp-image-$id}` : null),
11598      alt: alt,
11599      src: url,
11600      style: {
11601        objectPosition
11602      },
11603      "data-object-fit": "cover",
11604      "data-object-position": objectPosition
11605    }), isVideoBackground && url && (0,external_wp_element_namespaceObject.createElement)("video", {
11606      className: classnames_default()('wp-block-cover__video-background', 'intrinsic-ignore'),
11607      autoPlay: true,
11608      muted: true,
11609      loop: true,
11610      playsInline: true,
11611      src: url,
11612      style: {
11613        objectPosition
11614      },
11615      "data-object-fit": "cover",
11616      "data-object-position": objectPosition
11617    }), (0,external_wp_element_namespaceObject.createElement)("div", external_wp_blockEditor_namespaceObject.useInnerBlocksProps.save({
11618      className: 'wp-block-cover__inner-container'
11619    })));
11620  }
11621  
11622  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/cover/transforms.js
11623  /**
11624   * WordPress dependencies
11625   */
11626  
11627  /**
11628   * Internal dependencies
11629   */
11630  
11631  
11632  const cover_transforms_transforms = {
11633    from: [{
11634      type: 'block',
11635      blocks: ['core/image'],
11636      transform: _ref => {
11637        var _style$color;
11638  
11639        let {
11640          caption,
11641          url,
11642          alt,
11643          align,
11644          id,
11645          anchor,
11646          style
11647        } = _ref;
11648        return (0,external_wp_blocks_namespaceObject.createBlock)('core/cover', {
11649          dimRatio: 50,
11650          url,
11651          alt,
11652          align,
11653          id,
11654          anchor,
11655          style: {
11656            color: {
11657              duotone: style === null || style === void 0 ? void 0 : (_style$color = style.color) === null || _style$color === void 0 ? void 0 : _style$color.duotone
11658            }
11659          }
11660        }, [(0,external_wp_blocks_namespaceObject.createBlock)('core/paragraph', {
11661          content: caption,
11662          fontSize: 'large',
11663          align: 'center'
11664        })]);
11665      }
11666    }, {
11667      type: 'block',
11668      blocks: ['core/video'],
11669      transform: _ref2 => {
11670        let {
11671          caption,
11672          src,
11673          align,
11674          id,
11675          anchor
11676        } = _ref2;
11677        return (0,external_wp_blocks_namespaceObject.createBlock)('core/cover', {
11678          dimRatio: 50,
11679          url: src,
11680          align,
11681          id,
11682          backgroundType: VIDEO_BACKGROUND_TYPE,
11683          anchor
11684        }, [(0,external_wp_blocks_namespaceObject.createBlock)('core/paragraph', {
11685          content: caption,
11686          fontSize: 'large',
11687          align: 'center'
11688        })]);
11689      }
11690    }, {
11691      type: 'block',
11692      blocks: ['core/group'],
11693      transform: (attributes, innerBlocks) => {
11694        var _style$color2, _style$color3, _style$color4, _style$color5, _attributes$style;
11695  
11696        const {
11697          align,
11698          anchor,
11699          backgroundColor,
11700          gradient,
11701          style
11702        } = attributes; // If no background or gradient color is provided, default to 50% opacity.
11703        // This matches the styling of a Cover block with a background image,
11704        // in the state where a background image has been removed.
11705  
11706        const dimRatio = backgroundColor || gradient || style !== null && style !== void 0 && (_style$color2 = style.color) !== null && _style$color2 !== void 0 && _style$color2.background || style !== null && style !== void 0 && (_style$color3 = style.color) !== null && _style$color3 !== void 0 && _style$color3.gradient ? undefined : 50; // Move the background or gradient color to the parent Cover block.
11707  
11708        const parentAttributes = {
11709          align,
11710          anchor,
11711          dimRatio,
11712          overlayColor: backgroundColor,
11713          customOverlayColor: style === null || style === void 0 ? void 0 : (_style$color4 = style.color) === null || _style$color4 === void 0 ? void 0 : _style$color4.background,
11714          gradient,
11715          customGradient: style === null || style === void 0 ? void 0 : (_style$color5 = style.color) === null || _style$color5 === void 0 ? void 0 : _style$color5.gradient
11716        };
11717        const attributesWithoutBackgroundColors = { ...attributes,
11718          backgroundColor: undefined,
11719          gradient: undefined,
11720          style: { ...(attributes === null || attributes === void 0 ? void 0 : attributes.style),
11721            color: { ...(attributes === null || attributes === void 0 ? void 0 : (_attributes$style = attributes.style) === null || _attributes$style === void 0 ? void 0 : _attributes$style.color),
11722              background: undefined,
11723              gradient: undefined
11724            }
11725          }
11726        }; // Preserve the block by nesting it within the Cover block,
11727        // instead of converting the Group block directly to the Cover block.
11728  
11729        return (0,external_wp_blocks_namespaceObject.createBlock)('core/cover', parentAttributes, [(0,external_wp_blocks_namespaceObject.createBlock)('core/group', attributesWithoutBackgroundColors, innerBlocks)]);
11730      }
11731    }],
11732    to: [{
11733      type: 'block',
11734      blocks: ['core/image'],
11735      isMatch: _ref3 => {
11736        let {
11737          backgroundType,
11738          url,
11739          overlayColor,
11740          customOverlayColor,
11741          gradient,
11742          customGradient
11743        } = _ref3;
11744  
11745        if (url) {
11746          // If a url exists the transform could happen if that URL represents an image background.
11747          return backgroundType === IMAGE_BACKGROUND_TYPE;
11748        } // If a url is not set the transform could happen if the cover has no background color or gradient;
11749  
11750  
11751        return !overlayColor && !customOverlayColor && !gradient && !customGradient;
11752      },
11753      transform: _ref4 => {
11754        var _style$color6;
11755  
11756        let {
11757          title,
11758          url,
11759          alt,
11760          align,
11761          id,
11762          anchor,
11763          style
11764        } = _ref4;
11765        return (0,external_wp_blocks_namespaceObject.createBlock)('core/image', {
11766          caption: title,
11767          url,
11768          alt,
11769          align,
11770          id,
11771          anchor,
11772          style: {
11773            color: {
11774              duotone: style === null || style === void 0 ? void 0 : (_style$color6 = style.color) === null || _style$color6 === void 0 ? void 0 : _style$color6.duotone
11775            }
11776          }
11777        });
11778      }
11779    }, {
11780      type: 'block',
11781      blocks: ['core/video'],
11782      isMatch: _ref5 => {
11783        let {
11784          backgroundType,
11785          url,
11786          overlayColor,
11787          customOverlayColor,
11788          gradient,
11789          customGradient
11790        } = _ref5;
11791  
11792        if (url) {
11793          // If a url exists the transform could happen if that URL represents a video background.
11794          return backgroundType === VIDEO_BACKGROUND_TYPE;
11795        } // If a url is not set the transform could happen if the cover has no background color or gradient;
11796  
11797  
11798        return !overlayColor && !customOverlayColor && !gradient && !customGradient;
11799      },
11800      transform: _ref6 => {
11801        let {
11802          title,
11803          url,
11804          align,
11805          id,
11806          anchor
11807        } = _ref6;
11808        return (0,external_wp_blocks_namespaceObject.createBlock)('core/video', {
11809          caption: title,
11810          src: url,
11811          id,
11812          align,
11813          anchor
11814        });
11815      }
11816    }]
11817  };
11818  /* harmony default export */ var cover_transforms = (cover_transforms_transforms);
11819  
11820  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/cover/index.js
11821  /**
11822   * WordPress dependencies
11823   */
11824  
11825  
11826  /**
11827   * Internal dependencies
11828   */
11829  
11830  
11831  
11832  const cover_metadata = {
11833    $schema: "https://schemas.wp.org/trunk/block.json",
11834    apiVersion: 2,
11835    name: "core/cover",
11836    title: "Cover",
11837    category: "media",
11838    description: "Add an image or video with a text overlay \u2014 great for headers.",
11839    textdomain: "default",
11840    attributes: {
11841      url: {
11842        type: "string"
11843      },
11844      useFeaturedImage: {
11845        type: "boolean",
11846        "default": false
11847      },
11848      id: {
11849        type: "number"
11850      },
11851      alt: {
11852        type: "string",
11853        source: "attribute",
11854        selector: "img",
11855        attribute: "alt",
11856        "default": ""
11857      },
11858      hasParallax: {
11859        type: "boolean",
11860        "default": false
11861      },
11862      isRepeated: {
11863        type: "boolean",
11864        "default": false
11865      },
11866      dimRatio: {
11867        type: "number",
11868        "default": 100
11869      },
11870      overlayColor: {
11871        type: "string"
11872      },
11873      customOverlayColor: {
11874        type: "string"
11875      },
11876      backgroundType: {
11877        type: "string",
11878        "default": "image"
11879      },
11880      focalPoint: {
11881        type: "object"
11882      },
11883      minHeight: {
11884        type: "number"
11885      },
11886      minHeightUnit: {
11887        type: "string"
11888      },
11889      gradient: {
11890        type: "string"
11891      },
11892      customGradient: {
11893        type: "string"
11894      },
11895      contentPosition: {
11896        type: "string"
11897      },
11898      isDark: {
11899        type: "boolean",
11900        "default": true
11901      },
11902      allowedBlocks: {
11903        type: "array"
11904      },
11905      templateLock: {
11906        type: ["string", "boolean"],
11907        "enum": ["all", "insert", false]
11908      }
11909    },
11910    usesContext: ["postId", "postType"],
11911    supports: {
11912      anchor: true,
11913      align: true,
11914      html: false,
11915      spacing: {
11916        padding: true,
11917        __experimentalDefaultControls: {
11918          padding: true
11919        }
11920      },
11921      color: {
11922        __experimentalDuotone: "> .wp-block-cover__image-background, > .wp-block-cover__video-background",
11923        text: false,
11924        background: false
11925      }
11926    },
11927    editorStyle: "wp-block-cover-editor",
11928    style: "wp-block-cover"
11929  };
11930  
11931  
11932  const {
11933    name: cover_name
11934  } = cover_metadata;
11935  
11936  const cover_settings = {
11937    icon: library_cover,
11938    example: {
11939      attributes: {
11940        customOverlayColor: '#065174',
11941        dimRatio: 40,
11942        url: 'https://s.w.org/images/core/5.3/Windbuchencom.jpg'
11943      },
11944      innerBlocks: [{
11945        name: 'core/paragraph',
11946        attributes: {
11947          customFontSize: 48,
11948          content: (0,external_wp_i18n_namespaceObject.__)('<strong>Snow Patrol</strong>'),
11949          align: 'center'
11950        }
11951      }]
11952    },
11953    transforms: cover_transforms,
11954    save: cover_save_save,
11955    edit: cover_edit,
11956    deprecated: cover_deprecated
11957  };
11958  
11959  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/pencil.js
11960  
11961  
11962  /**
11963   * WordPress dependencies
11964   */
11965  
11966  const pencil = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
11967    xmlns: "http://www.w3.org/2000/svg",
11968    viewBox: "0 0 24 24"
11969  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
11970    d: "M20.1 5.1L16.9 2 6.2 12.7l-1.3 4.4 4.5-1.3L20.1 5.1zM4 20.8h8v-1.5H4v1.5z"
11971  }));
11972  /* harmony default export */ var library_pencil = (pencil);
11973  
11974  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/edit.js
11975  /**
11976   * Internal dependencies
11977   */
11978  
11979  /* harmony default export */ var library_edit = (library_pencil);
11980  
11981  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/embed/embed-controls.js
11982  
11983  
11984  /**
11985   * WordPress dependencies
11986   */
11987  
11988  
11989  
11990  
11991  
11992  function getResponsiveHelp(checked) {
11993    return checked ? (0,external_wp_i18n_namespaceObject.__)('This embed will preserve its aspect ratio when the browser is resized.') : (0,external_wp_i18n_namespaceObject.__)('This embed may not preserve its aspect ratio when the browser is resized.');
11994  }
11995  
11996  const EmbedControls = _ref => {
11997    let {
11998      blockSupportsResponsive,
11999      showEditButton,
12000      themeSupportsResponsive,
12001      allowResponsive,
12002      toggleResponsive,
12003      switchBackToURLInput
12004    } = _ref;
12005    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarGroup, null, showEditButton && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, {
12006      className: "components-toolbar__control",
12007      label: (0,external_wp_i18n_namespaceObject.__)('Edit URL'),
12008      icon: library_edit,
12009      onClick: switchBackToURLInput
12010    }))), themeSupportsResponsive && blockSupportsResponsive && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
12011      title: (0,external_wp_i18n_namespaceObject.__)('Media settings'),
12012      className: "blocks-responsive"
12013    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
12014      label: (0,external_wp_i18n_namespaceObject.__)('Resize for smaller devices'),
12015      checked: allowResponsive,
12016      help: getResponsiveHelp,
12017      onChange: toggleResponsive
12018    }))));
12019  };
12020  
12021  /* harmony default export */ var embed_controls = (EmbedControls);
12022  
12023  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/embed/icons.js
12024  
12025  
12026  /**
12027   * WordPress dependencies
12028   */
12029  
12030  const embedContentIcon = (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, {
12031    viewBox: "0 0 24 24",
12032    xmlns: "http://www.w3.org/2000/svg"
12033  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
12034    d: "M19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm.5 16c0 .3-.2.5-.5.5H5c-.3 0-.5-.2-.5-.5V9.8l4.7-5.3H19c.3 0 .5.2.5.5v14zm-6-9.5L16 12l-2.5 2.8 1.1 1L18 12l-3.5-3.5-1 1zm-3 0l-1-1L6 12l3.5 3.8 1.1-1L8 12l2.5-2.5z"
12035  }));
12036  const embedAudioIcon = (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, {
12037    viewBox: "0 0 24 24",
12038    xmlns: "http://www.w3.org/2000/svg"
12039  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
12040    d: "M19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm.5 16c0 .3-.2.5-.5.5H5c-.3 0-.5-.2-.5-.5V9.8l4.7-5.3H19c.3 0 .5.2.5.5v14zM13.2 7.7c-.4.4-.7 1.1-.7 1.9v3.7c-.4-.3-.8-.4-1.3-.4-1.2 0-2.2 1-2.2 2.2 0 1.2 1 2.2 2.2 2.2.5 0 1-.2 1.4-.5.9-.6 1.4-1.6 1.4-2.6V9.6c0-.4.1-.6.2-.8.3-.3 1-.3 1.6-.3h.2V7h-.2c-.7 0-1.8 0-2.6.7z"
12041  }));
12042  const embedPhotoIcon = (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, {
12043    viewBox: "0 0 24 24",
12044    xmlns: "http://www.w3.org/2000/svg"
12045  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
12046    d: "M19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zM9.2 4.5H19c.3 0 .5.2.5.5v8.4l-3-2.9c-.3-.3-.8-.3-1 0L11.9 14 9 12c-.3-.2-.6-.2-.8 0l-3.6 2.6V9.8l4.6-5.3zm9.8 15H5c-.3 0-.5-.2-.5-.5v-2.4l4.1-3 3 1.9c.3.2.7.2.9-.1L16 12l3.5 3.4V19c0 .3-.2.5-.5.5z"
12047  }));
12048  const embedVideoIcon = (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, {
12049    viewBox: "0 0 24 24",
12050    xmlns: "http://www.w3.org/2000/svg"
12051  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
12052    d: "M19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm.5 16c0 .3-.2.5-.5.5H5c-.3 0-.5-.2-.5-.5V9.8l4.7-5.3H19c.3 0 .5.2.5.5v14zM10 15l5-3-5-3v6z"
12053  }));
12054  const embedTwitterIcon = {
12055    foreground: '#1da1f2',
12056    src: (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, {
12057      xmlns: "http://www.w3.org/2000/svg",
12058      viewBox: "0 0 24 24"
12059    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.G, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
12060      d: "M22.23 5.924c-.736.326-1.527.547-2.357.646.847-.508 1.498-1.312 1.804-2.27-.793.47-1.67.812-2.606.996C18.325 4.498 17.258 4 16.078 4c-2.266 0-4.103 1.837-4.103 4.103 0 .322.036.635.106.935-3.41-.17-6.433-1.804-8.457-4.287-.353.607-.556 1.312-.556 2.064 0 1.424.724 2.68 1.825 3.415-.673-.022-1.305-.207-1.86-.514v.052c0 1.988 1.415 3.647 3.293 4.023-.344.095-.707.145-1.08.145-.265 0-.522-.026-.773-.074.522 1.63 2.038 2.817 3.833 2.85-1.404 1.1-3.174 1.757-5.096 1.757-.332 0-.66-.02-.98-.057 1.816 1.164 3.973 1.843 6.29 1.843 7.547 0 11.675-6.252 11.675-11.675 0-.178-.004-.355-.012-.53.802-.578 1.497-1.3 2.047-2.124z"
12061    })))
12062  };
12063  const embedYouTubeIcon = {
12064    foreground: '#ff0000',
12065    src: (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, {
12066      viewBox: "0 0 24 24"
12067    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
12068      d: "M21.8 8s-.195-1.377-.795-1.984c-.76-.797-1.613-.8-2.004-.847-2.798-.203-6.996-.203-6.996-.203h-.01s-4.197 0-6.996.202c-.39.046-1.242.05-2.003.846C2.395 6.623 2.2 8 2.2 8S2 9.62 2 11.24v1.517c0 1.618.2 3.237.2 3.237s.195 1.378.795 1.985c.76.797 1.76.77 2.205.855 1.6.153 6.8.2 6.8.2s4.203-.005 7-.208c.392-.047 1.244-.05 2.005-.847.6-.607.795-1.985.795-1.985s.2-1.618.2-3.237v-1.517C22 9.62 21.8 8 21.8 8zM9.935 14.595v-5.62l5.403 2.82-5.403 2.8z"
12069    }))
12070  };
12071  const embedFacebookIcon = {
12072    foreground: '#3b5998',
12073    src: (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, {
12074      viewBox: "0 0 24 24"
12075    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
12076      d: "M20 3H4c-.6 0-1 .4-1 1v16c0 .5.4 1 1 1h8.6v-7h-2.3v-2.7h2.3v-2c0-2.3 1.4-3.6 3.5-3.6 1 0 1.8.1 2.1.1v2.4h-1.4c-1.1 0-1.3.5-1.3 1.3v1.7h2.7l-.4 2.8h-2.3v7H20c.5 0 1-.4 1-1V4c0-.6-.4-1-1-1z"
12077    }))
12078  };
12079  const embedInstagramIcon = (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, {
12080    viewBox: "0 0 24 24"
12081  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.G, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
12082    d: "M12 4.622c2.403 0 2.688.01 3.637.052.877.04 1.354.187 1.67.31.42.163.72.358 1.036.673.315.315.51.615.673 1.035.123.317.27.794.31 1.67.043.95.052 1.235.052 3.638s-.01 2.688-.052 3.637c-.04.877-.187 1.354-.31 1.67-.163.42-.358.72-.673 1.036-.315.315-.615.51-1.035.673-.317.123-.794.27-1.67.31-.95.043-1.234.052-3.638.052s-2.688-.01-3.637-.052c-.877-.04-1.354-.187-1.67-.31-.42-.163-.72-.358-1.036-.673-.315-.315-.51-.615-.673-1.035-.123-.317-.27-.794-.31-1.67-.043-.95-.052-1.235-.052-3.638s.01-2.688.052-3.637c.04-.877.187-1.354.31-1.67.163-.42.358-.72.673-1.036.315-.315.615-.51 1.035-.673.317-.123.794-.27 1.67-.31.95-.043 1.235-.052 3.638-.052M12 3c-2.444 0-2.75.01-3.71.054s-1.613.196-2.185.418c-.592.23-1.094.538-1.594 1.04-.5.5-.807 1-1.037 1.593-.223.572-.375 1.226-.42 2.184C3.01 9.25 3 9.555 3 12s.01 2.75.054 3.71.196 1.613.418 2.186c.23.592.538 1.094 1.038 1.594s1.002.808 1.594 1.038c.572.222 1.227.375 2.185.418.96.044 1.266.054 3.71.054s2.75-.01 3.71-.054 1.613-.196 2.186-.418c.592-.23 1.094-.538 1.594-1.038s.808-1.002 1.038-1.594c.222-.572.375-1.227.418-2.185.044-.96.054-1.266.054-3.71s-.01-2.75-.054-3.71-.196-1.613-.418-2.186c-.23-.592-.538-1.094-1.038-1.594s-1.002-.808-1.594-1.038c-.572-.222-1.227-.375-2.185-.418C14.75 3.01 14.445 3 12 3zm0 4.378c-2.552 0-4.622 2.07-4.622 4.622s2.07 4.622 4.622 4.622 4.622-2.07 4.622-4.622S14.552 7.378 12 7.378zM12 15c-1.657 0-3-1.343-3-3s1.343-3 3-3 3 1.343 3 3-1.343 3-3 3zm4.804-8.884c-.596 0-1.08.484-1.08 1.08s.484 1.08 1.08 1.08c.596 0 1.08-.484 1.08-1.08s-.483-1.08-1.08-1.08z"
12083  })));
12084  const embedWordPressIcon = {
12085    foreground: '#0073AA',
12086    src: (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, {
12087      viewBox: "0 0 24 24"
12088    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.G, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
12089      d: "M12.158 12.786l-2.698 7.84c.806.236 1.657.365 2.54.365 1.047 0 2.05-.18 2.986-.51-.024-.037-.046-.078-.065-.123l-2.762-7.57zM3.008 12c0 3.56 2.07 6.634 5.068 8.092L3.788 8.342c-.5 1.117-.78 2.354-.78 3.658zm15.06-.454c0-1.112-.398-1.88-.74-2.48-.456-.74-.883-1.368-.883-2.11 0-.825.627-1.595 1.51-1.595.04 0 .078.006.116.008-1.598-1.464-3.73-2.36-6.07-2.36-3.14 0-5.904 1.613-7.512 4.053.21.008.41.012.58.012.94 0 2.395-.114 2.395-.114.484-.028.54.684.057.74 0 0-.487.058-1.03.086l3.275 9.74 1.968-5.902-1.4-3.838c-.485-.028-.944-.085-.944-.085-.486-.03-.43-.77.056-.742 0 0 1.484.114 2.368.114.94 0 2.397-.114 2.397-.114.486-.028.543.684.058.74 0 0-.488.058-1.03.086l3.25 9.665.897-2.997c.456-1.17.684-2.137.684-2.907zm1.82-3.86c.04.286.06.593.06.924 0 .912-.17 1.938-.683 3.22l-2.746 7.94c2.672-1.558 4.47-4.454 4.47-7.77 0-1.564-.4-3.033-1.1-4.314zM12 22C6.486 22 2 17.514 2 12S6.486 2 12 2s10 4.486 10 10-4.486 10-10 10z"
12090    })))
12091  };
12092  const embedSpotifyIcon = {
12093    foreground: '#1db954',
12094    src: (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, {
12095      viewBox: "0 0 24 24"
12096    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
12097      d: "M12 2C6.477 2 2 6.477 2 12s4.477 10 10 10 10-4.477 10-10S17.523 2 12 2m4.586 14.424c-.18.295-.563.387-.857.207-2.35-1.434-5.305-1.76-8.786-.963-.335.077-.67-.133-.746-.47-.077-.334.132-.67.47-.745 3.808-.87 7.076-.496 9.712 1.115.293.18.386.563.206.857M17.81 13.7c-.226.367-.706.482-1.072.257-2.687-1.652-6.785-2.13-9.965-1.166-.413.127-.848-.106-.973-.517-.125-.413.108-.848.52-.973 3.632-1.102 8.147-.568 11.234 1.328.366.226.48.707.256 1.072m.105-2.835C14.692 8.95 9.375 8.775 6.297 9.71c-.493.15-1.016-.13-1.166-.624-.148-.495.13-1.017.625-1.167 3.532-1.073 9.404-.866 13.115 1.337.445.264.59.838.327 1.282-.264.443-.838.59-1.282.325"
12098    }))
12099  };
12100  const embedFlickrIcon = (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, {
12101    viewBox: "0 0 24 24"
12102  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
12103    d: "m6.5 7c-2.75 0-5 2.25-5 5s2.25 5 5 5 5-2.25 5-5-2.25-5-5-5zm11 0c-2.75 0-5 2.25-5 5s2.25 5 5 5 5-2.25 5-5-2.25-5-5-5z"
12104  }));
12105  const embedVimeoIcon = {
12106    foreground: '#1ab7ea',
12107    src: (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, {
12108      xmlns: "http://www.w3.org/2000/svg",
12109      viewBox: "0 0 24 24"
12110    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.G, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
12111      d: "M22.396 7.164c-.093 2.026-1.507 4.8-4.245 8.32C15.323 19.16 12.93 21 10.97 21c-1.214 0-2.24-1.12-3.08-3.36-.56-2.052-1.118-4.105-1.68-6.158-.622-2.24-1.29-3.36-2.004-3.36-.156 0-.7.328-1.634.98l-.978-1.26c1.027-.903 2.04-1.806 3.037-2.71C6 3.95 7.03 3.328 7.716 3.265c1.62-.156 2.616.95 2.99 3.32.404 2.558.685 4.148.84 4.77.468 2.12.982 3.18 1.543 3.18.435 0 1.09-.687 1.963-2.064.872-1.376 1.34-2.422 1.402-3.142.125-1.187-.343-1.782-1.4-1.782-.5 0-1.013.115-1.542.34 1.023-3.35 2.977-4.976 5.862-4.883 2.14.063 3.148 1.45 3.024 4.16z"
12112    })))
12113  };
12114  const embedRedditIcon = (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, {
12115    viewBox: "0 0 24 24"
12116  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
12117    d: "M22 11.816c0-1.256-1.02-2.277-2.277-2.277-.593 0-1.122.24-1.526.613-1.48-.965-3.455-1.594-5.647-1.69l1.17-3.702 3.18.75c.01 1.027.847 1.86 1.877 1.86 1.035 0 1.877-.84 1.877-1.877 0-1.035-.842-1.877-1.877-1.877-.77 0-1.43.466-1.72 1.13L13.55 3.92c-.204-.047-.4.067-.46.26l-1.35 4.27c-2.317.037-4.412.67-5.97 1.67-.402-.355-.917-.58-1.493-.58C3.02 9.54 2 10.56 2 11.815c0 .814.433 1.523 1.078 1.925-.037.222-.06.445-.06.673 0 3.292 4.01 5.97 8.94 5.97s8.94-2.678 8.94-5.97c0-.214-.02-.424-.052-.632.687-.39 1.154-1.12 1.154-1.964zm-3.224-7.422c.606 0 1.1.493 1.1 1.1s-.493 1.1-1.1 1.1-1.1-.494-1.1-1.1.493-1.1 1.1-1.1zm-16 7.422c0-.827.673-1.5 1.5-1.5.313 0 .598.103.838.27-.85.675-1.477 1.478-1.812 2.36-.32-.274-.525-.676-.525-1.13zm9.183 7.79c-4.502 0-8.165-2.33-8.165-5.193S7.457 9.22 11.96 9.22s8.163 2.33 8.163 5.193-3.663 5.193-8.164 5.193zM20.635 13c-.326-.89-.948-1.7-1.797-2.383.247-.186.55-.3.882-.3.827 0 1.5.672 1.5 1.5 0 .482-.23.91-.586 1.184zm-11.64 1.704c-.76 0-1.397-.616-1.397-1.376 0-.76.636-1.397 1.396-1.397.76 0 1.376.638 1.376 1.398 0 .76-.616 1.376-1.376 1.376zm7.405-1.376c0 .76-.615 1.376-1.375 1.376s-1.4-.616-1.4-1.376c0-.76.64-1.397 1.4-1.397.76 0 1.376.638 1.376 1.398zm-1.17 3.38c.15.152.15.398 0 .55-.675.674-1.728 1.002-3.22 1.002l-.01-.002-.012.002c-1.492 0-2.544-.328-3.218-1.002-.152-.152-.152-.398 0-.55.152-.152.4-.15.55 0 .52.52 1.394.775 2.67.775l.01.002.01-.002c1.276 0 2.15-.253 2.67-.775.15-.152.398-.152.55 0z"
12118  }));
12119  const embedTumblrIcon = {
12120    foreground: '#35465c',
12121    src: (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, {
12122      viewBox: "0 0 24 24"
12123    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
12124      d: "M19 3H5a2 2 0 00-2 2v14c0 1.1.9 2 2 2h14a2 2 0 002-2V5a2 2 0 00-2-2zm-5.69 14.66c-2.72 0-3.1-1.9-3.1-3.16v-3.56H8.49V8.99c1.7-.62 2.54-1.99 2.64-2.87 0-.06.06-.41.06-.58h1.9v3.1h2.17v2.3h-2.18v3.1c0 .47.13 1.3 1.2 1.26h1.1v2.36c-1.01.02-2.07 0-2.07 0z"
12125    }))
12126  };
12127  const embedAmazonIcon = (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, {
12128    viewBox: "0 0 24 24"
12129  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
12130    d: "M18.42 14.58c-.51-.66-1.05-1.23-1.05-2.5V7.87c0-1.8.15-3.45-1.2-4.68-1.05-1.02-2.79-1.35-4.14-1.35-2.6 0-5.52.96-6.12 4.14-.06.36.18.54.4.57l2.66.3c.24-.03.42-.27.48-.5.24-1.12 1.17-1.63 2.2-1.63.56 0 1.22.21 1.55.7.4.56.33 1.31.33 1.97v.36c-1.59.18-3.66.27-5.16.93a4.63 4.63 0 0 0-2.93 4.44c0 2.82 1.8 4.23 4.1 4.23 1.95 0 3.03-.45 4.53-1.98.51.72.66 1.08 1.59 1.83.18.09.45.09.63-.1v.04l2.1-1.8c.24-.21.2-.48.03-.75zm-5.4-1.2c-.45.75-1.14 1.23-1.92 1.23-1.05 0-1.65-.81-1.65-1.98 0-2.31 2.1-2.73 4.08-2.73v.6c0 1.05.03 1.92-.5 2.88z"
12131  }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
12132    d: "M21.69 19.2a17.62 17.62 0 0 1-21.6-1.57c-.23-.2 0-.5.28-.33a23.88 23.88 0 0 0 20.93 1.3c.45-.19.84.3.39.6z"
12133  }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
12134    d: "M22.8 17.96c-.36-.45-2.22-.2-3.1-.12-.23.03-.3-.18-.05-.36 1.5-1.05 3.96-.75 4.26-.39.3.36-.1 2.82-1.5 4.02-.21.18-.42.1-.3-.15.3-.8 1.02-2.58.69-3z"
12135  }));
12136  const embedAnimotoIcon = (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, {
12137    viewBox: "0 0 24 24"
12138  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
12139    d: "m.0206909 21 19.8160091-13.07806 3.5831 6.20826z",
12140    fill: "#4bc7ee"
12141  }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
12142    d: "m23.7254 19.0205-10.1074-17.18468c-.6421-1.114428-1.7087-1.114428-2.3249 0l-11.2931 19.16418h22.5655c1.279 0 1.8019-.8905 1.1599-1.9795z",
12143    fill: "#d4cdcb"
12144  }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
12145    d: "m.0206909 21 15.2439091-16.38571 4.3029 7.32271z",
12146    fill: "#c3d82e"
12147  }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
12148    d: "m13.618 1.83582c-.6421-1.114428-1.7087-1.114428-2.3249 0l-11.2931 19.16418 15.2646-16.38573z",
12149    fill: "#e4ecb0"
12150  }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
12151    d: "m.0206909 21 19.5468091-9.063 1.6621 2.8344z",
12152    fill: "#209dbd"
12153  }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
12154    d: "m.0206909 21 17.9209091-11.82623 1.6259 2.76323z",
12155    fill: "#7cb3c9"
12156  }));
12157  const embedDailymotionIcon = (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, {
12158    viewBox: "0 0 24 24"
12159  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
12160    d: "m12.1479 18.5957c-2.4949 0-4.28131-1.7558-4.28131-4.0658 0-2.2176 1.78641-4.0965 4.09651-4.0965 2.2793 0 4.0349 1.7864 4.0349 4.1581 0 2.2794-1.7556 4.0042-3.8501 4.0042zm8.3521-18.5957-4.5329 1v7c-1.1088-1.41691-2.8028-1.8787-4.8049-1.8787-2.09443 0-3.97329.76993-5.5133 2.27917-1.72483 1.66323-2.6489 3.78863-2.6489 6.16033 0 2.5873.98562 4.8049 2.89526 6.499 1.44763 1.2936 3.17251 1.9402 5.17454 1.9402 1.9713 0 3.4498-.5236 4.8973-1.9402v1.9402h4.5329c0-7.6359 0-15.3641 0-23z",
12161    fill: "#333436"
12162  }));
12163  const embedPinterestIcon = (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, {
12164    width: "24",
12165    height: "24",
12166    viewBox: "0 0 24 24",
12167    version: "1.1"
12168  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
12169    d: "M12.289,2C6.617,2,3.606,5.648,3.606,9.622c0,1.846,1.025,4.146,2.666,4.878c0.25,0.111,0.381,0.063,0.439-0.169 c0.044-0.175,0.267-1.029,0.365-1.428c0.032-0.128,0.017-0.237-0.091-0.362C6.445,11.911,6.01,10.75,6.01,9.668 c0-2.777,2.194-5.464,5.933-5.464c3.23,0,5.49,2.108,5.49,5.122c0,3.407-1.794,5.768-4.13,5.768c-1.291,0-2.257-1.021-1.948-2.277 c0.372-1.495,1.089-3.112,1.089-4.191c0-0.967-0.542-1.775-1.663-1.775c-1.319,0-2.379,1.309-2.379,3.059 c0,1.115,0.394,1.869,0.394,1.869s-1.302,5.279-1.54,6.261c-0.405,1.666,0.053,4.368,0.094,4.604 c0.021,0.126,0.167,0.169,0.25,0.063c0.129-0.165,1.699-2.419,2.142-4.051c0.158-0.59,0.817-2.995,0.817-2.995 c0.43,0.784,1.681,1.446,3.013,1.446c3.963,0,6.822-3.494,6.822-7.833C20.394,5.112,16.849,2,12.289,2"
12170  }));
12171  const embedWolframIcon = (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, {
12172    viewBox: "0 0 44 44"
12173  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
12174    d: "M32.59521,22.001l4.31885-4.84473-6.34131-1.38379.646-6.459-5.94336,2.61035L22,6.31934l-3.27344,5.60351L12.78418,9.3125l.645,6.458L7.08643,17.15234,11.40479,21.999,7.08594,26.84375l6.34131,1.38379-.64551,6.458,5.94287-2.60938L22,37.68066l3.27344-5.60351,5.94287,2.61035-.64551-6.458,6.34277-1.38183Zm.44385,2.75244L30.772,23.97827l-1.59558-2.07391,1.97888.735Zm-8.82147,6.1579L22.75,33.424V30.88977l1.52228-2.22168ZM18.56226,13.48816,19.819,15.09534l-2.49219-.88642L15.94037,12.337Zm6.87719.00116,2.62043-1.15027-1.38654,1.86981L24.183,15.0946Zm3.59357,2.6029-1.22546,1.7381.07525-2.73486,1.44507-1.94867ZM22,29.33008l-2.16406-3.15686L22,23.23688l2.16406,2.93634Zm-4.25458-9.582-.10528-3.836,3.60986,1.284v3.73242Zm5.00458-2.552,3.60986-1.284-.10528,3.836L22.75,20.92853Zm-7.78174-1.10559-.29352-2.94263,1.44245,1.94739.07519,2.73321Zm2.30982,5.08319,3.50817,1.18164-2.16247,2.9342-3.678-1.08447Zm2.4486,7.49285L21.25,30.88977v2.53485L19.78052,30.91Zm3.48707-6.31121,3.50817-1.18164,2.33228,3.03137-3.678,1.08447Zm10.87219-4.28113-2.714,3.04529L28.16418,19.928l1.92176-2.72565ZM24.06036,12.81769l-2.06012,2.6322-2.059-2.63318L22,9.292ZM9.91455,18.07227l4.00079-.87195,1.921,2.72735-3.20794,1.19019Zm2.93024,4.565,1.9801-.73462L13.228,23.97827l-2.26838.77429Zm-1.55591,3.58819L13.701,25.4021l2.64935.78058-2.14447.67853Zm3.64868,1.977L18.19,27.17334l.08313,3.46332L14.52979,32.2793Zm10.7876,2.43549.08447-3.464,3.25165,1.03052.407,4.07684Zm4.06824-3.77478-2.14545-.68,2.65063-.781,2.41266.825Z"
12175  }));
12176  
12177  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/embed/embed-loading.js
12178  
12179  
12180  /**
12181   * WordPress dependencies
12182   */
12183  
12184  
12185  const EmbedLoading = () => (0,external_wp_element_namespaceObject.createElement)("div", {
12186    className: "wp-block-embed is-loading"
12187  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Spinner, null));
12188  
12189  /* harmony default export */ var embed_loading = (EmbedLoading);
12190  
12191  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/embed/embed-placeholder.js
12192  
12193  
12194  /**
12195   * WordPress dependencies
12196   */
12197  
12198  
12199  
12200  
12201  const EmbedPlaceholder = _ref => {
12202    let {
12203      icon,
12204      label,
12205      value,
12206      onSubmit,
12207      onChange,
12208      cannotEmbed,
12209      fallback,
12210      tryAgain
12211    } = _ref;
12212    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Placeholder, {
12213      icon: (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockIcon, {
12214        icon: icon,
12215        showColors: true
12216      }),
12217      label: label,
12218      className: "wp-block-embed",
12219      instructions: (0,external_wp_i18n_namespaceObject.__)('Paste a link to the content you want to display on your site.')
12220    }, (0,external_wp_element_namespaceObject.createElement)("form", {
12221      onSubmit: onSubmit
12222    }, (0,external_wp_element_namespaceObject.createElement)("input", {
12223      type: "url",
12224      value: value || '',
12225      className: "components-placeholder__input",
12226      "aria-label": label,
12227      placeholder: (0,external_wp_i18n_namespaceObject.__)('Enter URL to embed here…'),
12228      onChange: onChange
12229    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
12230      variant: "primary",
12231      type: "submit"
12232    }, (0,external_wp_i18n_namespaceObject._x)('Embed', 'button label'))), (0,external_wp_element_namespaceObject.createElement)("div", {
12233      className: "components-placeholder__learn-more"
12234    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ExternalLink, {
12235      href: (0,external_wp_i18n_namespaceObject.__)('https://wordpress.org/support/article/embeds/')
12236    }, (0,external_wp_i18n_namespaceObject.__)('Learn more about embeds'))), cannotEmbed && (0,external_wp_element_namespaceObject.createElement)("div", {
12237      className: "components-placeholder__error"
12238    }, (0,external_wp_element_namespaceObject.createElement)("div", {
12239      className: "components-placeholder__instructions"
12240    }, (0,external_wp_i18n_namespaceObject.__)('Sorry, this content could not be embedded.')), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
12241      variant: "secondary",
12242      onClick: tryAgain
12243    }, (0,external_wp_i18n_namespaceObject._x)('Try again', 'button label')), ' ', (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
12244      variant: "secondary",
12245      onClick: fallback
12246    }, (0,external_wp_i18n_namespaceObject._x)('Convert to link', 'button label'))));
12247  };
12248  
12249  /* harmony default export */ var embed_placeholder = (EmbedPlaceholder);
12250  
12251  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/embed/wp-embed-preview.js
12252  
12253  
12254  
12255  /**
12256   * WordPress dependencies
12257   */
12258  
12259  
12260  /** @typedef {import('@wordpress/element').WPSyntheticEvent} WPSyntheticEvent */
12261  
12262  const attributeMap = {
12263    class: 'className',
12264    frameborder: 'frameBorder',
12265    marginheight: 'marginHeight',
12266    marginwidth: 'marginWidth'
12267  };
12268  function WpEmbedPreview(_ref) {
12269    let {
12270      html
12271    } = _ref;
12272    const ref = (0,external_wp_element_namespaceObject.useRef)();
12273    const props = (0,external_wp_element_namespaceObject.useMemo)(() => {
12274      const doc = new window.DOMParser().parseFromString(html, 'text/html');
12275      const iframe = doc.querySelector('iframe');
12276      const iframeProps = {};
12277      if (!iframe) return iframeProps;
12278      Array.from(iframe.attributes).forEach(_ref2 => {
12279        let {
12280          name,
12281          value
12282        } = _ref2;
12283        if (name === 'style') return;
12284        iframeProps[attributeMap[name] || name] = value;
12285      });
12286      return iframeProps;
12287    }, [html]);
12288    (0,external_wp_element_namespaceObject.useEffect)(() => {
12289      const {
12290        ownerDocument
12291      } = ref.current;
12292      const {
12293        defaultView
12294      } = ownerDocument;
12295      /**
12296       * Checks for WordPress embed events signaling the height change when
12297       * iframe content loads or iframe's window is resized.  The event is
12298       * sent from WordPress core via the window.postMessage API.
12299       *
12300       * References:
12301       * window.postMessage:
12302       * https://developer.mozilla.org/en-US/docs/Web/API/Window/postMessage
12303       * WordPress core embed-template on load:
12304       * https://github.com/WordPress/WordPress/blob/HEAD/wp-includes/js/wp-embed-template.js#L143
12305       * WordPress core embed-template on resize:
12306       * https://github.com/WordPress/WordPress/blob/HEAD/wp-includes/js/wp-embed-template.js#L187
12307       *
12308       * @param {MessageEvent} event Message event.
12309       */
12310  
12311      function resizeWPembeds(_ref3) {
12312        let {
12313          data: {
12314            secret,
12315            message,
12316            value
12317          } = {}
12318        } = _ref3;
12319  
12320        if (message !== 'height' || secret !== props['data-secret']) {
12321          return;
12322        }
12323  
12324        ref.current.height = value;
12325      }
12326  
12327      defaultView.addEventListener('message', resizeWPembeds);
12328      return () => {
12329        defaultView.removeEventListener('message', resizeWPembeds);
12330      };
12331    }, []);
12332    return (0,external_wp_element_namespaceObject.createElement)("div", {
12333      className: "wp-block-embed__wrapper"
12334    }, (0,external_wp_element_namespaceObject.createElement)("iframe", _extends({
12335      ref: (0,external_wp_compose_namespaceObject.useMergeRefs)([ref, (0,external_wp_compose_namespaceObject.useFocusableIframe)()]),
12336      title: props.title
12337    }, props)));
12338  }
12339  
12340  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/embed/embed-preview.js
12341  
12342  
12343  /**
12344   * Internal dependencies
12345   */
12346  
12347  /**
12348   * External dependencies
12349   */
12350  
12351  
12352  /**
12353   * WordPress dependencies
12354   */
12355  
12356  
12357  
12358  
12359  
12360  
12361  /**
12362   * Internal dependencies
12363   */
12364  
12365  
12366  
12367  class EmbedPreview extends external_wp_element_namespaceObject.Component {
12368    constructor() {
12369      super(...arguments);
12370      this.hideOverlay = this.hideOverlay.bind(this);
12371      this.state = {
12372        interactive: false
12373      };
12374    }
12375  
12376    static getDerivedStateFromProps(nextProps, state) {
12377      if (!nextProps.isSelected && state.interactive) {
12378        // We only want to change this when the block is not selected, because changing it when
12379        // the block becomes selected makes the overlap disappear too early. Hiding the overlay
12380        // happens on mouseup when the overlay is clicked.
12381        return {
12382          interactive: false
12383        };
12384      }
12385  
12386      return null;
12387    }
12388  
12389    hideOverlay() {
12390      // This is called onMouseUp on the overlay. We can't respond to the `isSelected` prop
12391      // changing, because that happens on mouse down, and the overlay immediately disappears,
12392      // and the mouse event can end up in the preview content. We can't use onClick on
12393      // the overlay to hide it either, because then the editor misses the mouseup event, and
12394      // thinks we're multi-selecting blocks.
12395      this.setState({
12396        interactive: true
12397      });
12398    }
12399  
12400    render() {
12401      const {
12402        preview,
12403        previewable,
12404        url,
12405        type,
12406        caption,
12407        onCaptionChange,
12408        isSelected,
12409        className,
12410        icon,
12411        label,
12412        insertBlocksAfter
12413      } = this.props;
12414      const {
12415        scripts
12416      } = preview;
12417      const {
12418        interactive
12419      } = this.state;
12420      const html = 'photo' === type ? getPhotoHtml(preview) : preview.html;
12421      const parsedHost = new URL(url).host.split('.');
12422      const parsedHostBaseUrl = parsedHost.splice(parsedHost.length - 2, parsedHost.length - 1).join('.');
12423      const iframeTitle = (0,external_wp_i18n_namespaceObject.sprintf)( // translators: %s: host providing embed content e.g: www.youtube.com
12424      (0,external_wp_i18n_namespaceObject.__)('Embedded content from %s'), parsedHostBaseUrl);
12425      const sandboxClassnames = dedupe_default()(type, className, 'wp-block-embed__wrapper'); // Disabled because the overlay div doesn't actually have a role or functionality
12426      // as far as the user is concerned. We're just catching the first click so that
12427      // the block can be selected without interacting with the embed preview that the overlay covers.
12428  
12429      /* eslint-disable jsx-a11y/no-static-element-interactions */
12430  
12431      const embedWrapper = 'wp-embed' === type ? (0,external_wp_element_namespaceObject.createElement)(WpEmbedPreview, {
12432        html: html
12433      }) : (0,external_wp_element_namespaceObject.createElement)("div", {
12434        className: "wp-block-embed__wrapper"
12435      }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SandBox, {
12436        html: html,
12437        scripts: scripts,
12438        title: iframeTitle,
12439        type: sandboxClassnames,
12440        onFocus: this.hideOverlay
12441      }), !interactive && (0,external_wp_element_namespaceObject.createElement)("div", {
12442        className: "block-library-embed__interactive-overlay",
12443        onMouseUp: this.hideOverlay
12444      }));
12445      /* eslint-enable jsx-a11y/no-static-element-interactions */
12446  
12447      return (0,external_wp_element_namespaceObject.createElement)("figure", {
12448        className: dedupe_default()(className, 'wp-block-embed', {
12449          'is-type-video': 'video' === type
12450        })
12451      }, previewable ? embedWrapper : (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Placeholder, {
12452        icon: (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockIcon, {
12453          icon: icon,
12454          showColors: true
12455        }),
12456        label: label
12457      }, (0,external_wp_element_namespaceObject.createElement)("p", {
12458        className: "components-placeholder__error"
12459      }, (0,external_wp_element_namespaceObject.createElement)("a", {
12460        href: url
12461      }, url)), (0,external_wp_element_namespaceObject.createElement)("p", {
12462        className: "components-placeholder__error"
12463      }, (0,external_wp_i18n_namespaceObject.sprintf)(
12464      /* translators: %s: host providing embed content e.g: www.youtube.com */
12465      (0,external_wp_i18n_namespaceObject.__)("Embedded content from %s can't be previewed in the editor."), parsedHostBaseUrl))), (!external_wp_blockEditor_namespaceObject.RichText.isEmpty(caption) || isSelected) && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText, {
12466        tagName: "figcaption",
12467        placeholder: (0,external_wp_i18n_namespaceObject.__)('Add caption'),
12468        value: caption,
12469        onChange: onCaptionChange,
12470        inlineToolbar: true,
12471        __unstableOnSplitAtEnd: () => insertBlocksAfter((0,external_wp_blocks_namespaceObject.createBlock)('core/paragraph'))
12472      }));
12473    }
12474  
12475  }
12476  
12477  /* harmony default export */ var embed_preview = (EmbedPreview);
12478  
12479  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/embed/edit.js
12480  
12481  
12482  /**
12483   * Internal dependencies
12484   */
12485  
12486  
12487  
12488  
12489  
12490  
12491  /**
12492   * External dependencies
12493   */
12494  
12495  
12496  /**
12497   * WordPress dependencies
12498   */
12499  
12500  
12501  
12502  
12503  
12504  
12505  
12506  
12507  const EmbedEdit = props => {
12508    const {
12509      attributes: {
12510        providerNameSlug,
12511        previewable,
12512        responsive,
12513        url: attributesUrl
12514      },
12515      attributes,
12516      isSelected,
12517      onReplace,
12518      setAttributes,
12519      insertBlocksAfter,
12520      onFocus
12521    } = props;
12522    const defaultEmbedInfo = {
12523      title: (0,external_wp_i18n_namespaceObject._x)('Embed', 'block title'),
12524      icon: embedContentIcon
12525    };
12526    const {
12527      icon,
12528      title
12529    } = getEmbedInfoByProvider(providerNameSlug) || defaultEmbedInfo;
12530    const [url, setURL] = (0,external_wp_element_namespaceObject.useState)(attributesUrl);
12531    const [isEditingURL, setIsEditingURL] = (0,external_wp_element_namespaceObject.useState)(false);
12532    const {
12533      invalidateResolution
12534    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_coreData_namespaceObject.store);
12535    const {
12536      preview,
12537      fetching,
12538      themeSupportsResponsive,
12539      cannotEmbed
12540    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
12541      var _embedPreview$data;
12542  
12543      const {
12544        getEmbedPreview,
12545        isPreviewEmbedFallback,
12546        isRequestingEmbedPreview,
12547        getThemeSupports
12548      } = select(external_wp_coreData_namespaceObject.store);
12549  
12550      if (!attributesUrl) {
12551        return {
12552          fetching: false,
12553          cannotEmbed: false
12554        };
12555      }
12556  
12557      const embedPreview = getEmbedPreview(attributesUrl);
12558      const previewIsFallback = isPreviewEmbedFallback(attributesUrl); // The external oEmbed provider does not exist. We got no type info and no html.
12559  
12560      const badEmbedProvider = (embedPreview === null || embedPreview === void 0 ? void 0 : embedPreview.html) === false && (embedPreview === null || embedPreview === void 0 ? void 0 : embedPreview.type) === undefined; // Some WordPress URLs that can't be embedded will cause the API to return
12561      // a valid JSON response with no HTML and `data.status` set to 404, rather
12562      // than generating a fallback response as other embeds do.
12563  
12564      const wordpressCantEmbed = (embedPreview === null || embedPreview === void 0 ? void 0 : (_embedPreview$data = embedPreview.data) === null || _embedPreview$data === void 0 ? void 0 : _embedPreview$data.status) === 404;
12565      const validPreview = !!embedPreview && !badEmbedProvider && !wordpressCantEmbed;
12566      return {
12567        preview: validPreview ? embedPreview : undefined,
12568        fetching: isRequestingEmbedPreview(attributesUrl),
12569        themeSupportsResponsive: getThemeSupports()['responsive-embeds'],
12570        cannotEmbed: !validPreview || previewIsFallback
12571      };
12572    }, [attributesUrl]);
12573    /**
12574     * @return {Object} Attributes derived from the preview, merged with the current attributes.
12575     */
12576  
12577    const getMergedAttributes = () => {
12578      const {
12579        allowResponsive,
12580        className
12581      } = attributes;
12582      return { ...attributes,
12583        ...getAttributesFromPreview(preview, title, className, responsive, allowResponsive)
12584      };
12585    };
12586  
12587    const toggleResponsive = () => {
12588      const {
12589        allowResponsive,
12590        className
12591      } = attributes;
12592      const {
12593        html
12594      } = preview;
12595      const newAllowResponsive = !allowResponsive;
12596      setAttributes({
12597        allowResponsive: newAllowResponsive,
12598        className: getClassNames(html, className, responsive && newAllowResponsive)
12599      });
12600    };
12601  
12602    (0,external_wp_element_namespaceObject.useEffect)(() => {
12603      if (!(preview !== null && preview !== void 0 && preview.html) || !cannotEmbed || fetching) {
12604        return;
12605      } // At this stage, we're not fetching the preview and know it can't be embedded,
12606      // so try removing any trailing slash, and resubmit.
12607  
12608  
12609      const newURL = attributesUrl.replace(/\/$/, '');
12610      setURL(newURL);
12611      setIsEditingURL(false);
12612      setAttributes({
12613        url: newURL
12614      });
12615    }, [preview === null || preview === void 0 ? void 0 : preview.html, attributesUrl]); // Handle incoming preview.
12616  
12617    (0,external_wp_element_namespaceObject.useEffect)(() => {
12618      if (preview && !isEditingURL) {
12619        // Even though we set attributes that get derived from the preview,
12620        // we don't access them directly because for the initial render,
12621        // the `setAttributes` call will not have taken effect. If we're
12622        // rendering responsive content, setting the responsive classes
12623        // after the preview has been rendered can result in unwanted
12624        // clipping or scrollbars. The `getAttributesFromPreview` function
12625        // that `getMergedAttributes` uses is memoized so that we're not
12626        // calculating them on every render.
12627        setAttributes(getMergedAttributes());
12628  
12629        if (onReplace) {
12630          const upgradedBlock = createUpgradedEmbedBlock(props, getMergedAttributes());
12631  
12632          if (upgradedBlock) {
12633            onReplace(upgradedBlock);
12634          }
12635        }
12636      }
12637    }, [preview, isEditingURL]);
12638    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)();
12639  
12640    if (fetching) {
12641      return (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.View, blockProps, (0,external_wp_element_namespaceObject.createElement)(embed_loading, null));
12642    } // translators: %s: type of embed e.g: "YouTube", "Twitter", etc. "Embed" is used when no specific type exists
12643  
12644  
12645    const label = (0,external_wp_i18n_namespaceObject.sprintf)((0,external_wp_i18n_namespaceObject.__)('%s URL'), title); // No preview, or we can't embed the current URL, or we've clicked the edit button.
12646  
12647    const showEmbedPlaceholder = !preview || cannotEmbed || isEditingURL;
12648  
12649    if (showEmbedPlaceholder) {
12650      return (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.View, blockProps, (0,external_wp_element_namespaceObject.createElement)(embed_placeholder, {
12651        icon: icon,
12652        label: label,
12653        onFocus: onFocus,
12654        onSubmit: event => {
12655          if (event) {
12656            event.preventDefault();
12657          }
12658  
12659          setIsEditingURL(false);
12660          setAttributes({
12661            url
12662          });
12663        },
12664        value: url,
12665        cannotEmbed: cannotEmbed,
12666        onChange: event => setURL(event.target.value),
12667        fallback: () => fallback(url, onReplace),
12668        tryAgain: () => {
12669          invalidateResolution('getEmbedPreview', [url]);
12670        }
12671      }));
12672    } // Even though we set attributes that get derived from the preview,
12673    // we don't access them directly because for the initial render,
12674    // the `setAttributes` call will not have taken effect. If we're
12675    // rendering responsive content, setting the responsive classes
12676    // after the preview has been rendered can result in unwanted
12677    // clipping or scrollbars. The `getAttributesFromPreview` function
12678    // that `getMergedAttributes` uses is memoized so that we're not
12679    // calculating them on every render.
12680  
12681  
12682    const {
12683      caption,
12684      type,
12685      allowResponsive,
12686      className: classFromPreview
12687    } = getMergedAttributes();
12688    const className = classnames_default()(classFromPreview, props.className);
12689    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(embed_controls, {
12690      showEditButton: preview && !cannotEmbed,
12691      themeSupportsResponsive: themeSupportsResponsive,
12692      blockSupportsResponsive: responsive,
12693      allowResponsive: allowResponsive,
12694      toggleResponsive: toggleResponsive,
12695      switchBackToURLInput: () => setIsEditingURL(true)
12696    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.View, blockProps, (0,external_wp_element_namespaceObject.createElement)(embed_preview, {
12697      preview: preview,
12698      previewable: previewable,
12699      className: className,
12700      url: url,
12701      type: type,
12702      caption: caption,
12703      onCaptionChange: value => setAttributes({
12704        caption: value
12705      }),
12706      isSelected: isSelected,
12707      icon: icon,
12708      label: label,
12709      insertBlocksAfter: insertBlocksAfter
12710    })));
12711  };
12712  
12713  /* harmony default export */ var embed_edit = (EmbedEdit);
12714  
12715  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/embed/save.js
12716  
12717  
12718  /**
12719   * External dependencies
12720   */
12721  
12722  /**
12723   * WordPress dependencies
12724   */
12725  
12726  
12727  function embed_save_save(_ref) {
12728    let {
12729      attributes
12730    } = _ref;
12731    const {
12732      url,
12733      caption,
12734      type,
12735      providerNameSlug
12736    } = attributes;
12737  
12738    if (!url) {
12739      return null;
12740    }
12741  
12742    const className = dedupe_default()('wp-block-embed', {
12743      [`is-type-$type}`]: type,
12744      [`is-provider-$providerNameSlug}`]: providerNameSlug,
12745      [`wp-block-embed-$providerNameSlug}`]: providerNameSlug
12746    });
12747    return (0,external_wp_element_namespaceObject.createElement)("figure", external_wp_blockEditor_namespaceObject.useBlockProps.save({
12748      className
12749    }), (0,external_wp_element_namespaceObject.createElement)("div", {
12750      className: "wp-block-embed__wrapper"
12751    }, `\n$url}\n`
12752    /* URL needs to be on its own line. */
12753    ), !external_wp_blockEditor_namespaceObject.RichText.isEmpty(caption) && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
12754      tagName: "figcaption",
12755      value: caption
12756    }));
12757  }
12758  
12759  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/embed/transforms.js
12760  /**
12761   * WordPress dependencies
12762   */
12763  
12764  /**
12765   * Internal dependencies
12766   */
12767  
12768  const transforms_metadata = {
12769    $schema: "https://schemas.wp.org/trunk/block.json",
12770    apiVersion: 2,
12771    name: "core/embed",
12772    title: "Embed",
12773    category: "embed",
12774    description: "Add a block that displays content pulled from other sites, like Twitter or YouTube.",
12775    textdomain: "default",
12776    attributes: {
12777      url: {
12778        type: "string"
12779      },
12780      caption: {
12781        type: "string",
12782        source: "html",
12783        selector: "figcaption"
12784      },
12785      type: {
12786        type: "string"
12787      },
12788      providerNameSlug: {
12789        type: "string"
12790      },
12791      allowResponsive: {
12792        type: "boolean",
12793        "default": true
12794      },
12795      responsive: {
12796        type: "boolean",
12797        "default": false
12798      },
12799      previewable: {
12800        type: "boolean",
12801        "default": true
12802      }
12803    },
12804    supports: {
12805      align: true
12806    },
12807    editorStyle: "wp-block-embed-editor",
12808    style: "wp-block-embed"
12809  };
12810  const {
12811    name: EMBED_BLOCK
12812  } = transforms_metadata;
12813  /**
12814   * Default transforms for generic embeds.
12815   */
12816  
12817  const embed_transforms_transforms = {
12818    from: [{
12819      type: 'raw',
12820      isMatch: node => {
12821        var _node$textContent, _node$textContent$mat;
12822  
12823        return node.nodeName === 'P' && /^\s*(https?:\/\/\S+)\s*$/i.test(node.textContent) && ((_node$textContent = node.textContent) === null || _node$textContent === void 0 ? void 0 : (_node$textContent$mat = _node$textContent.match(/https/gi)) === null || _node$textContent$mat === void 0 ? void 0 : _node$textContent$mat.length) === 1;
12824      },
12825      transform: node => {
12826        return (0,external_wp_blocks_namespaceObject.createBlock)(EMBED_BLOCK, {
12827          url: node.textContent.trim()
12828        });
12829      }
12830    }],
12831    to: [{
12832      type: 'block',
12833      blocks: ['core/paragraph'],
12834      isMatch: _ref => {
12835        let {
12836          url
12837        } = _ref;
12838        return !!url;
12839      },
12840      transform: _ref2 => {
12841        let {
12842          url,
12843          caption
12844        } = _ref2;
12845        let value = `<a href="$url}">$url}</a>`;
12846  
12847        if (caption !== null && caption !== void 0 && caption.trim()) {
12848          value += `<br />$caption}`;
12849        }
12850  
12851        return (0,external_wp_blocks_namespaceObject.createBlock)('core/paragraph', {
12852          content: value
12853        });
12854      }
12855    }]
12856  };
12857  /* harmony default export */ var embed_transforms = (embed_transforms_transforms);
12858  
12859  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/embed/variations.js
12860  /**
12861   * WordPress dependencies
12862   */
12863  
12864  /**
12865   * Internal dependencies
12866   */
12867  
12868  
12869  /** @typedef {import('@wordpress/blocks').WPBlockVariation} WPBlockVariation */
12870  
12871  /**
12872   * Template option choices for predefined columns layouts.
12873   *
12874   * @type {WPBlockVariation[]}
12875   */
12876  
12877  const variations_variations = [{
12878    name: 'twitter',
12879    title: 'Twitter',
12880    icon: embedTwitterIcon,
12881    keywords: ['tweet', (0,external_wp_i18n_namespaceObject.__)('social')],
12882    description: (0,external_wp_i18n_namespaceObject.__)('Embed a tweet.'),
12883    patterns: [/^https?:\/\/(www\.)?twitter\.com\/.+/i],
12884    attributes: {
12885      providerNameSlug: 'twitter',
12886      responsive: true
12887    }
12888  }, {
12889    name: 'youtube',
12890    title: 'YouTube',
12891    icon: embedYouTubeIcon,
12892    keywords: [(0,external_wp_i18n_namespaceObject.__)('music'), (0,external_wp_i18n_namespaceObject.__)('video')],
12893    description: (0,external_wp_i18n_namespaceObject.__)('Embed a YouTube video.'),
12894    patterns: [/^https?:\/\/((m|www)\.)?youtube\.com\/.+/i, /^https?:\/\/youtu\.be\/.+/i],
12895    attributes: {
12896      providerNameSlug: 'youtube',
12897      responsive: true
12898    }
12899  }, {
12900    // Deprecate Facebook Embed per FB policy
12901    // See: https://developers.facebook.com/docs/plugins/oembed-legacy
12902    name: 'facebook',
12903    title: 'Facebook',
12904    icon: embedFacebookIcon,
12905    keywords: [(0,external_wp_i18n_namespaceObject.__)('social')],
12906    description: (0,external_wp_i18n_namespaceObject.__)('Embed a Facebook post.'),
12907    scope: ['block'],
12908    patterns: [],
12909    attributes: {
12910      providerNameSlug: 'facebook',
12911      previewable: false,
12912      responsive: true
12913    }
12914  }, {
12915    // Deprecate Instagram per FB policy
12916    // See: https://developers.facebook.com/docs/instagram/oembed-legacy
12917    name: 'instagram',
12918    title: 'Instagram',
12919    icon: embedInstagramIcon,
12920    keywords: [(0,external_wp_i18n_namespaceObject.__)('image'), (0,external_wp_i18n_namespaceObject.__)('social')],
12921    description: (0,external_wp_i18n_namespaceObject.__)('Embed an Instagram post.'),
12922    scope: ['block'],
12923    patterns: [],
12924    attributes: {
12925      providerNameSlug: 'instagram',
12926      responsive: true
12927    }
12928  }, {
12929    name: 'wordpress',
12930    title: 'WordPress',
12931    icon: embedWordPressIcon,
12932    keywords: [(0,external_wp_i18n_namespaceObject.__)('post'), (0,external_wp_i18n_namespaceObject.__)('blog')],
12933    description: (0,external_wp_i18n_namespaceObject.__)('Embed a WordPress post.'),
12934    attributes: {
12935      providerNameSlug: 'wordpress'
12936    }
12937  }, {
12938    name: 'soundcloud',
12939    title: 'SoundCloud',
12940    icon: embedAudioIcon,
12941    keywords: [(0,external_wp_i18n_namespaceObject.__)('music'), (0,external_wp_i18n_namespaceObject.__)('audio')],
12942    description: (0,external_wp_i18n_namespaceObject.__)('Embed SoundCloud content.'),
12943    patterns: [/^https?:\/\/(www\.)?soundcloud\.com\/.+/i],
12944    attributes: {
12945      providerNameSlug: 'soundcloud',
12946      responsive: true
12947    }
12948  }, {
12949    name: 'spotify',
12950    title: 'Spotify',
12951    icon: embedSpotifyIcon,
12952    keywords: [(0,external_wp_i18n_namespaceObject.__)('music'), (0,external_wp_i18n_namespaceObject.__)('audio')],
12953    description: (0,external_wp_i18n_namespaceObject.__)('Embed Spotify content.'),
12954    patterns: [/^https?:\/\/(open|play)\.spotify\.com\/.+/i],
12955    attributes: {
12956      providerNameSlug: 'spotify',
12957      responsive: true
12958    }
12959  }, {
12960    name: 'flickr',
12961    title: 'Flickr',
12962    icon: embedFlickrIcon,
12963    keywords: [(0,external_wp_i18n_namespaceObject.__)('image')],
12964    description: (0,external_wp_i18n_namespaceObject.__)('Embed Flickr content.'),
12965    patterns: [/^https?:\/\/(www\.)?flickr\.com\/.+/i, /^https?:\/\/flic\.kr\/.+/i],
12966    attributes: {
12967      providerNameSlug: 'flickr',
12968      responsive: true
12969    }
12970  }, {
12971    name: 'vimeo',
12972    title: 'Vimeo',
12973    icon: embedVimeoIcon,
12974    keywords: [(0,external_wp_i18n_namespaceObject.__)('video')],
12975    description: (0,external_wp_i18n_namespaceObject.__)('Embed a Vimeo video.'),
12976    patterns: [/^https?:\/\/(www\.)?vimeo\.com\/.+/i],
12977    attributes: {
12978      providerNameSlug: 'vimeo',
12979      responsive: true
12980    }
12981  }, {
12982    name: 'animoto',
12983    title: 'Animoto',
12984    icon: embedAnimotoIcon,
12985    description: (0,external_wp_i18n_namespaceObject.__)('Embed an Animoto video.'),
12986    patterns: [/^https?:\/\/(www\.)?(animoto|video214)\.com\/.+/i],
12987    attributes: {
12988      providerNameSlug: 'animoto',
12989      responsive: true
12990    }
12991  }, {
12992    name: 'cloudup',
12993    title: 'Cloudup',
12994    icon: embedContentIcon,
12995    description: (0,external_wp_i18n_namespaceObject.__)('Embed Cloudup content.'),
12996    patterns: [/^https?:\/\/cloudup\.com\/.+/i],
12997    attributes: {
12998      providerNameSlug: 'cloudup',
12999      responsive: true
13000    }
13001  }, {
13002    // Deprecated since CollegeHumor content is now powered by YouTube.
13003    name: 'collegehumor',
13004    title: 'CollegeHumor',
13005    icon: embedVideoIcon,
13006    description: (0,external_wp_i18n_namespaceObject.__)('Embed CollegeHumor content.'),
13007    scope: ['block'],
13008    patterns: [],
13009    attributes: {
13010      providerNameSlug: 'collegehumor',
13011      responsive: true
13012    }
13013  }, {
13014    name: 'crowdsignal',
13015    title: 'Crowdsignal',
13016    icon: embedContentIcon,
13017    keywords: ['polldaddy', (0,external_wp_i18n_namespaceObject.__)('survey')],
13018    description: (0,external_wp_i18n_namespaceObject.__)('Embed Crowdsignal (formerly Polldaddy) content.'),
13019    patterns: [/^https?:\/\/((.+\.)?polldaddy\.com|poll\.fm|.+\.survey\.fm)\/.+/i],
13020    attributes: {
13021      providerNameSlug: 'crowdsignal',
13022      responsive: true
13023    }
13024  }, {
13025    name: 'dailymotion',
13026    title: 'Dailymotion',
13027    icon: embedDailymotionIcon,
13028    keywords: [(0,external_wp_i18n_namespaceObject.__)('video')],
13029    description: (0,external_wp_i18n_namespaceObject.__)('Embed a Dailymotion video.'),
13030    patterns: [/^https?:\/\/(www\.)?dailymotion\.com\/.+/i],
13031    attributes: {
13032      providerNameSlug: 'dailymotion',
13033      responsive: true
13034    }
13035  }, {
13036    name: 'imgur',
13037    title: 'Imgur',
13038    icon: embedPhotoIcon,
13039    description: (0,external_wp_i18n_namespaceObject.__)('Embed Imgur content.'),
13040    patterns: [/^https?:\/\/(.+\.)?imgur\.com\/.+/i],
13041    attributes: {
13042      providerNameSlug: 'imgur',
13043      responsive: true
13044    }
13045  }, {
13046    name: 'issuu',
13047    title: 'Issuu',
13048    icon: embedContentIcon,
13049    description: (0,external_wp_i18n_namespaceObject.__)('Embed Issuu content.'),
13050    patterns: [/^https?:\/\/(www\.)?issuu\.com\/.+/i],
13051    attributes: {
13052      providerNameSlug: 'issuu',
13053      responsive: true
13054    }
13055  }, {
13056    name: 'kickstarter',
13057    title: 'Kickstarter',
13058    icon: embedContentIcon,
13059    description: (0,external_wp_i18n_namespaceObject.__)('Embed Kickstarter content.'),
13060    patterns: [/^https?:\/\/(www\.)?kickstarter\.com\/.+/i, /^https?:\/\/kck\.st\/.+/i],
13061    attributes: {
13062      providerNameSlug: 'kickstarter',
13063      responsive: true
13064    }
13065  }, {
13066    name: 'mixcloud',
13067    title: 'Mixcloud',
13068    icon: embedAudioIcon,
13069    keywords: [(0,external_wp_i18n_namespaceObject.__)('music'), (0,external_wp_i18n_namespaceObject.__)('audio')],
13070    description: (0,external_wp_i18n_namespaceObject.__)('Embed Mixcloud content.'),
13071    patterns: [/^https?:\/\/(www\.)?mixcloud\.com\/.+/i],
13072    attributes: {
13073      providerNameSlug: 'mixcloud',
13074      responsive: true
13075    }
13076  }, {
13077    name: 'reddit',
13078    title: 'Reddit',
13079    icon: embedRedditIcon,
13080    description: (0,external_wp_i18n_namespaceObject.__)('Embed a Reddit thread.'),
13081    patterns: [/^https?:\/\/(www\.)?reddit\.com\/.+/i],
13082    attributes: {
13083      providerNameSlug: 'reddit',
13084      responsive: true
13085    }
13086  }, {
13087    name: 'reverbnation',
13088    title: 'ReverbNation',
13089    icon: embedAudioIcon,
13090    description: (0,external_wp_i18n_namespaceObject.__)('Embed ReverbNation content.'),
13091    patterns: [/^https?:\/\/(www\.)?reverbnation\.com\/.+/i],
13092    attributes: {
13093      providerNameSlug: 'reverbnation',
13094      responsive: true
13095    }
13096  }, {
13097    name: 'screencast',
13098    title: 'Screencast',
13099    icon: embedVideoIcon,
13100    description: (0,external_wp_i18n_namespaceObject.__)('Embed Screencast content.'),
13101    patterns: [/^https?:\/\/(www\.)?screencast\.com\/.+/i],
13102    attributes: {
13103      providerNameSlug: 'screencast',
13104      responsive: true
13105    }
13106  }, {
13107    name: 'scribd',
13108    title: 'Scribd',
13109    icon: embedContentIcon,
13110    description: (0,external_wp_i18n_namespaceObject.__)('Embed Scribd content.'),
13111    patterns: [/^https?:\/\/(www\.)?scribd\.com\/.+/i],
13112    attributes: {
13113      providerNameSlug: 'scribd',
13114      responsive: true
13115    }
13116  }, {
13117    name: 'slideshare',
13118    title: 'Slideshare',
13119    icon: embedContentIcon,
13120    description: (0,external_wp_i18n_namespaceObject.__)('Embed Slideshare content.'),
13121    patterns: [/^https?:\/\/(.+?\.)?slideshare\.net\/.+/i],
13122    attributes: {
13123      providerNameSlug: 'slideshare',
13124      responsive: true
13125    }
13126  }, {
13127    name: 'smugmug',
13128    title: 'SmugMug',
13129    icon: embedPhotoIcon,
13130    description: (0,external_wp_i18n_namespaceObject.__)('Embed SmugMug content.'),
13131    patterns: [/^https?:\/\/(.+\.)?smugmug\.com\/.*/i],
13132    attributes: {
13133      providerNameSlug: 'smugmug',
13134      previewable: false,
13135      responsive: true
13136    }
13137  }, {
13138    name: 'speaker-deck',
13139    title: 'Speaker Deck',
13140    icon: embedContentIcon,
13141    description: (0,external_wp_i18n_namespaceObject.__)('Embed Speaker Deck content.'),
13142    patterns: [/^https?:\/\/(www\.)?speakerdeck\.com\/.+/i],
13143    attributes: {
13144      providerNameSlug: 'speaker-deck',
13145      responsive: true
13146    }
13147  }, {
13148    name: 'tiktok',
13149    title: 'TikTok',
13150    icon: embedVideoIcon,
13151    keywords: [(0,external_wp_i18n_namespaceObject.__)('video')],
13152    description: (0,external_wp_i18n_namespaceObject.__)('Embed a TikTok video.'),
13153    patterns: [/^https?:\/\/(www\.)?tiktok\.com\/.+/i],
13154    attributes: {
13155      providerNameSlug: 'tiktok',
13156      responsive: true
13157    }
13158  }, {
13159    name: 'ted',
13160    title: 'TED',
13161    icon: embedVideoIcon,
13162    description: (0,external_wp_i18n_namespaceObject.__)('Embed a TED video.'),
13163    patterns: [/^https?:\/\/(www\.|embed\.)?ted\.com\/.+/i],
13164    attributes: {
13165      providerNameSlug: 'ted',
13166      responsive: true
13167    }
13168  }, {
13169    name: 'tumblr',
13170    title: 'Tumblr',
13171    icon: embedTumblrIcon,
13172    keywords: [(0,external_wp_i18n_namespaceObject.__)('social')],
13173    description: (0,external_wp_i18n_namespaceObject.__)('Embed a Tumblr post.'),
13174    patterns: [/^https?:\/\/(www\.)?tumblr\.com\/.+/i],
13175    attributes: {
13176      providerNameSlug: 'tumblr',
13177      responsive: true
13178    }
13179  }, {
13180    name: 'videopress',
13181    title: 'VideoPress',
13182    icon: embedVideoIcon,
13183    keywords: [(0,external_wp_i18n_namespaceObject.__)('video')],
13184    description: (0,external_wp_i18n_namespaceObject.__)('Embed a VideoPress video.'),
13185    patterns: [/^https?:\/\/videopress\.com\/.+/i],
13186    attributes: {
13187      providerNameSlug: 'videopress',
13188      responsive: true
13189    }
13190  }, {
13191    name: 'wordpress-tv',
13192    title: 'WordPress.tv',
13193    icon: embedVideoIcon,
13194    description: (0,external_wp_i18n_namespaceObject.__)('Embed a WordPress.tv video.'),
13195    patterns: [/^https?:\/\/wordpress\.tv\/.+/i],
13196    attributes: {
13197      providerNameSlug: 'wordpress-tv',
13198      responsive: true
13199    }
13200  }, {
13201    name: 'amazon-kindle',
13202    title: 'Amazon Kindle',
13203    icon: embedAmazonIcon,
13204    keywords: [(0,external_wp_i18n_namespaceObject.__)('ebook')],
13205    description: (0,external_wp_i18n_namespaceObject.__)('Embed Amazon Kindle content.'),
13206    patterns: [/^https?:\/\/([a-z0-9-]+\.)?(amazon|amzn)(\.[a-z]{2,4})+\/.+/i, /^https?:\/\/(www\.)?(a\.co|z\.cn)\/.+/i],
13207    attributes: {
13208      providerNameSlug: 'amazon-kindle'
13209    }
13210  }, {
13211    name: 'pinterest',
13212    title: 'Pinterest',
13213    icon: embedPinterestIcon,
13214    keywords: [(0,external_wp_i18n_namespaceObject.__)('social'), (0,external_wp_i18n_namespaceObject.__)('bookmark')],
13215    description: (0,external_wp_i18n_namespaceObject.__)('Embed Pinterest pins, boards, and profiles.'),
13216    patterns: [/^https?:\/\/([a-z]{2}|www)\.pinterest\.com(\.(au|mx))?\/.*/i],
13217    attributes: {
13218      providerNameSlug: 'pinterest'
13219    }
13220  }, {
13221    name: 'wolfram-cloud',
13222    title: 'Wolfram',
13223    icon: embedWolframIcon,
13224    description: (0,external_wp_i18n_namespaceObject.__)('Embed Wolfram notebook content.'),
13225    patterns: [/^https?:\/\/(www\.)?wolframcloud\.com\/obj\/.+/i],
13226    attributes: {
13227      providerNameSlug: 'wolfram-cloud',
13228      responsive: true
13229    }
13230  }];
13231  /**
13232   * Add `isActive` function to all `embed` variations, if not defined.
13233   * `isActive` function is used to find a variation match from a created
13234   *  Block by providing its attributes.
13235   */
13236  
13237  variations_variations.forEach(variation => {
13238    if (variation.isActive) return;
13239  
13240    variation.isActive = (blockAttributes, variationAttributes) => blockAttributes.providerNameSlug === variationAttributes.providerNameSlug;
13241  });
13242  /* harmony default export */ var embed_variations = (variations_variations);
13243  
13244  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/embed/deprecated.js
13245  
13246  
13247  /**
13248   * External dependencies
13249   */
13250  
13251  /**
13252   * Internal dependencies
13253   */
13254  
13255  const deprecated_metadata = {
13256    $schema: "https://schemas.wp.org/trunk/block.json",
13257    apiVersion: 2,
13258    name: "core/embed",
13259    title: "Embed",
13260    category: "embed",
13261    description: "Add a block that displays content pulled from other sites, like Twitter or YouTube.",
13262    textdomain: "default",
13263    attributes: {
13264      url: {
13265        type: "string"
13266      },
13267      caption: {
13268        type: "string",
13269        source: "html",
13270        selector: "figcaption"
13271      },
13272      type: {
13273        type: "string"
13274      },
13275      providerNameSlug: {
13276        type: "string"
13277      },
13278      allowResponsive: {
13279        type: "boolean",
13280        "default": true
13281      },
13282      responsive: {
13283        type: "boolean",
13284        "default": false
13285      },
13286      previewable: {
13287        type: "boolean",
13288        "default": true
13289      }
13290    },
13291    supports: {
13292      align: true
13293    },
13294    editorStyle: "wp-block-embed-editor",
13295    style: "wp-block-embed"
13296  };
13297  /**
13298   * WordPress dependencies
13299   */
13300  
13301  
13302  const {
13303    attributes: embed_deprecated_blockAttributes
13304  } = deprecated_metadata;
13305  const embed_deprecated_deprecated = [{
13306    attributes: embed_deprecated_blockAttributes,
13307  
13308    save(_ref) {
13309      let {
13310        attributes: {
13311          url,
13312          caption,
13313          type,
13314          providerNameSlug
13315        }
13316      } = _ref;
13317  
13318      if (!url) {
13319        return null;
13320      }
13321  
13322      const embedClassName = classnames_default()('wp-block-embed', {
13323        [`is-type-$type}`]: type,
13324        [`is-provider-$providerNameSlug}`]: providerNameSlug
13325      });
13326      return (0,external_wp_element_namespaceObject.createElement)("figure", {
13327        className: embedClassName
13328      }, `\n$url}\n`
13329      /* URL needs to be on its own line. */
13330      , !external_wp_blockEditor_namespaceObject.RichText.isEmpty(caption) && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
13331        tagName: "figcaption",
13332        value: caption
13333      }));
13334    }
13335  
13336  }];
13337  /* harmony default export */ var embed_deprecated = (embed_deprecated_deprecated);
13338  
13339  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/embed/index.js
13340  /**
13341   * Internal dependencies
13342   */
13343  
13344  
13345  const embed_metadata = {
13346    $schema: "https://schemas.wp.org/trunk/block.json",
13347    apiVersion: 2,
13348    name: "core/embed",
13349    title: "Embed",
13350    category: "embed",
13351    description: "Add a block that displays content pulled from other sites, like Twitter or YouTube.",
13352    textdomain: "default",
13353    attributes: {
13354      url: {
13355        type: "string"
13356      },
13357      caption: {
13358        type: "string",
13359        source: "html",
13360        selector: "figcaption"
13361      },
13362      type: {
13363        type: "string"
13364      },
13365      providerNameSlug: {
13366        type: "string"
13367      },
13368      allowResponsive: {
13369        type: "boolean",
13370        "default": true
13371      },
13372      responsive: {
13373        type: "boolean",
13374        "default": false
13375      },
13376      previewable: {
13377        type: "boolean",
13378        "default": true
13379      }
13380    },
13381    supports: {
13382      align: true
13383    },
13384    editorStyle: "wp-block-embed-editor",
13385    style: "wp-block-embed"
13386  };
13387  
13388  
13389  
13390  
13391  const {
13392    name: embed_name
13393  } = embed_metadata;
13394  
13395  const embed_settings = {
13396    icon: embedContentIcon,
13397    edit: embed_edit,
13398    save: embed_save_save,
13399    transforms: embed_transforms,
13400    variations: embed_variations,
13401    deprecated: embed_deprecated
13402  };
13403  
13404  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/file.js
13405  
13406  
13407  /**
13408   * WordPress dependencies
13409   */
13410  
13411  const file = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
13412    viewBox: "0 0 24 24",
13413    xmlns: "http://www.w3.org/2000/svg"
13414  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
13415    d: "M19 6.2h-5.9l-.6-1.1c-.3-.7-1-1.1-1.8-1.1H5c-1.1 0-2 .9-2 2v11.8c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V8.2c0-1.1-.9-2-2-2zm.5 11.6c0 .3-.2.5-.5.5H5c-.3 0-.5-.2-.5-.5V6c0-.3.2-.5.5-.5h5.8c.2 0 .4.1.4.3l1 2H19c.3 0 .5.2.5.5v9.5z"
13416  }));
13417  /* harmony default export */ var library_file = (file);
13418  
13419  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/file/deprecated.js
13420  
13421  
13422  /**
13423   * WordPress dependencies
13424   */
13425  
13426   // Version of the file block without PR#28062 accessibility fix.
13427  
13428  const file_deprecated_deprecated = [{
13429    attributes: {
13430      id: {
13431        type: 'number'
13432      },
13433      href: {
13434        type: 'string'
13435      },
13436      fileName: {
13437        type: 'string',
13438        source: 'html',
13439        selector: 'a:not([download])'
13440      },
13441      textLinkHref: {
13442        type: 'string',
13443        source: 'attribute',
13444        selector: 'a:not([download])',
13445        attribute: 'href'
13446      },
13447      textLinkTarget: {
13448        type: 'string',
13449        source: 'attribute',
13450        selector: 'a:not([download])',
13451        attribute: 'target'
13452      },
13453      showDownloadButton: {
13454        type: 'boolean',
13455        default: true
13456      },
13457      downloadButtonText: {
13458        type: 'string',
13459        source: 'html',
13460        selector: 'a[download]'
13461      },
13462      displayPreview: {
13463        type: 'boolean'
13464      },
13465      previewHeight: {
13466        type: 'number',
13467        default: 600
13468      }
13469    },
13470    supports: {
13471      anchor: true,
13472      align: true
13473    },
13474  
13475    save(_ref) {
13476      let {
13477        attributes
13478      } = _ref;
13479      const {
13480        href,
13481        fileName,
13482        textLinkHref,
13483        textLinkTarget,
13484        showDownloadButton,
13485        downloadButtonText,
13486        displayPreview,
13487        previewHeight
13488      } = attributes;
13489      const pdfEmbedLabel = external_wp_blockEditor_namespaceObject.RichText.isEmpty(fileName) ? (0,external_wp_i18n_namespaceObject.__)('PDF embed') : (0,external_wp_i18n_namespaceObject.sprintf)(
13490      /* translators: %s: filename. */
13491      (0,external_wp_i18n_namespaceObject.__)('Embed of %s.'), fileName);
13492      return href && (0,external_wp_element_namespaceObject.createElement)("div", external_wp_blockEditor_namespaceObject.useBlockProps.save(), displayPreview && (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)("object", {
13493        className: "wp-block-file__embed",
13494        data: href,
13495        type: "application/pdf",
13496        style: {
13497          width: '100%',
13498          height: `$previewHeight}px`
13499        },
13500        "aria-label": pdfEmbedLabel
13501      })), !external_wp_blockEditor_namespaceObject.RichText.isEmpty(fileName) && (0,external_wp_element_namespaceObject.createElement)("a", {
13502        href: textLinkHref,
13503        target: textLinkTarget,
13504        rel: textLinkTarget ? 'noreferrer noopener' : undefined
13505      }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
13506        value: fileName
13507      })), showDownloadButton && (0,external_wp_element_namespaceObject.createElement)("a", {
13508        href: href,
13509        className: "wp-block-file__button",
13510        download: true
13511      }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
13512        value: downloadButtonText
13513      })));
13514    }
13515  
13516  }];
13517  /* harmony default export */ var file_deprecated = (file_deprecated_deprecated);
13518  
13519  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/file/inspector.js
13520  
13521  
13522  /**
13523   * WordPress dependencies
13524   */
13525  
13526  
13527  
13528  /**
13529   * Internal dependencies
13530   */
13531  
13532  
13533  function FileBlockInspector(_ref) {
13534    let {
13535      hrefs,
13536      openInNewWindow,
13537      showDownloadButton,
13538      changeLinkDestinationOption,
13539      changeOpenInNewWindow,
13540      changeShowDownloadButton,
13541      displayPreview,
13542      changeDisplayPreview,
13543      previewHeight,
13544      changePreviewHeight
13545    } = _ref;
13546    const {
13547      href,
13548      textLinkHref,
13549      attachmentPage
13550    } = hrefs;
13551    let linkDestinationOptions = [{
13552      value: href,
13553      label: (0,external_wp_i18n_namespaceObject.__)('URL')
13554    }];
13555  
13556    if (attachmentPage) {
13557      linkDestinationOptions = [{
13558        value: href,
13559        label: (0,external_wp_i18n_namespaceObject.__)('Media file')
13560      }, {
13561        value: attachmentPage,
13562        label: (0,external_wp_i18n_namespaceObject.__)('Attachment page')
13563      }];
13564    }
13565  
13566    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, href.endsWith('.pdf') && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
13567      title: (0,external_wp_i18n_namespaceObject.__)('PDF settings')
13568    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
13569      label: (0,external_wp_i18n_namespaceObject.__)('Show inline embed'),
13570      help: displayPreview ? (0,external_wp_i18n_namespaceObject.__)("Note: Most phone and tablet browsers won't display embedded PDFs.") : null,
13571      checked: !!displayPreview,
13572      onChange: changeDisplayPreview
13573    }), displayPreview && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.RangeControl, {
13574      label: (0,external_wp_i18n_namespaceObject.__)('Height in pixels'),
13575      min: MIN_PREVIEW_HEIGHT,
13576      max: Math.max(MAX_PREVIEW_HEIGHT, previewHeight),
13577      value: previewHeight,
13578      onChange: changePreviewHeight
13579    })), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
13580      title: (0,external_wp_i18n_namespaceObject.__)('Text link settings')
13581    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SelectControl, {
13582      label: (0,external_wp_i18n_namespaceObject.__)('Link to'),
13583      value: textLinkHref,
13584      options: linkDestinationOptions,
13585      onChange: changeLinkDestinationOption
13586    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
13587      label: (0,external_wp_i18n_namespaceObject.__)('Open in new tab'),
13588      checked: openInNewWindow,
13589      onChange: changeOpenInNewWindow
13590    })), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
13591      title: (0,external_wp_i18n_namespaceObject.__)('Download button settings')
13592    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
13593      label: (0,external_wp_i18n_namespaceObject.__)('Show download button'),
13594      checked: showDownloadButton,
13595      onChange: changeShowDownloadButton
13596    }))));
13597  }
13598  
13599  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/file/utils.js
13600  /**
13601   * Uses a combination of user agent matching and feature detection to determine whether
13602   * the current browser supports rendering PDFs inline.
13603   *
13604   * @return {boolean} Whether or not the browser supports inline PDFs.
13605   */
13606  const browserSupportsPdfs = () => {
13607    // Most mobile devices include "Mobi" in their UA.
13608    if (window.navigator.userAgent.indexOf('Mobi') > -1) {
13609      return false;
13610    } // Android tablets are the noteable exception.
13611  
13612  
13613    if (window.navigator.userAgent.indexOf('Android') > -1) {
13614      return false;
13615    } // iPad pretends to be a Mac.
13616  
13617  
13618    if (window.navigator.userAgent.indexOf('Macintosh') > -1 && window.navigator.maxTouchPoints && window.navigator.maxTouchPoints > 2) {
13619      return false;
13620    } // IE only supports PDFs when there's an ActiveX object available for it.
13621  
13622  
13623    if (!!(window.ActiveXObject || 'ActiveXObject' in window) && !(createActiveXObject('AcroPDF.PDF') || createActiveXObject('PDF.PdfCtrl'))) {
13624      return false;
13625    }
13626  
13627    return true;
13628  };
13629  /**
13630   * Helper function for creating ActiveX objects, catching any errors that are thrown
13631   * when it's generated.
13632   *
13633   * @param {string} type The name of the ActiveX object to create.
13634   * @return {window.ActiveXObject|undefined} The generated ActiveXObject, or null if it failed.
13635   */
13636  
13637  const createActiveXObject = type => {
13638    let ax;
13639  
13640    try {
13641      ax = new window.ActiveXObject(type);
13642    } catch (e) {
13643      ax = undefined;
13644    }
13645  
13646    return ax;
13647  };
13648  /**
13649   * Hides all .wp-block-file__embed elements on the document. This function is only intended
13650   * to be run on the front-end, it may have weird side effects running in the block editor.
13651   */
13652  
13653  
13654  const hidePdfEmbedsOnUnsupportedBrowsers = () => {
13655    if (!browserSupportsPdfs()) {
13656      const embeds = document.getElementsByClassName('wp-block-file__embed');
13657      Array.from(embeds).forEach(embed => {
13658        embed.style.display = 'none';
13659      });
13660    }
13661  };
13662  
13663  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/file/edit.js
13664  
13665  
13666  /**
13667   * External dependencies
13668   */
13669  
13670  /**
13671   * WordPress dependencies
13672   */
13673  
13674  
13675  
13676  
13677  
13678  
13679  
13680  
13681  
13682  
13683  
13684  /**
13685   * Internal dependencies
13686   */
13687  
13688  
13689  
13690  const MIN_PREVIEW_HEIGHT = 200;
13691  const MAX_PREVIEW_HEIGHT = 2000;
13692  
13693  function ClipboardToolbarButton(_ref) {
13694    let {
13695      text,
13696      disabled
13697    } = _ref;
13698    const {
13699      createNotice
13700    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_notices_namespaceObject.store);
13701    const ref = (0,external_wp_compose_namespaceObject.useCopyToClipboard)(text, () => {
13702      createNotice('info', (0,external_wp_i18n_namespaceObject.__)('Copied URL to clipboard.'), {
13703        isDismissible: true,
13704        type: 'snackbar'
13705      });
13706    });
13707    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, {
13708      className: "components-clipboard-toolbar-button",
13709      ref: ref,
13710      disabled: disabled
13711    }, (0,external_wp_i18n_namespaceObject.__)('Copy URL'));
13712  }
13713  
13714  function FileEdit(_ref2) {
13715    let {
13716      attributes,
13717      isSelected,
13718      setAttributes,
13719      noticeUI,
13720      noticeOperations,
13721      clientId
13722    } = _ref2;
13723    const {
13724      id,
13725      fileId,
13726      fileName,
13727      href,
13728      textLinkHref,
13729      textLinkTarget,
13730      showDownloadButton,
13731      downloadButtonText,
13732      displayPreview,
13733      previewHeight
13734    } = attributes;
13735    const {
13736      media,
13737      mediaUpload
13738    } = (0,external_wp_data_namespaceObject.useSelect)(select => ({
13739      media: id === undefined ? undefined : select(external_wp_coreData_namespaceObject.store).getMedia(id),
13740      mediaUpload: select(external_wp_blockEditor_namespaceObject.store).getSettings().mediaUpload
13741    }), [id]);
13742    const {
13743      toggleSelection,
13744      __unstableMarkNextChangeAsNotPersistent
13745    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_blockEditor_namespaceObject.store);
13746    (0,external_wp_element_namespaceObject.useEffect)(() => {
13747      // Upload a file drag-and-dropped into the editor.
13748      if ((0,external_wp_blob_namespaceObject.isBlobURL)(href)) {
13749        const file = (0,external_wp_blob_namespaceObject.getBlobByURL)(href);
13750        mediaUpload({
13751          filesList: [file],
13752          onFileChange: _ref3 => {
13753            let [newMedia] = _ref3;
13754            return onSelectFile(newMedia);
13755          },
13756          onError: onUploadError
13757        });
13758        (0,external_wp_blob_namespaceObject.revokeBlobURL)(href);
13759      }
13760  
13761      if (downloadButtonText === undefined) {
13762        changeDownloadButtonText((0,external_wp_i18n_namespaceObject._x)('Download', 'button label'));
13763      }
13764    }, []);
13765    (0,external_wp_element_namespaceObject.useEffect)(() => {
13766      if (!fileId && href) {
13767        // Add a unique fileId to each file block.
13768        __unstableMarkNextChangeAsNotPersistent();
13769  
13770        setAttributes({
13771          fileId: `wp-block-file--media-$clientId}`
13772        });
13773      }
13774    }, [href, fileId, clientId]);
13775  
13776    function onSelectFile(newMedia) {
13777      if (newMedia && newMedia.url) {
13778        const isPdf = newMedia.url.endsWith('.pdf');
13779        setAttributes({
13780          href: newMedia.url,
13781          fileName: newMedia.title,
13782          textLinkHref: newMedia.url,
13783          id: newMedia.id,
13784          displayPreview: isPdf ? true : undefined,
13785          previewHeight: isPdf ? 600 : undefined
13786        });
13787      }
13788    }
13789  
13790    function onUploadError(message) {
13791      setAttributes({
13792        href: undefined
13793      });
13794      noticeOperations.removeAllNotices();
13795      noticeOperations.createErrorNotice(message);
13796    }
13797  
13798    function changeLinkDestinationOption(newHref) {
13799      // Choose Media File or Attachment Page (when file is in Media Library).
13800      setAttributes({
13801        textLinkHref: newHref
13802      });
13803    }
13804  
13805    function changeOpenInNewWindow(newValue) {
13806      setAttributes({
13807        textLinkTarget: newValue ? '_blank' : false
13808      });
13809    }
13810  
13811    function changeShowDownloadButton(newValue) {
13812      setAttributes({
13813        showDownloadButton: newValue
13814      });
13815    }
13816  
13817    function changeDownloadButtonText(newValue) {
13818      // Remove anchor tags from button text content.
13819      setAttributes({
13820        downloadButtonText: newValue.replace(/<\/?a[^>]*>/g, '')
13821      });
13822    }
13823  
13824    function changeDisplayPreview(newValue) {
13825      setAttributes({
13826        displayPreview: newValue
13827      });
13828    }
13829  
13830    function handleOnResizeStop(event, direction, elt, delta) {
13831      toggleSelection(true);
13832      const newHeight = parseInt(previewHeight + delta.height, 10);
13833      setAttributes({
13834        previewHeight: newHeight
13835      });
13836    }
13837  
13838    function changePreviewHeight(newValue) {
13839      const newHeight = Math.max(parseInt(newValue, 10), MIN_PREVIEW_HEIGHT);
13840      setAttributes({
13841        previewHeight: newHeight
13842      });
13843    }
13844  
13845    const attachmentPage = media && media.link;
13846    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
13847      className: classnames_default()((0,external_wp_blob_namespaceObject.isBlobURL)(href) && (0,external_wp_components_namespaceObject.__unstableGetAnimateClassName)({
13848        type: 'loading'
13849      }), {
13850        'is-transient': (0,external_wp_blob_namespaceObject.isBlobURL)(href)
13851      })
13852    });
13853    const displayPreviewInEditor = browserSupportsPdfs() && displayPreview;
13854  
13855    if (!href) {
13856      return (0,external_wp_element_namespaceObject.createElement)("div", blockProps, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.MediaPlaceholder, {
13857        icon: (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockIcon, {
13858          icon: library_file
13859        }),
13860        labels: {
13861          title: (0,external_wp_i18n_namespaceObject.__)('File'),
13862          instructions: (0,external_wp_i18n_namespaceObject.__)('Upload a file or pick one from your media library.')
13863        },
13864        onSelect: onSelectFile,
13865        notices: noticeUI,
13866        onError: onUploadError,
13867        accept: "*"
13868      }));
13869    }
13870  
13871    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(FileBlockInspector, {
13872      hrefs: {
13873        href,
13874        textLinkHref,
13875        attachmentPage
13876      },
13877      openInNewWindow: !!textLinkTarget,
13878      showDownloadButton,
13879      changeLinkDestinationOption,
13880      changeOpenInNewWindow,
13881      changeShowDownloadButton,
13882      displayPreview,
13883      changeDisplayPreview,
13884      previewHeight,
13885      changePreviewHeight
13886    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, {
13887      group: "other"
13888    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.MediaReplaceFlow, {
13889      mediaId: id,
13890      mediaURL: href,
13891      accept: "*",
13892      onSelect: onSelectFile,
13893      onError: onUploadError
13894    }), (0,external_wp_element_namespaceObject.createElement)(ClipboardToolbarButton, {
13895      text: href,
13896      disabled: (0,external_wp_blob_namespaceObject.isBlobURL)(href)
13897    })), (0,external_wp_element_namespaceObject.createElement)("div", blockProps, displayPreviewInEditor && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ResizableBox, {
13898      size: {
13899        height: previewHeight
13900      },
13901      minHeight: MIN_PREVIEW_HEIGHT,
13902      maxHeight: MAX_PREVIEW_HEIGHT,
13903      minWidth: "100%",
13904      grid: [10, 10],
13905      enable: {
13906        top: false,
13907        right: false,
13908        bottom: true,
13909        left: false,
13910        topRight: false,
13911        bottomRight: false,
13912        bottomLeft: false,
13913        topLeft: false
13914      },
13915      onResizeStart: () => toggleSelection(false),
13916      onResizeStop: handleOnResizeStop,
13917      showHandle: isSelected
13918    }, (0,external_wp_element_namespaceObject.createElement)("object", {
13919      className: "wp-block-file__preview",
13920      data: href,
13921      type: "application/pdf",
13922      "aria-label": (0,external_wp_i18n_namespaceObject.__)('Embed of the selected PDF file.')
13923    }), !isSelected && (0,external_wp_element_namespaceObject.createElement)("div", {
13924      className: "wp-block-file__preview-overlay"
13925    })), (0,external_wp_element_namespaceObject.createElement)("div", {
13926      className: 'wp-block-file__content-wrapper'
13927    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText, {
13928      tagName: "a",
13929      value: fileName,
13930      placeholder: (0,external_wp_i18n_namespaceObject.__)('Write file name…'),
13931      withoutInteractiveFormatting: true,
13932      onChange: text => setAttributes({
13933        fileName: text
13934      }),
13935      href: textLinkHref
13936    }), showDownloadButton && (0,external_wp_element_namespaceObject.createElement)("div", {
13937      className: 'wp-block-file__button-richtext-wrapper'
13938    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText, {
13939      tagName: "div" // Must be block-level or else cursor disappears.
13940      ,
13941      "aria-label": (0,external_wp_i18n_namespaceObject.__)('Download button text'),
13942      className: 'wp-block-file__button',
13943      value: downloadButtonText,
13944      withoutInteractiveFormatting: true,
13945      placeholder: (0,external_wp_i18n_namespaceObject.__)('Add text…'),
13946      onChange: text => changeDownloadButtonText(text)
13947    })))));
13948  }
13949  
13950  /* harmony default export */ var file_edit = ((0,external_wp_components_namespaceObject.withNotices)(FileEdit));
13951  
13952  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/file/save.js
13953  
13954  
13955  /**
13956   * WordPress dependencies
13957   */
13958  
13959  
13960  function file_save_save(_ref) {
13961    let {
13962      attributes
13963    } = _ref;
13964    const {
13965      href,
13966      fileId,
13967      fileName,
13968      textLinkHref,
13969      textLinkTarget,
13970      showDownloadButton,
13971      downloadButtonText,
13972      displayPreview,
13973      previewHeight
13974    } = attributes;
13975    const pdfEmbedLabel = external_wp_blockEditor_namespaceObject.RichText.isEmpty(fileName) ? (0,external_wp_i18n_namespaceObject.__)('PDF embed') : (0,external_wp_i18n_namespaceObject.sprintf)(
13976    /* translators: %s: filename. */
13977    (0,external_wp_i18n_namespaceObject.__)('Embed of %s.'), fileName);
13978    const hasFilename = !external_wp_blockEditor_namespaceObject.RichText.isEmpty(fileName); // Only output an `aria-describedby` when the element it's referring to is
13979    // actually rendered.
13980  
13981    const describedById = hasFilename ? fileId : undefined;
13982    return href && (0,external_wp_element_namespaceObject.createElement)("div", external_wp_blockEditor_namespaceObject.useBlockProps.save(), displayPreview && (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)("object", {
13983      className: "wp-block-file__embed",
13984      data: href,
13985      type: "application/pdf",
13986      style: {
13987        width: '100%',
13988        height: `$previewHeight}px`
13989      },
13990      "aria-label": pdfEmbedLabel
13991    })), hasFilename && (0,external_wp_element_namespaceObject.createElement)("a", {
13992      id: describedById,
13993      href: textLinkHref,
13994      target: textLinkTarget,
13995      rel: textLinkTarget ? 'noreferrer noopener' : undefined
13996    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
13997      value: fileName
13998    })), showDownloadButton && (0,external_wp_element_namespaceObject.createElement)("a", {
13999      href: href,
14000      className: "wp-block-file__button",
14001      download: true,
14002      "aria-describedby": describedById
14003    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
14004      value: downloadButtonText
14005    })));
14006  }
14007  
14008  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/file/transforms.js
14009  /**
14010   * External dependencies
14011   */
14012  
14013  /**
14014   * WordPress dependencies
14015   */
14016  
14017  
14018  
14019  
14020  
14021  
14022  const file_transforms_transforms = {
14023    from: [{
14024      type: 'files',
14025  
14026      isMatch(files) {
14027        return files.length > 0;
14028      },
14029  
14030      // We define a lower priorty (higher number) than the default of 10. This
14031      // ensures that the File block is only created as a fallback.
14032      priority: 15,
14033      transform: files => {
14034        const blocks = [];
14035        files.forEach(file => {
14036          const blobURL = (0,external_wp_blob_namespaceObject.createBlobURL)(file); // File will be uploaded in componentDidMount()
14037  
14038          blocks.push((0,external_wp_blocks_namespaceObject.createBlock)('core/file', {
14039            href: blobURL,
14040            fileName: file.name,
14041            textLinkHref: blobURL
14042          }));
14043        });
14044        return blocks;
14045      }
14046    }, {
14047      type: 'block',
14048      blocks: ['core/audio'],
14049      transform: attributes => {
14050        return (0,external_wp_blocks_namespaceObject.createBlock)('core/file', {
14051          href: attributes.src,
14052          fileName: attributes.caption,
14053          textLinkHref: attributes.src,
14054          id: attributes.id,
14055          anchor: attributes.anchor
14056        });
14057      }
14058    }, {
14059      type: 'block',
14060      blocks: ['core/video'],
14061      transform: attributes => {
14062        return (0,external_wp_blocks_namespaceObject.createBlock)('core/file', {
14063          href: attributes.src,
14064          fileName: attributes.caption,
14065          textLinkHref: attributes.src,
14066          id: attributes.id,
14067          anchor: attributes.anchor
14068        });
14069      }
14070    }, {
14071      type: 'block',
14072      blocks: ['core/image'],
14073      transform: attributes => {
14074        return (0,external_wp_blocks_namespaceObject.createBlock)('core/file', {
14075          href: attributes.url,
14076          fileName: attributes.caption || (0,external_wp_url_namespaceObject.getFilename)(attributes.url),
14077          textLinkHref: attributes.url,
14078          id: attributes.id,
14079          anchor: attributes.anchor
14080        });
14081      }
14082    }],
14083    to: [{
14084      type: 'block',
14085      blocks: ['core/audio'],
14086      isMatch: _ref => {
14087        let {
14088          id
14089        } = _ref;
14090  
14091        if (!id) {
14092          return false;
14093        }
14094  
14095        const {
14096          getMedia
14097        } = (0,external_wp_data_namespaceObject.select)(external_wp_coreData_namespaceObject.store);
14098        const media = getMedia(id);
14099        return !!media && (0,external_lodash_namespaceObject.includes)(media.mime_type, 'audio');
14100      },
14101      transform: attributes => {
14102        return (0,external_wp_blocks_namespaceObject.createBlock)('core/audio', {
14103          src: attributes.href,
14104          caption: attributes.fileName,
14105          id: attributes.id,
14106          anchor: attributes.anchor
14107        });
14108      }
14109    }, {
14110      type: 'block',
14111      blocks: ['core/video'],
14112      isMatch: _ref2 => {
14113        let {
14114          id
14115        } = _ref2;
14116  
14117        if (!id) {
14118          return false;
14119        }
14120  
14121        const {
14122          getMedia
14123        } = (0,external_wp_data_namespaceObject.select)(external_wp_coreData_namespaceObject.store);
14124        const media = getMedia(id);
14125        return !!media && (0,external_lodash_namespaceObject.includes)(media.mime_type, 'video');
14126      },
14127      transform: attributes => {
14128        return (0,external_wp_blocks_namespaceObject.createBlock)('core/video', {
14129          src: attributes.href,
14130          caption: attributes.fileName,
14131          id: attributes.id,
14132          anchor: attributes.anchor
14133        });
14134      }
14135    }, {
14136      type: 'block',
14137      blocks: ['core/image'],
14138      isMatch: _ref3 => {
14139        let {
14140          id
14141        } = _ref3;
14142  
14143        if (!id) {
14144          return false;
14145        }
14146  
14147        const {
14148          getMedia
14149        } = (0,external_wp_data_namespaceObject.select)(external_wp_coreData_namespaceObject.store);
14150        const media = getMedia(id);
14151        return !!media && (0,external_lodash_namespaceObject.includes)(media.mime_type, 'image');
14152      },
14153      transform: attributes => {
14154        return (0,external_wp_blocks_namespaceObject.createBlock)('core/image', {
14155          url: attributes.href,
14156          caption: attributes.fileName,
14157          id: attributes.id,
14158          anchor: attributes.anchor
14159        });
14160      }
14161    }]
14162  };
14163  /* harmony default export */ var file_transforms = (file_transforms_transforms);
14164  
14165  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/file/index.js
14166  /**
14167   * WordPress dependencies
14168   */
14169  
14170  
14171  /**
14172   * Internal dependencies
14173   */
14174  
14175  
14176  
14177  const file_metadata = {
14178    $schema: "https://schemas.wp.org/trunk/block.json",
14179    apiVersion: 2,
14180    name: "core/file",
14181    title: "File",
14182    category: "media",
14183    description: "Add a link to a downloadable file.",
14184    keywords: ["document", "pdf", "download"],
14185    textdomain: "default",
14186    attributes: {
14187      id: {
14188        type: "number"
14189      },
14190      href: {
14191        type: "string"
14192      },
14193      fileId: {
14194        type: "string",
14195        source: "attribute",
14196        selector: "a:not([download])",
14197        attribute: "id"
14198      },
14199      fileName: {
14200        type: "string",
14201        source: "html",
14202        selector: "a:not([download])"
14203      },
14204      textLinkHref: {
14205        type: "string",
14206        source: "attribute",
14207        selector: "a:not([download])",
14208        attribute: "href"
14209      },
14210      textLinkTarget: {
14211        type: "string",
14212        source: "attribute",
14213        selector: "a:not([download])",
14214        attribute: "target"
14215      },
14216      showDownloadButton: {
14217        type: "boolean",
14218        "default": true
14219      },
14220      downloadButtonText: {
14221        type: "string",
14222        source: "html",
14223        selector: "a[download]"
14224      },
14225      displayPreview: {
14226        type: "boolean"
14227      },
14228      previewHeight: {
14229        type: "number",
14230        "default": 600
14231      }
14232    },
14233    supports: {
14234      anchor: true,
14235      align: true
14236    },
14237    viewScript: "file:./view.min.js",
14238    editorStyle: "wp-block-file-editor",
14239    style: "wp-block-file"
14240  };
14241  
14242  
14243  const {
14244    name: file_name
14245  } = file_metadata;
14246  
14247  const file_settings = {
14248    icon: library_file,
14249    example: {
14250      attributes: {
14251        href: 'https://upload.wikimedia.org/wikipedia/commons/d/dd/Armstrong_Small_Step.ogg',
14252        fileName: (0,external_wp_i18n_namespaceObject._x)('Armstrong_Small_Step', 'Name of the file')
14253      }
14254    },
14255    transforms: file_transforms,
14256    deprecated: file_deprecated,
14257    edit: file_edit,
14258    save: file_save_save
14259  };
14260  
14261  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/gallery.js
14262  
14263  
14264  /**
14265   * WordPress dependencies
14266   */
14267  
14268  const gallery = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
14269    viewBox: "0 0 24 24",
14270    xmlns: "http://www.w3.org/2000/svg"
14271  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
14272    d: "M20.2 8v11c0 .7-.6 1.2-1.2 1.2H6v1.5h13c1.5 0 2.7-1.2 2.7-2.8V8h-1.5zM18 16.4V4.6c0-.9-.7-1.6-1.6-1.6H4.6C3.7 3 3 3.7 3 4.6v11.8c0 .9.7 1.6 1.6 1.6h11.8c.9 0 1.6-.7 1.6-1.6zM4.5 4.6c0-.1.1-.1.1-.1h11.8c.1 0 .1.1.1.1V12l-2.3-1.7c-.3-.2-.6-.2-.9 0l-2.9 2.1L8 11.3c-.2-.1-.5-.1-.7 0l-2.9 1.5V4.6zm0 11.8v-1.8l3.2-1.7 2.4 1.2c.2.1.5.1.8-.1l2.8-2 2.8 2v2.5c0 .1-.1.1-.1.1H4.6c0-.1-.1-.2-.1-.2z"
14273  }));
14274  /* harmony default export */ var library_gallery = (gallery);
14275  
14276  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/gallery/constants.js
14277  const LINK_DESTINATION_NONE = 'none';
14278  const LINK_DESTINATION_MEDIA = 'media';
14279  const LINK_DESTINATION_ATTACHMENT = 'attachment';
14280  const LINK_DESTINATION_MEDIA_WP_CORE = 'file';
14281  const LINK_DESTINATION_ATTACHMENT_WP_CORE = 'post';
14282  
14283  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/gallery/shared.js
14284  /**
14285   * External dependencies
14286   */
14287  
14288  function defaultColumnsNumber(imageCount) {
14289    return imageCount ? Math.min(3, imageCount) : 3;
14290  }
14291  const pickRelevantMediaFiles = function (image) {
14292    let sizeSlug = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'large';
14293    const imageProps = (0,external_lodash_namespaceObject.pick)(image, ['alt', 'id', 'link', 'caption']);
14294    imageProps.url = (0,external_lodash_namespaceObject.get)(image, ['sizes', sizeSlug, 'url']) || (0,external_lodash_namespaceObject.get)(image, ['media_details', 'sizes', sizeSlug, 'source_url']) || image.url;
14295    const fullUrl = (0,external_lodash_namespaceObject.get)(image, ['sizes', 'full', 'url']) || (0,external_lodash_namespaceObject.get)(image, ['media_details', 'sizes', 'full', 'source_url']);
14296  
14297    if (fullUrl) {
14298      imageProps.fullUrl = fullUrl;
14299    }
14300  
14301    return imageProps;
14302  };
14303  /**
14304   * The new gallery block format is not compatible with the use_BalanceTags option
14305   * in WP versions <= 5.8 https://core.trac.wordpress.org/ticket/54130. The
14306   * window.wp.galleryBlockV2Enabled flag is set in lib/compat.php. This method
14307   * can be removed when minimum supported WP version >=5.9.
14308   */
14309  
14310  function isGalleryV2Enabled() {
14311    // Only run the Gallery version compat check if the plugin is running, otherwise
14312    // assume we are in 5.9 core and enable by default.
14313    if (false) {}
14314  
14315    return true;
14316  }
14317  
14318  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/gallery/deprecated.js
14319  
14320  
14321  /**
14322   * External dependencies
14323   */
14324  
14325  
14326  /**
14327   * WordPress dependencies
14328   */
14329  
14330  
14331  
14332  /**
14333   * Internal dependencies
14334   */
14335  
14336  
14337  
14338  const DEPRECATED_LINK_DESTINATION_MEDIA = 'file';
14339  const DEPRECATED_LINK_DESTINATION_ATTACHMENT = 'post';
14340  /**
14341   * Original function to determine default number of columns from a block's
14342   * attributes.
14343   *
14344   * Used in deprecations: v1-6, for versions of the gallery block that didn't use inner blocks.
14345   *
14346   * @param {Object} attributes Block attributes.
14347   * @return {number}           Default number of columns for the gallery.
14348   */
14349  
14350  function defaultColumnsNumberV1(attributes) {
14351    var _attributes$images;
14352  
14353    return Math.min(3, attributes === null || attributes === void 0 ? void 0 : (_attributes$images = attributes.images) === null || _attributes$images === void 0 ? void 0 : _attributes$images.length);
14354  }
14355  /**
14356   * Original function to determine new href and linkDestination values for an image block from the
14357   * supplied Gallery link destination.
14358   *
14359   * Used in deprecations: v1-6.
14360   *
14361   * @param {Object} image       Gallery image.
14362   * @param {string} destination Gallery's selected link destination.
14363   * @return {Object}            New attributes to assign to image block.
14364   */
14365  
14366  function getHrefAndDestination(image, destination) {
14367    // Need to determine the URL that the selected destination maps to.
14368    // Gutenberg and WordPress use different constants so the new link
14369    // destination also needs to be tweaked.
14370    switch (destination) {
14371      case DEPRECATED_LINK_DESTINATION_MEDIA:
14372        return {
14373          href: (image === null || image === void 0 ? void 0 : image.source_url) || (image === null || image === void 0 ? void 0 : image.url),
14374          // eslint-disable-line camelcase
14375          linkDestination: LINK_DESTINATION_MEDIA
14376        };
14377  
14378      case DEPRECATED_LINK_DESTINATION_ATTACHMENT:
14379        return {
14380          href: image === null || image === void 0 ? void 0 : image.link,
14381          linkDestination: LINK_DESTINATION_ATTACHMENT
14382        };
14383  
14384      case LINK_DESTINATION_MEDIA:
14385        return {
14386          href: (image === null || image === void 0 ? void 0 : image.source_url) || (image === null || image === void 0 ? void 0 : image.url),
14387          // eslint-disable-line camelcase
14388          linkDestination: LINK_DESTINATION_MEDIA
14389        };
14390  
14391      case LINK_DESTINATION_ATTACHMENT:
14392        return {
14393          href: image === null || image === void 0 ? void 0 : image.link,
14394          linkDestination: LINK_DESTINATION_ATTACHMENT
14395        };
14396  
14397      case LINK_DESTINATION_NONE:
14398        return {
14399          href: undefined,
14400          linkDestination: LINK_DESTINATION_NONE
14401        };
14402    }
14403  
14404    return {};
14405  }
14406  
14407  function runV2Migration(attributes) {
14408    let linkTo = attributes.linkTo ? attributes.linkTo : 'none';
14409  
14410    if (linkTo === 'post') {
14411      linkTo = 'attachment';
14412    } else if (linkTo === 'file') {
14413      linkTo = 'media';
14414    }
14415  
14416    const imageBlocks = attributes.images.map(image => {
14417      return getImageBlock(image, attributes.sizeSlug, linkTo);
14418    });
14419    return [{ ...(0,external_lodash_namespaceObject.omit)(attributes, ['images', 'ids']),
14420      linkTo,
14421      allowResize: false
14422    }, imageBlocks];
14423  }
14424  /**
14425   * Gets an Image block from gallery image data
14426   *
14427   * Used to migrate Galleries to nested Image InnerBlocks.
14428   *
14429   * @param {Object} image    Image properties.
14430   * @param {string} sizeSlug Gallery sizeSlug attribute.
14431   * @param {string} linkTo   Gallery linkTo attribute.
14432   * @return {Object}         Image block.
14433   */
14434  
14435  
14436  function getImageBlock(image, sizeSlug, linkTo) {
14437    return (0,external_wp_blocks_namespaceObject.createBlock)('core/image', { ...(image.id && {
14438        id: parseInt(image.id)
14439      }),
14440      url: image.url,
14441      alt: image.alt,
14442      caption: image.caption,
14443      sizeSlug,
14444      ...getHrefAndDestination(image, linkTo)
14445    });
14446  }
14447  const deprecated_v6 = {
14448    attributes: {
14449      images: {
14450        type: 'array',
14451        default: [],
14452        source: 'query',
14453        selector: '.blocks-gallery-item',
14454        query: {
14455          url: {
14456            type: 'string',
14457            source: 'attribute',
14458            selector: 'img',
14459            attribute: 'src'
14460          },
14461          fullUrl: {
14462            type: 'string',
14463            source: 'attribute',
14464            selector: 'img',
14465            attribute: 'data-full-url'
14466          },
14467          link: {
14468            type: 'string',
14469            source: 'attribute',
14470            selector: 'img',
14471            attribute: 'data-link'
14472          },
14473          alt: {
14474            type: 'string',
14475            source: 'attribute',
14476            selector: 'img',
14477            attribute: 'alt',
14478            default: ''
14479          },
14480          id: {
14481            type: 'string',
14482            source: 'attribute',
14483            selector: 'img',
14484            attribute: 'data-id'
14485          },
14486          caption: {
14487            type: 'string',
14488            source: 'html',
14489            selector: '.blocks-gallery-item__caption'
14490          }
14491        }
14492      },
14493      ids: {
14494        type: 'array',
14495        items: {
14496          type: 'number'
14497        },
14498        default: []
14499      },
14500      columns: {
14501        type: 'number',
14502        minimum: 1,
14503        maximum: 8
14504      },
14505      caption: {
14506        type: 'string',
14507        source: 'html',
14508        selector: '.blocks-gallery-caption'
14509      },
14510      imageCrop: {
14511        type: 'boolean',
14512        default: true
14513      },
14514      fixedHeight: {
14515        type: 'boolean',
14516        default: true
14517      },
14518      linkTo: {
14519        type: 'string'
14520      },
14521      sizeSlug: {
14522        type: 'string',
14523        default: 'large'
14524      }
14525    },
14526    supports: {
14527      anchor: true,
14528      align: true
14529    },
14530  
14531    save(_ref) {
14532      let {
14533        attributes
14534      } = _ref;
14535      const {
14536        images,
14537        columns = defaultColumnsNumberV1(attributes),
14538        imageCrop,
14539        caption,
14540        linkTo
14541      } = attributes;
14542      const className = `columns-$columns} $imageCrop ? 'is-cropped' : ''}`;
14543      return (0,external_wp_element_namespaceObject.createElement)("figure", external_wp_blockEditor_namespaceObject.useBlockProps.save({
14544        className
14545      }), (0,external_wp_element_namespaceObject.createElement)("ul", {
14546        className: "blocks-gallery-grid"
14547      }, images.map(image => {
14548        let href;
14549  
14550        switch (linkTo) {
14551          case DEPRECATED_LINK_DESTINATION_MEDIA:
14552            href = image.fullUrl || image.url;
14553            break;
14554  
14555          case DEPRECATED_LINK_DESTINATION_ATTACHMENT:
14556            href = image.link;
14557            break;
14558        }
14559  
14560        const img = (0,external_wp_element_namespaceObject.createElement)("img", {
14561          src: image.url,
14562          alt: image.alt,
14563          "data-id": image.id,
14564          "data-full-url": image.fullUrl,
14565          "data-link": image.link,
14566          className: image.id ? `wp-image-$image.id}` : null
14567        });
14568        return (0,external_wp_element_namespaceObject.createElement)("li", {
14569          key: image.id || image.url,
14570          className: "blocks-gallery-item"
14571        }, (0,external_wp_element_namespaceObject.createElement)("figure", null, href ? (0,external_wp_element_namespaceObject.createElement)("a", {
14572          href: href
14573        }, img) : img, !external_wp_blockEditor_namespaceObject.RichText.isEmpty(image.caption) && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
14574          tagName: "figcaption",
14575          className: "blocks-gallery-item__caption",
14576          value: image.caption
14577        })));
14578      })), !external_wp_blockEditor_namespaceObject.RichText.isEmpty(caption) && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
14579        tagName: "figcaption",
14580        className: "blocks-gallery-caption",
14581        value: caption
14582      }));
14583    },
14584  
14585    migrate(attributes) {
14586      if (isGalleryV2Enabled()) {
14587        return runV2Migration(attributes);
14588      }
14589  
14590      return attributes;
14591    }
14592  
14593  };
14594  const deprecated_v5 = {
14595    attributes: {
14596      images: {
14597        type: 'array',
14598        default: [],
14599        source: 'query',
14600        selector: '.blocks-gallery-item',
14601        query: {
14602          url: {
14603            type: 'string',
14604            source: 'attribute',
14605            selector: 'img',
14606            attribute: 'src'
14607          },
14608          fullUrl: {
14609            type: 'string',
14610            source: 'attribute',
14611            selector: 'img',
14612            attribute: 'data-full-url'
14613          },
14614          link: {
14615            type: 'string',
14616            source: 'attribute',
14617            selector: 'img',
14618            attribute: 'data-link'
14619          },
14620          alt: {
14621            type: 'string',
14622            source: 'attribute',
14623            selector: 'img',
14624            attribute: 'alt',
14625            default: ''
14626          },
14627          id: {
14628            type: 'string',
14629            source: 'attribute',
14630            selector: 'img',
14631            attribute: 'data-id'
14632          },
14633          caption: {
14634            type: 'string',
14635            source: 'html',
14636            selector: '.blocks-gallery-item__caption'
14637          }
14638        }
14639      },
14640      ids: {
14641        type: 'array',
14642        items: {
14643          type: 'number'
14644        },
14645        default: []
14646      },
14647      columns: {
14648        type: 'number',
14649        minimum: 1,
14650        maximum: 8
14651      },
14652      caption: {
14653        type: 'string',
14654        source: 'html',
14655        selector: '.blocks-gallery-caption'
14656      },
14657      imageCrop: {
14658        type: 'boolean',
14659        default: true
14660      },
14661      linkTo: {
14662        type: 'string',
14663        default: 'none'
14664      },
14665      sizeSlug: {
14666        type: 'string',
14667        default: 'large'
14668      }
14669    },
14670    supports: {
14671      align: true
14672    },
14673  
14674    isEligible(_ref2) {
14675      let {
14676        linkTo
14677      } = _ref2;
14678      return !linkTo || linkTo === 'attachment' || linkTo === 'media';
14679    },
14680  
14681    migrate(attributes) {
14682      if (isGalleryV2Enabled()) {
14683        return runV2Migration(attributes);
14684      }
14685  
14686      let linkTo = attributes.linkTo;
14687  
14688      if (!attributes.linkTo) {
14689        linkTo = 'none';
14690      } else if (attributes.linkTo === 'attachment') {
14691        linkTo = 'post';
14692      } else if (attributes.linkTo === 'media') {
14693        linkTo = 'file';
14694      }
14695  
14696      return { ...attributes,
14697        linkTo
14698      };
14699    },
14700  
14701    save(_ref3) {
14702      let {
14703        attributes
14704      } = _ref3;
14705      const {
14706        images,
14707        columns = defaultColumnsNumberV1(attributes),
14708        imageCrop,
14709        caption,
14710        linkTo
14711      } = attributes;
14712      return (0,external_wp_element_namespaceObject.createElement)("figure", {
14713        className: `columns-$columns} $imageCrop ? 'is-cropped' : ''}`
14714      }, (0,external_wp_element_namespaceObject.createElement)("ul", {
14715        className: "blocks-gallery-grid"
14716      }, images.map(image => {
14717        let href;
14718  
14719        switch (linkTo) {
14720          case 'media':
14721            href = image.fullUrl || image.url;
14722            break;
14723  
14724          case 'attachment':
14725            href = image.link;
14726            break;
14727        }
14728  
14729        const img = (0,external_wp_element_namespaceObject.createElement)("img", {
14730          src: image.url,
14731          alt: image.alt,
14732          "data-id": image.id,
14733          "data-full-url": image.fullUrl,
14734          "data-link": image.link,
14735          className: image.id ? `wp-image-$image.id}` : null
14736        });
14737        return (0,external_wp_element_namespaceObject.createElement)("li", {
14738          key: image.id || image.url,
14739          className: "blocks-gallery-item"
14740        }, (0,external_wp_element_namespaceObject.createElement)("figure", null, href ? (0,external_wp_element_namespaceObject.createElement)("a", {
14741          href: href
14742        }, img) : img, !external_wp_blockEditor_namespaceObject.RichText.isEmpty(image.caption) && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
14743          tagName: "figcaption",
14744          className: "blocks-gallery-item__caption",
14745          value: image.caption
14746        })));
14747      })), !external_wp_blockEditor_namespaceObject.RichText.isEmpty(caption) && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
14748        tagName: "figcaption",
14749        className: "blocks-gallery-caption",
14750        value: caption
14751      }));
14752    }
14753  
14754  };
14755  const deprecated_v4 = {
14756    attributes: {
14757      images: {
14758        type: 'array',
14759        default: [],
14760        source: 'query',
14761        selector: '.blocks-gallery-item',
14762        query: {
14763          url: {
14764            source: 'attribute',
14765            selector: 'img',
14766            attribute: 'src'
14767          },
14768          fullUrl: {
14769            source: 'attribute',
14770            selector: 'img',
14771            attribute: 'data-full-url'
14772          },
14773          link: {
14774            source: 'attribute',
14775            selector: 'img',
14776            attribute: 'data-link'
14777          },
14778          alt: {
14779            source: 'attribute',
14780            selector: 'img',
14781            attribute: 'alt',
14782            default: ''
14783          },
14784          id: {
14785            source: 'attribute',
14786            selector: 'img',
14787            attribute: 'data-id'
14788          },
14789          caption: {
14790            type: 'string',
14791            source: 'html',
14792            selector: '.blocks-gallery-item__caption'
14793          }
14794        }
14795      },
14796      ids: {
14797        type: 'array',
14798        default: []
14799      },
14800      columns: {
14801        type: 'number'
14802      },
14803      caption: {
14804        type: 'string',
14805        source: 'html',
14806        selector: '.blocks-gallery-caption'
14807      },
14808      imageCrop: {
14809        type: 'boolean',
14810        default: true
14811      },
14812      linkTo: {
14813        type: 'string',
14814        default: 'none'
14815      }
14816    },
14817    supports: {
14818      align: true
14819    },
14820  
14821    isEligible(_ref4) {
14822      let {
14823        ids
14824      } = _ref4;
14825      return ids && ids.some(id => typeof id === 'string');
14826    },
14827  
14828    migrate(attributes) {
14829      if (isGalleryV2Enabled()) {
14830        return runV2Migration(attributes);
14831      }
14832  
14833      return { ...attributes,
14834        ids: (0,external_lodash_namespaceObject.map)(attributes.ids, id => {
14835          const parsedId = parseInt(id, 10);
14836          return Number.isInteger(parsedId) ? parsedId : null;
14837        })
14838      };
14839    },
14840  
14841    save(_ref5) {
14842      let {
14843        attributes
14844      } = _ref5;
14845      const {
14846        images,
14847        columns = defaultColumnsNumberV1(attributes),
14848        imageCrop,
14849        caption,
14850        linkTo
14851      } = attributes;
14852      return (0,external_wp_element_namespaceObject.createElement)("figure", {
14853        className: `columns-$columns} $imageCrop ? 'is-cropped' : ''}`
14854      }, (0,external_wp_element_namespaceObject.createElement)("ul", {
14855        className: "blocks-gallery-grid"
14856      }, images.map(image => {
14857        let href;
14858  
14859        switch (linkTo) {
14860          case 'media':
14861            href = image.fullUrl || image.url;
14862            break;
14863  
14864          case 'attachment':
14865            href = image.link;
14866            break;
14867        }
14868  
14869        const img = (0,external_wp_element_namespaceObject.createElement)("img", {
14870          src: image.url,
14871          alt: image.alt,
14872          "data-id": image.id,
14873          "data-full-url": image.fullUrl,
14874          "data-link": image.link,
14875          className: image.id ? `wp-image-$image.id}` : null
14876        });
14877        return (0,external_wp_element_namespaceObject.createElement)("li", {
14878          key: image.id || image.url,
14879          className: "blocks-gallery-item"
14880        }, (0,external_wp_element_namespaceObject.createElement)("figure", null, href ? (0,external_wp_element_namespaceObject.createElement)("a", {
14881          href: href
14882        }, img) : img, !external_wp_blockEditor_namespaceObject.RichText.isEmpty(image.caption) && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
14883          tagName: "figcaption",
14884          className: "blocks-gallery-item__caption",
14885          value: image.caption
14886        })));
14887      })), !external_wp_blockEditor_namespaceObject.RichText.isEmpty(caption) && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
14888        tagName: "figcaption",
14889        className: "blocks-gallery-caption",
14890        value: caption
14891      }));
14892    }
14893  
14894  };
14895  const deprecated_v3 = {
14896    attributes: {
14897      images: {
14898        type: 'array',
14899        default: [],
14900        source: 'query',
14901        selector: 'ul.wp-block-gallery .blocks-gallery-item',
14902        query: {
14903          url: {
14904            source: 'attribute',
14905            selector: 'img',
14906            attribute: 'src'
14907          },
14908          fullUrl: {
14909            source: 'attribute',
14910            selector: 'img',
14911            attribute: 'data-full-url'
14912          },
14913          alt: {
14914            source: 'attribute',
14915            selector: 'img',
14916            attribute: 'alt',
14917            default: ''
14918          },
14919          id: {
14920            source: 'attribute',
14921            selector: 'img',
14922            attribute: 'data-id'
14923          },
14924          link: {
14925            source: 'attribute',
14926            selector: 'img',
14927            attribute: 'data-link'
14928          },
14929          caption: {
14930            type: 'array',
14931            source: 'children',
14932            selector: 'figcaption'
14933          }
14934        }
14935      },
14936      ids: {
14937        type: 'array',
14938        default: []
14939      },
14940      columns: {
14941        type: 'number'
14942      },
14943      imageCrop: {
14944        type: 'boolean',
14945        default: true
14946      },
14947      linkTo: {
14948        type: 'string',
14949        default: 'none'
14950      }
14951    },
14952    supports: {
14953      align: true
14954    },
14955  
14956    save(_ref6) {
14957      let {
14958        attributes
14959      } = _ref6;
14960      const {
14961        images,
14962        columns = defaultColumnsNumberV1(attributes),
14963        imageCrop,
14964        linkTo
14965      } = attributes;
14966      return (0,external_wp_element_namespaceObject.createElement)("ul", {
14967        className: `columns-$columns} $imageCrop ? 'is-cropped' : ''}`
14968      }, images.map(image => {
14969        let href;
14970  
14971        switch (linkTo) {
14972          case 'media':
14973            href = image.fullUrl || image.url;
14974            break;
14975  
14976          case 'attachment':
14977            href = image.link;
14978            break;
14979        }
14980  
14981        const img = (0,external_wp_element_namespaceObject.createElement)("img", {
14982          src: image.url,
14983          alt: image.alt,
14984          "data-id": image.id,
14985          "data-full-url": image.fullUrl,
14986          "data-link": image.link,
14987          className: image.id ? `wp-image-$image.id}` : null
14988        });
14989        return (0,external_wp_element_namespaceObject.createElement)("li", {
14990          key: image.id || image.url,
14991          className: "blocks-gallery-item"
14992        }, (0,external_wp_element_namespaceObject.createElement)("figure", null, href ? (0,external_wp_element_namespaceObject.createElement)("a", {
14993          href: href
14994        }, img) : img, image.caption && image.caption.length > 0 && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
14995          tagName: "figcaption",
14996          value: image.caption
14997        })));
14998      }));
14999    },
15000  
15001    migrate(attributes) {
15002      if (isGalleryV2Enabled()) {
15003        return runV2Migration(attributes);
15004      }
15005  
15006      return attributes;
15007    }
15008  
15009  };
15010  const deprecated_v2 = {
15011    attributes: {
15012      images: {
15013        type: 'array',
15014        default: [],
15015        source: 'query',
15016        selector: 'ul.wp-block-gallery .blocks-gallery-item',
15017        query: {
15018          url: {
15019            source: 'attribute',
15020            selector: 'img',
15021            attribute: 'src'
15022          },
15023          alt: {
15024            source: 'attribute',
15025            selector: 'img',
15026            attribute: 'alt',
15027            default: ''
15028          },
15029          id: {
15030            source: 'attribute',
15031            selector: 'img',
15032            attribute: 'data-id'
15033          },
15034          link: {
15035            source: 'attribute',
15036            selector: 'img',
15037            attribute: 'data-link'
15038          },
15039          caption: {
15040            type: 'array',
15041            source: 'children',
15042            selector: 'figcaption'
15043          }
15044        }
15045      },
15046      columns: {
15047        type: 'number'
15048      },
15049      imageCrop: {
15050        type: 'boolean',
15051        default: true
15052      },
15053      linkTo: {
15054        type: 'string',
15055        default: 'none'
15056      }
15057    },
15058  
15059    isEligible(_ref7) {
15060      let {
15061        images,
15062        ids
15063      } = _ref7;
15064      return images && images.length > 0 && (!ids && images || ids && images && ids.length !== images.length || (0,external_lodash_namespaceObject.some)(images, (id, index) => {
15065        if (!id && ids[index] !== null) {
15066          return true;
15067        }
15068  
15069        return parseInt(id, 10) !== ids[index];
15070      }));
15071    },
15072  
15073    migrate(attributes) {
15074      if (isGalleryV2Enabled()) {
15075        return runV2Migration(attributes);
15076      }
15077  
15078      return { ...attributes,
15079        ids: (0,external_lodash_namespaceObject.map)(attributes.images, _ref8 => {
15080          let {
15081            id
15082          } = _ref8;
15083  
15084          if (!id) {
15085            return null;
15086          }
15087  
15088          return parseInt(id, 10);
15089        })
15090      };
15091    },
15092  
15093    supports: {
15094      align: true
15095    },
15096  
15097    save(_ref9) {
15098      let {
15099        attributes
15100      } = _ref9;
15101      const {
15102        images,
15103        columns = defaultColumnsNumberV1(attributes),
15104        imageCrop,
15105        linkTo
15106      } = attributes;
15107      return (0,external_wp_element_namespaceObject.createElement)("ul", {
15108        className: `columns-$columns} $imageCrop ? 'is-cropped' : ''}`
15109      }, images.map(image => {
15110        let href;
15111  
15112        switch (linkTo) {
15113          case 'media':
15114            href = image.url;
15115            break;
15116  
15117          case 'attachment':
15118            href = image.link;
15119            break;
15120        }
15121  
15122        const img = (0,external_wp_element_namespaceObject.createElement)("img", {
15123          src: image.url,
15124          alt: image.alt,
15125          "data-id": image.id,
15126          "data-link": image.link,
15127          className: image.id ? `wp-image-$image.id}` : null
15128        });
15129        return (0,external_wp_element_namespaceObject.createElement)("li", {
15130          key: image.id || image.url,
15131          className: "blocks-gallery-item"
15132        }, (0,external_wp_element_namespaceObject.createElement)("figure", null, href ? (0,external_wp_element_namespaceObject.createElement)("a", {
15133          href: href
15134        }, img) : img, image.caption && image.caption.length > 0 && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
15135          tagName: "figcaption",
15136          value: image.caption
15137        })));
15138      }));
15139    }
15140  
15141  };
15142  const gallery_deprecated_v1 = {
15143    attributes: {
15144      images: {
15145        type: 'array',
15146        default: [],
15147        source: 'query',
15148        selector: 'div.wp-block-gallery figure.blocks-gallery-image img',
15149        query: {
15150          url: {
15151            source: 'attribute',
15152            attribute: 'src'
15153          },
15154          alt: {
15155            source: 'attribute',
15156            attribute: 'alt',
15157            default: ''
15158          },
15159          id: {
15160            source: 'attribute',
15161            attribute: 'data-id'
15162          }
15163        }
15164      },
15165      columns: {
15166        type: 'number'
15167      },
15168      imageCrop: {
15169        type: 'boolean',
15170        default: true
15171      },
15172      linkTo: {
15173        type: 'string',
15174        default: 'none'
15175      },
15176      align: {
15177        type: 'string',
15178        default: 'none'
15179      }
15180    },
15181    supports: {
15182      align: true
15183    },
15184  
15185    save(_ref10) {
15186      let {
15187        attributes
15188      } = _ref10;
15189      const {
15190        images,
15191        columns = defaultColumnsNumberV1(attributes),
15192        align,
15193        imageCrop,
15194        linkTo
15195      } = attributes;
15196      const className = classnames_default()(`columns-$columns}`, {
15197        alignnone: align === 'none',
15198        'is-cropped': imageCrop
15199      });
15200      return (0,external_wp_element_namespaceObject.createElement)("div", {
15201        className: className
15202      }, images.map(image => {
15203        let href;
15204  
15205        switch (linkTo) {
15206          case 'media':
15207            href = image.url;
15208            break;
15209  
15210          case 'attachment':
15211            href = image.link;
15212            break;
15213        }
15214  
15215        const img = (0,external_wp_element_namespaceObject.createElement)("img", {
15216          src: image.url,
15217          alt: image.alt,
15218          "data-id": image.id
15219        });
15220        return (0,external_wp_element_namespaceObject.createElement)("figure", {
15221          key: image.id || image.url,
15222          className: "blocks-gallery-image"
15223        }, href ? (0,external_wp_element_namespaceObject.createElement)("a", {
15224          href: href
15225        }, img) : img);
15226      }));
15227    },
15228  
15229    migrate(attributes) {
15230      if (isGalleryV2Enabled()) {
15231        return runV2Migration(attributes);
15232      }
15233  
15234      return attributes;
15235    }
15236  
15237  };
15238  /* harmony default export */ var gallery_deprecated = ([deprecated_v6, deprecated_v5, deprecated_v4, deprecated_v3, deprecated_v2, gallery_deprecated_v1]);
15239  
15240  ;// CONCATENATED MODULE: external ["wp","viewport"]
15241  var external_wp_viewport_namespaceObject = window["wp"]["viewport"];
15242  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/gallery/shared-icon.js
15243  
15244  
15245  /**
15246   * WordPress dependencies
15247   */
15248  
15249  
15250  const sharedIcon = (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockIcon, {
15251    icon: library_gallery
15252  });
15253  
15254  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/image/constants.js
15255  const MIN_SIZE = 20;
15256  const constants_LINK_DESTINATION_NONE = 'none';
15257  const constants_LINK_DESTINATION_MEDIA = 'media';
15258  const constants_LINK_DESTINATION_ATTACHMENT = 'attachment';
15259  const LINK_DESTINATION_CUSTOM = 'custom';
15260  const constants_NEW_TAB_REL = ['noreferrer', 'noopener'];
15261  const constants_ALLOWED_MEDIA_TYPES = ['image'];
15262  const MEDIA_ID_NO_FEATURED_IMAGE_SET = 0;
15263  
15264  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/gallery/utils.js
15265  /**
15266   * Internal dependencies
15267   */
15268  
15269  
15270  /**
15271   * Determines new href and linkDestination values for an image block from the
15272   * supplied Gallery link destination.
15273   *
15274   * @param {Object} image       Gallery image.
15275   * @param {string} destination Gallery's selected link destination.
15276   * @return {Object}            New attributes to assign to image block.
15277   */
15278  
15279  function utils_getHrefAndDestination(image, destination) {
15280    // Gutenberg and WordPress use different constants so if image_default_link_type
15281    // option is set we need to map from the WP Core values.
15282    switch (destination) {
15283      case LINK_DESTINATION_MEDIA_WP_CORE:
15284      case LINK_DESTINATION_MEDIA:
15285        return {
15286          href: (image === null || image === void 0 ? void 0 : image.source_url) || (image === null || image === void 0 ? void 0 : image.url),
15287          // eslint-disable-line camelcase
15288          linkDestination: constants_LINK_DESTINATION_MEDIA
15289        };
15290  
15291      case LINK_DESTINATION_ATTACHMENT_WP_CORE:
15292      case LINK_DESTINATION_ATTACHMENT:
15293        return {
15294          href: image === null || image === void 0 ? void 0 : image.link,
15295          linkDestination: constants_LINK_DESTINATION_ATTACHMENT
15296        };
15297  
15298      case LINK_DESTINATION_NONE:
15299        return {
15300          href: undefined,
15301          linkDestination: constants_LINK_DESTINATION_NONE
15302        };
15303    }
15304  
15305    return {};
15306  }
15307  
15308  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/image/utils.js
15309  /**
15310   * External dependencies
15311   */
15312  
15313  /**
15314   * Internal dependencies
15315   */
15316  
15317  
15318  function removeNewTabRel(currentRel) {
15319    let newRel = currentRel;
15320  
15321    if (currentRel !== undefined && !(0,external_lodash_namespaceObject.isEmpty)(newRel)) {
15322      if (!(0,external_lodash_namespaceObject.isEmpty)(newRel)) {
15323        (0,external_lodash_namespaceObject.each)(constants_NEW_TAB_REL, relVal => {
15324          const regExp = new RegExp('\\b' + relVal + '\\b', 'gi');
15325          newRel = newRel.replace(regExp, '');
15326        }); // Only trim if NEW_TAB_REL values was replaced.
15327  
15328        if (newRel !== currentRel) {
15329          newRel = newRel.trim();
15330        }
15331  
15332        if ((0,external_lodash_namespaceObject.isEmpty)(newRel)) {
15333          newRel = undefined;
15334        }
15335      }
15336    }
15337  
15338    return newRel;
15339  }
15340  /**
15341   * Helper to get the link target settings to be stored.
15342   *
15343   * @param {boolean} value          The new link target value.
15344   * @param {Object}  attributes     Block attributes.
15345   * @param {Object}  attributes.rel Image block's rel attribute.
15346   *
15347   * @return {Object} Updated link target settings.
15348   */
15349  
15350  function getUpdatedLinkTargetSettings(value, _ref) {
15351    let {
15352      rel
15353    } = _ref;
15354    const linkTarget = value ? '_blank' : undefined;
15355    let updatedRel;
15356  
15357    if (!linkTarget && !rel) {
15358      updatedRel = undefined;
15359    } else {
15360      updatedRel = removeNewTabRel(rel);
15361    }
15362  
15363    return {
15364      linkTarget,
15365      rel: updatedRel
15366    };
15367  }
15368  /**
15369   * Determines new Image block attributes size selection.
15370   *
15371   * @param {Object} image Media file object for gallery image.
15372   * @param {string} size  Selected size slug to apply.
15373   */
15374  
15375  function getImageSizeAttributes(image, size) {
15376    const url = (0,external_lodash_namespaceObject.get)(image, ['media_details', 'sizes', size, 'source_url']);
15377  
15378    if (url) {
15379      return {
15380        url,
15381        width: undefined,
15382        height: undefined,
15383        sizeSlug: size
15384      };
15385    }
15386  
15387    return {};
15388  }
15389  
15390  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/gallery/gallery.js
15391  
15392  
15393  
15394  /**
15395   * External dependencies
15396   */
15397  
15398  /**
15399   * WordPress dependencies
15400   */
15401  
15402  
15403  
15404  
15405  
15406  
15407  
15408  const allowedBlocks = ['core/image'];
15409  const Gallery = props => {
15410    const {
15411      attributes,
15412      isSelected,
15413      setAttributes,
15414      mediaPlaceholder,
15415      insertBlocksAfter,
15416      blockProps
15417    } = props;
15418    const {
15419      align,
15420      columns,
15421      caption,
15422      imageCrop
15423    } = attributes;
15424    const {
15425      children,
15426      ...innerBlocksProps
15427    } = (0,external_wp_blockEditor_namespaceObject.useInnerBlocksProps)(blockProps, {
15428      allowedBlocks,
15429      orientation: 'horizontal',
15430      renderAppender: false,
15431      __experimentalLayout: {
15432        type: 'default',
15433        alignments: []
15434      }
15435    });
15436    const [captionFocused, setCaptionFocused] = (0,external_wp_element_namespaceObject.useState)(false);
15437  
15438    function onFocusCaption() {
15439      if (!captionFocused) {
15440        setCaptionFocused(true);
15441      }
15442    }
15443  
15444    function removeCaptionFocus() {
15445      if (captionFocused) {
15446        setCaptionFocused(false);
15447      }
15448    }
15449  
15450    (0,external_wp_element_namespaceObject.useEffect)(() => {
15451      if (!isSelected) {
15452        setCaptionFocused(false);
15453      }
15454    }, [isSelected]);
15455    return (0,external_wp_element_namespaceObject.createElement)("figure", _extends({}, innerBlocksProps, {
15456      className: classnames_default()(blockProps.className, 'blocks-gallery-grid', {
15457        [`align$align}`]: align,
15458        [`columns-$columns}`]: columns !== undefined,
15459        [`columns-default`]: columns === undefined,
15460        'is-cropped': imageCrop
15461      })
15462    }), children, isSelected && !children && (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.View, {
15463      className: "blocks-gallery-media-placeholder-wrapper",
15464      onClick: removeCaptionFocus
15465    }, mediaPlaceholder), (0,external_wp_element_namespaceObject.createElement)(RichTextVisibilityHelper, {
15466      isHidden: !isSelected && external_wp_blockEditor_namespaceObject.RichText.isEmpty(caption),
15467      captionFocused: captionFocused,
15468      onFocusCaption: onFocusCaption,
15469      tagName: "figcaption",
15470      className: "blocks-gallery-caption",
15471      "aria-label": (0,external_wp_i18n_namespaceObject.__)('Gallery caption text'),
15472      placeholder: (0,external_wp_i18n_namespaceObject.__)('Write gallery caption…'),
15473      value: caption,
15474      onChange: value => setAttributes({
15475        caption: value
15476      }),
15477      inlineToolbar: true,
15478      __unstableOnSplitAtEnd: () => insertBlocksAfter((0,external_wp_blocks_namespaceObject.createBlock)('core/paragraph'))
15479    }));
15480  };
15481  
15482  function RichTextVisibilityHelper(_ref) {
15483    let {
15484      isHidden,
15485      captionFocused,
15486      onFocusCaption,
15487      className,
15488      value,
15489      placeholder,
15490      tagName,
15491      captionRef,
15492      ...richTextProps
15493    } = _ref;
15494  
15495    if (isHidden) {
15496      return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.VisuallyHidden, _extends({
15497        as: external_wp_blockEditor_namespaceObject.RichText
15498      }, richTextProps));
15499    }
15500  
15501    return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText, _extends({
15502      ref: captionRef,
15503      value: value,
15504      placeholder: placeholder,
15505      className: className,
15506      tagName: tagName,
15507      isSelected: captionFocused,
15508      onClick: onFocusCaption
15509    }, richTextProps));
15510  }
15511  
15512  /* harmony default export */ var gallery_gallery = (Gallery);
15513  
15514  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/gallery/use-image-sizes.js
15515  /**
15516   * External dependencies
15517   */
15518  
15519  /**
15520   * WordPress dependencies
15521   */
15522  
15523  
15524  /**
15525   * Calculates the image sizes that are avaible for the current gallery images in order to
15526   * populate the 'Image size' selector.
15527   *
15528   * @param {Array}    images      Basic image block data taken from current gallery innerBlock
15529   * @param {boolean}  isSelected  Is the block currently selected in the editor.
15530   * @param {Function} getSettings Block editor store selector.
15531   *
15532   * @return {Array} An array of image size options.
15533   */
15534  
15535  function useImageSizes(images, isSelected, getSettings) {
15536    return (0,external_wp_element_namespaceObject.useMemo)(() => getImageSizing(), [images, isSelected]);
15537  
15538    function getImageSizing() {
15539      if (!images || images.length === 0) {
15540        return;
15541      }
15542  
15543      const {
15544        imageSizes
15545      } = getSettings();
15546      let resizedImages = {};
15547  
15548      if (isSelected) {
15549        resizedImages = images.reduce((currentResizedImages, img) => {
15550          if (!img.id) {
15551            return currentResizedImages;
15552          }
15553  
15554          const sizes = imageSizes.reduce((currentSizes, size) => {
15555            const defaultUrl = (0,external_lodash_namespaceObject.get)(img, ['sizes', size.slug, 'url']);
15556            const mediaDetailsUrl = (0,external_lodash_namespaceObject.get)(img, ['media_details', 'sizes', size.slug, 'source_url']);
15557            return { ...currentSizes,
15558              [size.slug]: defaultUrl || mediaDetailsUrl
15559            };
15560          }, {});
15561          return { ...currentResizedImages,
15562            [parseInt(img.id, 10)]: sizes
15563          };
15564        }, {});
15565      }
15566  
15567      return imageSizes.filter(_ref => {
15568        let {
15569          slug
15570        } = _ref;
15571        return (0,external_lodash_namespaceObject.some)(resizedImages, sizes => sizes[slug]);
15572      }).map(_ref2 => {
15573        let {
15574          name,
15575          slug
15576        } = _ref2;
15577        return {
15578          value: slug,
15579          label: name
15580        };
15581      });
15582    }
15583  }
15584  
15585  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/gallery/use-short-code-transform.js
15586  /**
15587   * External dependencies
15588   */
15589  
15590  /**
15591   * WordPress dependencies
15592   */
15593  
15594  
15595  
15596  /**
15597   * Shortcode transforms don't currently have a tranform method and so can't use a selector to
15598   * retrieve the data for each image being transformer, so this selector handle this post transformation.
15599   *
15600   * @param {Array} shortCodeTransforms An array of image data passed from the shortcode transform.
15601   *
15602   * @return {Array} An array of extended image data objects for each of the shortcode transform images.
15603   */
15604  
15605  function useShortCodeTransform(shortCodeTransforms) {
15606    const newImageData = (0,external_wp_data_namespaceObject.useSelect)(select => {
15607      if (!shortCodeTransforms || shortCodeTransforms.length === 0) {
15608        return;
15609      }
15610  
15611      const getMedia = select(external_wp_coreData_namespaceObject.store).getMedia;
15612      return shortCodeTransforms.map(image => {
15613        const imageData = getMedia(image.id);
15614  
15615        if (imageData) {
15616          return {
15617            id: imageData.id,
15618            type: 'image',
15619            url: imageData.source_url,
15620            mime: imageData.mime_type,
15621            alt: imageData.alt_text,
15622            link: imageData.link
15623          };
15624        }
15625  
15626        return undefined;
15627      });
15628    }, [shortCodeTransforms]);
15629  
15630    if (!newImageData) {
15631      return;
15632    }
15633  
15634    if ((0,external_lodash_namespaceObject.every)(newImageData, img => img && img.url)) {
15635      return newImageData;
15636    }
15637  }
15638  
15639  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/gallery/use-get-new-images.js
15640  /**
15641   * WordPress dependencies
15642   */
15643  
15644  /**
15645   * Keeps track of images already in the gallery to allow new innerBlocks to be identified. This
15646   * is required so default gallery attributes can be applied without overwriting any custom
15647   * attributes applied to existing images.
15648   *
15649   * @param {Array} images    Basic image block data taken from current gallery innerBlock
15650   * @param {Array} imageData The related image data for each of the current gallery images.
15651   *
15652   * @return {Array} An array of any new images that have been added to the gallery.
15653   */
15654  
15655  function useGetNewImages(images, imageData) {
15656    const [currentImages, setCurrentImages] = (0,external_wp_element_namespaceObject.useState)([]);
15657    return (0,external_wp_element_namespaceObject.useMemo)(() => getNewImages(), [images, imageData]);
15658  
15659    function getNewImages() {
15660      let imagesUpdated = false; // First lets check if any images have been deleted.
15661  
15662      const newCurrentImages = currentImages.filter(currentImg => images.find(img => {
15663        return currentImg.clientId === img.clientId;
15664      }));
15665  
15666      if (newCurrentImages.length < currentImages.length) {
15667        imagesUpdated = true;
15668      } // Now lets see if we have any images hydrated from saved content and if so
15669      // add them to currentImages state.
15670  
15671  
15672      images.forEach(image => {
15673        if (image.fromSavedContent && !newCurrentImages.find(currentImage => currentImage.id === image.id)) {
15674          imagesUpdated = true;
15675          newCurrentImages.push(image);
15676        }
15677      }); // Now check for any new images that have been added to InnerBlocks and for which
15678      // we have the imageData we need for setting default block attributes.
15679  
15680      const newImages = images.filter(image => !newCurrentImages.find(currentImage => image.clientId && currentImage.clientId === image.clientId) && (imageData === null || imageData === void 0 ? void 0 : imageData.find(img => img.id === image.id)) && !image.fromSavedConent);
15681  
15682      if (imagesUpdated || (newImages === null || newImages === void 0 ? void 0 : newImages.length) > 0) {
15683        setCurrentImages([...newCurrentImages, ...newImages]);
15684      }
15685  
15686      return newImages.length > 0 ? newImages : null;
15687    }
15688  }
15689  
15690  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/gallery/use-get-media.js
15691  /**
15692   * WordPress dependencies
15693   */
15694  
15695  
15696  
15697  /**
15698   * Retrieves the extended media info for each gallery image from the store. This is used to
15699   * determine which image size options are available for the current gallery.
15700   *
15701   * @param {Array} innerBlockImages An array of the innerBlock images currently in the gallery.
15702   *
15703   * @return {Array} An array of media info options for each gallery image.
15704   */
15705  
15706  function useGetMedia(innerBlockImages) {
15707    const [currentImageMedia, setCurrentImageMedia] = (0,external_wp_element_namespaceObject.useState)([]);
15708    const imageMedia = (0,external_wp_data_namespaceObject.useSelect)(select => {
15709      if (!(innerBlockImages !== null && innerBlockImages !== void 0 && innerBlockImages.length)) {
15710        return currentImageMedia;
15711      }
15712  
15713      const imageIds = innerBlockImages.map(imageBlock => imageBlock.attributes.id).filter(id => id !== undefined);
15714  
15715      if (imageIds.length === 0) {
15716        return currentImageMedia;
15717      }
15718  
15719      return select(external_wp_coreData_namespaceObject.store).getMediaItems({
15720        include: imageIds.join(','),
15721        per_page: -1
15722      });
15723    }, [innerBlockImages]);
15724  
15725    if ((imageMedia === null || imageMedia === void 0 ? void 0 : imageMedia.length) !== (currentImageMedia === null || currentImageMedia === void 0 ? void 0 : currentImageMedia.length) || imageMedia !== null && imageMedia !== void 0 && imageMedia.some(newImage => !currentImageMedia.find(currentImage => currentImage.id === newImage.id))) {
15726      setCurrentImageMedia(imageMedia);
15727      return imageMedia;
15728    }
15729  
15730    return currentImageMedia;
15731  }
15732  
15733  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/gallery/gap-styles.js
15734  
15735  
15736  /**
15737   * WordPress dependencies
15738   */
15739  
15740  
15741  function GapStyles(_ref) {
15742    let {
15743      blockGap,
15744      clientId
15745    } = _ref;
15746    const styleElement = (0,external_wp_element_namespaceObject.useContext)(external_wp_blockEditor_namespaceObject.BlockList.__unstableElementContext); // --gallery-block--gutter-size is deprecated. --wp--style--gallery-gap-default should be used by themes that want to set a default
15747    // gap on the gallery.
15748  
15749    const gapValue = blockGap ? blockGap : `var( --wp--style--gallery-gap-default, var( --gallery-block--gutter-size, var( --wp--style--block-gap, 0.5em ) ) )`;
15750    const gap = `#block-$clientId} { 
15751          --wp--style--unstable-gallery-gap: $gapValue};
15752          gap: $gapValue} 
15753      }`;
15754  
15755    const GapStyle = () => {
15756      return (0,external_wp_element_namespaceObject.createElement)("style", null, gap);
15757    };
15758  
15759    return gap && styleElement ? (0,external_wp_element_namespaceObject.createPortal)((0,external_wp_element_namespaceObject.createElement)(GapStyle, null), styleElement) : null;
15760  }
15761  
15762  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/gallery/edit.js
15763  
15764  
15765  
15766  /**
15767   * External dependencies
15768   */
15769  
15770  
15771  /**
15772   * WordPress dependencies
15773   */
15774  
15775  
15776  
15777  
15778  
15779  
15780  
15781  
15782  
15783  
15784  
15785  
15786  /**
15787   * Internal dependencies
15788   */
15789  
15790  
15791  
15792  
15793  
15794  
15795  
15796  
15797  
15798  
15799  
15800  
15801  const MAX_COLUMNS = 8;
15802  const linkOptions = [{
15803    value: LINK_DESTINATION_ATTACHMENT,
15804    label: (0,external_wp_i18n_namespaceObject.__)('Attachment Page')
15805  }, {
15806    value: LINK_DESTINATION_MEDIA,
15807    label: (0,external_wp_i18n_namespaceObject.__)('Media File')
15808  }, {
15809    value: LINK_DESTINATION_NONE,
15810    label: (0,external_wp_i18n_namespaceObject._x)('None', 'Media item link option')
15811  }];
15812  const edit_ALLOWED_MEDIA_TYPES = ['image'];
15813  const PLACEHOLDER_TEXT = external_wp_element_namespaceObject.Platform.isNative ? (0,external_wp_i18n_namespaceObject.__)('ADD MEDIA') : (0,external_wp_i18n_namespaceObject.__)('Drag images, upload new ones or select files from your library.');
15814  const MOBILE_CONTROL_PROPS_RANGE_CONTROL = external_wp_element_namespaceObject.Platform.isNative ? {
15815    type: 'stepper'
15816  } : {};
15817  
15818  function GalleryEdit(props) {
15819    var _attributes$style, _attributes$style$spa;
15820  
15821    const {
15822      setAttributes,
15823      attributes,
15824      className,
15825      clientId,
15826      noticeOperations,
15827      isSelected,
15828      noticeUI,
15829      insertBlocksAfter
15830    } = props;
15831    const {
15832      columns,
15833      imageCrop,
15834      linkTarget,
15835      linkTo,
15836      shortCodeTransforms,
15837      sizeSlug
15838    } = attributes;
15839    const {
15840      __unstableMarkNextChangeAsNotPersistent,
15841      replaceInnerBlocks,
15842      updateBlockAttributes,
15843      selectBlock,
15844      clearSelectedBlock
15845    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_blockEditor_namespaceObject.store);
15846    const {
15847      createSuccessNotice
15848    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_notices_namespaceObject.store);
15849    const {
15850      getBlock,
15851      getSettings,
15852      preferredStyle
15853    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
15854      var _preferredStyleVariat;
15855  
15856      const settings = select(external_wp_blockEditor_namespaceObject.store).getSettings();
15857      const preferredStyleVariations = settings.__experimentalPreferredStyleVariations;
15858      return {
15859        getBlock: select(external_wp_blockEditor_namespaceObject.store).getBlock,
15860        getSettings: select(external_wp_blockEditor_namespaceObject.store).getSettings,
15861        preferredStyle: preferredStyleVariations === null || preferredStyleVariations === void 0 ? void 0 : (_preferredStyleVariat = preferredStyleVariations.value) === null || _preferredStyleVariat === void 0 ? void 0 : _preferredStyleVariat['core/image']
15862      };
15863    }, []);
15864    const innerBlockImages = (0,external_wp_data_namespaceObject.useSelect)(select => {
15865      var _select$getBlock;
15866  
15867      return (_select$getBlock = select(external_wp_blockEditor_namespaceObject.store).getBlock(clientId)) === null || _select$getBlock === void 0 ? void 0 : _select$getBlock.innerBlocks;
15868    }, [clientId]);
15869    const wasBlockJustInserted = (0,external_wp_data_namespaceObject.useSelect)(select => {
15870      return select(external_wp_blockEditor_namespaceObject.store).wasBlockJustInserted(clientId, 'inserter_menu');
15871    }, [clientId]);
15872    const images = (0,external_wp_element_namespaceObject.useMemo)(() => innerBlockImages === null || innerBlockImages === void 0 ? void 0 : innerBlockImages.map(block => ({
15873      clientId: block.clientId,
15874      id: block.attributes.id,
15875      url: block.attributes.url,
15876      attributes: block.attributes,
15877      fromSavedContent: Boolean(block.originalContent)
15878    })), [innerBlockImages]);
15879    const imageData = useGetMedia(innerBlockImages);
15880    const newImages = useGetNewImages(images, imageData);
15881    (0,external_wp_element_namespaceObject.useEffect)(() => {
15882      newImages === null || newImages === void 0 ? void 0 : newImages.forEach(newImage => {
15883        updateBlockAttributes(newImage.clientId, { ...buildImageAttributes(newImage.attributes),
15884          id: newImage.id,
15885          align: undefined
15886        });
15887      });
15888  
15889      if ((newImages === null || newImages === void 0 ? void 0 : newImages.length) > 0) {
15890        clearSelectedBlock();
15891      }
15892    }, [newImages]);
15893    const shortCodeImages = useShortCodeTransform(shortCodeTransforms);
15894    (0,external_wp_element_namespaceObject.useEffect)(() => {
15895      if (!shortCodeTransforms || !shortCodeImages) {
15896        return;
15897      }
15898  
15899      updateImages(shortCodeImages);
15900      setAttributes({
15901        shortCodeTransforms: undefined
15902      });
15903    }, [shortCodeTransforms, shortCodeImages]);
15904    const imageSizeOptions = useImageSizes(imageData, isSelected, getSettings);
15905    /**
15906     * Determines the image attributes that should be applied to an image block
15907     * after the gallery updates.
15908     *
15909     * The gallery will receive the full collection of images when a new image
15910     * is added. As a result we need to reapply the image's original settings if
15911     * it already existed in the gallery. If the image is in fact new, we need
15912     * to apply the gallery's current settings to the image.
15913     *
15914     * @param {Object} imageAttributes Media object for the actual image.
15915     * @return {Object}                Attributes to set on the new image block.
15916     */
15917  
15918    function buildImageAttributes(imageAttributes) {
15919      const image = imageAttributes.id ? (0,external_lodash_namespaceObject.find)(imageData, {
15920        id: imageAttributes.id
15921      }) : null;
15922      let newClassName;
15923  
15924      if (imageAttributes.className && imageAttributes.className !== '') {
15925        newClassName = imageAttributes.className;
15926      } else {
15927        newClassName = preferredStyle ? `is-style-$preferredStyle}` : undefined;
15928      }
15929  
15930      return { ...pickRelevantMediaFiles(imageAttributes, sizeSlug),
15931        ...utils_getHrefAndDestination(image, linkTo),
15932        ...getUpdatedLinkTargetSettings(linkTarget, attributes),
15933        className: newClassName,
15934        sizeSlug
15935      };
15936    }
15937  
15938    function isValidFileType(file) {
15939      var _file$url;
15940  
15941      return edit_ALLOWED_MEDIA_TYPES.some(mediaType => {
15942        var _file$type;
15943  
15944        return ((_file$type = file.type) === null || _file$type === void 0 ? void 0 : _file$type.indexOf(mediaType)) === 0;
15945      }) || ((_file$url = file.url) === null || _file$url === void 0 ? void 0 : _file$url.indexOf('blob:')) === 0;
15946    }
15947  
15948    function updateImages(selectedImages) {
15949      const newFileUploads = Object.prototype.toString.call(selectedImages) === '[object FileList]';
15950      const imageArray = newFileUploads ? Array.from(selectedImages).map(file => {
15951        if (!file.url) {
15952          return pickRelevantMediaFiles({
15953            url: (0,external_wp_blob_namespaceObject.createBlobURL)(file)
15954          });
15955        }
15956  
15957        return file;
15958      }) : selectedImages;
15959  
15960      if (!imageArray.every(isValidFileType)) {
15961        noticeOperations.removeAllNotices();
15962        noticeOperations.createErrorNotice((0,external_wp_i18n_namespaceObject.__)('If uploading to a gallery all files need to be image formats'), {
15963          id: 'gallery-upload-invalid-file'
15964        });
15965      }
15966  
15967      const processedImages = imageArray.filter(file => file.url || isValidFileType(file)).map(file => {
15968        if (!file.url) {
15969          return pickRelevantMediaFiles({
15970            url: (0,external_wp_blob_namespaceObject.createBlobURL)(file)
15971          });
15972        }
15973  
15974        return file;
15975      }); // Because we are reusing existing innerImage blocks any reordering
15976      // done in the media library will be lost so we need to reapply that ordering
15977      // once the new image blocks are merged in with existing.
15978  
15979      const newOrderMap = processedImages.reduce((result, image, index) => (result[image.id] = index, result), {});
15980      const existingImageBlocks = !newFileUploads ? innerBlockImages.filter(block => processedImages.find(img => img.id === block.attributes.id)) : innerBlockImages;
15981      const newImageList = processedImages.filter(img => !existingImageBlocks.find(existingImg => img.id === existingImg.attributes.id));
15982      const newBlocks = newImageList.map(image => {
15983        return (0,external_wp_blocks_namespaceObject.createBlock)('core/image', {
15984          id: image.id,
15985          url: image.url,
15986          caption: image.caption,
15987          alt: image.alt
15988        });
15989      });
15990  
15991      if ((newBlocks === null || newBlocks === void 0 ? void 0 : newBlocks.length) > 0) {
15992        selectBlock(newBlocks[0].clientId);
15993      }
15994  
15995      replaceInnerBlocks(clientId, (0,external_lodash_namespaceObject.concat)(existingImageBlocks, newBlocks).sort((a, b) => newOrderMap[a.attributes.id] - newOrderMap[b.attributes.id]));
15996    }
15997  
15998    function onUploadError(message) {
15999      noticeOperations.removeAllNotices();
16000      noticeOperations.createErrorNotice(message);
16001    }
16002  
16003    function setLinkTo(value) {
16004      setAttributes({
16005        linkTo: value
16006      });
16007      const changedAttributes = {};
16008      const blocks = [];
16009      getBlock(clientId).innerBlocks.forEach(block => {
16010        blocks.push(block.clientId);
16011        const image = block.attributes.id ? (0,external_lodash_namespaceObject.find)(imageData, {
16012          id: block.attributes.id
16013        }) : null;
16014        changedAttributes[block.clientId] = utils_getHrefAndDestination(image, value);
16015      });
16016      updateBlockAttributes(blocks, changedAttributes, true);
16017      const linkToText = [...linkOptions].find(linkType => linkType.value === value);
16018      createSuccessNotice((0,external_wp_i18n_namespaceObject.sprintf)(
16019      /* translators: %s: image size settings */
16020      (0,external_wp_i18n_namespaceObject.__)('All gallery image links updated to: %s'), linkToText.label), {
16021        id: 'gallery-attributes-linkTo',
16022        type: 'snackbar'
16023      });
16024    }
16025  
16026    function setColumnsNumber(value) {
16027      setAttributes({
16028        columns: value
16029      });
16030    }
16031  
16032    function toggleImageCrop() {
16033      setAttributes({
16034        imageCrop: !imageCrop
16035      });
16036    }
16037  
16038    function getImageCropHelp(checked) {
16039      return checked ? (0,external_wp_i18n_namespaceObject.__)('Thumbnails are cropped to align.') : (0,external_wp_i18n_namespaceObject.__)('Thumbnails are not cropped.');
16040    }
16041  
16042    function toggleOpenInNewTab(openInNewTab) {
16043      const newLinkTarget = openInNewTab ? '_blank' : undefined;
16044      setAttributes({
16045        linkTarget: newLinkTarget
16046      });
16047      const changedAttributes = {};
16048      const blocks = [];
16049      getBlock(clientId).innerBlocks.forEach(block => {
16050        blocks.push(block.clientId);
16051        changedAttributes[block.clientId] = getUpdatedLinkTargetSettings(newLinkTarget, block.attributes);
16052      });
16053      updateBlockAttributes(blocks, changedAttributes, true);
16054      const noticeText = openInNewTab ? (0,external_wp_i18n_namespaceObject.__)('All gallery images updated to open in new tab') : (0,external_wp_i18n_namespaceObject.__)('All gallery images updated to not open in new tab');
16055      createSuccessNotice(noticeText, {
16056        id: 'gallery-attributes-openInNewTab',
16057        type: 'snackbar'
16058      });
16059    }
16060  
16061    function updateImagesSize(newSizeSlug) {
16062      setAttributes({
16063        sizeSlug: newSizeSlug
16064      });
16065      const changedAttributes = {};
16066      const blocks = [];
16067      getBlock(clientId).innerBlocks.forEach(block => {
16068        blocks.push(block.clientId);
16069        const image = block.attributes.id ? (0,external_lodash_namespaceObject.find)(imageData, {
16070          id: block.attributes.id
16071        }) : null;
16072        changedAttributes[block.clientId] = getImageSizeAttributes(image, newSizeSlug);
16073      });
16074      updateBlockAttributes(blocks, changedAttributes, true);
16075      const imageSize = imageSizeOptions.find(size => size.value === newSizeSlug);
16076      createSuccessNotice((0,external_wp_i18n_namespaceObject.sprintf)(
16077      /* translators: %s: image size settings */
16078      (0,external_wp_i18n_namespaceObject.__)('All gallery image sizes updated to: %s'), imageSize.label), {
16079        id: 'gallery-attributes-sizeSlug',
16080        type: 'snackbar'
16081      });
16082    }
16083  
16084    (0,external_wp_element_namespaceObject.useEffect)(() => {
16085      // linkTo attribute must be saved so blocks don't break when changing image_default_link_type in options.php.
16086      if (!linkTo) {
16087        var _window, _window$wp, _window$wp$media, _window$wp$media$view, _window$wp$media$view2, _window$wp$media$view3;
16088  
16089        __unstableMarkNextChangeAsNotPersistent();
16090  
16091        setAttributes({
16092          linkTo: ((_window = window) === null || _window === void 0 ? void 0 : (_window$wp = _window.wp) === null || _window$wp === void 0 ? void 0 : (_window$wp$media = _window$wp.media) === null || _window$wp$media === void 0 ? void 0 : (_window$wp$media$view = _window$wp$media.view) === null || _window$wp$media$view === void 0 ? void 0 : (_window$wp$media$view2 = _window$wp$media$view.settings) === null || _window$wp$media$view2 === void 0 ? void 0 : (_window$wp$media$view3 = _window$wp$media$view2.defaultProps) === null || _window$wp$media$view3 === void 0 ? void 0 : _window$wp$media$view3.link) || LINK_DESTINATION_NONE
16093        });
16094      }
16095    }, [linkTo]);
16096    const hasImages = !!images.length;
16097    const hasImageIds = hasImages && images.some(image => !!image.id);
16098    const imagesUploading = images.some(img => {
16099      var _img$url;
16100  
16101      return !img.id && ((_img$url = img.url) === null || _img$url === void 0 ? void 0 : _img$url.indexOf('blob:')) === 0;
16102    }); // MediaPlaceholder props are different between web and native hence, we provide a platform-specific set.
16103  
16104    const mediaPlaceholderProps = external_wp_element_namespaceObject.Platform.select({
16105      web: {
16106        addToGallery: false,
16107        disableMediaButtons: imagesUploading,
16108        value: {}
16109      },
16110      native: {
16111        addToGallery: hasImageIds,
16112        isAppender: hasImages,
16113        disableMediaButtons: hasImages && !isSelected || imagesUploading,
16114        value: hasImageIds ? images : {},
16115        autoOpenMediaUpload: !hasImages && isSelected && wasBlockJustInserted
16116      }
16117    });
16118    const mediaPlaceholder = (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.MediaPlaceholder, _extends({
16119      handleUpload: false,
16120      icon: sharedIcon,
16121      labels: {
16122        title: (0,external_wp_i18n_namespaceObject.__)('Gallery'),
16123        instructions: PLACEHOLDER_TEXT
16124      },
16125      onSelect: updateImages,
16126      accept: "image/*",
16127      allowedTypes: edit_ALLOWED_MEDIA_TYPES,
16128      multiple: true,
16129      onError: onUploadError,
16130      notices: noticeUI
16131    }, mediaPlaceholderProps));
16132    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
16133      className: classnames_default()(className, 'has-nested-images')
16134    });
16135  
16136    if (!hasImages) {
16137      return (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.View, blockProps, mediaPlaceholder);
16138    }
16139  
16140    const hasLinkTo = linkTo && linkTo !== 'none';
16141    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
16142      title: (0,external_wp_i18n_namespaceObject.__)('Gallery settings')
16143    }, images.length > 1 && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.RangeControl, _extends({
16144      label: (0,external_wp_i18n_namespaceObject.__)('Columns'),
16145      value: columns ? columns : defaultColumnsNumber(images.length),
16146      onChange: setColumnsNumber,
16147      min: 1,
16148      max: Math.min(MAX_COLUMNS, images.length)
16149    }, MOBILE_CONTROL_PROPS_RANGE_CONTROL, {
16150      required: true
16151    })), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
16152      label: (0,external_wp_i18n_namespaceObject.__)('Crop images'),
16153      checked: !!imageCrop,
16154      onChange: toggleImageCrop,
16155      help: getImageCropHelp
16156    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SelectControl, {
16157      label: (0,external_wp_i18n_namespaceObject.__)('Link to'),
16158      value: linkTo,
16159      onChange: setLinkTo,
16160      options: linkOptions,
16161      hideCancelButton: true
16162    }), hasLinkTo && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
16163      label: (0,external_wp_i18n_namespaceObject.__)('Open in new tab'),
16164      checked: linkTarget === '_blank',
16165      onChange: toggleOpenInNewTab
16166    }), (imageSizeOptions === null || imageSizeOptions === void 0 ? void 0 : imageSizeOptions.length) > 0 && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SelectControl, {
16167      label: (0,external_wp_i18n_namespaceObject.__)('Image size'),
16168      value: sizeSlug,
16169      options: imageSizeOptions,
16170      onChange: updateImagesSize,
16171      hideCancelButton: true
16172    }), external_wp_element_namespaceObject.Platform.isWeb && !imageSizeOptions && hasImageIds && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.BaseControl, {
16173      className: 'gallery-image-sizes'
16174    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.BaseControl.VisualLabel, null, (0,external_wp_i18n_namespaceObject.__)('Image size')), (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.View, {
16175      className: 'gallery-image-sizes__loading'
16176    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Spinner, null), (0,external_wp_i18n_namespaceObject.__)('Loading options…'))))), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, {
16177      group: "other"
16178    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.MediaReplaceFlow, {
16179      allowedTypes: edit_ALLOWED_MEDIA_TYPES,
16180      accept: "image/*",
16181      handleUpload: false,
16182      onSelect: updateImages,
16183      name: (0,external_wp_i18n_namespaceObject.__)('Add'),
16184      multiple: true,
16185      mediaIds: images.map(image => image.id),
16186      addToGallery: hasImageIds
16187    })), noticeUI, external_wp_element_namespaceObject.Platform.isWeb && (0,external_wp_element_namespaceObject.createElement)(GapStyles, {
16188      blockGap: (_attributes$style = attributes.style) === null || _attributes$style === void 0 ? void 0 : (_attributes$style$spa = _attributes$style.spacing) === null || _attributes$style$spa === void 0 ? void 0 : _attributes$style$spa.blockGap,
16189      clientId: clientId
16190    }), (0,external_wp_element_namespaceObject.createElement)(gallery_gallery, _extends({}, props, {
16191      images: images,
16192      mediaPlaceholder: !hasImages || external_wp_element_namespaceObject.Platform.isNative ? mediaPlaceholder : undefined,
16193      blockProps: blockProps,
16194      insertBlocksAfter: insertBlocksAfter
16195    })));
16196  }
16197  
16198  /* harmony default export */ var gallery_edit = ((0,external_wp_compose_namespaceObject.compose)([external_wp_components_namespaceObject.withNotices, (0,external_wp_viewport_namespaceObject.withViewportMatch)({
16199    isNarrow: '< small'
16200  })])(GalleryEdit));
16201  
16202  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/gallery/v1/shared.js
16203  /**
16204   * External dependencies
16205   */
16206  
16207  const shared_pickRelevantMediaFiles = function (image) {
16208    let sizeSlug = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'large';
16209    const imageProps = (0,external_lodash_namespaceObject.pick)(image, ['alt', 'id', 'link', 'caption']);
16210    imageProps.url = (0,external_lodash_namespaceObject.get)(image, ['sizes', sizeSlug, 'url']) || (0,external_lodash_namespaceObject.get)(image, ['media_details', 'sizes', sizeSlug, 'source_url']) || image.url;
16211    const fullUrl = (0,external_lodash_namespaceObject.get)(image, ['sizes', 'full', 'url']) || (0,external_lodash_namespaceObject.get)(image, ['media_details', 'sizes', 'full', 'source_url']);
16212  
16213    if (fullUrl) {
16214      imageProps.fullUrl = fullUrl;
16215    }
16216  
16217    return imageProps;
16218  };
16219  
16220  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/image.js
16221  
16222  
16223  /**
16224   * WordPress dependencies
16225   */
16226  
16227  const image_image = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
16228    viewBox: "0 0 24 24",
16229    xmlns: "http://www.w3.org/2000/svg"
16230  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
16231    d: "M19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zM5 4.5h14c.3 0 .5.2.5.5v8.4l-3-2.9c-.3-.3-.8-.3-1 0L11.9 14 9 12c-.3-.2-.6-.2-.8 0l-3.6 2.6V5c-.1-.3.1-.5.4-.5zm14 15H5c-.3 0-.5-.2-.5-.5v-2.4l4.1-3 3 1.9c.3.2.7.2.9-.1L16 12l3.5 3.4V19c0 .3-.2.5-.5.5z"
16232  }));
16233  /* harmony default export */ var library_image = (image_image);
16234  
16235  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/chevron-left.js
16236  
16237  
16238  /**
16239   * WordPress dependencies
16240   */
16241  
16242  const chevronLeft = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
16243    xmlns: "http://www.w3.org/2000/svg",
16244    viewBox: "0 0 24 24"
16245  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
16246    d: "M14.6 7l-1.2-1L8 12l5.4 6 1.2-1-4.6-5z"
16247  }));
16248  /* harmony default export */ var chevron_left = (chevronLeft);
16249  
16250  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/chevron-right.js
16251  
16252  
16253  /**
16254   * WordPress dependencies
16255   */
16256  
16257  const chevronRight = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
16258    xmlns: "http://www.w3.org/2000/svg",
16259    viewBox: "0 0 24 24"
16260  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
16261    d: "M10.6 6L9.4 7l4.6 5-4.6 5 1.2 1 5.4-6z"
16262  }));
16263  /* harmony default export */ var chevron_right = (chevronRight);
16264  
16265  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/close-small.js
16266  
16267  
16268  /**
16269   * WordPress dependencies
16270   */
16271  
16272  const closeSmall = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
16273    xmlns: "http://www.w3.org/2000/svg",
16274    viewBox: "0 0 24 24"
16275  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
16276    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"
16277  }));
16278  /* harmony default export */ var close_small = (closeSmall);
16279  
16280  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/gallery/v1/constants.js
16281  const v1_constants_LINK_DESTINATION_NONE = 'none';
16282  const v1_constants_LINK_DESTINATION_MEDIA = 'file';
16283  const v1_constants_LINK_DESTINATION_ATTACHMENT = 'post';
16284  
16285  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/gallery/v1/gallery-image.js
16286  
16287  
16288  /**
16289   * External dependencies
16290   */
16291  
16292  
16293  /**
16294   * WordPress dependencies
16295   */
16296  
16297  
16298  
16299  
16300  
16301  
16302  
16303  
16304  
16305  
16306  
16307  /**
16308   * Internal dependencies
16309   */
16310  
16311  
16312  
16313  
16314  const isTemporaryImage = (id, url) => !id && (0,external_wp_blob_namespaceObject.isBlobURL)(url);
16315  
16316  class GalleryImage extends external_wp_element_namespaceObject.Component {
16317    constructor() {
16318      super(...arguments);
16319      this.onSelectImage = this.onSelectImage.bind(this);
16320      this.onRemoveImage = this.onRemoveImage.bind(this);
16321      this.bindContainer = this.bindContainer.bind(this);
16322      this.onEdit = this.onEdit.bind(this);
16323      this.onSelectImageFromLibrary = this.onSelectImageFromLibrary.bind(this);
16324      this.onSelectCustomURL = this.onSelectCustomURL.bind(this);
16325      this.state = {
16326        isEditing: false
16327      };
16328    }
16329  
16330    bindContainer(ref) {
16331      this.container = ref;
16332    }
16333  
16334    onSelectImage() {
16335      if (!this.props.isSelected) {
16336        this.props.onSelect();
16337      }
16338    }
16339  
16340    onRemoveImage(event) {
16341      if (this.container === this.container.ownerDocument.activeElement && this.props.isSelected && [external_wp_keycodes_namespaceObject.BACKSPACE, external_wp_keycodes_namespaceObject.DELETE].indexOf(event.keyCode) !== -1) {
16342        event.preventDefault();
16343        this.props.onRemove();
16344      }
16345    }
16346  
16347    onEdit() {
16348      this.setState({
16349        isEditing: true
16350      });
16351    }
16352  
16353    componentDidUpdate() {
16354      const {
16355        image,
16356        url,
16357        __unstableMarkNextChangeAsNotPersistent
16358      } = this.props;
16359  
16360      if (image && !url) {
16361        __unstableMarkNextChangeAsNotPersistent();
16362  
16363        this.props.setAttributes({
16364          url: image.source_url,
16365          alt: image.alt_text
16366        });
16367      }
16368    }
16369  
16370    deselectOnBlur() {
16371      this.props.onDeselect();
16372    }
16373  
16374    onSelectImageFromLibrary(media) {
16375      const {
16376        setAttributes,
16377        id,
16378        url,
16379        alt,
16380        caption,
16381        sizeSlug
16382      } = this.props;
16383  
16384      if (!media || !media.url) {
16385        return;
16386      }
16387  
16388      let mediaAttributes = shared_pickRelevantMediaFiles(media, sizeSlug); // If the current image is temporary but an alt text was meanwhile
16389      // written by the user, make sure the text is not overwritten.
16390  
16391      if (isTemporaryImage(id, url)) {
16392        if (alt) {
16393          mediaAttributes = (0,external_lodash_namespaceObject.omit)(mediaAttributes, ['alt']);
16394        }
16395      } // If a caption text was meanwhile written by the user,
16396      // make sure the text is not overwritten by empty captions.
16397  
16398  
16399      if (caption && !(0,external_lodash_namespaceObject.get)(mediaAttributes, ['caption'])) {
16400        mediaAttributes = (0,external_lodash_namespaceObject.omit)(mediaAttributes, ['caption']);
16401      }
16402  
16403      setAttributes(mediaAttributes);
16404      this.setState({
16405        isEditing: false
16406      });
16407    }
16408  
16409    onSelectCustomURL(newURL) {
16410      const {
16411        setAttributes,
16412        url
16413      } = this.props;
16414  
16415      if (newURL !== url) {
16416        setAttributes({
16417          url: newURL,
16418          id: undefined
16419        });
16420        this.setState({
16421          isEditing: false
16422        });
16423      }
16424    }
16425  
16426    render() {
16427      const {
16428        url,
16429        alt,
16430        id,
16431        linkTo,
16432        link,
16433        isFirstItem,
16434        isLastItem,
16435        isSelected,
16436        caption,
16437        onRemove,
16438        onMoveForward,
16439        onMoveBackward,
16440        setAttributes,
16441        'aria-label': ariaLabel
16442      } = this.props;
16443      const {
16444        isEditing
16445      } = this.state;
16446      let href;
16447  
16448      switch (linkTo) {
16449        case v1_constants_LINK_DESTINATION_MEDIA:
16450          href = url;
16451          break;
16452  
16453        case v1_constants_LINK_DESTINATION_ATTACHMENT:
16454          href = link;
16455          break;
16456      }
16457  
16458      const img = // Disable reason: Image itself is not meant to be interactive, but should
16459      // direct image selection and unfocus caption fields.
16460  
16461      /* eslint-disable jsx-a11y/no-noninteractive-element-interactions */
16462      (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)("img", {
16463        src: url,
16464        alt: alt,
16465        "data-id": id,
16466        onKeyDown: this.onRemoveImage,
16467        tabIndex: "0",
16468        "aria-label": ariaLabel,
16469        ref: this.bindContainer
16470      }), (0,external_wp_blob_namespaceObject.isBlobURL)(url) && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Spinner, null))
16471      /* eslint-enable jsx-a11y/no-noninteractive-element-interactions */
16472      ;
16473      const className = classnames_default()({
16474        'is-selected': isSelected,
16475        'is-transient': (0,external_wp_blob_namespaceObject.isBlobURL)(url)
16476      });
16477      return (// eslint-disable-next-line jsx-a11y/click-events-have-key-events, jsx-a11y/no-noninteractive-element-interactions
16478        (0,external_wp_element_namespaceObject.createElement)("figure", {
16479          className: className,
16480          onClick: this.onSelectImage,
16481          onFocus: this.onSelectImage
16482        }, !isEditing && (href ? (0,external_wp_element_namespaceObject.createElement)("a", {
16483          href: href
16484        }, img) : img), isEditing && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.MediaPlaceholder, {
16485          labels: {
16486            title: (0,external_wp_i18n_namespaceObject.__)('Edit gallery image')
16487          },
16488          icon: library_image,
16489          onSelect: this.onSelectImageFromLibrary,
16490          onSelectURL: this.onSelectCustomURL,
16491          accept: "image/*",
16492          allowedTypes: ['image'],
16493          value: {
16494            id,
16495            src: url
16496          }
16497        }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ButtonGroup, {
16498          className: "block-library-gallery-item__inline-menu is-left"
16499        }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
16500          icon: chevron_left,
16501          onClick: isFirstItem ? undefined : onMoveBackward,
16502          label: (0,external_wp_i18n_namespaceObject.__)('Move image backward'),
16503          "aria-disabled": isFirstItem,
16504          disabled: !isSelected
16505        }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
16506          icon: chevron_right,
16507          onClick: isLastItem ? undefined : onMoveForward,
16508          label: (0,external_wp_i18n_namespaceObject.__)('Move image forward'),
16509          "aria-disabled": isLastItem,
16510          disabled: !isSelected
16511        })), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ButtonGroup, {
16512          className: "block-library-gallery-item__inline-menu is-right"
16513        }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
16514          icon: library_edit,
16515          onClick: this.onEdit,
16516          label: (0,external_wp_i18n_namespaceObject.__)('Replace image'),
16517          disabled: !isSelected
16518        }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
16519          icon: close_small,
16520          onClick: onRemove,
16521          label: (0,external_wp_i18n_namespaceObject.__)('Remove image'),
16522          disabled: !isSelected
16523        })), !isEditing && (isSelected || caption) && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText, {
16524          tagName: "figcaption",
16525          "aria-label": (0,external_wp_i18n_namespaceObject.__)('Image caption text'),
16526          placeholder: isSelected ? (0,external_wp_i18n_namespaceObject.__)('Add caption') : null,
16527          value: caption,
16528          onChange: newCaption => setAttributes({
16529            caption: newCaption
16530          }),
16531          inlineToolbar: true
16532        }))
16533      );
16534    }
16535  
16536  }
16537  
16538  /* harmony default export */ var gallery_image = ((0,external_wp_compose_namespaceObject.compose)([(0,external_wp_data_namespaceObject.withSelect)((select, ownProps) => {
16539    const {
16540      getMedia
16541    } = select(external_wp_coreData_namespaceObject.store);
16542    const {
16543      id
16544    } = ownProps;
16545    return {
16546      image: id ? getMedia(parseInt(id, 10)) : null
16547    };
16548  }), (0,external_wp_data_namespaceObject.withDispatch)(dispatch => {
16549    const {
16550      __unstableMarkNextChangeAsNotPersistent
16551    } = dispatch(external_wp_blockEditor_namespaceObject.store);
16552    return {
16553      __unstableMarkNextChangeAsNotPersistent
16554    };
16555  })])(GalleryImage));
16556  
16557  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/gallery/v1/gallery.js
16558  
16559  
16560  
16561  /**
16562   * External dependencies
16563   */
16564  
16565  /**
16566   * WordPress dependencies
16567   */
16568  
16569  
16570  
16571  
16572  
16573  /**
16574   * Internal dependencies
16575   */
16576  
16577  
16578  
16579  const gallery_Gallery = props => {
16580    const {
16581      attributes,
16582      isSelected,
16583      setAttributes,
16584      selectedImage,
16585      mediaPlaceholder,
16586      onMoveBackward,
16587      onMoveForward,
16588      onRemoveImage,
16589      onSelectImage,
16590      onDeselectImage,
16591      onSetImageAttributes,
16592      insertBlocksAfter,
16593      blockProps
16594    } = props;
16595    const {
16596      align,
16597      columns = defaultColumnsNumberV1(attributes),
16598      caption,
16599      imageCrop,
16600      images
16601    } = attributes;
16602    return (0,external_wp_element_namespaceObject.createElement)("figure", _extends({}, blockProps, {
16603      className: classnames_default()(blockProps.className, {
16604        [`align$align}`]: align,
16605        [`columns-$columns}`]: columns,
16606        'is-cropped': imageCrop
16607      })
16608    }), (0,external_wp_element_namespaceObject.createElement)("ul", {
16609      className: "blocks-gallery-grid"
16610    }, images.map((img, index) => {
16611      const ariaLabel = (0,external_wp_i18n_namespaceObject.sprintf)(
16612      /* translators: 1: the order number of the image. 2: the total number of images. */
16613      (0,external_wp_i18n_namespaceObject.__)('image %1$d of %2$d in gallery'), index + 1, images.length);
16614      return (0,external_wp_element_namespaceObject.createElement)("li", {
16615        className: "blocks-gallery-item",
16616        key: img.id ? `$img.id}-$index}` : img.url
16617      }, (0,external_wp_element_namespaceObject.createElement)(gallery_image, {
16618        url: img.url,
16619        alt: img.alt,
16620        id: img.id,
16621        isFirstItem: index === 0,
16622        isLastItem: index + 1 === images.length,
16623        isSelected: isSelected && selectedImage === index,
16624        onMoveBackward: onMoveBackward(index),
16625        onMoveForward: onMoveForward(index),
16626        onRemove: onRemoveImage(index),
16627        onSelect: onSelectImage(index),
16628        onDeselect: onDeselectImage(index),
16629        setAttributes: attrs => onSetImageAttributes(index, attrs),
16630        caption: img.caption,
16631        "aria-label": ariaLabel,
16632        sizeSlug: attributes.sizeSlug
16633      }));
16634    })), mediaPlaceholder, (0,external_wp_element_namespaceObject.createElement)(gallery_RichTextVisibilityHelper, {
16635      isHidden: !isSelected && external_wp_blockEditor_namespaceObject.RichText.isEmpty(caption),
16636      tagName: "figcaption",
16637      className: "blocks-gallery-caption",
16638      "aria-label": (0,external_wp_i18n_namespaceObject.__)('Gallery caption text'),
16639      placeholder: (0,external_wp_i18n_namespaceObject.__)('Write gallery caption…'),
16640      value: caption,
16641      onChange: value => setAttributes({
16642        caption: value
16643      }),
16644      inlineToolbar: true,
16645      __unstableOnSplitAtEnd: () => insertBlocksAfter((0,external_wp_blocks_namespaceObject.createBlock)('core/paragraph'))
16646    }));
16647  };
16648  
16649  function gallery_RichTextVisibilityHelper(_ref) {
16650    let {
16651      isHidden,
16652      ...richTextProps
16653    } = _ref;
16654    return isHidden ? (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.VisuallyHidden, _extends({
16655      as: external_wp_blockEditor_namespaceObject.RichText
16656    }, richTextProps)) : (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText, richTextProps);
16657  }
16658  
16659  /* harmony default export */ var v1_gallery = (gallery_Gallery);
16660  
16661  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/gallery/v1/edit.js
16662  
16663  
16664  
16665  /**
16666   * External dependencies
16667   */
16668  
16669  /**
16670   * WordPress dependencies
16671   */
16672  
16673  
16674  
16675  
16676  
16677  
16678  
16679  
16680  
16681  
16682  
16683  /**
16684   * Internal dependencies
16685   */
16686  
16687  
16688  
16689  
16690  
16691  
16692  const edit_MAX_COLUMNS = 8;
16693  const edit_linkOptions = [{
16694    value: v1_constants_LINK_DESTINATION_ATTACHMENT,
16695    label: (0,external_wp_i18n_namespaceObject.__)('Attachment Page')
16696  }, {
16697    value: v1_constants_LINK_DESTINATION_MEDIA,
16698    label: (0,external_wp_i18n_namespaceObject.__)('Media File')
16699  }, {
16700    value: v1_constants_LINK_DESTINATION_NONE,
16701    label: (0,external_wp_i18n_namespaceObject.__)('None')
16702  }];
16703  const v1_edit_ALLOWED_MEDIA_TYPES = ['image'];
16704  const edit_PLACEHOLDER_TEXT = external_wp_element_namespaceObject.Platform.select({
16705    web: (0,external_wp_i18n_namespaceObject.__)('Drag images, upload new ones or select files from your library.'),
16706    native: (0,external_wp_i18n_namespaceObject.__)('ADD MEDIA')
16707  });
16708  const edit_MOBILE_CONTROL_PROPS_RANGE_CONTROL = external_wp_element_namespaceObject.Platform.select({
16709    web: {},
16710    native: {
16711      type: 'stepper'
16712    }
16713  });
16714  
16715  function edit_GalleryEdit(props) {
16716    const {
16717      attributes,
16718      clientId,
16719      isSelected,
16720      noticeUI,
16721      noticeOperations,
16722      onFocus
16723    } = props;
16724    const {
16725      columns = defaultColumnsNumberV1(attributes),
16726      imageCrop,
16727      images,
16728      linkTo,
16729      sizeSlug
16730    } = attributes;
16731    const [selectedImage, setSelectedImage] = (0,external_wp_element_namespaceObject.useState)();
16732    const [attachmentCaptions, setAttachmentCaptions] = (0,external_wp_element_namespaceObject.useState)();
16733    const {
16734      __unstableMarkNextChangeAsNotPersistent
16735    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_blockEditor_namespaceObject.store);
16736    const {
16737      imageSizes,
16738      mediaUpload,
16739      getMedia,
16740      wasBlockJustInserted
16741    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
16742      const settings = select(external_wp_blockEditor_namespaceObject.store).getSettings();
16743      return {
16744        imageSizes: settings.imageSizes,
16745        mediaUpload: settings.mediaUpload,
16746        getMedia: select(external_wp_coreData_namespaceObject.store).getMedia,
16747        wasBlockJustInserted: select(external_wp_blockEditor_namespaceObject.store).wasBlockJustInserted(clientId, 'inserter_menu')
16748      };
16749    });
16750    const resizedImages = (0,external_wp_element_namespaceObject.useMemo)(() => {
16751      if (isSelected) {
16752        return (0,external_lodash_namespaceObject.reduce)(attributes.ids, (currentResizedImages, id) => {
16753          if (!id) {
16754            return currentResizedImages;
16755          }
16756  
16757          const image = getMedia(id);
16758          const sizes = (0,external_lodash_namespaceObject.reduce)(imageSizes, (currentSizes, size) => {
16759            const defaultUrl = (0,external_lodash_namespaceObject.get)(image, ['sizes', size.slug, 'url']);
16760            const mediaDetailsUrl = (0,external_lodash_namespaceObject.get)(image, ['media_details', 'sizes', size.slug, 'source_url']);
16761            return { ...currentSizes,
16762              [size.slug]: defaultUrl || mediaDetailsUrl
16763            };
16764          }, {});
16765          return { ...currentResizedImages,
16766            [parseInt(id, 10)]: sizes
16767          };
16768        }, {});
16769      }
16770  
16771      return {};
16772    }, [isSelected, attributes.ids, imageSizes]);
16773  
16774    function onFocusGalleryCaption() {
16775      setSelectedImage();
16776    }
16777  
16778    function setAttributes(newAttrs) {
16779      if (newAttrs.ids) {
16780        throw new Error('The "ids" attribute should not be changed directly. It is managed automatically when "images" attribute changes');
16781      }
16782  
16783      if (newAttrs.images) {
16784        newAttrs = { ...newAttrs,
16785          // Unlike images[ n ].id which is a string, always ensure the
16786          // ids array contains numbers as per its attribute type.
16787          ids: (0,external_lodash_namespaceObject.map)(newAttrs.images, _ref => {
16788            let {
16789              id
16790            } = _ref;
16791            return parseInt(id, 10);
16792          })
16793        };
16794      }
16795  
16796      props.setAttributes(newAttrs);
16797    }
16798  
16799    function onSelectImage(index) {
16800      return () => {
16801        setSelectedImage(index);
16802      };
16803    }
16804  
16805    function onDeselectImage() {
16806      return () => {
16807        setSelectedImage();
16808      };
16809    }
16810  
16811    function onMove(oldIndex, newIndex) {
16812      const newImages = [...images];
16813      newImages.splice(newIndex, 1, images[oldIndex]);
16814      newImages.splice(oldIndex, 1, images[newIndex]);
16815      setSelectedImage(newIndex);
16816      setAttributes({
16817        images: newImages
16818      });
16819    }
16820  
16821    function onMoveForward(oldIndex) {
16822      return () => {
16823        if (oldIndex === images.length - 1) {
16824          return;
16825        }
16826  
16827        onMove(oldIndex, oldIndex + 1);
16828      };
16829    }
16830  
16831    function onMoveBackward(oldIndex) {
16832      return () => {
16833        if (oldIndex === 0) {
16834          return;
16835        }
16836  
16837        onMove(oldIndex, oldIndex - 1);
16838      };
16839    }
16840  
16841    function onRemoveImage(index) {
16842      return () => {
16843        const newImages = (0,external_lodash_namespaceObject.filter)(images, (img, i) => index !== i);
16844        setSelectedImage();
16845        setAttributes({
16846          images: newImages,
16847          columns: attributes.columns ? Math.min(newImages.length, attributes.columns) : attributes.columns
16848        });
16849      };
16850    }
16851  
16852    function selectCaption(newImage) {
16853      // The image id in both the images and attachmentCaptions arrays is a
16854      // string, so ensure comparison works correctly by converting the
16855      // newImage.id to a string.
16856      const newImageId = (0,external_lodash_namespaceObject.toString)(newImage.id);
16857      const currentImage = (0,external_lodash_namespaceObject.find)(images, {
16858        id: newImageId
16859      });
16860      const currentImageCaption = currentImage ? currentImage.caption : newImage.caption;
16861  
16862      if (!attachmentCaptions) {
16863        return currentImageCaption;
16864      }
16865  
16866      const attachment = (0,external_lodash_namespaceObject.find)(attachmentCaptions, {
16867        id: newImageId
16868      }); // If the attachment caption is updated.
16869  
16870      if (attachment && attachment.caption !== newImage.caption) {
16871        return newImage.caption;
16872      }
16873  
16874      return currentImageCaption;
16875    }
16876  
16877    function onSelectImages(newImages) {
16878      setAttachmentCaptions(newImages.map(newImage => ({
16879        // Store the attachmentCaption id as a string for consistency
16880        // with the type of the id in the images attribute.
16881        id: (0,external_lodash_namespaceObject.toString)(newImage.id),
16882        caption: newImage.caption
16883      })));
16884      setAttributes({
16885        images: newImages.map(newImage => ({ ...shared_pickRelevantMediaFiles(newImage, sizeSlug),
16886          caption: selectCaption(newImage, images, attachmentCaptions),
16887          // The id value is stored in a data attribute, so when the
16888          // block is parsed it's converted to a string. Converting
16889          // to a string here ensures it's type is consistent.
16890          id: (0,external_lodash_namespaceObject.toString)(newImage.id)
16891        })),
16892        columns: attributes.columns ? Math.min(newImages.length, attributes.columns) : attributes.columns
16893      });
16894    }
16895  
16896    function onUploadError(message) {
16897      noticeOperations.removeAllNotices();
16898      noticeOperations.createErrorNotice(message);
16899    }
16900  
16901    function setLinkTo(value) {
16902      setAttributes({
16903        linkTo: value
16904      });
16905    }
16906  
16907    function setColumnsNumber(value) {
16908      setAttributes({
16909        columns: value
16910      });
16911    }
16912  
16913    function toggleImageCrop() {
16914      setAttributes({
16915        imageCrop: !imageCrop
16916      });
16917    }
16918  
16919    function getImageCropHelp(checked) {
16920      return checked ? (0,external_wp_i18n_namespaceObject.__)('Thumbnails are cropped to align.') : (0,external_wp_i18n_namespaceObject.__)('Thumbnails are not cropped.');
16921    }
16922  
16923    function setImageAttributes(index, newAttributes) {
16924      if (!images[index]) {
16925        return;
16926      }
16927  
16928      setAttributes({
16929        images: [...images.slice(0, index), { ...images[index],
16930          ...newAttributes
16931        }, ...images.slice(index + 1)]
16932      });
16933    }
16934  
16935    function getImagesSizeOptions() {
16936      return (0,external_lodash_namespaceObject.map)((0,external_lodash_namespaceObject.filter)(imageSizes, _ref2 => {
16937        let {
16938          slug
16939        } = _ref2;
16940        return (0,external_lodash_namespaceObject.some)(resizedImages, sizes => sizes[slug]);
16941      }), _ref3 => {
16942        let {
16943          name,
16944          slug
16945        } = _ref3;
16946        return {
16947          value: slug,
16948          label: name
16949        };
16950      });
16951    }
16952  
16953    function updateImagesSize(newSizeSlug) {
16954      const updatedImages = (0,external_lodash_namespaceObject.map)(images, image => {
16955        if (!image.id) {
16956          return image;
16957        }
16958  
16959        const url = (0,external_lodash_namespaceObject.get)(resizedImages, [parseInt(image.id, 10), newSizeSlug]);
16960        return { ...image,
16961          ...(url && {
16962            url
16963          })
16964        };
16965      });
16966      setAttributes({
16967        images: updatedImages,
16968        sizeSlug: newSizeSlug
16969      });
16970    }
16971  
16972    (0,external_wp_element_namespaceObject.useEffect)(() => {
16973      if (external_wp_element_namespaceObject.Platform.OS === 'web' && images && images.length > 0 && (0,external_lodash_namespaceObject.every)(images, _ref4 => {
16974        let {
16975          url
16976        } = _ref4;
16977        return (0,external_wp_blob_namespaceObject.isBlobURL)(url);
16978      })) {
16979        const filesList = (0,external_lodash_namespaceObject.map)(images, _ref5 => {
16980          let {
16981            url
16982          } = _ref5;
16983          return (0,external_wp_blob_namespaceObject.getBlobByURL)(url);
16984        });
16985        (0,external_lodash_namespaceObject.forEach)(images, _ref6 => {
16986          let {
16987            url
16988          } = _ref6;
16989          return (0,external_wp_blob_namespaceObject.revokeBlobURL)(url);
16990        });
16991        mediaUpload({
16992          filesList,
16993          onFileChange: onSelectImages,
16994          allowedTypes: ['image']
16995        });
16996      }
16997    }, []);
16998    (0,external_wp_element_namespaceObject.useEffect)(() => {
16999      // Deselect images when deselecting the block.
17000      if (!isSelected) {
17001        setSelectedImage();
17002      }
17003    }, [isSelected]);
17004    (0,external_wp_element_namespaceObject.useEffect)(() => {
17005      // linkTo attribute must be saved so blocks don't break when changing
17006      // image_default_link_type in options.php.
17007      if (!linkTo) {
17008        var _window, _window$wp, _window$wp$media, _window$wp$media$view, _window$wp$media$view2, _window$wp$media$view3;
17009  
17010        __unstableMarkNextChangeAsNotPersistent();
17011  
17012        setAttributes({
17013          linkTo: ((_window = window) === null || _window === void 0 ? void 0 : (_window$wp = _window.wp) === null || _window$wp === void 0 ? void 0 : (_window$wp$media = _window$wp.media) === null || _window$wp$media === void 0 ? void 0 : (_window$wp$media$view = _window$wp$media.view) === null || _window$wp$media$view === void 0 ? void 0 : (_window$wp$media$view2 = _window$wp$media$view.settings) === null || _window$wp$media$view2 === void 0 ? void 0 : (_window$wp$media$view3 = _window$wp$media$view2.defaultProps) === null || _window$wp$media$view3 === void 0 ? void 0 : _window$wp$media$view3.link) || v1_constants_LINK_DESTINATION_NONE
17014        });
17015      }
17016    }, [linkTo]);
17017    const hasImages = !!images.length;
17018    const hasImageIds = hasImages && images.some(image => !!image.id);
17019    const mediaPlaceholder = (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.MediaPlaceholder, {
17020      addToGallery: hasImageIds,
17021      isAppender: hasImages,
17022      disableMediaButtons: hasImages && !isSelected,
17023      icon: !hasImages && sharedIcon,
17024      labels: {
17025        title: !hasImages && (0,external_wp_i18n_namespaceObject.__)('Gallery'),
17026        instructions: !hasImages && edit_PLACEHOLDER_TEXT
17027      },
17028      onSelect: onSelectImages,
17029      accept: "image/*",
17030      allowedTypes: v1_edit_ALLOWED_MEDIA_TYPES,
17031      multiple: true,
17032      value: hasImageIds ? images : {},
17033      onError: onUploadError,
17034      notices: hasImages ? undefined : noticeUI,
17035      onFocus: onFocus,
17036      autoOpenMediaUpload: !hasImages && isSelected && wasBlockJustInserted
17037    });
17038    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)();
17039  
17040    if (!hasImages) {
17041      return (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.View, blockProps, mediaPlaceholder);
17042    }
17043  
17044    const imageSizeOptions = getImagesSizeOptions();
17045    const shouldShowSizeOptions = hasImages && !(0,external_lodash_namespaceObject.isEmpty)(imageSizeOptions);
17046    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
17047      title: (0,external_wp_i18n_namespaceObject.__)('Gallery settings')
17048    }, images.length > 1 && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.RangeControl, _extends({
17049      label: (0,external_wp_i18n_namespaceObject.__)('Columns'),
17050      value: columns,
17051      onChange: setColumnsNumber,
17052      min: 1,
17053      max: Math.min(edit_MAX_COLUMNS, images.length)
17054    }, edit_MOBILE_CONTROL_PROPS_RANGE_CONTROL, {
17055      required: true
17056    })), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
17057      label: (0,external_wp_i18n_namespaceObject.__)('Crop images'),
17058      checked: !!imageCrop,
17059      onChange: toggleImageCrop,
17060      help: getImageCropHelp
17061    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SelectControl, {
17062      label: (0,external_wp_i18n_namespaceObject.__)('Link to'),
17063      value: linkTo,
17064      onChange: setLinkTo,
17065      options: edit_linkOptions,
17066      hideCancelButton: true
17067    }), shouldShowSizeOptions && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SelectControl, {
17068      label: (0,external_wp_i18n_namespaceObject.__)('Image size'),
17069      value: sizeSlug,
17070      options: imageSizeOptions,
17071      onChange: updateImagesSize,
17072      hideCancelButton: true
17073    }))), noticeUI, (0,external_wp_element_namespaceObject.createElement)(v1_gallery, _extends({}, props, {
17074      selectedImage: selectedImage,
17075      mediaPlaceholder: mediaPlaceholder,
17076      onMoveBackward: onMoveBackward,
17077      onMoveForward: onMoveForward,
17078      onRemoveImage: onRemoveImage,
17079      onSelectImage: onSelectImage,
17080      onDeselectImage: onDeselectImage,
17081      onSetImageAttributes: setImageAttributes,
17082      blockProps: blockProps // This prop is used by gallery.native.js.
17083      ,
17084      onFocusGalleryCaption: onFocusGalleryCaption
17085    })));
17086  }
17087  
17088  /* harmony default export */ var v1_edit = ((0,external_wp_compose_namespaceObject.compose)([external_wp_components_namespaceObject.withNotices, (0,external_wp_viewport_namespaceObject.withViewportMatch)({
17089    isNarrow: '< small'
17090  })])(edit_GalleryEdit));
17091  
17092  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/gallery/edit-wrapper.js
17093  
17094  
17095  /**
17096   * WordPress dependencies
17097   */
17098  
17099  
17100  /**
17101   * Internal dependencies
17102   */
17103  
17104  
17105  
17106  
17107  /*
17108   * Using a wrapper around the logic to load the edit for v1 of Gallery block
17109   * or the refactored version with InnerBlocks. This is to prevent conditional
17110   * use of hooks lint errors if adding this logic to the top of the edit component.
17111   */
17112  
17113  function GalleryEditWrapper(props) {
17114    if (!isGalleryV2Enabled()) {
17115      return (0,external_wp_element_namespaceObject.createElement)(v1_edit, props);
17116    }
17117  
17118    return (0,external_wp_element_namespaceObject.createElement)(gallery_edit, props);
17119  }
17120  
17121  /* harmony default export */ var edit_wrapper = ((0,external_wp_compose_namespaceObject.compose)([external_wp_components_namespaceObject.withNotices])(GalleryEditWrapper));
17122  
17123  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/gallery/v1/save.js
17124  
17125  
17126  /**
17127   * WordPress dependencies
17128   */
17129  
17130  /**
17131   * Internal dependencies
17132   */
17133  
17134  
17135  
17136  function saveV1(_ref) {
17137    let {
17138      attributes
17139    } = _ref;
17140    const {
17141      images,
17142      columns = defaultColumnsNumberV1(attributes),
17143      imageCrop,
17144      caption,
17145      linkTo
17146    } = attributes;
17147    const className = `columns-$columns} $imageCrop ? 'is-cropped' : ''}`;
17148    return (0,external_wp_element_namespaceObject.createElement)("figure", external_wp_blockEditor_namespaceObject.useBlockProps.save({
17149      className
17150    }), (0,external_wp_element_namespaceObject.createElement)("ul", {
17151      className: "blocks-gallery-grid"
17152    }, images.map(image => {
17153      let href;
17154  
17155      switch (linkTo) {
17156        case v1_constants_LINK_DESTINATION_MEDIA:
17157          href = image.fullUrl || image.url;
17158          break;
17159  
17160        case v1_constants_LINK_DESTINATION_ATTACHMENT:
17161          href = image.link;
17162          break;
17163      }
17164  
17165      const img = (0,external_wp_element_namespaceObject.createElement)("img", {
17166        src: image.url,
17167        alt: image.alt,
17168        "data-id": image.id,
17169        "data-full-url": image.fullUrl,
17170        "data-link": image.link,
17171        className: image.id ? `wp-image-$image.id}` : null
17172      });
17173      return (0,external_wp_element_namespaceObject.createElement)("li", {
17174        key: image.id || image.url,
17175        className: "blocks-gallery-item"
17176      }, (0,external_wp_element_namespaceObject.createElement)("figure", null, href ? (0,external_wp_element_namespaceObject.createElement)("a", {
17177        href: href
17178      }, img) : img, !external_wp_blockEditor_namespaceObject.RichText.isEmpty(image.caption) && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
17179        tagName: "figcaption",
17180        className: "blocks-gallery-item__caption",
17181        value: image.caption
17182      })));
17183    })), !external_wp_blockEditor_namespaceObject.RichText.isEmpty(caption) && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
17184      tagName: "figcaption",
17185      className: "blocks-gallery-caption",
17186      value: caption
17187    }));
17188  }
17189  
17190  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/gallery/save.js
17191  
17192  
17193  /**
17194   * External dependencies
17195   */
17196  
17197  /**
17198   * WordPress dependencies
17199   */
17200  
17201  
17202  /**
17203   * Internal dependencies
17204   */
17205  
17206  
17207  
17208  function saveWithInnerBlocks(_ref) {
17209    let {
17210      attributes
17211    } = _ref;
17212  
17213    if (!isGalleryV2Enabled()) {
17214      return saveV1({
17215        attributes
17216      });
17217    }
17218  
17219    const {
17220      caption,
17221      columns,
17222      imageCrop
17223    } = attributes;
17224    const className = classnames_default()('has-nested-images', {
17225      [`columns-$columns}`]: columns !== undefined,
17226      [`columns-default`]: columns === undefined,
17227      'is-cropped': imageCrop
17228    });
17229    const blockProps = external_wp_blockEditor_namespaceObject.useBlockProps.save({
17230      className
17231    });
17232    const innerBlocksProps = external_wp_blockEditor_namespaceObject.useInnerBlocksProps.save(blockProps);
17233    return (0,external_wp_element_namespaceObject.createElement)("figure", innerBlocksProps, innerBlocksProps.children, !external_wp_blockEditor_namespaceObject.RichText.isEmpty(caption) && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
17234      tagName: "figcaption",
17235      className: "blocks-gallery-caption",
17236      value: caption
17237    }));
17238  }
17239  
17240  ;// CONCATENATED MODULE: external ["wp","hooks"]
17241  var external_wp_hooks_namespaceObject = window["wp"]["hooks"];
17242  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/gallery/transforms.js
17243  /**
17244   * External dependencies
17245   */
17246  
17247  /**
17248   * WordPress dependencies
17249   */
17250  
17251  
17252  
17253  
17254  /**
17255   * Internal dependencies
17256   */
17257  
17258  
17259  
17260  
17261  
17262  const parseShortcodeIds = ids => {
17263    if (!ids) {
17264      return [];
17265    }
17266  
17267    return ids.split(',').map(id => parseInt(id, 10));
17268  };
17269  /**
17270   * Third party block plugins don't have an easy way to detect if the
17271   * innerBlocks version of the Gallery is running when they run a
17272   * 3rdPartyBlock -> GalleryBlock transform so this tranform filter
17273   * will handle this. Once the innerBlocks version is the default
17274   * in a core release, this could be deprecated and removed after
17275   * plugin authors have been given time to update transforms.
17276   *
17277   * @typedef  {Object} Attributes
17278   * @typedef  {Object} Block
17279   * @property {Attributes} attributes The attributes of the block.
17280   * @param    {Block}      block      The transformed block.
17281   * @return   {Block}                 The transformed block.
17282   */
17283  
17284  
17285  function updateThirdPartyTransformToGallery(block) {
17286    var _block$attributes;
17287  
17288    if (isGalleryV2Enabled() && block.name === 'core/gallery' && ((_block$attributes = block.attributes) === null || _block$attributes === void 0 ? void 0 : _block$attributes.images.length) > 0) {
17289      const innerBlocks = block.attributes.images.map(_ref => {
17290        let {
17291          url,
17292          id,
17293          alt
17294        } = _ref;
17295        return (0,external_wp_blocks_namespaceObject.createBlock)('core/image', {
17296          url,
17297          id: id ? parseInt(id, 10) : null,
17298          alt,
17299          sizeSlug: block.attributes.sizeSlug,
17300          linkDestination: block.attributes.linkDestination
17301        });
17302      });
17303      delete block.attributes.ids;
17304      delete block.attributes.images;
17305      block.innerBlocks = innerBlocks;
17306    }
17307  
17308    return block;
17309  }
17310  
17311  (0,external_wp_hooks_namespaceObject.addFilter)('blocks.switchToBlockType.transformedBlock', 'core/gallery/update-third-party-transform-to', updateThirdPartyTransformToGallery);
17312  /**
17313   * Third party block plugins don't have an easy way to detect if the
17314   * innerBlocks version of the Gallery is running when they run a
17315   * GalleryBlock -> 3rdPartyBlock transform so this transform filter
17316   * will handle this. Once the innerBlocks version is the default
17317   * in a core release, this could be deprecated and removed after
17318   * plugin authors have been given time to update transforms.
17319   *
17320   * @typedef  {Object} Attributes
17321   * @typedef  {Object} Block
17322   * @property {Attributes} attributes The attributes of the block.
17323   * @param    {Block}      toBlock    The block to transform to.
17324   * @param    {Block[]}    fromBlocks The blocks to transform from.
17325   * @return   {Block}                 The transformed block.
17326   */
17327  
17328  function updateThirdPartyTransformFromGallery(toBlock, fromBlocks) {
17329    const from = Array.isArray(fromBlocks) ? fromBlocks : [fromBlocks];
17330    const galleryBlock = from.find(transformedBlock => {
17331      var _transformedBlock$att;
17332  
17333      return transformedBlock.name === 'core/gallery' && transformedBlock.innerBlocks.length > 0 && !((_transformedBlock$att = transformedBlock.attributes.images) !== null && _transformedBlock$att !== void 0 && _transformedBlock$att.length) > 0 && !toBlock.name.includes('core/');
17334    });
17335  
17336    if (galleryBlock) {
17337      const images = galleryBlock.innerBlocks.map(_ref2 => {
17338        let {
17339          attributes: {
17340            url,
17341            id,
17342            alt
17343          }
17344        } = _ref2;
17345        return {
17346          url,
17347          id: id ? parseInt(id, 10) : null,
17348          alt
17349        };
17350      });
17351      const ids = images.map(_ref3 => {
17352        let {
17353          id
17354        } = _ref3;
17355        return id;
17356      });
17357      galleryBlock.attributes.images = images;
17358      galleryBlock.attributes.ids = ids;
17359    }
17360  
17361    return toBlock;
17362  }
17363  
17364  (0,external_wp_hooks_namespaceObject.addFilter)('blocks.switchToBlockType.transformedBlock', 'core/gallery/update-third-party-transform-from', updateThirdPartyTransformFromGallery);
17365  const gallery_transforms_transforms = {
17366    from: [{
17367      type: 'block',
17368      isMultiBlock: true,
17369      blocks: ['core/image'],
17370      transform: attributes => {
17371        // Init the align and size from the first item which may be either the placeholder or an image.
17372        let {
17373          align,
17374          sizeSlug
17375        } = attributes[0]; // Loop through all the images and check if they have the same align and size.
17376  
17377        align = (0,external_lodash_namespaceObject.every)(attributes, ['align', align]) ? align : undefined;
17378        sizeSlug = (0,external_lodash_namespaceObject.every)(attributes, ['sizeSlug', sizeSlug]) ? sizeSlug : undefined;
17379        const validImages = (0,external_lodash_namespaceObject.filter)(attributes, _ref4 => {
17380          let {
17381            url
17382          } = _ref4;
17383          return url;
17384        });
17385  
17386        if (isGalleryV2Enabled()) {
17387          const innerBlocks = validImages.map(image => {
17388            return (0,external_wp_blocks_namespaceObject.createBlock)('core/image', image);
17389          });
17390          return (0,external_wp_blocks_namespaceObject.createBlock)('core/gallery', {
17391            align,
17392            sizeSlug
17393          }, innerBlocks);
17394        }
17395  
17396        return (0,external_wp_blocks_namespaceObject.createBlock)('core/gallery', {
17397          images: validImages.map(_ref5 => {
17398            let {
17399              id,
17400              url,
17401              alt,
17402              caption
17403            } = _ref5;
17404            return {
17405              id: (0,external_lodash_namespaceObject.toString)(id),
17406              url,
17407              alt,
17408              caption
17409            };
17410          }),
17411          ids: validImages.map(_ref6 => {
17412            let {
17413              id
17414            } = _ref6;
17415            return parseInt(id, 10);
17416          }),
17417          align,
17418          sizeSlug
17419        });
17420      }
17421    }, {
17422      type: 'shortcode',
17423      tag: 'gallery',
17424      attributes: {
17425        images: {
17426          type: 'array',
17427          shortcode: _ref7 => {
17428            let {
17429              named: {
17430                ids
17431              }
17432            } = _ref7;
17433  
17434            if (!isGalleryV2Enabled()) {
17435              return parseShortcodeIds(ids).map(id => ({
17436                id: (0,external_lodash_namespaceObject.toString)(id)
17437              }));
17438            }
17439          }
17440        },
17441        ids: {
17442          type: 'array',
17443          shortcode: _ref8 => {
17444            let {
17445              named: {
17446                ids
17447              }
17448            } = _ref8;
17449  
17450            if (!isGalleryV2Enabled()) {
17451              return parseShortcodeIds(ids);
17452            }
17453          }
17454        },
17455        shortCodeTransforms: {
17456          type: 'array',
17457          shortcode: _ref9 => {
17458            let {
17459              named: {
17460                ids
17461              }
17462            } = _ref9;
17463  
17464            if (isGalleryV2Enabled()) {
17465              return parseShortcodeIds(ids).map(id => ({
17466                id: parseInt(id)
17467              }));
17468            }
17469          }
17470        },
17471        columns: {
17472          type: 'number',
17473          shortcode: _ref10 => {
17474            let {
17475              named: {
17476                columns = '3'
17477              }
17478            } = _ref10;
17479            return parseInt(columns, 10);
17480          }
17481        },
17482        linkTo: {
17483          type: 'string',
17484          shortcode: _ref11 => {
17485            let {
17486              named: {
17487                link
17488              }
17489            } = _ref11;
17490  
17491            if (!isGalleryV2Enabled()) {
17492              switch (link) {
17493                case 'post':
17494                  return v1_constants_LINK_DESTINATION_ATTACHMENT;
17495  
17496                case 'file':
17497                  return v1_constants_LINK_DESTINATION_MEDIA;
17498  
17499                default:
17500                  return v1_constants_LINK_DESTINATION_ATTACHMENT;
17501              }
17502            }
17503  
17504            switch (link) {
17505              case 'post':
17506                return LINK_DESTINATION_ATTACHMENT;
17507  
17508              case 'file':
17509                return LINK_DESTINATION_MEDIA;
17510  
17511              default:
17512                return LINK_DESTINATION_NONE;
17513            }
17514          }
17515        }
17516      },
17517  
17518      isMatch(_ref12) {
17519        let {
17520          named
17521        } = _ref12;
17522        return undefined !== named.ids;
17523      }
17524  
17525    }, {
17526      // When created by drag and dropping multiple files on an insertion point. Because multiple
17527      // files must not be transformed to a gallery when dropped within a gallery there is another transform
17528      // within the image block to handle that case. Therefore this transform has to have priority 1
17529      // set so that it overrrides the image block transformation when mulitple images are dropped outside
17530      // of a gallery block.
17531      type: 'files',
17532      priority: 1,
17533  
17534      isMatch(files) {
17535        return files.length !== 1 && (0,external_lodash_namespaceObject.every)(files, file => file.type.indexOf('image/') === 0);
17536      },
17537  
17538      transform(files) {
17539        if (isGalleryV2Enabled()) {
17540          const innerBlocks = files.map(file => (0,external_wp_blocks_namespaceObject.createBlock)('core/image', {
17541            url: (0,external_wp_blob_namespaceObject.createBlobURL)(file)
17542          }));
17543          return (0,external_wp_blocks_namespaceObject.createBlock)('core/gallery', {}, innerBlocks);
17544        }
17545  
17546        const block = (0,external_wp_blocks_namespaceObject.createBlock)('core/gallery', {
17547          images: files.map(file => pickRelevantMediaFiles({
17548            url: (0,external_wp_blob_namespaceObject.createBlobURL)(file)
17549          }))
17550        });
17551        return block;
17552      }
17553  
17554    }],
17555    to: [{
17556      type: 'block',
17557      blocks: ['core/image'],
17558      transform: (_ref13, innerBlocks) => {
17559        let {
17560          align,
17561          images,
17562          ids,
17563          sizeSlug
17564        } = _ref13;
17565  
17566        if (isGalleryV2Enabled()) {
17567          if (innerBlocks.length > 0) {
17568            return innerBlocks.map(_ref14 => {
17569              let {
17570                attributes: {
17571                  id,
17572                  url,
17573                  alt,
17574                  caption,
17575                  sizeSlug: imageSizeSlug,
17576                  linkDestination,
17577                  href,
17578                  linkTarget
17579                }
17580              } = _ref14;
17581              return (0,external_wp_blocks_namespaceObject.createBlock)('core/image', {
17582                id,
17583                url,
17584                alt,
17585                caption,
17586                sizeSlug: imageSizeSlug,
17587                align,
17588                linkDestination,
17589                href,
17590                linkTarget
17591              });
17592            });
17593          }
17594  
17595          return (0,external_wp_blocks_namespaceObject.createBlock)('core/image', {
17596            align
17597          });
17598        }
17599  
17600        if (images.length > 0) {
17601          return images.map((_ref15, index) => {
17602            let {
17603              url,
17604              alt,
17605              caption
17606            } = _ref15;
17607            return (0,external_wp_blocks_namespaceObject.createBlock)('core/image', {
17608              id: ids[index],
17609              url,
17610              alt,
17611              caption,
17612              align,
17613              sizeSlug
17614            });
17615          });
17616        }
17617  
17618        return (0,external_wp_blocks_namespaceObject.createBlock)('core/image', {
17619          align
17620        });
17621      }
17622    }]
17623  };
17624  /* harmony default export */ var gallery_transforms = (gallery_transforms_transforms);
17625  
17626  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/gallery/index.js
17627  /**
17628   * WordPress dependencies
17629   */
17630  
17631  /**
17632   * Internal dependencies
17633   */
17634  
17635  
17636  
17637  const gallery_metadata = {
17638    $schema: "https://schemas.wp.org/trunk/block.json",
17639    apiVersion: 2,
17640    name: "core/gallery",
17641    title: "Gallery",
17642    category: "media",
17643    description: "Display multiple images in a rich gallery.",
17644    keywords: ["images", "photos"],
17645    textdomain: "default",
17646    attributes: {
17647      images: {
17648        type: "array",
17649        "default": [],
17650        source: "query",
17651        selector: ".blocks-gallery-item",
17652        query: {
17653          url: {
17654            type: "string",
17655            source: "attribute",
17656            selector: "img",
17657            attribute: "src"
17658          },
17659          fullUrl: {
17660            type: "string",
17661            source: "attribute",
17662            selector: "img",
17663            attribute: "data-full-url"
17664          },
17665          link: {
17666            type: "string",
17667            source: "attribute",
17668            selector: "img",
17669            attribute: "data-link"
17670          },
17671          alt: {
17672            type: "string",
17673            source: "attribute",
17674            selector: "img",
17675            attribute: "alt",
17676            "default": ""
17677          },
17678          id: {
17679            type: "string",
17680            source: "attribute",
17681            selector: "img",
17682            attribute: "data-id"
17683          },
17684          caption: {
17685            type: "string",
17686            source: "html",
17687            selector: ".blocks-gallery-item__caption"
17688          }
17689        }
17690      },
17691      ids: {
17692        type: "array",
17693        items: {
17694          type: "number"
17695        },
17696        "default": []
17697      },
17698      shortCodeTransforms: {
17699        type: "array",
17700        "default": [],
17701        items: {
17702          type: "object"
17703        }
17704      },
17705      columns: {
17706        type: "number",
17707        minimum: 1,
17708        maximum: 8
17709      },
17710      caption: {
17711        type: "string",
17712        source: "html",
17713        selector: ".blocks-gallery-caption"
17714      },
17715      imageCrop: {
17716        type: "boolean",
17717        "default": true
17718      },
17719      fixedHeight: {
17720        type: "boolean",
17721        "default": true
17722      },
17723      linkTarget: {
17724        type: "string"
17725      },
17726      linkTo: {
17727        type: "string"
17728      },
17729      sizeSlug: {
17730        type: "string",
17731        "default": "large"
17732      },
17733      allowResize: {
17734        type: "boolean",
17735        "default": false
17736      }
17737    },
17738    providesContext: {
17739      allowResize: "allowResize",
17740      imageCrop: "imageCrop",
17741      fixedHeight: "fixedHeight"
17742    },
17743    supports: {
17744      anchor: true,
17745      align: true,
17746      html: false,
17747      units: ["px", "em", "rem", "vh", "vw"],
17748      spacing: {
17749        blockGap: true,
17750        __experimentalSkipSerialization: ["blockGap"],
17751        __experimentalDefaultControls: {
17752          blockGap: true
17753        }
17754      },
17755      __experimentalLayout: {
17756        allowSwitching: false,
17757        allowInheriting: false,
17758        allowEditing: false,
17759        "default": {
17760          type: "flex"
17761        }
17762      }
17763    },
17764    editorStyle: "wp-block-gallery-editor",
17765    style: "wp-block-gallery"
17766  };
17767  
17768  
17769  const {
17770    name: gallery_name
17771  } = gallery_metadata;
17772  
17773  const gallery_settings = {
17774    icon: library_gallery,
17775    example: {
17776      attributes: {
17777        columns: 2
17778      },
17779      innerBlocks: [{
17780        name: 'core/image',
17781        attributes: {
17782          url: 'https://s.w.org/images/core/5.3/Glacial_lakes%2C_Bhutan.jpg'
17783        }
17784      }, {
17785        name: 'core/image',
17786        attributes: {
17787          url: 'https://s.w.org/images/core/5.3/Sediment_off_the_Yucatan_Peninsula.jpg'
17788        }
17789      }]
17790    },
17791    transforms: gallery_transforms,
17792    edit: edit_wrapper,
17793    save: saveWithInnerBlocks,
17794    deprecated: gallery_deprecated
17795  };
17796  
17797  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/group.js
17798  
17799  
17800  /**
17801   * WordPress dependencies
17802   */
17803  
17804  const group = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
17805    viewBox: "0 0 24 24",
17806    xmlns: "http://www.w3.org/2000/svg"
17807  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
17808    d: "M18 4h-7c-1.1 0-2 .9-2 2v3H6c-1.1 0-2 .9-2 2v7c0 1.1.9 2 2 2h7c1.1 0 2-.9 2-2v-3h3c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zm-4.5 14c0 .3-.2.5-.5.5H6c-.3 0-.5-.2-.5-.5v-7c0-.3.2-.5.5-.5h3V13c0 1.1.9 2 2 2h2.5v3zm0-4.5H11c-.3 0-.5-.2-.5-.5v-2.5H13c.3 0 .5.2.5.5v2.5zm5-.5c0 .3-.2.5-.5.5h-3V11c0-1.1-.9-2-2-2h-2.5V6c0-.3.2-.5.5-.5h7c.3 0 .5.2.5.5v7z"
17809  }));
17810  /* harmony default export */ var library_group = (group);
17811  
17812  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/group/deprecated.js
17813  
17814  
17815  /**
17816   * External dependencies
17817   */
17818  
17819  
17820  /**
17821   * WordPress dependencies
17822   */
17823  
17824  
17825  
17826  const migrateAttributes = attributes => {
17827    if (!attributes.tagName) {
17828      attributes = { ...attributes,
17829        tagName: 'div'
17830      };
17831    }
17832  
17833    if (!attributes.customTextColor && !attributes.customBackgroundColor) {
17834      return attributes;
17835    }
17836  
17837    const style = {
17838      color: {}
17839    };
17840  
17841    if (attributes.customTextColor) {
17842      style.color.text = attributes.customTextColor;
17843    }
17844  
17845    if (attributes.customBackgroundColor) {
17846      style.color.background = attributes.customBackgroundColor;
17847    }
17848  
17849    return { ...(0,external_lodash_namespaceObject.omit)(attributes, ['customTextColor', 'customBackgroundColor']),
17850      style
17851    };
17852  };
17853  
17854  const group_deprecated_deprecated = [// Version of the block with the double div.
17855  {
17856    attributes: {
17857      tagName: {
17858        type: 'string',
17859        default: 'div'
17860      },
17861      templateLock: {
17862        type: 'string'
17863      }
17864    },
17865    supports: {
17866      align: ['wide', 'full'],
17867      anchor: true,
17868      color: {
17869        gradients: true,
17870        link: true
17871      },
17872      spacing: {
17873        padding: true
17874      },
17875      __experimentalBorder: {
17876        radius: true
17877      }
17878    },
17879  
17880    save(_ref) {
17881      let {
17882        attributes
17883      } = _ref;
17884      const {
17885        tagName: Tag
17886      } = attributes;
17887      return (0,external_wp_element_namespaceObject.createElement)(Tag, external_wp_blockEditor_namespaceObject.useBlockProps.save(), (0,external_wp_element_namespaceObject.createElement)("div", {
17888        className: "wp-block-group__inner-container"
17889      }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InnerBlocks.Content, null)));
17890    }
17891  
17892  }, // Version of the block without global styles support
17893  {
17894    attributes: {
17895      backgroundColor: {
17896        type: 'string'
17897      },
17898      customBackgroundColor: {
17899        type: 'string'
17900      },
17901      textColor: {
17902        type: 'string'
17903      },
17904      customTextColor: {
17905        type: 'string'
17906      }
17907    },
17908    supports: {
17909      align: ['wide', 'full'],
17910      anchor: true,
17911      html: false
17912    },
17913    migrate: migrateAttributes,
17914  
17915    save(_ref2) {
17916      let {
17917        attributes
17918      } = _ref2;
17919      const {
17920        backgroundColor,
17921        customBackgroundColor,
17922        textColor,
17923        customTextColor
17924      } = attributes;
17925      const backgroundClass = (0,external_wp_blockEditor_namespaceObject.getColorClassName)('background-color', backgroundColor);
17926      const textClass = (0,external_wp_blockEditor_namespaceObject.getColorClassName)('color', textColor);
17927      const className = classnames_default()(backgroundClass, textClass, {
17928        'has-text-color': textColor || customTextColor,
17929        'has-background': backgroundColor || customBackgroundColor
17930      });
17931      const styles = {
17932        backgroundColor: backgroundClass ? undefined : customBackgroundColor,
17933        color: textClass ? undefined : customTextColor
17934      };
17935      return (0,external_wp_element_namespaceObject.createElement)("div", {
17936        className: className,
17937        style: styles
17938      }, (0,external_wp_element_namespaceObject.createElement)("div", {
17939        className: "wp-block-group__inner-container"
17940      }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InnerBlocks.Content, null)));
17941    }
17942  
17943  }, // Version of the group block with a bug that made text color class not applied.
17944  {
17945    attributes: {
17946      backgroundColor: {
17947        type: 'string'
17948      },
17949      customBackgroundColor: {
17950        type: 'string'
17951      },
17952      textColor: {
17953        type: 'string'
17954      },
17955      customTextColor: {
17956        type: 'string'
17957      }
17958    },
17959    migrate: migrateAttributes,
17960    supports: {
17961      align: ['wide', 'full'],
17962      anchor: true,
17963      html: false
17964    },
17965  
17966    save(_ref3) {
17967      let {
17968        attributes
17969      } = _ref3;
17970      const {
17971        backgroundColor,
17972        customBackgroundColor,
17973        textColor,
17974        customTextColor
17975      } = attributes;
17976      const backgroundClass = (0,external_wp_blockEditor_namespaceObject.getColorClassName)('background-color', backgroundColor);
17977      const textClass = (0,external_wp_blockEditor_namespaceObject.getColorClassName)('color', textColor);
17978      const className = classnames_default()(backgroundClass, {
17979        'has-text-color': textColor || customTextColor,
17980        'has-background': backgroundColor || customBackgroundColor
17981      });
17982      const styles = {
17983        backgroundColor: backgroundClass ? undefined : customBackgroundColor,
17984        color: textClass ? undefined : customTextColor
17985      };
17986      return (0,external_wp_element_namespaceObject.createElement)("div", {
17987        className: className,
17988        style: styles
17989      }, (0,external_wp_element_namespaceObject.createElement)("div", {
17990        className: "wp-block-group__inner-container"
17991      }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InnerBlocks.Content, null)));
17992    }
17993  
17994  }, // v1 of group block. Deprecated to add an inner-container div around `InnerBlocks.Content`.
17995  {
17996    attributes: {
17997      backgroundColor: {
17998        type: 'string'
17999      },
18000      customBackgroundColor: {
18001        type: 'string'
18002      }
18003    },
18004    supports: {
18005      align: ['wide', 'full'],
18006      anchor: true,
18007      html: false
18008    },
18009    migrate: migrateAttributes,
18010  
18011    save(_ref4) {
18012      let {
18013        attributes
18014      } = _ref4;
18015      const {
18016        backgroundColor,
18017        customBackgroundColor
18018      } = attributes;
18019      const backgroundClass = (0,external_wp_blockEditor_namespaceObject.getColorClassName)('background-color', backgroundColor);
18020      const className = classnames_default()(backgroundClass, {
18021        'has-background': backgroundColor || customBackgroundColor
18022      });
18023      const styles = {
18024        backgroundColor: backgroundClass ? undefined : customBackgroundColor
18025      };
18026      return (0,external_wp_element_namespaceObject.createElement)("div", {
18027        className: className,
18028        style: styles
18029      }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InnerBlocks.Content, null));
18030    }
18031  
18032  }];
18033  /* harmony default export */ var group_deprecated = (group_deprecated_deprecated);
18034  
18035  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/group/edit.js
18036  
18037  
18038  /**
18039   * WordPress dependencies
18040   */
18041  
18042  
18043  
18044  
18045  const htmlElementMessages = {
18046    header: (0,external_wp_i18n_namespaceObject.__)('The <header> element should represent introductory content, typically a group of introductory or navigational aids.'),
18047    main: (0,external_wp_i18n_namespaceObject.__)('The <main> element should be used for the primary content of your document only. '),
18048    section: (0,external_wp_i18n_namespaceObject.__)("The <section> element should represent a standalone portion of the document that can't be better represented by another element."),
18049    article: (0,external_wp_i18n_namespaceObject.__)('The <article> element should represent a self contained, syndicatable portion of the document.'),
18050    aside: (0,external_wp_i18n_namespaceObject.__)("The <aside> element should represent a portion of a document whose content is only indirectly related to the document's main content."),
18051    footer: (0,external_wp_i18n_namespaceObject.__)('The <footer> element should represent a footer for its nearest sectioning element (e.g.: <section>, <article>, <main> etc.).')
18052  };
18053  
18054  function GroupEdit(_ref) {
18055    let {
18056      attributes,
18057      setAttributes,
18058      clientId
18059    } = _ref;
18060    const {
18061      hasInnerBlocks,
18062      themeSupportsLayout
18063    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
18064      var _getSettings;
18065  
18066      const {
18067        getBlock,
18068        getSettings
18069      } = select(external_wp_blockEditor_namespaceObject.store);
18070      const block = getBlock(clientId);
18071      return {
18072        hasInnerBlocks: !!(block && block.innerBlocks.length),
18073        themeSupportsLayout: (_getSettings = getSettings()) === null || _getSettings === void 0 ? void 0 : _getSettings.supportsLayout
18074      };
18075    }, [clientId]);
18076    const defaultLayout = (0,external_wp_blockEditor_namespaceObject.useSetting)('layout') || {};
18077    const {
18078      tagName: TagName = 'div',
18079      templateLock,
18080      layout = {}
18081    } = attributes;
18082    const usedLayout = !!layout && layout.inherit ? defaultLayout : layout;
18083    const {
18084      type = 'default'
18085    } = usedLayout;
18086    const layoutSupportEnabled = themeSupportsLayout || type !== 'default';
18087    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
18088      className: `is-layout-$type}`
18089    });
18090    const innerBlocksProps = (0,external_wp_blockEditor_namespaceObject.useInnerBlocksProps)(layoutSupportEnabled ? blockProps : {
18091      className: 'wp-block-group__inner-container'
18092    }, {
18093      templateLock,
18094      renderAppender: hasInnerBlocks ? undefined : external_wp_blockEditor_namespaceObject.InnerBlocks.ButtonBlockAppender,
18095      __experimentalLayout: layoutSupportEnabled ? usedLayout : undefined
18096    });
18097    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, {
18098      __experimentalGroup: "advanced"
18099    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SelectControl, {
18100      label: (0,external_wp_i18n_namespaceObject.__)('HTML element'),
18101      options: [{
18102        label: (0,external_wp_i18n_namespaceObject.__)('Default (<div>)'),
18103        value: 'div'
18104      }, {
18105        label: '<header>',
18106        value: 'header'
18107      }, {
18108        label: '<main>',
18109        value: 'main'
18110      }, {
18111        label: '<section>',
18112        value: 'section'
18113      }, {
18114        label: '<article>',
18115        value: 'article'
18116      }, {
18117        label: '<aside>',
18118        value: 'aside'
18119      }, {
18120        label: '<footer>',
18121        value: 'footer'
18122      }],
18123      value: TagName,
18124      onChange: value => setAttributes({
18125        tagName: value
18126      }),
18127      help: htmlElementMessages[TagName]
18128    })), layoutSupportEnabled && (0,external_wp_element_namespaceObject.createElement)(TagName, innerBlocksProps), !layoutSupportEnabled && (0,external_wp_element_namespaceObject.createElement)(TagName, blockProps, (0,external_wp_element_namespaceObject.createElement)("div", innerBlocksProps)));
18129  }
18130  
18131  /* harmony default export */ var group_edit = (GroupEdit);
18132  
18133  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/group/save.js
18134  
18135  
18136  /**
18137   * WordPress dependencies
18138   */
18139  
18140  function group_save_save(_ref) {
18141    let {
18142      attributes: {
18143        tagName: Tag
18144      }
18145    } = _ref;
18146    return (0,external_wp_element_namespaceObject.createElement)(Tag, external_wp_blockEditor_namespaceObject.useInnerBlocksProps.save(external_wp_blockEditor_namespaceObject.useBlockProps.save()));
18147  }
18148  
18149  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/group/transforms.js
18150  /**
18151   * WordPress dependencies
18152   */
18153  
18154  const group_transforms_transforms = {
18155    from: [{
18156      type: 'block',
18157      isMultiBlock: true,
18158      blocks: ['*'],
18159  
18160      __experimentalConvert(blocks) {
18161        const alignments = ['wide', 'full']; // Determine the widest setting of all the blocks to be grouped
18162  
18163        const widestAlignment = blocks.reduce((accumulator, block) => {
18164          const {
18165            align
18166          } = block.attributes;
18167          return alignments.indexOf(align) > alignments.indexOf(accumulator) ? align : accumulator;
18168        }, undefined); // Clone the Blocks to be Grouped
18169        // Failing to create new block references causes the original blocks
18170        // to be replaced in the switchToBlockType call thereby meaning they
18171        // are removed both from their original location and within the
18172        // new group block.
18173  
18174        const groupInnerBlocks = blocks.map(block => {
18175          return (0,external_wp_blocks_namespaceObject.createBlock)(block.name, block.attributes, block.innerBlocks);
18176        });
18177        return (0,external_wp_blocks_namespaceObject.createBlock)('core/group', {
18178          align: widestAlignment
18179        }, groupInnerBlocks);
18180      }
18181  
18182    }]
18183  };
18184  /* harmony default export */ var group_transforms = (group_transforms_transforms);
18185  
18186  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/row.js
18187  
18188  
18189  /**
18190   * WordPress dependencies
18191   */
18192  
18193  const row = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
18194    xmlns: "http://www.w3.org/2000/svg",
18195    viewBox: "0 0 24 24"
18196  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
18197    d: "M9.2 6.5H4V8h5.2c.3 0 .5.2.5.5v7c0 .3-.2.5-.5.5H4v1.5h5.2c1.1 0 2-.9 2-2v-7c0-1.1-.8-2-2-2zM14.8 8H20V6.5h-5.2c-1.1 0-2 .9-2 2v7c0 1.1.9 2 2 2H20V16h-5.2c-.3 0-.5-.2-.5-.5v-7c-.1-.3.2-.5.5-.5z"
18198  }));
18199  /* harmony default export */ var library_row = (row);
18200  
18201  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/stack.js
18202  
18203  
18204  /**
18205   * WordPress dependencies
18206   */
18207  
18208  const stack = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
18209    xmlns: "http://www.w3.org/2000/svg",
18210    viewBox: "0 0 24 24"
18211  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
18212    d: "M16 4v5.2c0 .3-.2.5-.5.5h-7c-.3.1-.5-.2-.5-.5V4H6.5v5.2c0 1.1.9 2 2 2h7c1.1 0 2-.9 2-2V4H16zm-.5 8.8h-7c-1.1 0-2 .9-2 2V20H8v-5.2c0-.3.2-.5.5-.5h7c.3 0 .5.2.5.5V20h1.5v-5.2c0-1.2-.9-2-2-2z"
18213  }));
18214  /* harmony default export */ var library_stack = (stack);
18215  
18216  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/group/variations.js
18217  /**
18218   * WordPress dependencies
18219   */
18220  
18221  
18222  const group_variations_variations = [{
18223    name: 'group',
18224    title: (0,external_wp_i18n_namespaceObject.__)('Group'),
18225    description: (0,external_wp_i18n_namespaceObject.__)('Gather blocks in a layout container.'),
18226    attributes: {
18227      layout: {
18228        type: 'default'
18229      }
18230    },
18231    scope: ['transform'],
18232    isActive: blockAttributes => {
18233      var _blockAttributes$layo, _blockAttributes$layo2;
18234  
18235      return !blockAttributes.layout || !((_blockAttributes$layo = blockAttributes.layout) !== null && _blockAttributes$layo !== void 0 && _blockAttributes$layo.type) || ((_blockAttributes$layo2 = blockAttributes.layout) === null || _blockAttributes$layo2 === void 0 ? void 0 : _blockAttributes$layo2.type) === 'default';
18236    },
18237    icon: library_group
18238  }, {
18239    name: 'group-row',
18240    title: (0,external_wp_i18n_namespaceObject.__)('Row'),
18241    description: (0,external_wp_i18n_namespaceObject.__)('Arrange blocks horizontally.'),
18242    attributes: {
18243      layout: {
18244        type: 'flex',
18245        flexWrap: 'nowrap'
18246      }
18247    },
18248    scope: ['inserter', 'transform'],
18249    isActive: blockAttributes => {
18250      var _blockAttributes$layo3, _blockAttributes$layo4, _blockAttributes$layo5;
18251  
18252      return ((_blockAttributes$layo3 = blockAttributes.layout) === null || _blockAttributes$layo3 === void 0 ? void 0 : _blockAttributes$layo3.type) === 'flex' && (!((_blockAttributes$layo4 = blockAttributes.layout) !== null && _blockAttributes$layo4 !== void 0 && _blockAttributes$layo4.orientation) || ((_blockAttributes$layo5 = blockAttributes.layout) === null || _blockAttributes$layo5 === void 0 ? void 0 : _blockAttributes$layo5.orientation) === 'horizontal');
18253    },
18254    icon: library_row
18255  }, {
18256    name: 'group-stack',
18257    title: (0,external_wp_i18n_namespaceObject.__)('Stack'),
18258    description: (0,external_wp_i18n_namespaceObject.__)('Arrange blocks vertically.'),
18259    attributes: {
18260      layout: {
18261        type: 'flex',
18262        orientation: 'vertical'
18263      }
18264    },
18265    scope: ['inserter', 'transform'],
18266    isActive: blockAttributes => {
18267      var _blockAttributes$layo6, _blockAttributes$layo7;
18268  
18269      return ((_blockAttributes$layo6 = blockAttributes.layout) === null || _blockAttributes$layo6 === void 0 ? void 0 : _blockAttributes$layo6.type) === 'flex' && ((_blockAttributes$layo7 = blockAttributes.layout) === null || _blockAttributes$layo7 === void 0 ? void 0 : _blockAttributes$layo7.orientation) === 'vertical';
18270    },
18271    icon: library_stack
18272  }];
18273  /* harmony default export */ var group_variations = (group_variations_variations);
18274  
18275  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/group/index.js
18276  /**
18277   * WordPress dependencies
18278   */
18279  
18280  
18281  /**
18282   * Internal dependencies
18283   */
18284  
18285  
18286  
18287  const group_metadata = {
18288    $schema: "https://schemas.wp.org/trunk/block.json",
18289    apiVersion: 2,
18290    name: "core/group",
18291    title: "Group",
18292    category: "design",
18293    description: "Gather blocks in a layout container.",
18294    keywords: ["container", "wrapper", "row", "section"],
18295    textdomain: "default",
18296    attributes: {
18297      tagName: {
18298        type: "string",
18299        "default": "div"
18300      },
18301      templateLock: {
18302        type: ["string", "boolean"],
18303        "enum": ["all", "insert", false]
18304      }
18305    },
18306    supports: {
18307      align: ["wide", "full"],
18308      anchor: true,
18309      html: false,
18310      color: {
18311        gradients: true,
18312        link: true,
18313        __experimentalDefaultControls: {
18314          background: true,
18315          text: true
18316        }
18317      },
18318      spacing: {
18319        margin: ["top", "bottom"],
18320        padding: true,
18321        blockGap: true,
18322        __experimentalDefaultControls: {
18323          padding: true,
18324          blockGap: true
18325        }
18326      },
18327      __experimentalBorder: {
18328        color: true,
18329        radius: true,
18330        style: true,
18331        width: true,
18332        __experimentalDefaultControls: {
18333          color: true,
18334          radius: true,
18335          style: true,
18336          width: true
18337        }
18338      },
18339      typography: {
18340        fontSize: true,
18341        lineHeight: true,
18342        __experimentalFontStyle: true,
18343        __experimentalFontWeight: true,
18344        __experimentalLetterSpacing: true,
18345        __experimentalTextTransform: true,
18346        __experimentalDefaultControls: {
18347          fontSize: true
18348        }
18349      },
18350      __experimentalLayout: true
18351    },
18352    editorStyle: "wp-block-group-editor",
18353    style: "wp-block-group"
18354  };
18355  
18356  
18357  
18358  const {
18359    name: group_name
18360  } = group_metadata;
18361  
18362  const group_settings = {
18363    icon: library_group,
18364    example: {
18365      attributes: {
18366        style: {
18367          color: {
18368            text: '#000000',
18369            background: '#ffffff'
18370          }
18371        }
18372      },
18373      innerBlocks: [{
18374        name: 'core/paragraph',
18375        attributes: {
18376          customTextColor: '#cf2e2e',
18377          fontSize: 'large',
18378          content: (0,external_wp_i18n_namespaceObject.__)('One.')
18379        }
18380      }, {
18381        name: 'core/paragraph',
18382        attributes: {
18383          customTextColor: '#ff6900',
18384          fontSize: 'large',
18385          content: (0,external_wp_i18n_namespaceObject.__)('Two.')
18386        }
18387      }, {
18388        name: 'core/paragraph',
18389        attributes: {
18390          customTextColor: '#fcb900',
18391          fontSize: 'large',
18392          content: (0,external_wp_i18n_namespaceObject.__)('Three.')
18393        }
18394      }, {
18395        name: 'core/paragraph',
18396        attributes: {
18397          customTextColor: '#00d084',
18398          fontSize: 'large',
18399          content: (0,external_wp_i18n_namespaceObject.__)('Four.')
18400        }
18401      }, {
18402        name: 'core/paragraph',
18403        attributes: {
18404          customTextColor: '#0693e3',
18405          fontSize: 'large',
18406          content: (0,external_wp_i18n_namespaceObject.__)('Five.')
18407        }
18408      }, {
18409        name: 'core/paragraph',
18410        attributes: {
18411          customTextColor: '#9b51e0',
18412          fontSize: 'large',
18413          content: (0,external_wp_i18n_namespaceObject.__)('Six.')
18414        }
18415      }]
18416    },
18417    transforms: group_transforms,
18418    edit: group_edit,
18419    save: group_save_save,
18420    deprecated: group_deprecated,
18421    variations: group_variations
18422  };
18423  
18424  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/heading.js
18425  
18426  
18427  /**
18428   * WordPress dependencies
18429   */
18430  
18431  const heading = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
18432    xmlns: "http://www.w3.org/2000/svg",
18433    viewBox: "0 0 24 24"
18434  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
18435    d: "M6.2 5.2v13.4l5.8-4.8 5.8 4.8V5.2z"
18436  }));
18437  /* harmony default export */ var library_heading = (heading);
18438  
18439  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/heading/deprecated.js
18440  
18441  
18442  /**
18443   * External dependencies
18444   */
18445  
18446  
18447  /**
18448   * WordPress dependencies
18449   */
18450  
18451  
18452  const blockSupports = {
18453    className: false,
18454    anchor: true
18455  };
18456  const heading_deprecated_blockAttributes = {
18457    align: {
18458      type: 'string'
18459    },
18460    content: {
18461      type: 'string',
18462      source: 'html',
18463      selector: 'h1,h2,h3,h4,h5,h6',
18464      default: ''
18465    },
18466    level: {
18467      type: 'number',
18468      default: 2
18469    },
18470    placeholder: {
18471      type: 'string'
18472    }
18473  };
18474  
18475  const deprecated_migrateCustomColors = attributes => {
18476    if (!attributes.customTextColor) {
18477      return attributes;
18478    }
18479  
18480    const style = {
18481      color: {
18482        text: attributes.customTextColor
18483      }
18484    };
18485    return { ...(0,external_lodash_namespaceObject.omit)(attributes, ['customTextColor']),
18486      style
18487    };
18488  };
18489  
18490  const TEXT_ALIGN_OPTIONS = ['left', 'right', 'center'];
18491  
18492  const migrateTextAlign = attributes => {
18493    const {
18494      align,
18495      ...rest
18496    } = attributes;
18497    return TEXT_ALIGN_OPTIONS.includes(align) ? { ...rest,
18498      textAlign: align
18499    } : attributes;
18500  };
18501  
18502  const heading_deprecated_deprecated = [{
18503    supports: {
18504      align: ['wide', 'full'],
18505      anchor: true,
18506      className: false,
18507      color: {
18508        link: true
18509      },
18510      fontSize: true,
18511      lineHeight: true,
18512      __experimentalSelector: {
18513        'core/heading/h1': 'h1',
18514        'core/heading/h2': 'h2',
18515        'core/heading/h3': 'h3',
18516        'core/heading/h4': 'h4',
18517        'core/heading/h5': 'h5',
18518        'core/heading/h6': 'h6'
18519      },
18520      __unstablePasteTextInline: true
18521    },
18522    attributes: heading_deprecated_blockAttributes,
18523    isEligible: _ref => {
18524      let {
18525        align
18526      } = _ref;
18527      return TEXT_ALIGN_OPTIONS.includes(align);
18528    },
18529    migrate: migrateTextAlign,
18530  
18531    save(_ref2) {
18532      let {
18533        attributes
18534      } = _ref2;
18535      const {
18536        align,
18537        content,
18538        level
18539      } = attributes;
18540      const TagName = 'h' + level;
18541      const className = classnames_default()({
18542        [`has-text-align-$align}`]: align
18543      });
18544      return (0,external_wp_element_namespaceObject.createElement)(TagName, external_wp_blockEditor_namespaceObject.useBlockProps.save({
18545        className
18546      }), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
18547        value: content
18548      }));
18549    }
18550  
18551  }, {
18552    supports: blockSupports,
18553    attributes: { ...heading_deprecated_blockAttributes,
18554      customTextColor: {
18555        type: 'string'
18556      },
18557      textColor: {
18558        type: 'string'
18559      }
18560    },
18561    migrate: attributes => deprecated_migrateCustomColors(migrateTextAlign(attributes)),
18562  
18563    save(_ref3) {
18564      let {
18565        attributes
18566      } = _ref3;
18567      const {
18568        align,
18569        content,
18570        customTextColor,
18571        level,
18572        textColor
18573      } = attributes;
18574      const tagName = 'h' + level;
18575      const textClass = (0,external_wp_blockEditor_namespaceObject.getColorClassName)('color', textColor);
18576      const className = classnames_default()({
18577        [textClass]: textClass,
18578        'has-text-color': textColor || customTextColor,
18579        [`has-text-align-$align}`]: align
18580      });
18581      return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
18582        className: className ? className : undefined,
18583        tagName: tagName,
18584        style: {
18585          color: textClass ? undefined : customTextColor
18586        },
18587        value: content
18588      });
18589    }
18590  
18591  }, {
18592    attributes: { ...heading_deprecated_blockAttributes,
18593      customTextColor: {
18594        type: 'string'
18595      },
18596      textColor: {
18597        type: 'string'
18598      }
18599    },
18600    migrate: attributes => deprecated_migrateCustomColors(migrateTextAlign(attributes)),
18601  
18602    save(_ref4) {
18603      let {
18604        attributes
18605      } = _ref4;
18606      const {
18607        align,
18608        content,
18609        customTextColor,
18610        level,
18611        textColor
18612      } = attributes;
18613      const tagName = 'h' + level;
18614      const textClass = (0,external_wp_blockEditor_namespaceObject.getColorClassName)('color', textColor);
18615      const className = classnames_default()({
18616        [textClass]: textClass,
18617        [`has-text-align-$align}`]: align
18618      });
18619      return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
18620        className: className ? className : undefined,
18621        tagName: tagName,
18622        style: {
18623          color: textClass ? undefined : customTextColor
18624        },
18625        value: content
18626      });
18627    },
18628  
18629    supports: blockSupports
18630  }, {
18631    supports: blockSupports,
18632    attributes: { ...heading_deprecated_blockAttributes,
18633      customTextColor: {
18634        type: 'string'
18635      },
18636      textColor: {
18637        type: 'string'
18638      }
18639    },
18640    migrate: attributes => deprecated_migrateCustomColors(migrateTextAlign(attributes)),
18641  
18642    save(_ref5) {
18643      let {
18644        attributes
18645      } = _ref5;
18646      const {
18647        align,
18648        level,
18649        content,
18650        textColor,
18651        customTextColor
18652      } = attributes;
18653      const tagName = 'h' + level;
18654      const textClass = (0,external_wp_blockEditor_namespaceObject.getColorClassName)('color', textColor);
18655      const className = classnames_default()({
18656        [textClass]: textClass
18657      });
18658      return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
18659        className: className ? className : undefined,
18660        tagName: tagName,
18661        style: {
18662          textAlign: align,
18663          color: textClass ? undefined : customTextColor
18664        },
18665        value: content
18666      });
18667    }
18668  
18669  }];
18670  /* harmony default export */ var heading_deprecated = (heading_deprecated_deprecated);
18671  
18672  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/heading/autogenerate-anchors.js
18673  /**
18674   * External dependencies
18675   */
18676  
18677  /**
18678   * Object map tracking anchors.
18679   *
18680   * @type {Record<string, string | null>}
18681   */
18682  
18683  const autogenerate_anchors_anchors = {};
18684  /**
18685   * Returns the text without markup.
18686   *
18687   * @param {string} text The text.
18688   *
18689   * @return {string} The text without markup.
18690   */
18691  
18692  const getTextWithoutMarkup = text => {
18693    const dummyElement = document.createElement('div');
18694    dummyElement.innerHTML = text;
18695    return dummyElement.innerText;
18696  };
18697  /**
18698   * Get the slug from the content.
18699   *
18700   * @param {string} content The block content.
18701   *
18702   * @return {string} Returns the slug.
18703   */
18704  
18705  
18706  const getSlug = content => {
18707    // Get the slug.
18708    return (0,external_lodash_namespaceObject.trim)((0,external_lodash_namespaceObject.deburr)(getTextWithoutMarkup(content)).replace(/[^\p{L}\p{N}]+/gu, '-').toLowerCase(), '-');
18709  };
18710  /**
18711   * Generate the anchor for a heading.
18712   *
18713   * @param {string} clientId The block ID.
18714   * @param {string} content  The block content.
18715   *
18716   * @return {string|null} Return the heading anchor.
18717   */
18718  
18719  
18720  const generateAnchor = (clientId, content) => {
18721    const slug = getSlug(content); // If slug is empty, then return null.
18722    // Returning null instead of an empty string allows us to check again when the content changes.
18723  
18724    if ('' === slug) {
18725      return null;
18726    }
18727  
18728    delete autogenerate_anchors_anchors[clientId];
18729    let anchor = slug;
18730    let i = 0; // If the anchor already exists in another heading, append -i.
18731  
18732    while (Object.values(autogenerate_anchors_anchors).includes(anchor)) {
18733      i += 1;
18734      anchor = slug + '-' + i;
18735    }
18736  
18737    return anchor;
18738  };
18739  /**
18740   * Set the anchor for a heading.
18741   *
18742   * @param {string}      clientId The block ID.
18743   * @param {string|null} anchor   The block anchor.
18744   */
18745  
18746  const setAnchor = (clientId, anchor) => {
18747    autogenerate_anchors_anchors[clientId] = anchor;
18748  };
18749  
18750  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/heading/edit.js
18751  
18752  
18753  
18754  /**
18755   * External dependencies
18756   */
18757  
18758  /**
18759   * WordPress dependencies
18760   */
18761  
18762  
18763  
18764  
18765  
18766  
18767  /**
18768   * Internal dependencies
18769   */
18770  
18771  
18772  
18773  
18774  function HeadingEdit(_ref) {
18775    let {
18776      attributes,
18777      setAttributes,
18778      mergeBlocks,
18779      onReplace,
18780      style,
18781      clientId
18782    } = _ref;
18783    const {
18784      textAlign,
18785      content,
18786      level,
18787      placeholder,
18788      anchor
18789    } = attributes;
18790    const tagName = 'h' + level;
18791    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
18792      className: classnames_default()({
18793        [`has-text-align-$textAlign}`]: textAlign
18794      }),
18795      style
18796    });
18797    const {
18798      canGenerateAnchors
18799    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
18800      const settings = select(external_wp_blockEditor_namespaceObject.store).getSettings();
18801      return {
18802        canGenerateAnchors: !!settings.generateAnchors
18803      };
18804    }, []);
18805    const {
18806      __unstableMarkNextChangeAsNotPersistent
18807    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_blockEditor_namespaceObject.store); // Initially set anchor for headings that have content but no anchor set.
18808    // This is used when transforming a block to heading, or for legacy anchors.
18809  
18810    (0,external_wp_element_namespaceObject.useEffect)(() => {
18811      if (!canGenerateAnchors) {
18812        return;
18813      }
18814  
18815      if (!anchor && content) {
18816        // This side-effect should not create an undo level.
18817        __unstableMarkNextChangeAsNotPersistent();
18818  
18819        setAttributes({
18820          anchor: generateAnchor(clientId, content)
18821        });
18822      }
18823  
18824      setAnchor(clientId, anchor); // Remove anchor map when block unmounts.
18825  
18826      return () => setAnchor(clientId, null);
18827    }, [anchor, content, clientId, canGenerateAnchors]);
18828  
18829    const onContentChange = value => {
18830      const newAttrs = {
18831        content: value
18832      };
18833  
18834      if (canGenerateAnchors && (!anchor || !value || generateAnchor(clientId, content) === anchor)) {
18835        newAttrs.anchor = generateAnchor(clientId, value);
18836      }
18837  
18838      setAttributes(newAttrs);
18839    };
18840  
18841    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, {
18842      group: "block"
18843    }, (0,external_wp_element_namespaceObject.createElement)(HeadingLevelDropdown, {
18844      selectedLevel: level,
18845      onChange: newLevel => setAttributes({
18846        level: newLevel
18847      })
18848    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.AlignmentControl, {
18849      value: textAlign,
18850      onChange: nextAlign => {
18851        setAttributes({
18852          textAlign: nextAlign
18853        });
18854      }
18855    })), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText, _extends({
18856      identifier: "content",
18857      tagName: tagName,
18858      value: content,
18859      onChange: onContentChange,
18860      onMerge: mergeBlocks,
18861      onSplit: (value, isOriginal) => {
18862        let block;
18863  
18864        if (isOriginal || value) {
18865          block = (0,external_wp_blocks_namespaceObject.createBlock)('core/heading', { ...attributes,
18866            content: value
18867          });
18868        } else {
18869          var _getDefaultBlockName;
18870  
18871          block = (0,external_wp_blocks_namespaceObject.createBlock)((_getDefaultBlockName = (0,external_wp_blocks_namespaceObject.getDefaultBlockName)()) !== null && _getDefaultBlockName !== void 0 ? _getDefaultBlockName : 'core/heading');
18872        }
18873  
18874        if (isOriginal) {
18875          block.clientId = clientId;
18876        }
18877  
18878        return block;
18879      },
18880      onReplace: onReplace,
18881      onRemove: () => onReplace([]),
18882      "aria-label": (0,external_wp_i18n_namespaceObject.__)('Heading text'),
18883      placeholder: placeholder || (0,external_wp_i18n_namespaceObject.__)('Heading'),
18884      textAlign: textAlign
18885    }, external_wp_element_namespaceObject.Platform.isNative && {
18886      deleteEnter: true
18887    }, blockProps)));
18888  }
18889  
18890  /* harmony default export */ var heading_edit = (HeadingEdit);
18891  
18892  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/heading/save.js
18893  
18894  
18895  /**
18896   * External dependencies
18897   */
18898  
18899  /**
18900   * WordPress dependencies
18901   */
18902  
18903  
18904  function heading_save_save(_ref) {
18905    let {
18906      attributes
18907    } = _ref;
18908    const {
18909      textAlign,
18910      content,
18911      level
18912    } = attributes;
18913    const TagName = 'h' + level;
18914    const className = classnames_default()({
18915      [`has-text-align-$textAlign}`]: textAlign
18916    });
18917    return (0,external_wp_element_namespaceObject.createElement)(TagName, external_wp_blockEditor_namespaceObject.useBlockProps.save({
18918      className
18919    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
18920      value: content
18921    }));
18922  }
18923  
18924  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/heading/shared.js
18925  /**
18926   * Given a node name string for a heading node, returns its numeric level.
18927   *
18928   * @param {string} nodeName Heading node name.
18929   *
18930   * @return {number} Heading level.
18931   */
18932  function getLevelFromHeadingNodeName(nodeName) {
18933    return Number(nodeName.substr(1));
18934  }
18935  
18936  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/heading/transforms.js
18937  /**
18938   * WordPress dependencies
18939   */
18940  
18941  /**
18942   * Internal dependencies
18943   */
18944  
18945  
18946  const {
18947    name: heading_transforms_name
18948  } = {
18949    $schema: "https://schemas.wp.org/trunk/block.json",
18950    apiVersion: 2,
18951    name: "core/heading",
18952    title: "Heading",
18953    category: "text",
18954    description: "Introduce new sections and organize content to help visitors (and search engines) understand the structure of your content.",
18955    keywords: ["title", "subtitle"],
18956    textdomain: "default",
18957    attributes: {
18958      textAlign: {
18959        type: "string"
18960      },
18961      content: {
18962        type: "string",
18963        source: "html",
18964        selector: "h1,h2,h3,h4,h5,h6",
18965        "default": "",
18966        __experimentalRole: "content"
18967      },
18968      level: {
18969        type: "number",
18970        "default": 2
18971      },
18972      placeholder: {
18973        type: "string"
18974      }
18975    },
18976    supports: {
18977      align: ["wide", "full"],
18978      anchor: true,
18979      className: false,
18980      color: {
18981        link: true,
18982        __experimentalDefaultControls: {
18983          background: true,
18984          text: true
18985        }
18986      },
18987      spacing: {
18988        margin: true
18989      },
18990      typography: {
18991        fontSize: true,
18992        lineHeight: true,
18993        __experimentalFontStyle: true,
18994        __experimentalFontWeight: true,
18995        __experimentalLetterSpacing: true,
18996        __experimentalTextTransform: true,
18997        __experimentalDefaultControls: {
18998          fontSize: true,
18999          fontAppearance: true,
19000          textTransform: true
19001        }
19002      },
19003      __experimentalSelector: "h1,h2,h3,h4,h5,h6",
19004      __unstablePasteTextInline: true,
19005      __experimentalSlashInserter: true
19006    },
19007    editorStyle: "wp-block-heading-editor",
19008    style: "wp-block-heading"
19009  };
19010  const heading_transforms_transforms = {
19011    from: [{
19012      type: 'block',
19013      isMultiBlock: true,
19014      blocks: ['core/paragraph'],
19015      transform: attributes => attributes.map(_ref => {
19016        let {
19017          content,
19018          anchor
19019        } = _ref;
19020        return (0,external_wp_blocks_namespaceObject.createBlock)(heading_transforms_name, {
19021          content,
19022          anchor
19023        });
19024      })
19025    }, {
19026      type: 'raw',
19027      selector: 'h1,h2,h3,h4,h5,h6',
19028      schema: _ref2 => {
19029        let {
19030          phrasingContentSchema,
19031          isPaste
19032        } = _ref2;
19033        const schema = {
19034          children: phrasingContentSchema,
19035          attributes: isPaste ? [] : ['style', 'id']
19036        };
19037        return {
19038          h1: schema,
19039          h2: schema,
19040          h3: schema,
19041          h4: schema,
19042          h5: schema,
19043          h6: schema
19044        };
19045      },
19046  
19047      transform(node) {
19048        const attributes = (0,external_wp_blocks_namespaceObject.getBlockAttributes)(heading_transforms_name, node.outerHTML);
19049        const {
19050          textAlign
19051        } = node.style || {};
19052        attributes.level = getLevelFromHeadingNodeName(node.nodeName);
19053  
19054        if (textAlign === 'left' || textAlign === 'center' || textAlign === 'right') {
19055          attributes.align = textAlign;
19056        }
19057  
19058        return (0,external_wp_blocks_namespaceObject.createBlock)(heading_transforms_name, attributes);
19059      }
19060  
19061    }, ...[1, 2, 3, 4, 5, 6].map(level => ({
19062      type: 'prefix',
19063      prefix: Array(level + 1).join('#'),
19064  
19065      transform(content) {
19066        return (0,external_wp_blocks_namespaceObject.createBlock)(heading_transforms_name, {
19067          level,
19068          content
19069        });
19070      }
19071  
19072    })), ...[1, 2, 3, 4, 5, 6].map(level => ({
19073      type: 'enter',
19074      regExp: new RegExp(`^/(h|H)$level}$`),
19075  
19076      transform(content) {
19077        return (0,external_wp_blocks_namespaceObject.createBlock)(heading_transforms_name, {
19078          level,
19079          content
19080        });
19081      }
19082  
19083    }))],
19084    to: [{
19085      type: 'block',
19086      isMultiBlock: true,
19087      blocks: ['core/paragraph'],
19088      transform: attributes => attributes.map(_ref3 => {
19089        let {
19090          content
19091        } = _ref3;
19092        return (0,external_wp_blocks_namespaceObject.createBlock)('core/paragraph', {
19093          content
19094        });
19095      })
19096    }]
19097  };
19098  /* harmony default export */ var heading_transforms = (heading_transforms_transforms);
19099  
19100  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/heading/index.js
19101  /**
19102   * External dependencies
19103   */
19104  
19105  /**
19106   * WordPress dependencies
19107   */
19108  
19109  
19110  
19111  /**
19112   * Internal dependencies
19113   */
19114  
19115  
19116  
19117  const heading_metadata = {
19118    $schema: "https://schemas.wp.org/trunk/block.json",
19119    apiVersion: 2,
19120    name: "core/heading",
19121    title: "Heading",
19122    category: "text",
19123    description: "Introduce new sections and organize content to help visitors (and search engines) understand the structure of your content.",
19124    keywords: ["title", "subtitle"],
19125    textdomain: "default",
19126    attributes: {
19127      textAlign: {
19128        type: "string"
19129      },
19130      content: {
19131        type: "string",
19132        source: "html",
19133        selector: "h1,h2,h3,h4,h5,h6",
19134        "default": "",
19135        __experimentalRole: "content"
19136      },
19137      level: {
19138        type: "number",
19139        "default": 2
19140      },
19141      placeholder: {
19142        type: "string"
19143      }
19144    },
19145    supports: {
19146      align: ["wide", "full"],
19147      anchor: true,
19148      className: false,
19149      color: {
19150        link: true,
19151        __experimentalDefaultControls: {
19152          background: true,
19153          text: true
19154        }
19155      },
19156      spacing: {
19157        margin: true
19158      },
19159      typography: {
19160        fontSize: true,
19161        lineHeight: true,
19162        __experimentalFontStyle: true,
19163        __experimentalFontWeight: true,
19164        __experimentalLetterSpacing: true,
19165        __experimentalTextTransform: true,
19166        __experimentalDefaultControls: {
19167          fontSize: true,
19168          fontAppearance: true,
19169          textTransform: true
19170        }
19171      },
19172      __experimentalSelector: "h1,h2,h3,h4,h5,h6",
19173      __unstablePasteTextInline: true,
19174      __experimentalSlashInserter: true
19175    },
19176    editorStyle: "wp-block-heading-editor",
19177    style: "wp-block-heading"
19178  };
19179  
19180  
19181  const {
19182    name: heading_name
19183  } = heading_metadata;
19184  
19185  const heading_settings = {
19186    icon: library_heading,
19187    example: {
19188      attributes: {
19189        content: (0,external_wp_i18n_namespaceObject.__)('Code is Poetry'),
19190        level: 2
19191      }
19192    },
19193  
19194    __experimentalLabel(attributes, _ref) {
19195      let {
19196        context
19197      } = _ref;
19198  
19199      if (context === 'accessibility') {
19200        const {
19201          content,
19202          level
19203        } = attributes;
19204        return (0,external_lodash_namespaceObject.isEmpty)(content) ? (0,external_wp_i18n_namespaceObject.sprintf)(
19205        /* translators: accessibility text. %s: heading level. */
19206        (0,external_wp_i18n_namespaceObject.__)('Level %s. Empty.'), level) : (0,external_wp_i18n_namespaceObject.sprintf)(
19207        /* translators: accessibility text. 1: heading level. 2: heading content. */
19208        (0,external_wp_i18n_namespaceObject.__)('Level %1$s. %2$s'), level, content);
19209      }
19210    },
19211  
19212    transforms: heading_transforms,
19213    deprecated: heading_deprecated,
19214  
19215    merge(attributes, attributesToMerge) {
19216      return {
19217        content: (attributes.content || '') + (attributesToMerge.content || '')
19218      };
19219    },
19220  
19221    edit: heading_edit,
19222    save: heading_save_save
19223  };
19224  
19225  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/home.js
19226  
19227  
19228  /**
19229   * WordPress dependencies
19230   */
19231  
19232  const home = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
19233    xmlns: "http://www.w3.org/2000/svg",
19234    viewBox: "0 0 24 24"
19235  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
19236    d: "M12 4L4 7.9V20h16V7.9L12 4zm6.5 14.5H14V13h-4v5.5H5.5V8.8L12 5.7l6.5 3.1v9.7z"
19237  }));
19238  /* harmony default export */ var library_home = (home);
19239  
19240  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/home-link/edit.js
19241  
19242  
19243  /**
19244   * External dependencies
19245   */
19246  
19247  /**
19248   * WordPress dependencies
19249   */
19250  
19251  
19252  
19253  
19254  
19255  
19256  
19257  const preventDefault = event => event.preventDefault();
19258  
19259  function HomeEdit(_ref) {
19260    var _style$color, _style$color2, _style$color3, _style$color4;
19261  
19262    let {
19263      attributes,
19264      setAttributes,
19265      context,
19266      clientId
19267    } = _ref;
19268    const {
19269      homeUrl
19270    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
19271      var _getUnstableBase;
19272  
19273      const {
19274        getUnstableBase // Site index.
19275  
19276      } = select(external_wp_coreData_namespaceObject.store);
19277      return {
19278        homeUrl: (_getUnstableBase = getUnstableBase()) === null || _getUnstableBase === void 0 ? void 0 : _getUnstableBase.home
19279      };
19280    }, [clientId]);
19281    const {
19282      textColor,
19283      backgroundColor,
19284      style
19285    } = context;
19286    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
19287      className: classnames_default()('wp-block-navigation-item', {
19288        'has-text-color': !!textColor || !!(style !== null && style !== void 0 && (_style$color = style.color) !== null && _style$color !== void 0 && _style$color.text),
19289        [`has-$textColor}-color`]: !!textColor,
19290        'has-background': !!backgroundColor || !!(style !== null && style !== void 0 && (_style$color2 = style.color) !== null && _style$color2 !== void 0 && _style$color2.background),
19291        [`has-$backgroundColor}-background-color`]: !!backgroundColor
19292      }),
19293      style: {
19294        color: style === null || style === void 0 ? void 0 : (_style$color3 = style.color) === null || _style$color3 === void 0 ? void 0 : _style$color3.text,
19295        backgroundColor: style === null || style === void 0 ? void 0 : (_style$color4 = style.color) === null || _style$color4 === void 0 ? void 0 : _style$color4.background
19296      }
19297    });
19298    const {
19299      label
19300    } = attributes;
19301    (0,external_wp_element_namespaceObject.useEffect)(() => {
19302      if (label === undefined) {
19303        setAttributes({
19304          label: (0,external_wp_i18n_namespaceObject.__)('Home')
19305        });
19306      }
19307    }, [clientId, label]);
19308    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)("div", blockProps, (0,external_wp_element_namespaceObject.createElement)("a", {
19309      className: "wp-block-home-link__content wp-block-navigation-item__content",
19310      href: homeUrl,
19311      onClick: preventDefault
19312    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText, {
19313      identifier: "label",
19314      className: "wp-block-home-link__label",
19315      value: label,
19316      onChange: labelValue => {
19317        setAttributes({
19318          label: labelValue
19319        });
19320      },
19321      "aria-label": (0,external_wp_i18n_namespaceObject.__)('Home link text'),
19322      placeholder: (0,external_wp_i18n_namespaceObject.__)('Add home link'),
19323      withoutInteractiveFormatting: true,
19324      allowedFormats: ['core/bold', 'core/italic', 'core/image', 'core/strikethrough']
19325    }))));
19326  }
19327  
19328  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/home-link/save.js
19329  
19330  
19331  /**
19332   * WordPress dependencies
19333   */
19334  
19335  function home_link_save_save() {
19336    return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InnerBlocks.Content, null);
19337  }
19338  
19339  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/home-link/index.js
19340  /**
19341   * WordPress dependencies
19342   */
19343  
19344  
19345  /**
19346   * Internal dependencies
19347   */
19348  
19349  const home_link_metadata = {
19350    $schema: "https://schemas.wp.org/trunk/block.json",
19351    apiVersion: 2,
19352    name: "core/home-link",
19353    category: "design",
19354    parent: ["core/navigation"],
19355    title: "Home Link",
19356    description: "Create a link that always points to the homepage of the site. Usually not necessary if there is already a site title link present in the header.",
19357    textdomain: "default",
19358    attributes: {
19359      label: {
19360        type: "string"
19361      }
19362    },
19363    usesContext: ["textColor", "customTextColor", "backgroundColor", "customBackgroundColor", "fontSize", "customFontSize", "style"],
19364    supports: {
19365      reusable: false,
19366      html: false
19367    },
19368    editorStyle: "wp-block-home-link-editor",
19369    style: "wp-block-home-link"
19370  };
19371  
19372  
19373  const {
19374    name: home_link_name
19375  } = home_link_metadata;
19376  
19377  const home_link_settings = {
19378    icon: library_home,
19379    edit: HomeEdit,
19380    save: home_link_save_save,
19381    example: {
19382      attributes: {
19383        label: (0,external_wp_i18n_namespaceObject._x)('Home Link', 'block example')
19384      }
19385    }
19386  };
19387  
19388  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/html.js
19389  
19390  
19391  /**
19392   * WordPress dependencies
19393   */
19394  
19395  const html = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
19396    viewBox: "0 0 24 24",
19397    xmlns: "http://www.w3.org/2000/svg"
19398  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
19399    d: "M4.8 11.4H2.1V9H1v6h1.1v-2.6h2.7V15h1.1V9H4.8v2.4zm1.9-1.3h1.7V15h1.1v-4.9h1.7V9H6.7v1.1zM16.2 9l-1.5 2.7L13.3 9h-.9l-.8 6h1.1l.5-4 1.5 2.8 1.5-2.8.5 4h1.1L17 9h-.8zm3.8 5V9h-1.1v6h3.6v-1H20z"
19400  }));
19401  /* harmony default export */ var library_html = (html);
19402  
19403  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/html/edit.js
19404  
19405  
19406  /**
19407   * WordPress dependencies
19408   */
19409  
19410  
19411  
19412  
19413  
19414  function HTMLEdit(_ref) {
19415    let {
19416      attributes,
19417      setAttributes,
19418      isSelected
19419    } = _ref;
19420    const [isPreview, setIsPreview] = (0,external_wp_element_namespaceObject.useState)();
19421    const isDisabled = (0,external_wp_element_namespaceObject.useContext)(external_wp_components_namespaceObject.Disabled.Context);
19422    const styles = (0,external_wp_data_namespaceObject.useSelect)(select => {
19423      // Default styles used to unset some of the styles
19424      // that might be inherited from the editor style.
19425      const defaultStyles = `
19426              html,body,:root {
19427                  margin: 0 !important;
19428                  padding: 0 !important;
19429                  overflow: visible !important;
19430                  min-height: auto !important;
19431              }
19432          `;
19433      return [defaultStyles, ...(0,external_wp_blockEditor_namespaceObject.transformStyles)(select(external_wp_blockEditor_namespaceObject.store).getSettings().styles)];
19434    }, []);
19435  
19436    function switchToPreview() {
19437      setIsPreview(true);
19438    }
19439  
19440    function switchToHTML() {
19441      setIsPreview(false);
19442    }
19443  
19444    return (0,external_wp_element_namespaceObject.createElement)("div", (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
19445      className: 'block-library-html__edit'
19446    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarGroup, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, {
19447      className: "components-tab-button",
19448      isPressed: !isPreview,
19449      onClick: switchToHTML
19450    }, (0,external_wp_element_namespaceObject.createElement)("span", null, "HTML")), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, {
19451      className: "components-tab-button",
19452      isPressed: isPreview,
19453      onClick: switchToPreview
19454    }, (0,external_wp_element_namespaceObject.createElement)("span", null, (0,external_wp_i18n_namespaceObject.__)('Preview'))))), isPreview || isDisabled ? (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SandBox, {
19455      html: attributes.content,
19456      styles: styles
19457    }), !isSelected && (0,external_wp_element_namespaceObject.createElement)("div", {
19458      className: "block-library-html__preview-overlay"
19459    })) : (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.PlainText, {
19460      value: attributes.content,
19461      onChange: content => setAttributes({
19462        content
19463      }),
19464      placeholder: (0,external_wp_i18n_namespaceObject.__)('Write HTML…'),
19465      "aria-label": (0,external_wp_i18n_namespaceObject.__)('HTML')
19466    }));
19467  }
19468  
19469  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/html/save.js
19470  
19471  
19472  /**
19473   * WordPress dependencies
19474   */
19475  
19476  function html_save_save(_ref) {
19477    let {
19478      attributes
19479    } = _ref;
19480    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.RawHTML, null, attributes.content);
19481  }
19482  
19483  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/html/transforms.js
19484  /**
19485   * WordPress dependencies
19486   */
19487  
19488  const html_transforms_transforms = {
19489    from: [{
19490      type: 'block',
19491      blocks: ['core/code'],
19492      transform: _ref => {
19493        let {
19494          content
19495        } = _ref;
19496        return (0,external_wp_blocks_namespaceObject.createBlock)('core/html', {
19497          content
19498        });
19499      }
19500    }]
19501  };
19502  /* harmony default export */ var html_transforms = (html_transforms_transforms);
19503  
19504  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/html/index.js
19505  /**
19506   * WordPress dependencies
19507   */
19508  
19509  
19510  /**
19511   * Internal dependencies
19512   */
19513  
19514  
19515  const html_metadata = {
19516    $schema: "https://schemas.wp.org/trunk/block.json",
19517    apiVersion: 2,
19518    name: "core/html",
19519    title: "Custom HTML",
19520    category: "widgets",
19521    description: "Add custom HTML code and preview it as you edit.",
19522    keywords: ["embed"],
19523    textdomain: "default",
19524    attributes: {
19525      content: {
19526        type: "string",
19527        source: "html"
19528      }
19529    },
19530    supports: {
19531      customClassName: false,
19532      className: false,
19533      html: false
19534    },
19535    editorStyle: "wp-block-html-editor"
19536  };
19537  
19538  
19539  const {
19540    name: html_name
19541  } = html_metadata;
19542  
19543  const html_settings = {
19544    icon: library_html,
19545    example: {
19546      attributes: {
19547        content: '<marquee>' + (0,external_wp_i18n_namespaceObject.__)('Welcome to the wonderful world of blocks…') + '</marquee>'
19548      }
19549    },
19550    edit: HTMLEdit,
19551    save: html_save_save,
19552    transforms: html_transforms
19553  };
19554  
19555  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/image/deprecated.js
19556  
19557  
19558  
19559  /**
19560   * External dependencies
19561   */
19562  
19563  
19564  /**
19565   * WordPress dependencies
19566   */
19567  
19568  
19569  const image_deprecated_blockAttributes = {
19570    align: {
19571      type: 'string'
19572    },
19573    url: {
19574      type: 'string',
19575      source: 'attribute',
19576      selector: 'img',
19577      attribute: 'src'
19578    },
19579    alt: {
19580      type: 'string',
19581      source: 'attribute',
19582      selector: 'img',
19583      attribute: 'alt',
19584      default: ''
19585    },
19586    caption: {
19587      type: 'string',
19588      source: 'html',
19589      selector: 'figcaption'
19590    },
19591    href: {
19592      type: 'string',
19593      source: 'attribute',
19594      selector: 'figure > a',
19595      attribute: 'href'
19596    },
19597    rel: {
19598      type: 'string',
19599      source: 'attribute',
19600      selector: 'figure > a',
19601      attribute: 'rel'
19602    },
19603    linkClass: {
19604      type: 'string',
19605      source: 'attribute',
19606      selector: 'figure > a',
19607      attribute: 'class'
19608    },
19609    id: {
19610      type: 'number'
19611    },
19612    width: {
19613      type: 'number'
19614    },
19615    height: {
19616      type: 'number'
19617    },
19618    linkDestination: {
19619      type: 'string'
19620    },
19621    linkTarget: {
19622      type: 'string',
19623      source: 'attribute',
19624      selector: 'figure > a',
19625      attribute: 'target'
19626    }
19627  };
19628  const deprecated_blockSupports = {
19629    anchor: true,
19630    color: {
19631      __experimentalDuotone: 'img',
19632      text: false,
19633      background: false
19634    },
19635    __experimentalBorder: {
19636      radius: true,
19637      __experimentalDefaultControls: {
19638        radius: true
19639      }
19640    }
19641  };
19642  const image_deprecated_deprecated = [{
19643    attributes: { ...image_deprecated_blockAttributes,
19644      title: {
19645        type: 'string',
19646        source: 'attribute',
19647        selector: 'img',
19648        attribute: 'title'
19649      },
19650      sizeSlug: {
19651        type: 'string'
19652      }
19653    },
19654    supports: deprecated_blockSupports,
19655  
19656    save(_ref) {
19657      let {
19658        attributes
19659      } = _ref;
19660      const {
19661        url,
19662        alt,
19663        caption,
19664        align,
19665        href,
19666        rel,
19667        linkClass,
19668        width,
19669        height,
19670        id,
19671        linkTarget,
19672        sizeSlug,
19673        title
19674      } = attributes;
19675      const newRel = (0,external_lodash_namespaceObject.isEmpty)(rel) ? undefined : rel;
19676      const classes = classnames_default()({
19677        [`align$align}`]: align,
19678        [`size-$sizeSlug}`]: sizeSlug,
19679        'is-resized': width || height
19680      });
19681      const image = (0,external_wp_element_namespaceObject.createElement)("img", {
19682        src: url,
19683        alt: alt,
19684        className: id ? `wp-image-$id}` : null,
19685        width: width,
19686        height: height,
19687        title: title
19688      });
19689      const figure = (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, href ? (0,external_wp_element_namespaceObject.createElement)("a", {
19690        className: linkClass,
19691        href: href,
19692        target: linkTarget,
19693        rel: newRel
19694      }, image) : image, !external_wp_blockEditor_namespaceObject.RichText.isEmpty(caption) && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
19695        tagName: "figcaption",
19696        value: caption
19697      }));
19698  
19699      if ('left' === align || 'right' === align || 'center' === align) {
19700        return (0,external_wp_element_namespaceObject.createElement)("div", external_wp_blockEditor_namespaceObject.useBlockProps.save(), (0,external_wp_element_namespaceObject.createElement)("figure", {
19701          className: classes
19702        }, figure));
19703      }
19704  
19705      return (0,external_wp_element_namespaceObject.createElement)("figure", external_wp_blockEditor_namespaceObject.useBlockProps.save({
19706        className: classes
19707      }), figure);
19708    }
19709  
19710  }, {
19711    attributes: image_deprecated_blockAttributes,
19712  
19713    save(_ref2) {
19714      let {
19715        attributes
19716      } = _ref2;
19717      const {
19718        url,
19719        alt,
19720        caption,
19721        align,
19722        href,
19723        width,
19724        height,
19725        id
19726      } = attributes;
19727      const classes = classnames_default()({
19728        [`align$align}`]: align,
19729        'is-resized': width || height
19730      });
19731      const image = (0,external_wp_element_namespaceObject.createElement)("img", {
19732        src: url,
19733        alt: alt,
19734        className: id ? `wp-image-$id}` : null,
19735        width: width,
19736        height: height
19737      });
19738      return (0,external_wp_element_namespaceObject.createElement)("figure", {
19739        className: classes
19740      }, href ? (0,external_wp_element_namespaceObject.createElement)("a", {
19741        href: href
19742      }, image) : image, !external_wp_blockEditor_namespaceObject.RichText.isEmpty(caption) && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
19743        tagName: "figcaption",
19744        value: caption
19745      }));
19746    }
19747  
19748  }, {
19749    attributes: image_deprecated_blockAttributes,
19750  
19751    save(_ref3) {
19752      let {
19753        attributes
19754      } = _ref3;
19755      const {
19756        url,
19757        alt,
19758        caption,
19759        align,
19760        href,
19761        width,
19762        height,
19763        id
19764      } = attributes;
19765      const image = (0,external_wp_element_namespaceObject.createElement)("img", {
19766        src: url,
19767        alt: alt,
19768        className: id ? `wp-image-$id}` : null,
19769        width: width,
19770        height: height
19771      });
19772      return (0,external_wp_element_namespaceObject.createElement)("figure", {
19773        className: align ? `align$align}` : null
19774      }, href ? (0,external_wp_element_namespaceObject.createElement)("a", {
19775        href: href
19776      }, image) : image, !external_wp_blockEditor_namespaceObject.RichText.isEmpty(caption) && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
19777        tagName: "figcaption",
19778        value: caption
19779      }));
19780    }
19781  
19782  }, {
19783    attributes: image_deprecated_blockAttributes,
19784  
19785    save(_ref4) {
19786      let {
19787        attributes
19788      } = _ref4;
19789      const {
19790        url,
19791        alt,
19792        caption,
19793        align,
19794        href,
19795        width,
19796        height
19797      } = attributes;
19798      const extraImageProps = width || height ? {
19799        width,
19800        height
19801      } : {};
19802      const image = (0,external_wp_element_namespaceObject.createElement)("img", _extends({
19803        src: url,
19804        alt: alt
19805      }, extraImageProps));
19806      let figureStyle = {};
19807  
19808      if (width) {
19809        figureStyle = {
19810          width
19811        };
19812      } else if (align === 'left' || align === 'right') {
19813        figureStyle = {
19814          maxWidth: '50%'
19815        };
19816      }
19817  
19818      return (0,external_wp_element_namespaceObject.createElement)("figure", {
19819        className: align ? `align$align}` : null,
19820        style: figureStyle
19821      }, href ? (0,external_wp_element_namespaceObject.createElement)("a", {
19822        href: href
19823      }, image) : image, !external_wp_blockEditor_namespaceObject.RichText.isEmpty(caption) && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
19824        tagName: "figcaption",
19825        value: caption
19826      }));
19827    }
19828  
19829  }];
19830  /* harmony default export */ var image_deprecated = (image_deprecated_deprecated);
19831  
19832  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/crop.js
19833  
19834  
19835  /**
19836   * WordPress dependencies
19837   */
19838  
19839  const crop = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
19840    xmlns: "http://www.w3.org/2000/svg",
19841    viewBox: "0 0 24 24"
19842  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
19843    d: "M16.5 7.8v7H18v-7c0-1-.8-1.8-1.8-1.8h-7v1.5h7c.2 0 .3.1.3.3zm-8.7 8.7c-.1 0-.2-.1-.2-.2V2H6v4H2v1.5h4v8.8c0 1 .8 1.8 1.8 1.8h8.8v4H18v-4h4v-1.5H7.8z"
19844  }));
19845  /* harmony default export */ var library_crop = (crop);
19846  
19847  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/upload.js
19848  
19849  
19850  /**
19851   * WordPress dependencies
19852   */
19853  
19854  const upload = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
19855    xmlns: "http://www.w3.org/2000/svg",
19856    viewBox: "0 0 24 24"
19857  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
19858    d: "M18.5 15v3.5H13V6.7l4.5 4.1 1-1.1-6.2-5.8-5.8 5.8 1 1.1 4-4v11.7h-6V15H4v5h16v-5z"
19859  }));
19860  /* harmony default export */ var library_upload = (upload);
19861  
19862  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/overlay-text.js
19863  
19864  
19865  /**
19866   * WordPress dependencies
19867   */
19868  
19869  const overlayText = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
19870    xmlns: "http://www.w3.org/2000/svg",
19871    viewBox: "0 0 24 24"
19872  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
19873    d: "M18 4H6c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h12-9.8c.4 0 .8-.3.9-.7l1.1-3h3.6l.5 1.7h1.9L13 9h-2.2l-3.4 9.5H6c-.3 0-.5-.2-.5-.5V6c0-.3.2-.5.5-.5h12c.3 0 .5.2.5.5v12H20V6c0-1.1-.9-2-2-2zm-6 7l1.4 3.9h-2.7L12 11z"
19874  }));
19875  /* harmony default export */ var overlay_text = (overlayText);
19876  
19877  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/image/use-client-width.js
19878  /**
19879   * WordPress dependencies
19880   */
19881  
19882  function useClientWidth(ref, dependencies) {
19883    const [clientWidth, setClientWidth] = (0,external_wp_element_namespaceObject.useState)();
19884  
19885    function calculateClientWidth() {
19886      setClientWidth(ref.current.clientWidth);
19887    }
19888  
19889    (0,external_wp_element_namespaceObject.useEffect)(calculateClientWidth, dependencies);
19890    (0,external_wp_element_namespaceObject.useEffect)(() => {
19891      const {
19892        defaultView
19893      } = ref.current.ownerDocument;
19894      defaultView.addEventListener('resize', calculateClientWidth);
19895      return () => {
19896        defaultView.removeEventListener('resize', calculateClientWidth);
19897      };
19898    }, []);
19899    return clientWidth;
19900  }
19901  
19902  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/image/image.js
19903  
19904  
19905  /**
19906   * External dependencies
19907   */
19908  
19909  /**
19910   * WordPress dependencies
19911   */
19912  
19913  
19914  
19915  
19916  
19917  
19918  
19919  
19920  
19921  
19922  
19923  
19924  
19925  /**
19926   * Internal dependencies
19927   */
19928  
19929  
19930  
19931  
19932  /**
19933   * Module constants
19934   */
19935  
19936  
19937  function Image(_ref) {
19938    var _imageRef$current3;
19939  
19940    let {
19941      temporaryURL,
19942      attributes: {
19943        url = '',
19944        alt,
19945        caption,
19946        align,
19947        id,
19948        href,
19949        rel,
19950        linkClass,
19951        linkDestination,
19952        title,
19953        width,
19954        height,
19955        linkTarget,
19956        sizeSlug
19957      },
19958      setAttributes,
19959      isSelected,
19960      insertBlocksAfter,
19961      onReplace,
19962      onCloseModal,
19963      onSelectImage,
19964      onSelectURL,
19965      onUploadError,
19966      containerRef,
19967      context,
19968      clientId,
19969      onImageLoadError
19970    } = _ref;
19971    const imageRef = (0,external_wp_element_namespaceObject.useRef)();
19972    const captionRef = (0,external_wp_element_namespaceObject.useRef)();
19973    const prevUrl = (0,external_wp_compose_namespaceObject.usePrevious)(url);
19974    const {
19975      allowResize = true
19976    } = context;
19977    const {
19978      getBlock
19979    } = (0,external_wp_data_namespaceObject.useSelect)(external_wp_blockEditor_namespaceObject.store);
19980    const {
19981      image,
19982      multiImageSelection
19983    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
19984      const {
19985        getMedia
19986      } = select(external_wp_coreData_namespaceObject.store);
19987      const {
19988        getMultiSelectedBlockClientIds,
19989        getBlockName
19990      } = select(external_wp_blockEditor_namespaceObject.store);
19991      const multiSelectedClientIds = getMultiSelectedBlockClientIds();
19992      return {
19993        image: id && isSelected ? getMedia(id, {
19994          context: 'view'
19995        }) : null,
19996        multiImageSelection: multiSelectedClientIds.length && multiSelectedClientIds.every(_clientId => getBlockName(_clientId) === 'core/image')
19997      };
19998    }, [id, isSelected]);
19999    const {
20000      canInsertCover,
20001      imageEditing,
20002      imageSizes,
20003      maxWidth,
20004      mediaUpload
20005    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
20006      const {
20007        getBlockRootClientId,
20008        getSettings,
20009        canInsertBlockType
20010      } = select(external_wp_blockEditor_namespaceObject.store);
20011      const rootClientId = getBlockRootClientId(clientId);
20012      const settings = (0,external_lodash_namespaceObject.pick)(getSettings(), ['imageEditing', 'imageSizes', 'maxWidth', 'mediaUpload']);
20013      return { ...settings,
20014        canInsertCover: canInsertBlockType('core/cover', rootClientId)
20015      };
20016    }, [clientId]);
20017    const {
20018      replaceBlocks,
20019      toggleSelection
20020    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_blockEditor_namespaceObject.store);
20021    const {
20022      createErrorNotice,
20023      createSuccessNotice
20024    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_notices_namespaceObject.store);
20025    const isLargeViewport = (0,external_wp_compose_namespaceObject.useViewportMatch)('medium');
20026    const isWideAligned = (0,external_lodash_namespaceObject.includes)(['wide', 'full'], align);
20027    const [{
20028      loadedNaturalWidth,
20029      loadedNaturalHeight
20030    }, setLoadedNaturalSize] = (0,external_wp_element_namespaceObject.useState)({});
20031    const [isEditingImage, setIsEditingImage] = (0,external_wp_element_namespaceObject.useState)(false);
20032    const [externalBlob, setExternalBlob] = (0,external_wp_element_namespaceObject.useState)();
20033    const clientWidth = useClientWidth(containerRef, [align]);
20034    const isResizable = allowResize && !(isWideAligned && isLargeViewport);
20035    const imageSizeOptions = (0,external_lodash_namespaceObject.map)((0,external_lodash_namespaceObject.filter)(imageSizes, _ref2 => {
20036      let {
20037        slug
20038      } = _ref2;
20039      return (0,external_lodash_namespaceObject.get)(image, ['media_details', 'sizes', slug, 'source_url']);
20040    }), _ref3 => {
20041      let {
20042        name,
20043        slug
20044      } = _ref3;
20045      return {
20046        value: slug,
20047        label: name
20048      };
20049    }); // If an image is externally hosted, try to fetch the image data. This may
20050    // fail if the image host doesn't allow CORS with the domain. If it works,
20051    // we can enable a button in the toolbar to upload the image.
20052  
20053    (0,external_wp_element_namespaceObject.useEffect)(() => {
20054      if (!isExternalImage(id, url) || !isSelected || externalBlob) {
20055        return;
20056      }
20057  
20058      window.fetch(url).then(response => response.blob()).then(blob => setExternalBlob(blob)) // Do nothing, cannot upload.
20059      .catch(() => {});
20060    }, [id, url, isSelected, externalBlob]); // Focus the caption after inserting an image from the placeholder. This is
20061    // done to preserve the behaviour of focussing the first tabbable element
20062    // when a block is mounted. Previously, the image block would remount when
20063    // the placeholder is removed. Maybe this behaviour could be removed.
20064  
20065    (0,external_wp_element_namespaceObject.useEffect)(() => {
20066      if (url && !prevUrl && isSelected) {
20067        captionRef.current.focus();
20068      }
20069    }, [url, prevUrl]); // Get naturalWidth and naturalHeight from image ref, and fall back to loaded natural
20070    // width and height. This resolves an issue in Safari where the loaded natural
20071    // witdth and height is otherwise lost when switching between alignments.
20072    // See: https://github.com/WordPress/gutenberg/pull/37210.
20073  
20074    const {
20075      naturalWidth,
20076      naturalHeight
20077    } = (0,external_wp_element_namespaceObject.useMemo)(() => {
20078      var _imageRef$current, _imageRef$current2;
20079  
20080      return {
20081        naturalWidth: ((_imageRef$current = imageRef.current) === null || _imageRef$current === void 0 ? void 0 : _imageRef$current.naturalWidth) || loadedNaturalWidth || undefined,
20082        naturalHeight: ((_imageRef$current2 = imageRef.current) === null || _imageRef$current2 === void 0 ? void 0 : _imageRef$current2.naturalHeight) || loadedNaturalHeight || undefined
20083      };
20084    }, [loadedNaturalWidth, loadedNaturalHeight, (_imageRef$current3 = imageRef.current) === null || _imageRef$current3 === void 0 ? void 0 : _imageRef$current3.complete]);
20085  
20086    function onResizeStart() {
20087      toggleSelection(false);
20088    }
20089  
20090    function onResizeStop() {
20091      toggleSelection(true);
20092    }
20093  
20094    function onImageError() {
20095      // Check if there's an embed block that handles this URL, e.g., instagram URL.
20096      // See: https://github.com/WordPress/gutenberg/pull/11472
20097      const embedBlock = createUpgradedEmbedBlock({
20098        attributes: {
20099          url
20100        }
20101      });
20102      const shouldReplace = undefined !== embedBlock;
20103  
20104      if (shouldReplace) {
20105        onReplace(embedBlock);
20106      }
20107  
20108      onImageLoadError(shouldReplace);
20109    }
20110  
20111    function onSetHref(props) {
20112      setAttributes(props);
20113    }
20114  
20115    function onSetTitle(value) {
20116      // This is the HTML title attribute, separate from the media object
20117      // title.
20118      setAttributes({
20119        title: value
20120      });
20121    }
20122  
20123    function updateAlt(newAlt) {
20124      setAttributes({
20125        alt: newAlt
20126      });
20127    }
20128  
20129    function updateImage(newSizeSlug) {
20130      const newUrl = (0,external_lodash_namespaceObject.get)(image, ['media_details', 'sizes', newSizeSlug, 'source_url']);
20131  
20132      if (!newUrl) {
20133        return null;
20134      }
20135  
20136      setAttributes({
20137        url: newUrl,
20138        width: undefined,
20139        height: undefined,
20140        sizeSlug: newSizeSlug
20141      });
20142    }
20143  
20144    function uploadExternal() {
20145      mediaUpload({
20146        filesList: [externalBlob],
20147  
20148        onFileChange(_ref4) {
20149          let [img] = _ref4;
20150          onSelectImage(img);
20151  
20152          if ((0,external_wp_blob_namespaceObject.isBlobURL)(img.url)) {
20153            return;
20154          }
20155  
20156          setExternalBlob();
20157          createSuccessNotice((0,external_wp_i18n_namespaceObject.__)('Image uploaded.'), {
20158            type: 'snackbar'
20159          });
20160        },
20161  
20162        allowedTypes: constants_ALLOWED_MEDIA_TYPES,
20163  
20164        onError(message) {
20165          createErrorNotice(message, {
20166            type: 'snackbar'
20167          });
20168        }
20169  
20170      });
20171    }
20172  
20173    function updateAlignment(nextAlign) {
20174      const extraUpdatedAttributes = ['wide', 'full'].includes(nextAlign) ? {
20175        width: undefined,
20176        height: undefined
20177      } : {};
20178      setAttributes({ ...extraUpdatedAttributes,
20179        align: nextAlign
20180      });
20181    }
20182  
20183    (0,external_wp_element_namespaceObject.useEffect)(() => {
20184      if (!isSelected) {
20185        setIsEditingImage(false);
20186      }
20187  
20188      if (isSelected && isMediaDestroyed(id)) {
20189        onImageLoadError();
20190      }
20191    }, [isSelected]);
20192    const canEditImage = id && naturalWidth && naturalHeight && imageEditing;
20193    const allowCrop = !multiImageSelection && canEditImage && !isEditingImage;
20194  
20195    function switchToCover() {
20196      replaceBlocks(clientId, (0,external_wp_blocks_namespaceObject.switchToBlockType)(getBlock(clientId), 'core/cover'));
20197    }
20198  
20199    const controls = (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, {
20200      group: "block"
20201    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockAlignmentControl, {
20202      value: align,
20203      onChange: updateAlignment
20204    }), !multiImageSelection && !isEditingImage && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.__experimentalImageURLInputUI, {
20205      url: href || '',
20206      onChangeUrl: onSetHref,
20207      linkDestination: linkDestination,
20208      mediaUrl: image && image.source_url || url,
20209      mediaLink: image && image.link,
20210      linkTarget: linkTarget,
20211      linkClass: linkClass,
20212      rel: rel
20213    }), allowCrop && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, {
20214      onClick: () => setIsEditingImage(true),
20215      icon: library_crop,
20216      label: (0,external_wp_i18n_namespaceObject.__)('Crop')
20217    }), externalBlob && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, {
20218      onClick: uploadExternal,
20219      icon: library_upload,
20220      label: (0,external_wp_i18n_namespaceObject.__)('Upload external image')
20221    }), !multiImageSelection && canInsertCover && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, {
20222      icon: overlay_text,
20223      label: (0,external_wp_i18n_namespaceObject.__)('Add text over image'),
20224      onClick: switchToCover
20225    })), !multiImageSelection && !isEditingImage && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, {
20226      group: "other"
20227    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.MediaReplaceFlow, {
20228      mediaId: id,
20229      mediaURL: url,
20230      allowedTypes: constants_ALLOWED_MEDIA_TYPES,
20231      accept: "image/*",
20232      onSelect: onSelectImage,
20233      onSelectURL: onSelectURL,
20234      onError: onUploadError,
20235      onCloseModal: onCloseModal
20236    })), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
20237      title: (0,external_wp_i18n_namespaceObject.__)('Image settings')
20238    }, !multiImageSelection && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TextareaControl, {
20239      label: (0,external_wp_i18n_namespaceObject.__)('Alt text (alternative text)'),
20240      value: alt,
20241      onChange: updateAlt,
20242      help: (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ExternalLink, {
20243        href: "https://www.w3.org/WAI/tutorials/images/decision-tree"
20244      }, (0,external_wp_i18n_namespaceObject.__)('Describe the purpose of the image')), (0,external_wp_i18n_namespaceObject.__)('Leave empty if the image is purely decorative.'))
20245    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.__experimentalImageSizeControl, {
20246      onChangeImage: updateImage,
20247      onChange: value => setAttributes(value),
20248      slug: sizeSlug,
20249      width: width,
20250      height: height,
20251      imageSizeOptions: imageSizeOptions,
20252      isResizable: isResizable,
20253      imageWidth: naturalWidth,
20254      imageHeight: naturalHeight
20255    }))), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, {
20256      __experimentalGroup: "advanced"
20257    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TextControl, {
20258      label: (0,external_wp_i18n_namespaceObject.__)('Title attribute'),
20259      value: title || '',
20260      onChange: onSetTitle,
20261      help: (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_i18n_namespaceObject.__)('Describe the role of this image on the page.'), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ExternalLink, {
20262        href: "https://www.w3.org/TR/html52/dom.html#the-title-attribute"
20263      }, (0,external_wp_i18n_namespaceObject.__)('(Note: many devices and browsers do not display this text.)')))
20264    })));
20265    const filename = (0,external_wp_url_namespaceObject.getFilename)(url);
20266    let defaultedAlt;
20267  
20268    if (alt) {
20269      defaultedAlt = alt;
20270    } else if (filename) {
20271      defaultedAlt = (0,external_wp_i18n_namespaceObject.sprintf)(
20272      /* translators: %s: file name */
20273      (0,external_wp_i18n_namespaceObject.__)('This image has an empty alt attribute; its file name is %s'), filename);
20274    } else {
20275      defaultedAlt = (0,external_wp_i18n_namespaceObject.__)('This image has an empty alt attribute');
20276    }
20277  
20278    let img = // Disable reason: Image itself is not meant to be interactive, but
20279    // should direct focus to block.
20280  
20281    /* eslint-disable jsx-a11y/no-noninteractive-element-interactions, jsx-a11y/click-events-have-key-events */
20282    (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)("img", {
20283      src: temporaryURL || url,
20284      alt: defaultedAlt,
20285      onError: () => onImageError(),
20286      onLoad: event => {
20287        var _event$target, _event$target2;
20288  
20289        setLoadedNaturalSize({
20290          loadedNaturalWidth: (_event$target = event.target) === null || _event$target === void 0 ? void 0 : _event$target.naturalWidth,
20291          loadedNaturalHeight: (_event$target2 = event.target) === null || _event$target2 === void 0 ? void 0 : _event$target2.naturalHeight
20292        });
20293      },
20294      ref: imageRef
20295    }), temporaryURL && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Spinner, null))
20296    /* eslint-enable jsx-a11y/no-noninteractive-element-interactions, jsx-a11y/click-events-have-key-events */
20297    ;
20298    let imageWidthWithinContainer;
20299    let imageHeightWithinContainer;
20300  
20301    if (clientWidth && naturalWidth && naturalHeight) {
20302      const exceedMaxWidth = naturalWidth > clientWidth;
20303      const ratio = naturalHeight / naturalWidth;
20304      imageWidthWithinContainer = exceedMaxWidth ? clientWidth : naturalWidth;
20305      imageHeightWithinContainer = exceedMaxWidth ? clientWidth * ratio : naturalHeight;
20306    }
20307  
20308    if (canEditImage && isEditingImage) {
20309      img = (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.__experimentalImageEditor, {
20310        url: url,
20311        width: width,
20312        height: height,
20313        clientWidth: clientWidth,
20314        naturalHeight: naturalHeight,
20315        naturalWidth: naturalWidth
20316      });
20317    } else if (!isResizable || !imageWidthWithinContainer) {
20318      img = (0,external_wp_element_namespaceObject.createElement)("div", {
20319        style: {
20320          width,
20321          height
20322        }
20323      }, img);
20324    } else {
20325      const currentWidth = width || imageWidthWithinContainer;
20326      const currentHeight = height || imageHeightWithinContainer;
20327      const ratio = naturalWidth / naturalHeight;
20328      const minWidth = naturalWidth < naturalHeight ? MIN_SIZE : MIN_SIZE * ratio;
20329      const minHeight = naturalHeight < naturalWidth ? MIN_SIZE : MIN_SIZE / ratio; // With the current implementation of ResizableBox, an image needs an
20330      // explicit pixel value for the max-width. In absence of being able to
20331      // set the content-width, this max-width is currently dictated by the
20332      // vanilla editor style. The following variable adds a buffer to this
20333      // vanilla style, so 3rd party themes have some wiggleroom. This does,
20334      // in most cases, allow you to scale the image beyond the width of the
20335      // main column, though not infinitely.
20336      // @todo It would be good to revisit this once a content-width variable
20337      // becomes available.
20338  
20339      const maxWidthBuffer = maxWidth * 2.5;
20340      let showRightHandle = false;
20341      let showLeftHandle = false;
20342      /* eslint-disable no-lonely-if */
20343      // See https://github.com/WordPress/gutenberg/issues/7584.
20344  
20345      if (align === 'center') {
20346        // When the image is centered, show both handles.
20347        showRightHandle = true;
20348        showLeftHandle = true;
20349      } else if ((0,external_wp_i18n_namespaceObject.isRTL)()) {
20350        // In RTL mode the image is on the right by default.
20351        // Show the right handle and hide the left handle only when it is
20352        // aligned left. Otherwise always show the left handle.
20353        if (align === 'left') {
20354          showRightHandle = true;
20355        } else {
20356          showLeftHandle = true;
20357        }
20358      } else {
20359        // Show the left handle and hide the right handle only when the
20360        // image is aligned right. Otherwise always show the right handle.
20361        if (align === 'right') {
20362          showLeftHandle = true;
20363        } else {
20364          showRightHandle = true;
20365        }
20366      }
20367      /* eslint-enable no-lonely-if */
20368  
20369  
20370      img = (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ResizableBox, {
20371        size: {
20372          width: width !== null && width !== void 0 ? width : 'auto',
20373          height: height !== null && height !== void 0 ? height : 'auto'
20374        },
20375        showHandle: isSelected,
20376        minWidth: minWidth,
20377        maxWidth: maxWidthBuffer,
20378        minHeight: minHeight,
20379        maxHeight: maxWidthBuffer / ratio,
20380        lockAspectRatio: true,
20381        enable: {
20382          top: false,
20383          right: showRightHandle,
20384          bottom: true,
20385          left: showLeftHandle
20386        },
20387        onResizeStart: onResizeStart,
20388        onResizeStop: (event, direction, elt, delta) => {
20389          onResizeStop();
20390          setAttributes({
20391            width: parseInt(currentWidth + delta.width, 10),
20392            height: parseInt(currentHeight + delta.height, 10)
20393          });
20394        }
20395      }, img);
20396    }
20397  
20398    return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.__experimentalImageEditingProvider, {
20399      id: id,
20400      url: url,
20401      naturalWidth: naturalWidth,
20402      naturalHeight: naturalHeight,
20403      clientWidth: clientWidth,
20404      onSaveImage: imageAttributes => setAttributes(imageAttributes),
20405      isEditing: isEditingImage,
20406      onFinishEditing: () => setIsEditingImage(false)
20407    }, !temporaryURL && controls, img, (!external_wp_blockEditor_namespaceObject.RichText.isEmpty(caption) || isSelected) && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText, {
20408      ref: captionRef,
20409      tagName: "figcaption",
20410      "aria-label": (0,external_wp_i18n_namespaceObject.__)('Image caption text'),
20411      placeholder: (0,external_wp_i18n_namespaceObject.__)('Add caption'),
20412      value: caption,
20413      onChange: value => setAttributes({
20414        caption: value
20415      }),
20416      inlineToolbar: true,
20417      __unstableOnSplitAtEnd: () => insertBlocksAfter((0,external_wp_blocks_namespaceObject.createBlock)('core/paragraph'))
20418    }));
20419  }
20420  
20421  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/image/edit.js
20422  
20423  
20424  /**
20425   * External dependencies
20426   */
20427  
20428  
20429  /**
20430   * WordPress dependencies
20431   */
20432  
20433  
20434  
20435  
20436  
20437  
20438  
20439  
20440  /* global wp */
20441  
20442  /**
20443   * Internal dependencies
20444   */
20445  
20446  
20447  /**
20448   * Module constants
20449   */
20450  
20451  
20452  const edit_pickRelevantMediaFiles = (image, size) => {
20453    const imageProps = (0,external_lodash_namespaceObject.pick)(image, ['alt', 'id', 'link', 'caption']);
20454    imageProps.url = (0,external_lodash_namespaceObject.get)(image, ['sizes', size, 'url']) || (0,external_lodash_namespaceObject.get)(image, ['media_details', 'sizes', size, 'source_url']) || image.url;
20455    return imageProps;
20456  };
20457  /**
20458   * Is the URL a temporary blob URL? A blob URL is one that is used temporarily
20459   * while the image is being uploaded and will not have an id yet allocated.
20460   *
20461   * @param {number=} id  The id of the image.
20462   * @param {string=} url The url of the image.
20463   *
20464   * @return {boolean} Is the URL a Blob URL
20465   */
20466  
20467  const edit_isTemporaryImage = (id, url) => !id && (0,external_wp_blob_namespaceObject.isBlobURL)(url);
20468  /**
20469   * Is the url for the image hosted externally. An externally hosted image has no
20470   * id and is not a blob url.
20471   *
20472   * @param {number=} id  The id of the image.
20473   * @param {string=} url The url of the image.
20474   *
20475   * @return {boolean} Is the url an externally hosted url?
20476   */
20477  
20478  
20479  const isExternalImage = (id, url) => url && !id && !(0,external_wp_blob_namespaceObject.isBlobURL)(url);
20480  /**
20481   * Checks if WP generated default image size. Size generation is skipped
20482   * when the image is smaller than the said size.
20483   *
20484   * @param {Object} image
20485   * @param {string} defaultSize
20486   *
20487   * @return {boolean} Whether or not it has default image size.
20488   */
20489  
20490  function hasDefaultSize(image, defaultSize) {
20491    return (0,external_lodash_namespaceObject.has)(image, ['sizes', defaultSize, 'url']) || (0,external_lodash_namespaceObject.has)(image, ['media_details', 'sizes', defaultSize, 'source_url']);
20492  }
20493  /**
20494   * Checks if a media attachment object has been "destroyed",
20495   * that is, removed from the media library. The core Media Library
20496   * adds a `destroyed` property to a deleted attachment object in the media collection.
20497   *
20498   * @param {number} id The attachment id.
20499   *
20500   * @return {boolean} Whether the image has been destroyed.
20501   */
20502  
20503  
20504  function isMediaDestroyed(id) {
20505    var _wp, _wp$media;
20506  
20507    const attachment = ((_wp = wp) === null || _wp === void 0 ? void 0 : (_wp$media = _wp.media) === null || _wp$media === void 0 ? void 0 : _wp$media.attachment(id)) || {};
20508    return attachment.destroyed;
20509  }
20510  function ImageEdit(_ref) {
20511    let {
20512      attributes,
20513      setAttributes,
20514      isSelected,
20515      className,
20516      noticeUI,
20517      insertBlocksAfter,
20518      noticeOperations,
20519      onReplace,
20520      context,
20521      clientId
20522    } = _ref;
20523    const {
20524      url = '',
20525      alt,
20526      caption,
20527      align,
20528      id,
20529      width,
20530      height,
20531      sizeSlug
20532    } = attributes;
20533    const [temporaryURL, setTemporaryURL] = (0,external_wp_element_namespaceObject.useState)();
20534    const altRef = (0,external_wp_element_namespaceObject.useRef)();
20535    (0,external_wp_element_namespaceObject.useEffect)(() => {
20536      altRef.current = alt;
20537    }, [alt]);
20538    const captionRef = (0,external_wp_element_namespaceObject.useRef)();
20539    (0,external_wp_element_namespaceObject.useEffect)(() => {
20540      captionRef.current = caption;
20541    }, [caption]);
20542    const ref = (0,external_wp_element_namespaceObject.useRef)();
20543    const {
20544      imageDefaultSize,
20545      mediaUpload
20546    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
20547      const {
20548        getSettings
20549      } = select(external_wp_blockEditor_namespaceObject.store);
20550      return (0,external_lodash_namespaceObject.pick)(getSettings(), ['imageDefaultSize', 'mediaUpload']);
20551    }, []); // A callback passed to MediaUpload,
20552    // fired when the media modal closes.
20553  
20554    function onCloseModal() {
20555      if (isMediaDestroyed(attributes === null || attributes === void 0 ? void 0 : attributes.id)) {
20556        setAttributes({
20557          url: undefined,
20558          id: undefined
20559        });
20560      }
20561    }
20562    /*
20563         Runs an error callback if the image does not load.
20564         If the error callback is triggered, we infer that that image
20565         has been deleted.
20566    */
20567  
20568  
20569    function onImageError() {
20570      let isReplaced = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;
20571  
20572      // If the image block was not replaced with an embed,
20573      // clear the attributes and trigger the placeholder.
20574      if (!isReplaced) {
20575        setAttributes({
20576          url: undefined,
20577          id: undefined
20578        });
20579      }
20580    }
20581  
20582    function onUploadError(message) {
20583      noticeOperations.removeAllNotices();
20584      noticeOperations.createErrorNotice(message);
20585      setAttributes({
20586        src: undefined,
20587        id: undefined,
20588        url: undefined
20589      });
20590      setTemporaryURL(undefined);
20591    }
20592  
20593    function onSelectImage(media) {
20594      var _wp2, _wp2$media, _wp2$media$view, _wp2$media$view$setti, _wp2$media$view$setti2;
20595  
20596      if (!media || !media.url) {
20597        setAttributes({
20598          url: undefined,
20599          alt: undefined,
20600          id: undefined,
20601          title: undefined,
20602          caption: undefined
20603        });
20604        return;
20605      }
20606  
20607      if ((0,external_wp_blob_namespaceObject.isBlobURL)(media.url)) {
20608        setTemporaryURL(media.url);
20609        return;
20610      }
20611  
20612      setTemporaryURL();
20613      let mediaAttributes = edit_pickRelevantMediaFiles(media, imageDefaultSize); // If a caption text was meanwhile written by the user,
20614      // make sure the text is not overwritten by empty captions.
20615  
20616      if (captionRef.current && !(0,external_lodash_namespaceObject.get)(mediaAttributes, ['caption'])) {
20617        mediaAttributes = (0,external_lodash_namespaceObject.omit)(mediaAttributes, ['caption']);
20618      }
20619  
20620      let additionalAttributes; // Reset the dimension attributes if changing to a different image.
20621  
20622      if (!media.id || media.id !== id) {
20623        additionalAttributes = {
20624          width: undefined,
20625          height: undefined,
20626          // Fallback to size "full" if there's no default image size.
20627          // It means the image is smaller, and the block will use a full-size URL.
20628          sizeSlug: hasDefaultSize(media, imageDefaultSize) ? imageDefaultSize : 'full'
20629        };
20630      } else {
20631        // Keep the same url when selecting the same file, so "Image Size"
20632        // option is not changed.
20633        additionalAttributes = {
20634          url
20635        };
20636      } // Check if default link setting should be used.
20637  
20638  
20639      let linkDestination = attributes.linkDestination;
20640  
20641      if (!linkDestination) {
20642        // Use the WordPress option to determine the proper default.
20643        // The constants used in Gutenberg do not match WP options so a little more complicated than ideal.
20644        // TODO: fix this in a follow up PR, requires updating media-text and ui component.
20645        switch (((_wp2 = wp) === null || _wp2 === void 0 ? void 0 : (_wp2$media = _wp2.media) === null || _wp2$media === void 0 ? void 0 : (_wp2$media$view = _wp2$media.view) === null || _wp2$media$view === void 0 ? void 0 : (_wp2$media$view$setti = _wp2$media$view.settings) === null || _wp2$media$view$setti === void 0 ? void 0 : (_wp2$media$view$setti2 = _wp2$media$view$setti.defaultProps) === null || _wp2$media$view$setti2 === void 0 ? void 0 : _wp2$media$view$setti2.link) || constants_LINK_DESTINATION_NONE) {
20646          case 'file':
20647          case constants_LINK_DESTINATION_MEDIA:
20648            linkDestination = constants_LINK_DESTINATION_MEDIA;
20649            break;
20650  
20651          case 'post':
20652          case constants_LINK_DESTINATION_ATTACHMENT:
20653            linkDestination = constants_LINK_DESTINATION_ATTACHMENT;
20654            break;
20655  
20656          case LINK_DESTINATION_CUSTOM:
20657            linkDestination = LINK_DESTINATION_CUSTOM;
20658            break;
20659  
20660          case constants_LINK_DESTINATION_NONE:
20661            linkDestination = constants_LINK_DESTINATION_NONE;
20662            break;
20663        }
20664      } // Check if the image is linked to it's media.
20665  
20666  
20667      let href;
20668  
20669      switch (linkDestination) {
20670        case constants_LINK_DESTINATION_MEDIA:
20671          href = media.url;
20672          break;
20673  
20674        case constants_LINK_DESTINATION_ATTACHMENT:
20675          href = media.link;
20676          break;
20677      }
20678  
20679      mediaAttributes.href = href;
20680      setAttributes({ ...mediaAttributes,
20681        ...additionalAttributes,
20682        linkDestination
20683      });
20684    }
20685  
20686    function onSelectURL(newURL) {
20687      if (newURL !== url) {
20688        setAttributes({
20689          url: newURL,
20690          id: undefined,
20691          width: undefined,
20692          height: undefined,
20693          sizeSlug: imageDefaultSize
20694        });
20695      }
20696    }
20697  
20698    function updateAlignment(nextAlign) {
20699      const extraUpdatedAttributes = ['wide', 'full'].includes(nextAlign) ? {
20700        width: undefined,
20701        height: undefined
20702      } : {};
20703      setAttributes({ ...extraUpdatedAttributes,
20704        align: nextAlign
20705      });
20706    }
20707  
20708    let isTemp = edit_isTemporaryImage(id, url); // Upload a temporary image on mount.
20709  
20710    (0,external_wp_element_namespaceObject.useEffect)(() => {
20711      if (!isTemp) {
20712        return;
20713      }
20714  
20715      const file = (0,external_wp_blob_namespaceObject.getBlobByURL)(url);
20716  
20717      if (file) {
20718        mediaUpload({
20719          filesList: [file],
20720          onFileChange: _ref2 => {
20721            let [img] = _ref2;
20722            onSelectImage(img);
20723          },
20724          allowedTypes: constants_ALLOWED_MEDIA_TYPES,
20725          onError: message => {
20726            isTemp = false;
20727            onUploadError(message);
20728          }
20729        });
20730      }
20731    }, []); // If an image is temporary, revoke the Blob url when it is uploaded (and is
20732    // no longer temporary).
20733  
20734    (0,external_wp_element_namespaceObject.useEffect)(() => {
20735      if (isTemp) {
20736        setTemporaryURL(url);
20737        return;
20738      }
20739  
20740      (0,external_wp_blob_namespaceObject.revokeBlobURL)(temporaryURL);
20741    }, [isTemp, url]);
20742    const isExternal = isExternalImage(id, url);
20743    const src = isExternal ? url : undefined;
20744    const mediaPreview = !!url && (0,external_wp_element_namespaceObject.createElement)("img", {
20745      alt: (0,external_wp_i18n_namespaceObject.__)('Edit image'),
20746      title: (0,external_wp_i18n_namespaceObject.__)('Edit image'),
20747      className: 'edit-image-preview',
20748      src: url
20749    });
20750    const classes = classnames_default()(className, {
20751      'is-transient': temporaryURL,
20752      'is-resized': !!width || !!height,
20753      [`size-$sizeSlug}`]: sizeSlug
20754    });
20755    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
20756      ref,
20757      className: classes
20758    });
20759    return (0,external_wp_element_namespaceObject.createElement)("figure", blockProps, (temporaryURL || url) && (0,external_wp_element_namespaceObject.createElement)(Image, {
20760      temporaryURL: temporaryURL,
20761      attributes: attributes,
20762      setAttributes: setAttributes,
20763      isSelected: isSelected,
20764      insertBlocksAfter: insertBlocksAfter,
20765      onReplace: onReplace,
20766      onSelectImage: onSelectImage,
20767      onSelectURL: onSelectURL,
20768      onUploadError: onUploadError,
20769      containerRef: ref,
20770      context: context,
20771      clientId: clientId,
20772      onCloseModal: onCloseModal,
20773      onImageLoadError: onImageError
20774    }), !url && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, {
20775      group: "block"
20776    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockAlignmentControl, {
20777      value: align,
20778      onChange: updateAlignment
20779    })), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.MediaPlaceholder, {
20780      icon: (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockIcon, {
20781        icon: library_image
20782      }),
20783      onSelect: onSelectImage,
20784      onSelectURL: onSelectURL,
20785      notices: noticeUI,
20786      onError: onUploadError,
20787      onClose: onCloseModal,
20788      accept: "image/*",
20789      allowedTypes: constants_ALLOWED_MEDIA_TYPES,
20790      value: {
20791        id,
20792        src
20793      },
20794      mediaPreview: mediaPreview,
20795      disableMediaButtons: temporaryURL || url
20796    }));
20797  }
20798  /* harmony default export */ var image_edit = ((0,external_wp_components_namespaceObject.withNotices)(ImageEdit));
20799  
20800  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/image/save.js
20801  
20802  
20803  /**
20804   * External dependencies
20805   */
20806  
20807  
20808  /**
20809   * WordPress dependencies
20810   */
20811  
20812  
20813  function image_save_save(_ref) {
20814    let {
20815      attributes
20816    } = _ref;
20817    const {
20818      url,
20819      alt,
20820      caption,
20821      align,
20822      href,
20823      rel,
20824      linkClass,
20825      width,
20826      height,
20827      id,
20828      linkTarget,
20829      sizeSlug,
20830      title
20831    } = attributes;
20832    const newRel = (0,external_lodash_namespaceObject.isEmpty)(rel) ? undefined : rel;
20833    const classes = classnames_default()({
20834      [`align$align}`]: align,
20835      [`size-$sizeSlug}`]: sizeSlug,
20836      'is-resized': width || height
20837    });
20838    const image = (0,external_wp_element_namespaceObject.createElement)("img", {
20839      src: url,
20840      alt: alt,
20841      className: id ? `wp-image-$id}` : null,
20842      width: width,
20843      height: height,
20844      title: title
20845    });
20846    const figure = (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, href ? (0,external_wp_element_namespaceObject.createElement)("a", {
20847      className: linkClass,
20848      href: href,
20849      target: linkTarget,
20850      rel: newRel
20851    }, image) : image, !external_wp_blockEditor_namespaceObject.RichText.isEmpty(caption) && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
20852      tagName: "figcaption",
20853      value: caption
20854    }));
20855    return (0,external_wp_element_namespaceObject.createElement)("figure", external_wp_blockEditor_namespaceObject.useBlockProps.save({
20856      className: classes
20857    }), figure);
20858  }
20859  
20860  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/image/transforms.js
20861  /**
20862   * External dependencies
20863   */
20864  
20865  /**
20866   * WordPress dependencies
20867   */
20868  
20869  
20870  
20871  
20872  
20873  
20874  function stripFirstImage(attributes, _ref) {
20875    let {
20876      shortcode
20877    } = _ref;
20878    const {
20879      body
20880    } = document.implementation.createHTMLDocument('');
20881    body.innerHTML = shortcode.content;
20882    let nodeToRemove = body.querySelector('img'); // If an image has parents, find the topmost node to remove.
20883  
20884    while (nodeToRemove && nodeToRemove.parentNode && nodeToRemove.parentNode !== body) {
20885      nodeToRemove = nodeToRemove.parentNode;
20886    }
20887  
20888    if (nodeToRemove) {
20889      nodeToRemove.parentNode.removeChild(nodeToRemove);
20890    }
20891  
20892    return body.innerHTML.trim();
20893  }
20894  
20895  function getFirstAnchorAttributeFormHTML(html, attributeName) {
20896    const {
20897      body
20898    } = document.implementation.createHTMLDocument('');
20899    body.innerHTML = html;
20900    const {
20901      firstElementChild
20902    } = body;
20903  
20904    if (firstElementChild && firstElementChild.nodeName === 'A') {
20905      return firstElementChild.getAttribute(attributeName) || undefined;
20906    }
20907  }
20908  
20909  const imageSchema = {
20910    img: {
20911      attributes: ['src', 'alt', 'title'],
20912      classes: ['alignleft', 'aligncenter', 'alignright', 'alignnone', /^wp-image-\d+$/]
20913    }
20914  };
20915  
20916  const schema = _ref2 => {
20917    let {
20918      phrasingContentSchema
20919    } = _ref2;
20920    return {
20921      figure: {
20922        require: ['img'],
20923        children: { ...imageSchema,
20924          a: {
20925            attributes: ['href', 'rel', 'target'],
20926            children: imageSchema
20927          },
20928          figcaption: {
20929            children: phrasingContentSchema
20930          }
20931        }
20932      }
20933    };
20934  };
20935  
20936  const image_transforms_transforms = {
20937    from: [{
20938      type: 'raw',
20939      isMatch: node => node.nodeName === 'FIGURE' && !!node.querySelector('img'),
20940      schema,
20941      transform: node => {
20942        // Search both figure and image classes. Alignment could be
20943        // set on either. ID is set on the image.
20944        const className = node.className + ' ' + node.querySelector('img').className;
20945        const alignMatches = /(?:^|\s)align(left|center|right)(?:$|\s)/.exec(className);
20946        const anchor = node.id === '' ? undefined : node.id;
20947        const align = alignMatches ? alignMatches[1] : undefined;
20948        const idMatches = /(?:^|\s)wp-image-(\d+)(?:$|\s)/.exec(className);
20949        const id = idMatches ? Number(idMatches[1]) : undefined;
20950        const anchorElement = node.querySelector('a');
20951        const linkDestination = anchorElement && anchorElement.href ? 'custom' : undefined;
20952        const href = anchorElement && anchorElement.href ? anchorElement.href : undefined;
20953        const rel = anchorElement && anchorElement.rel ? anchorElement.rel : undefined;
20954        const linkClass = anchorElement && anchorElement.className ? anchorElement.className : undefined;
20955        const attributes = (0,external_wp_blocks_namespaceObject.getBlockAttributes)('core/image', node.outerHTML, {
20956          align,
20957          id,
20958          linkDestination,
20959          href,
20960          rel,
20961          linkClass,
20962          anchor
20963        });
20964        return (0,external_wp_blocks_namespaceObject.createBlock)('core/image', attributes);
20965      }
20966    }, {
20967      // Note: when dragging and dropping multiple files onto a gallery this overrides the
20968      // gallery transform in order to add new images to the gallery instead of
20969      // creating a new gallery.
20970      type: 'files',
20971  
20972      isMatch(files) {
20973        // The following check is intended to catch non-image files when dropped together with images.
20974        if (files.some(file => file.type.indexOf('image/') === 0) && files.some(file => file.type.indexOf('image/') !== 0)) {
20975          const {
20976            createErrorNotice
20977          } = (0,external_wp_data_namespaceObject.dispatch)(external_wp_notices_namespaceObject.store);
20978          createErrorNotice((0,external_wp_i18n_namespaceObject.__)('If uploading to a gallery all files need to be image formats'), {
20979            id: 'gallery-transform-invalid-file'
20980          });
20981        }
20982  
20983        return (0,external_lodash_namespaceObject.every)(files, file => file.type.indexOf('image/') === 0);
20984      },
20985  
20986      transform(files) {
20987        const blocks = files.map(file => {
20988          return (0,external_wp_blocks_namespaceObject.createBlock)('core/image', {
20989            url: (0,external_wp_blob_namespaceObject.createBlobURL)(file)
20990          });
20991        });
20992        return blocks;
20993      }
20994  
20995    }, {
20996      type: 'shortcode',
20997      tag: 'caption',
20998      attributes: {
20999        url: {
21000          type: 'string',
21001          source: 'attribute',
21002          attribute: 'src',
21003          selector: 'img'
21004        },
21005        alt: {
21006          type: 'string',
21007          source: 'attribute',
21008          attribute: 'alt',
21009          selector: 'img'
21010        },
21011        caption: {
21012          shortcode: stripFirstImage
21013        },
21014        href: {
21015          shortcode: (attributes, _ref3) => {
21016            let {
21017              shortcode
21018            } = _ref3;
21019            return getFirstAnchorAttributeFormHTML(shortcode.content, 'href');
21020          }
21021        },
21022        rel: {
21023          shortcode: (attributes, _ref4) => {
21024            let {
21025              shortcode
21026            } = _ref4;
21027            return getFirstAnchorAttributeFormHTML(shortcode.content, 'rel');
21028          }
21029        },
21030        linkClass: {
21031          shortcode: (attributes, _ref5) => {
21032            let {
21033              shortcode
21034            } = _ref5;
21035            return getFirstAnchorAttributeFormHTML(shortcode.content, 'class');
21036          }
21037        },
21038        id: {
21039          type: 'number',
21040          shortcode: _ref6 => {
21041            let {
21042              named: {
21043                id
21044              }
21045            } = _ref6;
21046  
21047            if (!id) {
21048              return;
21049            }
21050  
21051            return parseInt(id.replace('attachment_', ''), 10);
21052          }
21053        },
21054        align: {
21055          type: 'string',
21056          shortcode: _ref7 => {
21057            let {
21058              named: {
21059                align = 'alignnone'
21060              }
21061            } = _ref7;
21062            return align.replace('align', '');
21063          }
21064        }
21065      }
21066    }]
21067  };
21068  /* harmony default export */ var image_transforms = (image_transforms_transforms);
21069  
21070  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/image/index.js
21071  /**
21072   * WordPress dependencies
21073   */
21074  
21075  
21076  /**
21077   * Internal dependencies
21078   */
21079  
21080  
21081  
21082  const image_metadata = {
21083    $schema: "https://schemas.wp.org/trunk/block.json",
21084    apiVersion: 2,
21085    name: "core/image",
21086    title: "Image",
21087    category: "media",
21088    usesContext: ["allowResize", "imageCrop", "fixedHeight"],
21089    description: "Insert an image to make a visual statement.",
21090    keywords: ["img", "photo", "picture"],
21091    textdomain: "default",
21092    attributes: {
21093      align: {
21094        type: "string"
21095      },
21096      url: {
21097        type: "string",
21098        source: "attribute",
21099        selector: "img",
21100        attribute: "src"
21101      },
21102      alt: {
21103        type: "string",
21104        source: "attribute",
21105        selector: "img",
21106        attribute: "alt",
21107        "default": ""
21108      },
21109      caption: {
21110        type: "string",
21111        source: "html",
21112        selector: "figcaption"
21113      },
21114      title: {
21115        type: "string",
21116        source: "attribute",
21117        selector: "img",
21118        attribute: "title"
21119      },
21120      href: {
21121        type: "string",
21122        source: "attribute",
21123        selector: "figure > a",
21124        attribute: "href"
21125      },
21126      rel: {
21127        type: "string",
21128        source: "attribute",
21129        selector: "figure > a",
21130        attribute: "rel"
21131      },
21132      linkClass: {
21133        type: "string",
21134        source: "attribute",
21135        selector: "figure > a",
21136        attribute: "class"
21137      },
21138      id: {
21139        type: "number"
21140      },
21141      width: {
21142        type: "number"
21143      },
21144      height: {
21145        type: "number"
21146      },
21147      sizeSlug: {
21148        type: "string"
21149      },
21150      linkDestination: {
21151        type: "string"
21152      },
21153      linkTarget: {
21154        type: "string",
21155        source: "attribute",
21156        selector: "figure > a",
21157        attribute: "target"
21158      }
21159    },
21160    supports: {
21161      anchor: true,
21162      color: {
21163        __experimentalDuotone: "img",
21164        text: false,
21165        background: false
21166      },
21167      __experimentalBorder: {
21168        radius: true,
21169        __experimentalDefaultControls: {
21170          radius: true
21171        }
21172      }
21173    },
21174    styles: [{
21175      name: "default",
21176      label: "Default",
21177      isDefault: true
21178    }, {
21179      name: "rounded",
21180      label: "Rounded"
21181    }],
21182    editorStyle: "wp-block-image-editor",
21183    style: "wp-block-image"
21184  };
21185  
21186  
21187  const {
21188    name: image_name
21189  } = image_metadata;
21190  
21191  const image_settings = {
21192    icon: library_image,
21193    example: {
21194      attributes: {
21195        sizeSlug: 'large',
21196        url: 'https://s.w.org/images/core/5.3/MtBlanc1.jpg',
21197        // translators: Caption accompanying an image of the Mont Blanc, which serves as an example for the Image block.
21198        caption: (0,external_wp_i18n_namespaceObject.__)('Mont Blanc appears—still, snowy, and serene.')
21199      }
21200    },
21201  
21202    __experimentalLabel(attributes, _ref) {
21203      let {
21204        context
21205      } = _ref;
21206  
21207      if (context === 'accessibility') {
21208        const {
21209          caption,
21210          alt,
21211          url
21212        } = attributes;
21213  
21214        if (!url) {
21215          return (0,external_wp_i18n_namespaceObject.__)('Empty');
21216        }
21217  
21218        if (!alt) {
21219          return caption || '';
21220        } // This is intended to be read by a screen reader.
21221        // A period simply means a pause, no need to translate it.
21222  
21223  
21224        return alt + (caption ? '. ' + caption : '');
21225      }
21226    },
21227  
21228    getEditWrapperProps(attributes) {
21229      return {
21230        'data-align': attributes.align
21231      };
21232    },
21233  
21234    transforms: image_transforms,
21235    edit: image_edit,
21236    save: image_save_save,
21237    deprecated: image_deprecated
21238  };
21239  
21240  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/comment.js
21241  
21242  
21243  /**
21244   * WordPress dependencies
21245   */
21246  
21247  const comment = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
21248    viewBox: "0 0 24 24",
21249    xmlns: "http://www.w3.org/2000/svg"
21250  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
21251    d: "M18 4H6c-1.1 0-2 .9-2 2v12.9c0 .6.5 1.1 1.1 1.1.3 0 .5-.1.8-.3L8.5 17H18c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zm.5 11c0 .3-.2.5-.5.5H7.9l-2.4 2.4V6c0-.3.2-.5.5-.5h12c.3 0 .5.2.5.5v9z"
21252  }));
21253  /* harmony default export */ var library_comment = (comment);
21254  
21255  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/latest-comments/edit.js
21256  
21257  
21258  /**
21259   * WordPress dependencies
21260   */
21261  
21262  
21263  
21264  
21265  /**
21266   * Minimum number of comments a user can show using this block.
21267   *
21268   * @type {number}
21269   */
21270  
21271  const MIN_COMMENTS = 1;
21272  /**
21273   * Maximum number of comments a user can show using this block.
21274   *
21275   * @type {number}
21276   */
21277  
21278  const MAX_COMMENTS = 100;
21279  function LatestComments(_ref) {
21280    let {
21281      attributes,
21282      setAttributes
21283    } = _ref;
21284    const {
21285      commentsToShow,
21286      displayAvatar,
21287      displayDate,
21288      displayExcerpt
21289    } = attributes;
21290    return (0,external_wp_element_namespaceObject.createElement)("div", (0,external_wp_blockEditor_namespaceObject.useBlockProps)(), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
21291      title: (0,external_wp_i18n_namespaceObject.__)('Latest comments settings')
21292    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
21293      label: (0,external_wp_i18n_namespaceObject.__)('Display avatar'),
21294      checked: displayAvatar,
21295      onChange: () => setAttributes({
21296        displayAvatar: !displayAvatar
21297      })
21298    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
21299      label: (0,external_wp_i18n_namespaceObject.__)('Display date'),
21300      checked: displayDate,
21301      onChange: () => setAttributes({
21302        displayDate: !displayDate
21303      })
21304    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
21305      label: (0,external_wp_i18n_namespaceObject.__)('Display excerpt'),
21306      checked: displayExcerpt,
21307      onChange: () => setAttributes({
21308        displayExcerpt: !displayExcerpt
21309      })
21310    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.RangeControl, {
21311      label: (0,external_wp_i18n_namespaceObject.__)('Number of comments'),
21312      value: commentsToShow,
21313      onChange: value => setAttributes({
21314        commentsToShow: value
21315      }),
21316      min: MIN_COMMENTS,
21317      max: MAX_COMMENTS,
21318      required: true
21319    }))), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Disabled, null, (0,external_wp_element_namespaceObject.createElement)((external_wp_serverSideRender_default()), {
21320      block: "core/latest-comments",
21321      attributes: attributes // The preview uses the site's locale to make it more true to how
21322      // the block appears on the frontend. Setting the locale
21323      // explicitly prevents any middleware from setting it to 'user'.
21324      ,
21325      urlQueryArgs: {
21326        _locale: 'site'
21327      }
21328    })));
21329  }
21330  
21331  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/latest-comments/index.js
21332  /**
21333   * WordPress dependencies
21334   */
21335  
21336  /**
21337   * Internal dependencies
21338   */
21339  
21340  const latest_comments_metadata = {
21341    $schema: "https://schemas.wp.org/trunk/block.json",
21342    apiVersion: 2,
21343    name: "core/latest-comments",
21344    title: "Latest Comments",
21345    category: "widgets",
21346    description: "Display a list of your most recent comments.",
21347    keywords: ["recent comments"],
21348    textdomain: "default",
21349    attributes: {
21350      commentsToShow: {
21351        type: "number",
21352        "default": 5,
21353        minimum: 1,
21354        maximum: 100
21355      },
21356      displayAvatar: {
21357        type: "boolean",
21358        "default": true
21359      },
21360      displayDate: {
21361        type: "boolean",
21362        "default": true
21363      },
21364      displayExcerpt: {
21365        type: "boolean",
21366        "default": true
21367      }
21368    },
21369    supports: {
21370      align: true,
21371      html: false
21372    },
21373    editorStyle: "wp-block-latest-comments-editor",
21374    style: "wp-block-latest-comments"
21375  };
21376  
21377  const {
21378    name: latest_comments_name
21379  } = latest_comments_metadata;
21380  
21381  const latest_comments_settings = {
21382    icon: library_comment,
21383    example: {},
21384    edit: LatestComments
21385  };
21386  
21387  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/post-list.js
21388  
21389  
21390  /**
21391   * WordPress dependencies
21392   */
21393  
21394  const postList = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
21395    viewBox: "0 0 24 24",
21396    xmlns: "http://www.w3.org/2000/svg"
21397  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
21398    d: "M18 4H6c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h12c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zm.5 14c0 .3-.2.5-.5.5H6c-.3 0-.5-.2-.5-.5V6c0-.3.2-.5.5-.5h12c.3 0 .5.2.5.5v12zM7 11h2V9H7v2zm0 4h2v-2H7v2zm3-4h7V9h-7v2zm0 4h7v-2h-7v2z"
21399  }));
21400  /* harmony default export */ var post_list = (postList);
21401  
21402  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/latest-posts/deprecated.js
21403  /**
21404   * Internal dependencies
21405   */
21406  const latest_posts_deprecated_metadata = {
21407    $schema: "https://schemas.wp.org/trunk/block.json",
21408    apiVersion: 2,
21409    name: "core/latest-posts",
21410    title: "Latest Posts",
21411    category: "widgets",
21412    description: "Display a list of your most recent posts.",
21413    keywords: ["recent posts"],
21414    textdomain: "default",
21415    attributes: {
21416      categories: {
21417        type: "array",
21418        items: {
21419          type: "object"
21420        }
21421      },
21422      selectedAuthor: {
21423        type: "number"
21424      },
21425      postsToShow: {
21426        type: "number",
21427        "default": 5
21428      },
21429      displayPostContent: {
21430        type: "boolean",
21431        "default": false
21432      },
21433      displayPostContentRadio: {
21434        type: "string",
21435        "default": "excerpt"
21436      },
21437      excerptLength: {
21438        type: "number",
21439        "default": 55
21440      },
21441      displayAuthor: {
21442        type: "boolean",
21443        "default": false
21444      },
21445      displayPostDate: {
21446        type: "boolean",
21447        "default": false
21448      },
21449      postLayout: {
21450        type: "string",
21451        "default": "list"
21452      },
21453      columns: {
21454        type: "number",
21455        "default": 3
21456      },
21457      order: {
21458        type: "string",
21459        "default": "desc"
21460      },
21461      orderBy: {
21462        type: "string",
21463        "default": "date"
21464      },
21465      displayFeaturedImage: {
21466        type: "boolean",
21467        "default": false
21468      },
21469      featuredImageAlign: {
21470        type: "string",
21471        "enum": ["left", "center", "right"]
21472      },
21473      featuredImageSizeSlug: {
21474        type: "string",
21475        "default": "thumbnail"
21476      },
21477      featuredImageSizeWidth: {
21478        type: "number",
21479        "default": null
21480      },
21481      featuredImageSizeHeight: {
21482        type: "number",
21483        "default": null
21484      },
21485      addLinkToFeaturedImage: {
21486        type: "boolean",
21487        "default": false
21488      }
21489    },
21490    supports: {
21491      align: true,
21492      html: false
21493    },
21494    editorStyle: "wp-block-latest-posts-editor",
21495    style: "wp-block-latest-posts"
21496  };
21497  const {
21498    attributes
21499  } = latest_posts_deprecated_metadata;
21500  /* harmony default export */ var latest_posts_deprecated = ([{
21501    attributes: { ...attributes,
21502      categories: {
21503        type: 'string'
21504      }
21505    },
21506    supports: {
21507      align: true,
21508      html: false
21509    },
21510    migrate: oldAttributes => {
21511      // This needs the full category object, not just the ID.
21512      return { ...oldAttributes,
21513        categories: [{
21514          id: Number(oldAttributes.categories)
21515        }]
21516      };
21517    },
21518    isEligible: _ref => {
21519      let {
21520        categories
21521      } = _ref;
21522      return categories && 'string' === typeof categories;
21523    },
21524    save: () => null
21525  }]);
21526  
21527  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/list.js
21528  
21529  
21530  /**
21531   * WordPress dependencies
21532   */
21533  
21534  const list = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
21535    viewBox: "0 0 24 24",
21536    xmlns: "http://www.w3.org/2000/svg"
21537  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
21538    d: "M4 4v1.5h16V4H4zm8 8.5h8V11h-8v1.5zM4 20h16v-1.5H4V20zm4-8c0-1.1-.9-2-2-2s-2 .9-2 2 .9 2 2 2 2-.9 2-2z"
21539  }));
21540  /* harmony default export */ var library_list = (list);
21541  
21542  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/grid.js
21543  
21544  
21545  /**
21546   * WordPress dependencies
21547   */
21548  
21549  const grid = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
21550    xmlns: "http://www.w3.org/2000/svg",
21551    viewBox: "0 0 24 24"
21552  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
21553    d: "M19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm-7.8 16.5H5c-.3 0-.5-.2-.5-.5v-6.2h6.8v6.7zm0-8.3H4.5V5c0-.3.2-.5.5-.5h6.2v6.7zm8.3 7.8c0 .3-.2.5-.5.5h-6.2v-6.8h6.8V19zm0-7.8h-6.8V4.5H19c.3 0 .5.2.5.5v6.2z",
21554    fillRule: "evenodd",
21555    clipRule: "evenodd"
21556  }));
21557  /* harmony default export */ var library_grid = (grid);
21558  
21559  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/latest-posts/constants.js
21560  const MIN_EXCERPT_LENGTH = 10;
21561  const MAX_EXCERPT_LENGTH = 100;
21562  const MAX_POSTS_COLUMNS = 6;
21563  
21564  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/latest-posts/edit.js
21565  
21566  
21567  /**
21568   * External dependencies
21569   */
21570  
21571  
21572  /**
21573   * WordPress dependencies
21574   */
21575  
21576  
21577  
21578  
21579  
21580  
21581  
21582  
21583  /**
21584   * Internal dependencies
21585   */
21586  
21587  
21588  /**
21589   * Module Constants
21590   */
21591  
21592  const CATEGORIES_LIST_QUERY = {
21593    per_page: -1,
21594    context: 'view'
21595  };
21596  const USERS_LIST_QUERY = {
21597    per_page: -1,
21598    has_published_posts: ['post'],
21599    context: 'view'
21600  };
21601  
21602  function getFeaturedImageDetails(post, size) {
21603    var _image$media_details$, _image$media_details, _image$media_details$2, _image$media_details$3;
21604  
21605    const image = (0,external_lodash_namespaceObject.get)(post, ['_embedded', 'wp:featuredmedia', '0']);
21606    return {
21607      url: (_image$media_details$ = image === null || image === void 0 ? void 0 : (_image$media_details = image.media_details) === null || _image$media_details === void 0 ? void 0 : (_image$media_details$2 = _image$media_details.sizes) === null || _image$media_details$2 === void 0 ? void 0 : (_image$media_details$3 = _image$media_details$2[size]) === null || _image$media_details$3 === void 0 ? void 0 : _image$media_details$3.source_url) !== null && _image$media_details$ !== void 0 ? _image$media_details$ : image === null || image === void 0 ? void 0 : image.source_url,
21608      alt: image === null || image === void 0 ? void 0 : image.alt_text
21609    };
21610  }
21611  
21612  function LatestPostsEdit(_ref) {
21613    var _categoriesList$reduc;
21614  
21615    let {
21616      attributes,
21617      setAttributes
21618    } = _ref;
21619    const {
21620      postsToShow,
21621      order,
21622      orderBy,
21623      categories,
21624      selectedAuthor,
21625      displayFeaturedImage,
21626      displayPostContentRadio,
21627      displayPostContent,
21628      displayPostDate,
21629      displayAuthor,
21630      postLayout,
21631      columns,
21632      excerptLength,
21633      featuredImageAlign,
21634      featuredImageSizeSlug,
21635      featuredImageSizeWidth,
21636      featuredImageSizeHeight,
21637      addLinkToFeaturedImage
21638    } = attributes;
21639    const {
21640      imageSizes,
21641      latestPosts,
21642      defaultImageWidth,
21643      defaultImageHeight,
21644      categoriesList,
21645      authorList
21646    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
21647      const {
21648        getEntityRecords,
21649        getUsers
21650      } = select(external_wp_coreData_namespaceObject.store);
21651      const settings = select(external_wp_blockEditor_namespaceObject.store).getSettings();
21652      const catIds = categories && categories.length > 0 ? categories.map(cat => cat.id) : [];
21653      const latestPostsQuery = (0,external_lodash_namespaceObject.pickBy)({
21654        categories: catIds,
21655        author: selectedAuthor,
21656        order,
21657        orderby: orderBy,
21658        per_page: postsToShow,
21659        _embed: 'wp:featuredmedia'
21660      }, value => !(0,external_lodash_namespaceObject.isUndefined)(value));
21661      return {
21662        defaultImageWidth: (0,external_lodash_namespaceObject.get)(settings.imageDimensions, [featuredImageSizeSlug, 'width'], 0),
21663        defaultImageHeight: (0,external_lodash_namespaceObject.get)(settings.imageDimensions, [featuredImageSizeSlug, 'height'], 0),
21664        imageSizes: settings.imageSizes,
21665        latestPosts: getEntityRecords('postType', 'post', latestPostsQuery),
21666        categoriesList: getEntityRecords('taxonomy', 'category', CATEGORIES_LIST_QUERY),
21667        authorList: getUsers(USERS_LIST_QUERY)
21668      };
21669    }, [featuredImageSizeSlug, postsToShow, order, orderBy, categories, selectedAuthor]);
21670    const imageSizeOptions = imageSizes.filter(_ref2 => {
21671      let {
21672        slug
21673      } = _ref2;
21674      return slug !== 'full';
21675    }).map(_ref3 => {
21676      let {
21677        name,
21678        slug
21679      } = _ref3;
21680      return {
21681        value: slug,
21682        label: name
21683      };
21684    });
21685    const categorySuggestions = (_categoriesList$reduc = categoriesList === null || categoriesList === void 0 ? void 0 : categoriesList.reduce((accumulator, category) => ({ ...accumulator,
21686      [category.name]: category
21687    }), {})) !== null && _categoriesList$reduc !== void 0 ? _categoriesList$reduc : {};
21688  
21689    const selectCategories = tokens => {
21690      const hasNoSuggestion = tokens.some(token => typeof token === 'string' && !categorySuggestions[token]);
21691  
21692      if (hasNoSuggestion) {
21693        return;
21694      } // Categories that are already will be objects, while new additions will be strings (the name).
21695      // allCategories nomalizes the array so that they are all objects.
21696  
21697  
21698      const allCategories = tokens.map(token => {
21699        return typeof token === 'string' ? categorySuggestions[token] : token;
21700      }); // We do nothing if the category is not selected
21701      // from suggestions.
21702  
21703      if ((0,external_lodash_namespaceObject.includes)(allCategories, null)) {
21704        return false;
21705      }
21706  
21707      setAttributes({
21708        categories: allCategories
21709      });
21710    };
21711  
21712    const hasPosts = !!(latestPosts !== null && latestPosts !== void 0 && latestPosts.length);
21713    const inspectorControls = (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
21714      title: (0,external_wp_i18n_namespaceObject.__)('Post content settings')
21715    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
21716      label: (0,external_wp_i18n_namespaceObject.__)('Post content'),
21717      checked: displayPostContent,
21718      onChange: value => setAttributes({
21719        displayPostContent: value
21720      })
21721    }), displayPostContent && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.RadioControl, {
21722      label: (0,external_wp_i18n_namespaceObject.__)('Show:'),
21723      selected: displayPostContentRadio,
21724      options: [{
21725        label: (0,external_wp_i18n_namespaceObject.__)('Excerpt'),
21726        value: 'excerpt'
21727      }, {
21728        label: (0,external_wp_i18n_namespaceObject.__)('Full post'),
21729        value: 'full_post'
21730      }],
21731      onChange: value => setAttributes({
21732        displayPostContentRadio: value
21733      })
21734    }), displayPostContent && displayPostContentRadio === 'excerpt' && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.RangeControl, {
21735      label: (0,external_wp_i18n_namespaceObject.__)('Max number of words in excerpt'),
21736      value: excerptLength,
21737      onChange: value => setAttributes({
21738        excerptLength: value
21739      }),
21740      min: MIN_EXCERPT_LENGTH,
21741      max: MAX_EXCERPT_LENGTH
21742    })), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
21743      title: (0,external_wp_i18n_namespaceObject.__)('Post meta settings')
21744    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
21745      label: (0,external_wp_i18n_namespaceObject.__)('Display author name'),
21746      checked: displayAuthor,
21747      onChange: value => setAttributes({
21748        displayAuthor: value
21749      })
21750    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
21751      label: (0,external_wp_i18n_namespaceObject.__)('Display post date'),
21752      checked: displayPostDate,
21753      onChange: value => setAttributes({
21754        displayPostDate: value
21755      })
21756    })), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
21757      title: (0,external_wp_i18n_namespaceObject.__)('Featured image settings')
21758    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
21759      label: (0,external_wp_i18n_namespaceObject.__)('Display featured image'),
21760      checked: displayFeaturedImage,
21761      onChange: value => setAttributes({
21762        displayFeaturedImage: value
21763      })
21764    }), displayFeaturedImage && (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.__experimentalImageSizeControl, {
21765      onChange: value => {
21766        const newAttrs = {};
21767  
21768        if (value.hasOwnProperty('width')) {
21769          newAttrs.featuredImageSizeWidth = value.width;
21770        }
21771  
21772        if (value.hasOwnProperty('height')) {
21773          newAttrs.featuredImageSizeHeight = value.height;
21774        }
21775  
21776        setAttributes(newAttrs);
21777      },
21778      slug: featuredImageSizeSlug,
21779      width: featuredImageSizeWidth,
21780      height: featuredImageSizeHeight,
21781      imageWidth: defaultImageWidth,
21782      imageHeight: defaultImageHeight,
21783      imageSizeOptions: imageSizeOptions,
21784      onChangeImage: value => setAttributes({
21785        featuredImageSizeSlug: value,
21786        featuredImageSizeWidth: undefined,
21787        featuredImageSizeHeight: undefined
21788      })
21789    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.BaseControl, {
21790      className: "editor-latest-posts-image-alignment-control"
21791    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.BaseControl.VisualLabel, null, (0,external_wp_i18n_namespaceObject.__)('Image alignment')), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockAlignmentToolbar, {
21792      value: featuredImageAlign,
21793      onChange: value => setAttributes({
21794        featuredImageAlign: value
21795      }),
21796      controls: ['left', 'center', 'right'],
21797      isCollapsed: false
21798    })), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
21799      label: (0,external_wp_i18n_namespaceObject.__)('Add link to featured image'),
21800      checked: addLinkToFeaturedImage,
21801      onChange: value => setAttributes({
21802        addLinkToFeaturedImage: value
21803      })
21804    }))), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
21805      title: (0,external_wp_i18n_namespaceObject.__)('Sorting and filtering')
21806    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.QueryControls, {
21807      order,
21808      orderBy,
21809      numberOfItems: postsToShow,
21810      onOrderChange: value => setAttributes({
21811        order: value
21812      }),
21813      onOrderByChange: value => setAttributes({
21814        orderBy: value
21815      }),
21816      onNumberOfItemsChange: value => setAttributes({
21817        postsToShow: value
21818      }),
21819      categorySuggestions: categorySuggestions,
21820      onCategoryChange: selectCategories,
21821      selectedCategories: categories,
21822      onAuthorChange: value => setAttributes({
21823        selectedAuthor: '' !== value ? Number(value) : undefined
21824      }),
21825      authorList: authorList !== null && authorList !== void 0 ? authorList : [],
21826      selectedAuthorId: selectedAuthor
21827    }), postLayout === 'grid' && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.RangeControl, {
21828      label: (0,external_wp_i18n_namespaceObject.__)('Columns'),
21829      value: columns,
21830      onChange: value => setAttributes({
21831        columns: value
21832      }),
21833      min: 2,
21834      max: !hasPosts ? MAX_POSTS_COLUMNS : Math.min(MAX_POSTS_COLUMNS, latestPosts.length),
21835      required: true
21836    })));
21837    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
21838      className: classnames_default()({
21839        'wp-block-latest-posts__list': true,
21840        'is-grid': postLayout === 'grid',
21841        'has-dates': displayPostDate,
21842        'has-author': displayAuthor,
21843        [`columns-$columns}`]: postLayout === 'grid'
21844      })
21845    });
21846  
21847    if (!hasPosts) {
21848      return (0,external_wp_element_namespaceObject.createElement)("div", blockProps, inspectorControls, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Placeholder, {
21849        icon: library_pin,
21850        label: (0,external_wp_i18n_namespaceObject.__)('Latest Posts')
21851      }, !Array.isArray(latestPosts) ? (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Spinner, null) : (0,external_wp_i18n_namespaceObject.__)('No posts found.')));
21852    } // Removing posts from display should be instant.
21853  
21854  
21855    const displayPosts = latestPosts.length > postsToShow ? latestPosts.slice(0, postsToShow) : latestPosts;
21856    const layoutControls = [{
21857      icon: library_list,
21858      title: (0,external_wp_i18n_namespaceObject.__)('List view'),
21859      onClick: () => setAttributes({
21860        postLayout: 'list'
21861      }),
21862      isActive: postLayout === 'list'
21863    }, {
21864      icon: library_grid,
21865      title: (0,external_wp_i18n_namespaceObject.__)('Grid view'),
21866      onClick: () => setAttributes({
21867        postLayout: 'grid'
21868      }),
21869      isActive: postLayout === 'grid'
21870    }];
21871  
21872    const dateFormat = (0,external_wp_date_namespaceObject.__experimentalGetSettings)().formats.date;
21873  
21874    return (0,external_wp_element_namespaceObject.createElement)("div", null, inspectorControls, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarGroup, {
21875      controls: layoutControls
21876    })), (0,external_wp_element_namespaceObject.createElement)("ul", blockProps, displayPosts.map((post, i) => {
21877      const titleTrimmed = (0,external_lodash_namespaceObject.invoke)(post, ['title', 'rendered', 'trim']);
21878      let excerpt = post.excerpt.rendered;
21879      const currentAuthor = authorList === null || authorList === void 0 ? void 0 : authorList.find(author => author.id === post.author);
21880      const excerptElement = document.createElement('div');
21881      excerptElement.innerHTML = excerpt;
21882      excerpt = excerptElement.textContent || excerptElement.innerText || '';
21883      const {
21884        url: imageSourceUrl,
21885        alt: featuredImageAlt
21886      } = getFeaturedImageDetails(post, featuredImageSizeSlug);
21887      const imageClasses = classnames_default()({
21888        'wp-block-latest-posts__featured-image': true,
21889        [`align$featuredImageAlign}`]: !!featuredImageAlign
21890      });
21891      const renderFeaturedImage = displayFeaturedImage && imageSourceUrl;
21892      const featuredImage = renderFeaturedImage && (0,external_wp_element_namespaceObject.createElement)("img", {
21893        src: imageSourceUrl,
21894        alt: featuredImageAlt,
21895        style: {
21896          maxWidth: featuredImageSizeWidth,
21897          maxHeight: featuredImageSizeHeight
21898        }
21899      });
21900      const needsReadMore = excerptLength < excerpt.trim().split(' ').length && post.excerpt.raw === '';
21901      const postExcerpt = needsReadMore ? (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, excerpt.trim().split(' ', excerptLength).join(' '), (0,external_wp_i18n_namespaceObject.__)(' … '), (0,external_wp_element_namespaceObject.createElement)("a", {
21902        href: post.link,
21903        rel: "noopener noreferrer"
21904      }, (0,external_wp_i18n_namespaceObject.__)('Read more'))) : excerpt;
21905      return (0,external_wp_element_namespaceObject.createElement)("li", {
21906        key: i
21907      }, renderFeaturedImage && (0,external_wp_element_namespaceObject.createElement)("div", {
21908        className: imageClasses
21909      }, addLinkToFeaturedImage ? (0,external_wp_element_namespaceObject.createElement)("a", {
21910        className: "wp-block-latest-posts__post-title",
21911        href: post.link,
21912        rel: "noreferrer noopener"
21913      }, featuredImage) : featuredImage), (0,external_wp_element_namespaceObject.createElement)("a", {
21914        href: post.link,
21915        rel: "noreferrer noopener",
21916        dangerouslySetInnerHTML: !!titleTrimmed ? {
21917          __html: titleTrimmed
21918        } : undefined
21919      }, !titleTrimmed ? (0,external_wp_i18n_namespaceObject.__)('(no title)') : null), displayAuthor && currentAuthor && (0,external_wp_element_namespaceObject.createElement)("div", {
21920        className: "wp-block-latest-posts__post-author"
21921      }, (0,external_wp_i18n_namespaceObject.sprintf)(
21922      /* translators: byline. %s: current author. */
21923      (0,external_wp_i18n_namespaceObject.__)('by %s'), currentAuthor.name)), displayPostDate && post.date_gmt && (0,external_wp_element_namespaceObject.createElement)("time", {
21924        dateTime: (0,external_wp_date_namespaceObject.format)('c', post.date_gmt),
21925        className: "wp-block-latest-posts__post-date"
21926      }, (0,external_wp_date_namespaceObject.dateI18n)(dateFormat, post.date_gmt)), displayPostContent && displayPostContentRadio === 'excerpt' && (0,external_wp_element_namespaceObject.createElement)("div", {
21927        className: "wp-block-latest-posts__post-excerpt"
21928      }, postExcerpt), displayPostContent && displayPostContentRadio === 'full_post' && (0,external_wp_element_namespaceObject.createElement)("div", {
21929        className: "wp-block-latest-posts__post-full-content",
21930        dangerouslySetInnerHTML: {
21931          __html: post.content.raw.trim()
21932        }
21933      }));
21934    })));
21935  }
21936  
21937  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/latest-posts/index.js
21938  /**
21939   * WordPress dependencies
21940   */
21941  
21942  /**
21943   * Internal dependencies
21944   */
21945  
21946  
21947  
21948  const latest_posts_metadata = {
21949    $schema: "https://schemas.wp.org/trunk/block.json",
21950    apiVersion: 2,
21951    name: "core/latest-posts",
21952    title: "Latest Posts",
21953    category: "widgets",
21954    description: "Display a list of your most recent posts.",
21955    keywords: ["recent posts"],
21956    textdomain: "default",
21957    attributes: {
21958      categories: {
21959        type: "array",
21960        items: {
21961          type: "object"
21962        }
21963      },
21964      selectedAuthor: {
21965        type: "number"
21966      },
21967      postsToShow: {
21968        type: "number",
21969        "default": 5
21970      },
21971      displayPostContent: {
21972        type: "boolean",
21973        "default": false
21974      },
21975      displayPostContentRadio: {
21976        type: "string",
21977        "default": "excerpt"
21978      },
21979      excerptLength: {
21980        type: "number",
21981        "default": 55
21982      },
21983      displayAuthor: {
21984        type: "boolean",
21985        "default": false
21986      },
21987      displayPostDate: {
21988        type: "boolean",
21989        "default": false
21990      },
21991      postLayout: {
21992        type: "string",
21993        "default": "list"
21994      },
21995      columns: {
21996        type: "number",
21997        "default": 3
21998      },
21999      order: {
22000        type: "string",
22001        "default": "desc"
22002      },
22003      orderBy: {
22004        type: "string",
22005        "default": "date"
22006      },
22007      displayFeaturedImage: {
22008        type: "boolean",
22009        "default": false
22010      },
22011      featuredImageAlign: {
22012        type: "string",
22013        "enum": ["left", "center", "right"]
22014      },
22015      featuredImageSizeSlug: {
22016        type: "string",
22017        "default": "thumbnail"
22018      },
22019      featuredImageSizeWidth: {
22020        type: "number",
22021        "default": null
22022      },
22023      featuredImageSizeHeight: {
22024        type: "number",
22025        "default": null
22026      },
22027      addLinkToFeaturedImage: {
22028        type: "boolean",
22029        "default": false
22030      }
22031    },
22032    supports: {
22033      align: true,
22034      html: false
22035    },
22036    editorStyle: "wp-block-latest-posts-editor",
22037    style: "wp-block-latest-posts"
22038  };
22039  const {
22040    name: latest_posts_name
22041  } = latest_posts_metadata;
22042  
22043  const latest_posts_settings = {
22044    icon: post_list,
22045    example: {},
22046    edit: LatestPostsEdit,
22047    deprecated: latest_posts_deprecated
22048  };
22049  
22050  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/list/deprecated.js
22051  
22052  
22053  /**
22054   * WordPress dependencies
22055   */
22056  
22057  /**
22058   * Internal dependencies
22059   */
22060  
22061  
22062  const v0 = {
22063    attributes: {
22064      ordered: {
22065        type: 'boolean',
22066        default: false,
22067        __experimentalRole: 'content'
22068      },
22069      values: {
22070        type: 'string',
22071        source: 'html',
22072        selector: 'ol,ul',
22073        multiline: 'li',
22074        __unstableMultilineWrapperTags: ['ol', 'ul'],
22075        default: '',
22076        __experimentalRole: 'content'
22077      },
22078      type: {
22079        type: 'string'
22080      },
22081      start: {
22082        type: 'number'
22083      },
22084      reversed: {
22085        type: 'boolean'
22086      },
22087      placeholder: {
22088        type: 'string'
22089      }
22090    },
22091    supports: {
22092      anchor: true,
22093      className: false,
22094      typography: {
22095        fontSize: true,
22096        __experimentalFontFamily: true
22097      },
22098      color: {
22099        gradients: true,
22100        link: true
22101      },
22102      __unstablePasteTextInline: true,
22103      __experimentalSelector: 'ol,ul',
22104      __experimentalSlashInserter: true
22105    },
22106  
22107    save(_ref) {
22108      let {
22109        attributes
22110      } = _ref;
22111      const {
22112        ordered,
22113        values,
22114        type,
22115        reversed,
22116        start
22117      } = attributes;
22118      const TagName = ordered ? 'ol' : 'ul';
22119      return (0,external_wp_element_namespaceObject.createElement)(TagName, external_wp_blockEditor_namespaceObject.useBlockProps.save({
22120        type,
22121        reversed,
22122        start
22123      }), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
22124        value: values,
22125        multiline: "li"
22126      }));
22127    },
22128  
22129    migrate: migrate_font_family,
22130  
22131    isEligible(_ref2) {
22132      var _style$typography;
22133  
22134      let {
22135        style
22136      } = _ref2;
22137      return style === null || style === void 0 ? void 0 : (_style$typography = style.typography) === null || _style$typography === void 0 ? void 0 : _style$typography.fontFamily;
22138    }
22139  
22140  };
22141  /**
22142   * New deprecations need to be placed first
22143   * for them to have higher priority.
22144   *
22145   * Old deprecations may need to be updated as well.
22146   *
22147   * See block-deprecation.md
22148   */
22149  
22150  /* harmony default export */ var list_deprecated = ([v0]);
22151  
22152  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/format-list-bullets-rtl.js
22153  
22154  
22155  /**
22156   * WordPress dependencies
22157   */
22158  
22159  const formatListBulletsRTL = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
22160    xmlns: "http://www.w3.org/2000/svg",
22161    viewBox: "0 0 24 24"
22162  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
22163    d: "M4 8.8h8.9V7.2H4v1.6zm0 7h8.9v-1.5H4v1.5zM18 13c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm0-3c1.1 0 2-.9 2-2s-.9-2-2-2-2 .9-2 2 .9 2 2 2z"
22164  }));
22165  /* harmony default export */ var format_list_bullets_rtl = (formatListBulletsRTL);
22166  
22167  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/format-list-bullets.js
22168  
22169  
22170  /**
22171   * WordPress dependencies
22172   */
22173  
22174  const formatListBullets = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
22175    xmlns: "http://www.w3.org/2000/svg",
22176    viewBox: "0 0 24 24"
22177  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
22178    d: "M11.1 15.8H20v-1.5h-8.9v1.5zm0-8.6v1.5H20V7.2h-8.9zM6 13c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm0-7c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2z"
22179  }));
22180  /* harmony default export */ var format_list_bullets = (formatListBullets);
22181  
22182  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/format-list-numbered-rtl.js
22183  
22184  
22185  /**
22186   * WordPress dependencies
22187   */
22188  
22189  const formatListNumberedRTL = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
22190    xmlns: "http://www.w3.org/2000/svg",
22191    viewBox: "0 0 24 24"
22192  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
22193    d: "M3.8 15.8h8.9v-1.5H3.8v1.5zm0-7h8.9V7.2H3.8v1.6zm14.7-2.1V10h1V5.3l-2.2.7.3 1 .9-.3zm1.2 6.1c-.5-.6-1.2-.5-1.7-.4-.3.1-.5.2-.7.3l.1 1.1c.2-.2.5-.4.8-.5.3-.1.6 0 .7.1.2.3 0 .8-.2 1.1-.5.8-.9 1.6-1.4 2.5H20v-1h-.9c.3-.6.8-1.4.9-2.1 0-.3 0-.8-.3-1.1z"
22194  }));
22195  /* harmony default export */ var format_list_numbered_rtl = (formatListNumberedRTL);
22196  
22197  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/format-list-numbered.js
22198  
22199  
22200  /**
22201   * WordPress dependencies
22202   */
22203  
22204  const formatListNumbered = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
22205    xmlns: "http://www.w3.org/2000/svg",
22206    viewBox: "0 0 24 24"
22207  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
22208    d: "M11.1 15.8H20v-1.5h-8.9v1.5zm0-8.6v1.5H20V7.2h-8.9zM5 6.7V10h1V5.3L3.8 6l.4 1 .8-.3zm-.4 5.7c-.3.1-.5.2-.7.3l.1 1.1c.2-.2.5-.4.8-.5.3-.1.6 0 .7.1.2.3 0 .8-.2 1.1-.5.8-.9 1.6-1.4 2.5h2.7v-1h-1c.3-.6.8-1.4.9-2.1.1-.3 0-.8-.2-1.1-.5-.6-1.3-.5-1.7-.4z"
22209  }));
22210  /* harmony default export */ var format_list_numbered = (formatListNumbered);
22211  
22212  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/format-outdent-rtl.js
22213  
22214  
22215  /**
22216   * WordPress dependencies
22217   */
22218  
22219  const formatOutdentRTL = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
22220    xmlns: "http://www.w3.org/2000/svg",
22221    viewBox: "0 0 24 24"
22222  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
22223    d: "M20 5.5H4V4H20V5.5ZM12 12.5H4V11H12V12.5ZM20 20V18.5H4V20H20ZM15.4697 14.9697L18.4393 12L15.4697 9.03033L16.5303 7.96967L20.0303 11.4697L20.5607 12L20.0303 12.5303L16.5303 16.0303L15.4697 14.9697Z"
22224  }));
22225  /* harmony default export */ var format_outdent_rtl = (formatOutdentRTL);
22226  
22227  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/format-outdent.js
22228  
22229  
22230  /**
22231   * WordPress dependencies
22232   */
22233  
22234  const formatOutdent = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
22235    xmlns: "http://www.w3.org/2000/svg",
22236    viewBox: "0 0 24 24"
22237  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
22238    d: "M4 7.2v1.5h16V7.2H4zm8 8.6h8v-1.5h-8v1.5zm-4-4.6l-4 4 4 4 1-1-3-3 3-3-1-1z"
22239  }));
22240  /* harmony default export */ var format_outdent = (formatOutdent);
22241  
22242  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/format-indent-rtl.js
22243  
22244  
22245  /**
22246   * WordPress dependencies
22247   */
22248  
22249  const formatIndentRTL = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
22250    xmlns: "http://www.w3.org/2000/svg",
22251    viewBox: "0 0 24 24"
22252  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
22253    d: "M20 5.5H4V4H20V5.5ZM12 12.5H4V11H12V12.5ZM20 20V18.5H4V20H20ZM20.0303 9.03033L17.0607 12L20.0303 14.9697L18.9697 16.0303L15.4697 12.5303L14.9393 12L15.4697 11.4697L18.9697 7.96967L20.0303 9.03033Z"
22254  }));
22255  /* harmony default export */ var format_indent_rtl = (formatIndentRTL);
22256  
22257  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/format-indent.js
22258  
22259  
22260  /**
22261   * WordPress dependencies
22262   */
22263  
22264  const formatIndent = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
22265    xmlns: "http://www.w3.org/2000/svg",
22266    viewBox: "0 0 24 24"
22267  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
22268    d: "M4 7.2v1.5h16V7.2H4zm8 8.6h8v-1.5h-8v1.5zm-8-3.5l3 3-3 3 1 1 4-4-4-4-1 1z"
22269  }));
22270  /* harmony default export */ var format_indent = (formatIndent);
22271  
22272  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/list/ordered-list-settings.js
22273  
22274  
22275  /**
22276   * WordPress dependencies
22277   */
22278  
22279  
22280  
22281  
22282  const OrderedListSettings = _ref => {
22283    let {
22284      setAttributes,
22285      reversed,
22286      start
22287    } = _ref;
22288    return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
22289      title: (0,external_wp_i18n_namespaceObject.__)('Ordered list settings')
22290    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TextControl, {
22291      label: (0,external_wp_i18n_namespaceObject.__)('Start value'),
22292      type: "number",
22293      onChange: value => {
22294        const int = parseInt(value, 10);
22295        setAttributes({
22296          // It should be possible to unset the value,
22297          // e.g. with an empty string.
22298          start: isNaN(int) ? undefined : int
22299        });
22300      },
22301      value: Number.isInteger(start) ? start.toString(10) : '',
22302      step: "1"
22303    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
22304      label: (0,external_wp_i18n_namespaceObject.__)('Reverse list numbering'),
22305      checked: reversed || false,
22306      onChange: value => {
22307        setAttributes({
22308          // Unset the attribute if not reversed.
22309          reversed: value || undefined
22310        });
22311      }
22312    })));
22313  };
22314  
22315  /* harmony default export */ var ordered_list_settings = (OrderedListSettings);
22316  
22317  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/list/edit.js
22318  
22319  
22320  
22321  /**
22322   * WordPress dependencies
22323   */
22324  
22325  
22326  
22327  
22328  
22329  
22330  /**
22331   * Internal dependencies
22332   */
22333  
22334  
22335  
22336  function ListEdit(_ref) {
22337    let {
22338      attributes,
22339      setAttributes,
22340      mergeBlocks,
22341      onReplace,
22342      style
22343    } = _ref;
22344    const {
22345      ordered,
22346      values,
22347      type,
22348      reversed,
22349      start,
22350      placeholder
22351    } = attributes;
22352    const tagName = ordered ? 'ol' : 'ul';
22353  
22354    const controls = _ref2 => {
22355      let {
22356        value,
22357        onChange,
22358        onFocus
22359      } = _ref2;
22360      return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichTextShortcut, {
22361        type: "primary",
22362        character: "[",
22363        onUse: () => {
22364          onChange((0,external_wp_richText_namespaceObject.__unstableOutdentListItems)(value));
22365        }
22366      }), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichTextShortcut, {
22367        type: "primary",
22368        character: "]",
22369        onUse: () => {
22370          onChange((0,external_wp_richText_namespaceObject.__unstableIndentListItems)(value, {
22371            type: tagName
22372          }));
22373        }
22374      }), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichTextShortcut, {
22375        type: "primary",
22376        character: "m",
22377        onUse: () => {
22378          onChange((0,external_wp_richText_namespaceObject.__unstableIndentListItems)(value, {
22379            type: tagName
22380          }));
22381        }
22382      }), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichTextShortcut, {
22383        type: "primaryShift",
22384        character: "m",
22385        onUse: () => {
22386          onChange((0,external_wp_richText_namespaceObject.__unstableOutdentListItems)(value));
22387        }
22388      }), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, {
22389        group: "block"
22390      }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, {
22391        icon: (0,external_wp_i18n_namespaceObject.isRTL)() ? format_list_bullets_rtl : format_list_bullets,
22392        title: (0,external_wp_i18n_namespaceObject.__)('Unordered'),
22393        describedBy: (0,external_wp_i18n_namespaceObject.__)('Convert to unordered list'),
22394        isActive: (0,external_wp_richText_namespaceObject.__unstableIsActiveListType)(value, 'ul', tagName),
22395        onClick: () => {
22396          onChange((0,external_wp_richText_namespaceObject.__unstableChangeListType)(value, {
22397            type: 'ul'
22398          }));
22399          onFocus();
22400  
22401          if ((0,external_wp_richText_namespaceObject.__unstableIsListRootSelected)(value)) {
22402            setAttributes({
22403              ordered: false
22404            });
22405          }
22406        }
22407      }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, {
22408        icon: (0,external_wp_i18n_namespaceObject.isRTL)() ? format_list_numbered_rtl : format_list_numbered,
22409        title: (0,external_wp_i18n_namespaceObject.__)('Ordered'),
22410        describedBy: (0,external_wp_i18n_namespaceObject.__)('Convert to ordered list'),
22411        isActive: (0,external_wp_richText_namespaceObject.__unstableIsActiveListType)(value, 'ol', tagName),
22412        onClick: () => {
22413          onChange((0,external_wp_richText_namespaceObject.__unstableChangeListType)(value, {
22414            type: 'ol'
22415          }));
22416          onFocus();
22417  
22418          if ((0,external_wp_richText_namespaceObject.__unstableIsListRootSelected)(value)) {
22419            setAttributes({
22420              ordered: true
22421            });
22422          }
22423        }
22424      }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, {
22425        icon: (0,external_wp_i18n_namespaceObject.isRTL)() ? format_outdent_rtl : format_outdent,
22426        title: (0,external_wp_i18n_namespaceObject.__)('Outdent'),
22427        describedBy: (0,external_wp_i18n_namespaceObject.__)('Outdent list item'),
22428        shortcut: (0,external_wp_i18n_namespaceObject._x)('Backspace', 'keyboard key'),
22429        isDisabled: !(0,external_wp_richText_namespaceObject.__unstableCanOutdentListItems)(value),
22430        onClick: () => {
22431          onChange((0,external_wp_richText_namespaceObject.__unstableOutdentListItems)(value));
22432          onFocus();
22433        }
22434      }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, {
22435        icon: (0,external_wp_i18n_namespaceObject.isRTL)() ? format_indent_rtl : format_indent,
22436        title: (0,external_wp_i18n_namespaceObject.__)('Indent'),
22437        describedBy: (0,external_wp_i18n_namespaceObject.__)('Indent list item'),
22438        shortcut: (0,external_wp_i18n_namespaceObject._x)('Space', 'keyboard key'),
22439        isDisabled: !(0,external_wp_richText_namespaceObject.__unstableCanIndentListItems)(value),
22440        onClick: () => {
22441          onChange((0,external_wp_richText_namespaceObject.__unstableIndentListItems)(value, {
22442            type: tagName
22443          }));
22444          onFocus();
22445        }
22446      })));
22447    };
22448  
22449    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
22450      style
22451    });
22452    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText, _extends({
22453      identifier: "values",
22454      multiline: "li",
22455      tagName: tagName,
22456      onChange: nextValues => setAttributes({
22457        values: nextValues
22458      }),
22459      value: values,
22460      "aria-label": (0,external_wp_i18n_namespaceObject.__)('List text'),
22461      placeholder: placeholder || (0,external_wp_i18n_namespaceObject.__)('List'),
22462      onMerge: mergeBlocks,
22463      onSplit: value => (0,external_wp_blocks_namespaceObject.createBlock)(list_name, { ...attributes,
22464        values: value
22465      }),
22466      __unstableOnSplitMiddle: () => (0,external_wp_blocks_namespaceObject.createBlock)('core/paragraph'),
22467      onReplace: onReplace,
22468      onRemove: () => onReplace([]),
22469      start: start,
22470      reversed: reversed,
22471      type: type
22472    }, blockProps), controls), ordered && (0,external_wp_element_namespaceObject.createElement)(ordered_list_settings, {
22473      setAttributes: setAttributes,
22474      ordered: ordered,
22475      reversed: reversed,
22476      start: start,
22477      placeholder: placeholder
22478    }));
22479  }
22480  
22481  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/list/save.js
22482  
22483  
22484  /**
22485   * WordPress dependencies
22486   */
22487  
22488  function list_save_save(_ref) {
22489    let {
22490      attributes
22491    } = _ref;
22492    const {
22493      ordered,
22494      values,
22495      type,
22496      reversed,
22497      start
22498    } = attributes;
22499    const TagName = ordered ? 'ol' : 'ul';
22500    return (0,external_wp_element_namespaceObject.createElement)(TagName, external_wp_blockEditor_namespaceObject.useBlockProps.save({
22501      type,
22502      reversed,
22503      start
22504    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
22505      value: values,
22506      multiline: "li"
22507    }));
22508  }
22509  
22510  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/list/transforms.js
22511  /**
22512   * WordPress dependencies
22513   */
22514  
22515  
22516  
22517  function getListContentSchema(_ref) {
22518    let {
22519      phrasingContentSchema
22520    } = _ref;
22521    const listContentSchema = { ...phrasingContentSchema,
22522      ul: {},
22523      ol: {
22524        attributes: ['type', 'start', 'reversed']
22525      }
22526    }; // Recursion is needed.
22527    // Possible: ul > li > ul.
22528    // Impossible: ul > ul.
22529  
22530    ['ul', 'ol'].forEach(tag => {
22531      listContentSchema[tag].children = {
22532        li: {
22533          children: listContentSchema
22534        }
22535      };
22536    });
22537    return listContentSchema;
22538  }
22539  
22540  const list_transforms_transforms = {
22541    from: [{
22542      type: 'block',
22543      isMultiBlock: true,
22544      blocks: ['core/paragraph', 'core/heading'],
22545      transform: blockAttributes => {
22546        return (0,external_wp_blocks_namespaceObject.createBlock)('core/list', {
22547          values: (0,external_wp_richText_namespaceObject.toHTMLString)({
22548            value: (0,external_wp_richText_namespaceObject.join)(blockAttributes.map(_ref2 => {
22549              let {
22550                content
22551              } = _ref2;
22552              const value = (0,external_wp_richText_namespaceObject.create)({
22553                html: content
22554              });
22555  
22556              if (blockAttributes.length > 1) {
22557                return value;
22558              } // When converting only one block, transform
22559              // every line to a list item.
22560  
22561  
22562              return (0,external_wp_richText_namespaceObject.replace)(value, /\n/g, external_wp_richText_namespaceObject.__UNSTABLE_LINE_SEPARATOR);
22563            }), external_wp_richText_namespaceObject.__UNSTABLE_LINE_SEPARATOR),
22564            multilineTag: 'li'
22565          }),
22566          anchor: blockAttributes.anchor
22567        });
22568      }
22569    }, {
22570      type: 'block',
22571      blocks: ['core/quote', 'core/pullquote'],
22572      transform: _ref3 => {
22573        let {
22574          value,
22575          anchor
22576        } = _ref3;
22577        return (0,external_wp_blocks_namespaceObject.createBlock)('core/list', {
22578          values: (0,external_wp_richText_namespaceObject.toHTMLString)({
22579            value: (0,external_wp_richText_namespaceObject.create)({
22580              html: value,
22581              multilineTag: 'p'
22582            }),
22583            multilineTag: 'li'
22584          }),
22585          anchor
22586        });
22587      }
22588    }, {
22589      type: 'raw',
22590      selector: 'ol,ul',
22591      schema: args => ({
22592        ol: getListContentSchema(args).ol,
22593        ul: getListContentSchema(args).ul
22594      }),
22595  
22596      transform(node) {
22597        const attributes = {
22598          ordered: node.nodeName === 'OL',
22599          anchor: node.id === '' ? undefined : node.id
22600        };
22601  
22602        if (attributes.ordered) {
22603          const type = node.getAttribute('type');
22604  
22605          if (type) {
22606            attributes.type = type;
22607          }
22608  
22609          if (node.getAttribute('reversed') !== null) {
22610            attributes.reversed = true;
22611          }
22612  
22613          const start = parseInt(node.getAttribute('start'), 10);
22614  
22615          if (!isNaN(start) && ( // start=1 only makes sense if the list is reversed.
22616          start !== 1 || attributes.reversed)) {
22617            attributes.start = start;
22618          }
22619        }
22620  
22621        return (0,external_wp_blocks_namespaceObject.createBlock)('core/list', { ...(0,external_wp_blocks_namespaceObject.getBlockAttributes)('core/list', node.outerHTML),
22622          ...attributes
22623        });
22624      }
22625  
22626    }, ...['*', '-'].map(prefix => ({
22627      type: 'prefix',
22628      prefix,
22629  
22630      transform(content) {
22631        return (0,external_wp_blocks_namespaceObject.createBlock)('core/list', {
22632          values: `<li>$content}</li>`
22633        });
22634      }
22635  
22636    })), ...['1.', '1)'].map(prefix => ({
22637      type: 'prefix',
22638      prefix,
22639  
22640      transform(content) {
22641        return (0,external_wp_blocks_namespaceObject.createBlock)('core/list', {
22642          ordered: true,
22643          values: `<li>$content}</li>`
22644        });
22645      }
22646  
22647    }))],
22648    to: [{
22649      type: 'block',
22650      blocks: ['core/paragraph'],
22651      transform: _ref4 => {
22652        let {
22653          values
22654        } = _ref4;
22655        return (0,external_wp_richText_namespaceObject.split)((0,external_wp_richText_namespaceObject.create)({
22656          html: values,
22657          multilineTag: 'li',
22658          multilineWrapperTags: ['ul', 'ol']
22659        }), external_wp_richText_namespaceObject.__UNSTABLE_LINE_SEPARATOR).map(piece => (0,external_wp_blocks_namespaceObject.createBlock)('core/paragraph', {
22660          content: (0,external_wp_richText_namespaceObject.toHTMLString)({
22661            value: piece
22662          })
22663        }));
22664      }
22665    }, {
22666      type: 'block',
22667      blocks: ['core/heading'],
22668      transform: _ref5 => {
22669        let {
22670          values
22671        } = _ref5;
22672        return (0,external_wp_richText_namespaceObject.split)((0,external_wp_richText_namespaceObject.create)({
22673          html: values,
22674          multilineTag: 'li',
22675          multilineWrapperTags: ['ul', 'ol']
22676        }), external_wp_richText_namespaceObject.__UNSTABLE_LINE_SEPARATOR).map(piece => (0,external_wp_blocks_namespaceObject.createBlock)('core/heading', {
22677          content: (0,external_wp_richText_namespaceObject.toHTMLString)({
22678            value: piece
22679          })
22680        }));
22681      }
22682    }, {
22683      type: 'block',
22684      blocks: ['core/quote'],
22685      transform: _ref6 => {
22686        let {
22687          values,
22688          anchor
22689        } = _ref6;
22690        return (0,external_wp_blocks_namespaceObject.createBlock)('core/quote', {
22691          value: (0,external_wp_richText_namespaceObject.toHTMLString)({
22692            value: (0,external_wp_richText_namespaceObject.create)({
22693              html: values,
22694              multilineTag: 'li',
22695              multilineWrapperTags: ['ul', 'ol']
22696            }),
22697            multilineTag: 'p'
22698          }),
22699          anchor
22700        });
22701      }
22702    }, {
22703      type: 'block',
22704      blocks: ['core/pullquote'],
22705      transform: _ref7 => {
22706        let {
22707          values,
22708          anchor
22709        } = _ref7;
22710        return (0,external_wp_blocks_namespaceObject.createBlock)('core/pullquote', {
22711          value: (0,external_wp_richText_namespaceObject.toHTMLString)({
22712            value: (0,external_wp_richText_namespaceObject.create)({
22713              html: values,
22714              multilineTag: 'li',
22715              multilineWrapperTags: ['ul', 'ol']
22716            }),
22717            multilineTag: 'p'
22718          }),
22719          anchor
22720        });
22721      }
22722    }]
22723  };
22724  /* harmony default export */ var list_transforms = (list_transforms_transforms);
22725  
22726  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/list/index.js
22727  /**
22728   * WordPress dependencies
22729   */
22730  
22731  /**
22732   * Internal dependencies
22733   */
22734  
22735  
22736  
22737  const list_metadata = {
22738    $schema: "https://schemas.wp.org/trunk/block.json",
22739    apiVersion: 2,
22740    name: "core/list",
22741    title: "List",
22742    category: "text",
22743    description: "Create a bulleted or numbered list.",
22744    keywords: ["bullet list", "ordered list", "numbered list"],
22745    textdomain: "default",
22746    attributes: {
22747      ordered: {
22748        type: "boolean",
22749        "default": false,
22750        __experimentalRole: "content"
22751      },
22752      values: {
22753        type: "string",
22754        source: "html",
22755        selector: "ol,ul",
22756        multiline: "li",
22757        __unstableMultilineWrapperTags: ["ol", "ul"],
22758        "default": "",
22759        __experimentalRole: "content"
22760      },
22761      type: {
22762        type: "string"
22763      },
22764      start: {
22765        type: "number"
22766      },
22767      reversed: {
22768        type: "boolean"
22769      },
22770      placeholder: {
22771        type: "string"
22772      }
22773    },
22774    supports: {
22775      anchor: true,
22776      className: false,
22777      typography: {
22778        fontSize: true,
22779        __experimentalFontFamily: true,
22780        lineHeight: true,
22781        __experimentalFontStyle: true,
22782        __experimentalFontWeight: true,
22783        __experimentalLetterSpacing: true,
22784        __experimentalTextTransform: true,
22785        __experimentalDefaultControls: {
22786          fontSize: true
22787        }
22788      },
22789      color: {
22790        gradients: true,
22791        link: true,
22792        __experimentalDefaultControls: {
22793          background: true,
22794          text: true
22795        }
22796      },
22797      __unstablePasteTextInline: true,
22798      __experimentalSelector: "ol,ul",
22799      __experimentalSlashInserter: true
22800    },
22801    editorStyle: "wp-block-list-editor",
22802    style: "wp-block-list"
22803  };
22804  
22805  
22806  
22807  const {
22808    name: list_name
22809  } = list_metadata;
22810  
22811  const settingsV1 = {
22812    icon: library_list,
22813    example: {
22814      attributes: {
22815        values: '<li>Alice.</li><li>The White Rabbit.</li><li>The Cheshire Cat.</li><li>The Mad Hatter.</li><li>The Queen of Hearts.</li>'
22816      }
22817    },
22818    transforms: list_transforms,
22819  
22820    merge(attributes, attributesToMerge) {
22821      const {
22822        values
22823      } = attributesToMerge;
22824  
22825      if (!values || values === '<li></li>') {
22826        return attributes;
22827      }
22828  
22829      return { ...attributes,
22830        values: attributes.values + values
22831      };
22832    },
22833  
22834    edit: ListEdit,
22835    save: list_save_save,
22836    deprecated: list_deprecated
22837  };
22838  let list_settings = settingsV1;
22839  
22840  if (false) { var _window; }
22841  
22842  
22843  
22844  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/login.js
22845  
22846  
22847  /**
22848   * WordPress dependencies
22849   */
22850  
22851  const login = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
22852    xmlns: "http://www.w3.org/2000/svg",
22853    viewBox: "0 0 24 24"
22854  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
22855    d: "M11 14.5l1.1 1.1 3-3 .5-.5-.6-.6-3-3-1 1 1.7 1.7H5v1.5h7.7L11 14.5zM16.8 5h-7c-1.1 0-2 .9-2 2v1.5h1.5V7c0-.3.2-.5.5-.5h7c.3 0 .5.2.5.5v10c0 .3-.2.5-.5.5h-7c-.3 0-.5-.2-.5-.5v-1.5H7.8V17c0 1.1.9 2 2 2h7c1.1 0 2-.9 2-2V7c0-1.1-.9-2-2-2z"
22856  }));
22857  /* harmony default export */ var library_login = (login);
22858  
22859  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/loginout/edit.js
22860  
22861  
22862  /**
22863   * WordPress dependencies
22864   */
22865  
22866  
22867  
22868  function LoginOutEdit(_ref) {
22869    let {
22870      attributes,
22871      setAttributes
22872    } = _ref;
22873    const {
22874      displayLoginAsForm,
22875      redirectToCurrent
22876    } = attributes;
22877    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
22878      title: (0,external_wp_i18n_namespaceObject.__)('Login/out settings')
22879    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
22880      label: (0,external_wp_i18n_namespaceObject.__)('Display login as form'),
22881      checked: displayLoginAsForm,
22882      onChange: () => setAttributes({
22883        displayLoginAsForm: !displayLoginAsForm
22884      })
22885    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
22886      label: (0,external_wp_i18n_namespaceObject.__)('Redirect to current URL'),
22887      checked: redirectToCurrent,
22888      onChange: () => setAttributes({
22889        redirectToCurrent: !redirectToCurrent
22890      })
22891    }))), (0,external_wp_element_namespaceObject.createElement)("div", (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
22892      className: 'logged-in'
22893    }), (0,external_wp_element_namespaceObject.createElement)("a", {
22894      href: "#login-pseudo-link"
22895    }, (0,external_wp_i18n_namespaceObject.__)('Log out'))));
22896  }
22897  
22898  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/loginout/index.js
22899  /**
22900   * WordPress dependencies
22901   */
22902  
22903  /**
22904   * Internal dependencies
22905   */
22906  
22907  
22908  const loginout_metadata = {
22909    $schema: "https://schemas.wp.org/trunk/block.json",
22910    apiVersion: 2,
22911    name: "core/loginout",
22912    title: "Login/out",
22913    category: "theme",
22914    description: "Show login & logout links.",
22915    keywords: ["login", "logout", "form"],
22916    textdomain: "default",
22917    attributes: {
22918      displayLoginAsForm: {
22919        type: "boolean",
22920        "default": false
22921      },
22922      redirectToCurrent: {
22923        type: "boolean",
22924        "default": true
22925      }
22926    },
22927    supports: {
22928      className: true,
22929      typography: {
22930        fontSize: false
22931      }
22932    }
22933  };
22934  const {
22935    name: loginout_name
22936  } = loginout_metadata;
22937  
22938  const loginout_settings = {
22939    icon: library_login,
22940    edit: LoginOutEdit
22941  };
22942  
22943  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/media-and-text.js
22944  
22945  
22946  /**
22947   * WordPress dependencies
22948   */
22949  
22950  const mediaAndText = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
22951    xmlns: "http://www.w3.org/2000/svg",
22952    viewBox: "0 0 24 24"
22953  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
22954    d: "M3 18h8V6H3v12zM14 7.5V9h7V7.5h-7zm0 5.3h7v-1.5h-7v1.5zm0 3.7h7V15h-7v1.5z"
22955  }));
22956  /* harmony default export */ var media_and_text = (mediaAndText);
22957  
22958  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/media-text/media-container-icon.js
22959  
22960  
22961  /**
22962   * WordPress dependencies
22963   */
22964  
22965  /* harmony default export */ var media_container_icon = ((0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, {
22966    xmlns: "http://www.w3.org/2000/svg",
22967    viewBox: "0 0 24 24"
22968  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
22969    d: "M18 2l2 4h-2l-2-4h-3l2 4h-2l-2-4h-1a2 2 0 0 0-2 2v10a2 2 0 0 0 2 2h10a2 2 0 0 0 2-2V2zm2 12H10V4.4L11.8 8H20z"
22970  }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
22971    d: "M14 20H4V10h3V8H4a2 2 0 0 0-2 2v10a2 2 0 0 0 2 2h10a2 2 0 0 0 2-2v-3h-2z"
22972  }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
22973    d: "M5 19h8l-1.59-2H9.24l-.84 1.1L7 16.3 5 19z"
22974  })));
22975  
22976  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/media-text/media-container.js
22977  
22978  
22979  
22980  /**
22981   * External dependencies
22982   */
22983  
22984  
22985  /**
22986   * WordPress dependencies
22987   */
22988  
22989  
22990  
22991  
22992  
22993  
22994  
22995  
22996  /**
22997   * Internal dependencies
22998   */
22999  
23000  
23001  /**
23002   * Constants
23003   */
23004  
23005  const media_container_ALLOWED_MEDIA_TYPES = ['image', 'video'];
23006  function imageFillStyles(url, focalPoint) {
23007    return url ? {
23008      backgroundImage: `url($url})`,
23009      backgroundPosition: focalPoint ? `$focalPoint.x * 100}% $focalPoint.y * 100}%` : `50% 50%`
23010    } : {};
23011  }
23012  const ResizableBoxContainer = (0,external_wp_element_namespaceObject.forwardRef)((_ref, ref) => {
23013    let {
23014      isSelected,
23015      isStackedOnMobile,
23016      ...props
23017    } = _ref;
23018    const isMobile = (0,external_wp_compose_namespaceObject.useViewportMatch)('small', '<');
23019    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ResizableBox, _extends({
23020      ref: ref,
23021      showHandle: isSelected && (!isMobile || !isStackedOnMobile)
23022    }, props));
23023  });
23024  
23025  function ToolbarEditButton(_ref2) {
23026    let {
23027      mediaId,
23028      mediaUrl,
23029      onSelectMedia
23030    } = _ref2;
23031    return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, {
23032      group: "other"
23033    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.MediaReplaceFlow, {
23034      mediaId: mediaId,
23035      mediaURL: mediaUrl,
23036      allowedTypes: media_container_ALLOWED_MEDIA_TYPES,
23037      accept: "image/*,video/*",
23038      onSelect: onSelectMedia
23039    }));
23040  }
23041  
23042  function PlaceholderContainer(_ref3) {
23043    let {
23044      className,
23045      noticeOperations,
23046      noticeUI,
23047      mediaUrl,
23048      onSelectMedia
23049    } = _ref3;
23050  
23051    const onUploadError = message => {
23052      noticeOperations.removeAllNotices();
23053      noticeOperations.createErrorNotice(message);
23054    };
23055  
23056    return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.MediaPlaceholder, {
23057      icon: (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockIcon, {
23058        icon: media_container_icon
23059      }),
23060      labels: {
23061        title: (0,external_wp_i18n_namespaceObject.__)('Media area')
23062      },
23063      className: className,
23064      onSelect: onSelectMedia,
23065      accept: "image/*,video/*",
23066      allowedTypes: media_container_ALLOWED_MEDIA_TYPES,
23067      notices: noticeUI,
23068      onError: onUploadError,
23069      disableMediaButtons: mediaUrl
23070    });
23071  }
23072  
23073  function MediaContainer(props, ref) {
23074    const {
23075      className,
23076      commitWidthChange,
23077      focalPoint,
23078      imageFill,
23079      isSelected,
23080      isStackedOnMobile,
23081      mediaAlt,
23082      mediaId,
23083      mediaPosition,
23084      mediaType,
23085      mediaUrl,
23086      mediaWidth,
23087      onSelectMedia,
23088      onWidthChange
23089    } = props;
23090    const isTemporaryMedia = !mediaId && (0,external_wp_blob_namespaceObject.isBlobURL)(mediaUrl);
23091    const {
23092      toggleSelection
23093    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_blockEditor_namespaceObject.store);
23094  
23095    if (mediaUrl) {
23096      const onResizeStart = () => {
23097        toggleSelection(false);
23098      };
23099  
23100      const onResize = (event, direction, elt) => {
23101        onWidthChange(parseInt(elt.style.width));
23102      };
23103  
23104      const onResizeStop = (event, direction, elt) => {
23105        toggleSelection(true);
23106        commitWidthChange(parseInt(elt.style.width));
23107      };
23108  
23109      const enablePositions = {
23110        right: mediaPosition === 'left',
23111        left: mediaPosition === 'right'
23112      };
23113      const backgroundStyles = mediaType === 'image' && imageFill ? imageFillStyles(mediaUrl, focalPoint) : {};
23114      const mediaTypeRenderers = {
23115        image: () => (0,external_wp_element_namespaceObject.createElement)("img", {
23116          src: mediaUrl,
23117          alt: mediaAlt
23118        }),
23119        video: () => (0,external_wp_element_namespaceObject.createElement)("video", {
23120          controls: true,
23121          src: mediaUrl
23122        })
23123      };
23124      return (0,external_wp_element_namespaceObject.createElement)(ResizableBoxContainer, {
23125        as: "figure",
23126        className: classnames_default()(className, 'editor-media-container__resizer', {
23127          'is-transient': isTemporaryMedia
23128        }),
23129        style: backgroundStyles,
23130        size: {
23131          width: mediaWidth + '%'
23132        },
23133        minWidth: "10%",
23134        maxWidth: "100%",
23135        enable: enablePositions,
23136        onResizeStart: onResizeStart,
23137        onResize: onResize,
23138        onResizeStop: onResizeStop,
23139        axis: "x",
23140        isSelected: isSelected,
23141        isStackedOnMobile: isStackedOnMobile,
23142        ref: ref
23143      }, (0,external_wp_element_namespaceObject.createElement)(ToolbarEditButton, {
23144        onSelectMedia: onSelectMedia,
23145        mediaUrl: mediaUrl,
23146        mediaId: mediaId
23147      }), (mediaTypeRenderers[mediaType] || external_lodash_namespaceObject.noop)(), isTemporaryMedia && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Spinner, null), (0,external_wp_element_namespaceObject.createElement)(PlaceholderContainer, props));
23148    }
23149  
23150    return (0,external_wp_element_namespaceObject.createElement)(PlaceholderContainer, props);
23151  }
23152  
23153  /* harmony default export */ var media_container = ((0,external_wp_components_namespaceObject.withNotices)((0,external_wp_element_namespaceObject.forwardRef)(MediaContainer)));
23154  
23155  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/media-text/deprecated.js
23156  
23157  
23158  /**
23159   * External dependencies
23160   */
23161  
23162  
23163  /**
23164   * WordPress dependencies
23165   */
23166  
23167  
23168  /**
23169   * Internal dependencies
23170   */
23171  
23172  
23173  const DEFAULT_MEDIA_WIDTH = 50;
23174  
23175  const media_text_deprecated_migrateCustomColors = attributes => {
23176    if (!attributes.customBackgroundColor) {
23177      return attributes;
23178    }
23179  
23180    const style = {
23181      color: {
23182        background: attributes.customBackgroundColor
23183      }
23184    };
23185    return { ...(0,external_lodash_namespaceObject.omit)(attributes, ['customBackgroundColor']),
23186      style
23187    };
23188  };
23189  
23190  const baseAttributes = {
23191    align: {
23192      type: 'string',
23193      default: 'wide'
23194    },
23195    backgroundColor: {
23196      type: 'string'
23197    },
23198    mediaAlt: {
23199      type: 'string',
23200      source: 'attribute',
23201      selector: 'figure img',
23202      attribute: 'alt',
23203      default: ''
23204    },
23205    mediaPosition: {
23206      type: 'string',
23207      default: 'left'
23208    },
23209    mediaId: {
23210      type: 'number'
23211    },
23212    mediaType: {
23213      type: 'string'
23214    },
23215    mediaWidth: {
23216      type: 'number',
23217      default: 50
23218    },
23219    isStackedOnMobile: {
23220      type: 'boolean',
23221      default: true
23222    }
23223  };
23224  /* harmony default export */ var media_text_deprecated = ([{
23225    attributes: { ...baseAttributes,
23226      customBackgroundColor: {
23227        type: 'string'
23228      },
23229      mediaLink: {
23230        type: 'string'
23231      },
23232      linkDestination: {
23233        type: 'string'
23234      },
23235      linkTarget: {
23236        type: 'string',
23237        source: 'attribute',
23238        selector: 'figure a',
23239        attribute: 'target'
23240      },
23241      href: {
23242        type: 'string',
23243        source: 'attribute',
23244        selector: 'figure a',
23245        attribute: 'href'
23246      },
23247      rel: {
23248        type: 'string',
23249        source: 'attribute',
23250        selector: 'figure a',
23251        attribute: 'rel'
23252      },
23253      linkClass: {
23254        type: 'string',
23255        source: 'attribute',
23256        selector: 'figure a',
23257        attribute: 'class'
23258      },
23259      verticalAlignment: {
23260        type: 'string'
23261      },
23262      imageFill: {
23263        type: 'boolean'
23264      },
23265      focalPoint: {
23266        type: 'object'
23267      }
23268    },
23269    migrate: media_text_deprecated_migrateCustomColors,
23270  
23271    save(_ref) {
23272      let {
23273        attributes
23274      } = _ref;
23275      const {
23276        backgroundColor,
23277        customBackgroundColor,
23278        isStackedOnMobile,
23279        mediaAlt,
23280        mediaPosition,
23281        mediaType,
23282        mediaUrl,
23283        mediaWidth,
23284        mediaId,
23285        verticalAlignment,
23286        imageFill,
23287        focalPoint,
23288        linkClass,
23289        href,
23290        linkTarget,
23291        rel
23292      } = attributes;
23293      const newRel = (0,external_lodash_namespaceObject.isEmpty)(rel) ? undefined : rel;
23294      let image = (0,external_wp_element_namespaceObject.createElement)("img", {
23295        src: mediaUrl,
23296        alt: mediaAlt,
23297        className: mediaId && mediaType === 'image' ? `wp-image-$mediaId}` : null
23298      });
23299  
23300      if (href) {
23301        image = (0,external_wp_element_namespaceObject.createElement)("a", {
23302          className: linkClass,
23303          href: href,
23304          target: linkTarget,
23305          rel: newRel
23306        }, image);
23307      }
23308  
23309      const mediaTypeRenders = {
23310        image: () => image,
23311        video: () => (0,external_wp_element_namespaceObject.createElement)("video", {
23312          controls: true,
23313          src: mediaUrl
23314        })
23315      };
23316      const backgroundClass = (0,external_wp_blockEditor_namespaceObject.getColorClassName)('background-color', backgroundColor);
23317      const className = classnames_default()({
23318        'has-media-on-the-right': 'right' === mediaPosition,
23319        'has-background': backgroundClass || customBackgroundColor,
23320        [backgroundClass]: backgroundClass,
23321        'is-stacked-on-mobile': isStackedOnMobile,
23322        [`is-vertically-aligned-$verticalAlignment}`]: verticalAlignment,
23323        'is-image-fill': imageFill
23324      });
23325      const backgroundStyles = imageFill ? imageFillStyles(mediaUrl, focalPoint) : {};
23326      let gridTemplateColumns;
23327  
23328      if (mediaWidth !== DEFAULT_MEDIA_WIDTH) {
23329        gridTemplateColumns = 'right' === mediaPosition ? `auto $mediaWidth}%` : `$mediaWidth}% auto`;
23330      }
23331  
23332      const style = {
23333        backgroundColor: backgroundClass ? undefined : customBackgroundColor,
23334        gridTemplateColumns
23335      };
23336      return (0,external_wp_element_namespaceObject.createElement)("div", {
23337        className: className,
23338        style: style
23339      }, (0,external_wp_element_namespaceObject.createElement)("figure", {
23340        className: "wp-block-media-text__media",
23341        style: backgroundStyles
23342      }, (mediaTypeRenders[mediaType] || external_lodash_namespaceObject.noop)()), (0,external_wp_element_namespaceObject.createElement)("div", {
23343        className: "wp-block-media-text__content"
23344      }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InnerBlocks.Content, null)));
23345    }
23346  
23347  }, {
23348    attributes: { ...baseAttributes,
23349      customBackgroundColor: {
23350        type: 'string'
23351      },
23352      mediaUrl: {
23353        type: 'string',
23354        source: 'attribute',
23355        selector: 'figure video,figure img',
23356        attribute: 'src'
23357      },
23358      verticalAlignment: {
23359        type: 'string'
23360      },
23361      imageFill: {
23362        type: 'boolean'
23363      },
23364      focalPoint: {
23365        type: 'object'
23366      }
23367    },
23368    migrate: media_text_deprecated_migrateCustomColors,
23369  
23370    save(_ref2) {
23371      let {
23372        attributes
23373      } = _ref2;
23374      const {
23375        backgroundColor,
23376        customBackgroundColor,
23377        isStackedOnMobile,
23378        mediaAlt,
23379        mediaPosition,
23380        mediaType,
23381        mediaUrl,
23382        mediaWidth,
23383        mediaId,
23384        verticalAlignment,
23385        imageFill,
23386        focalPoint
23387      } = attributes;
23388      const mediaTypeRenders = {
23389        image: () => (0,external_wp_element_namespaceObject.createElement)("img", {
23390          src: mediaUrl,
23391          alt: mediaAlt,
23392          className: mediaId && mediaType === 'image' ? `wp-image-$mediaId}` : null
23393        }),
23394        video: () => (0,external_wp_element_namespaceObject.createElement)("video", {
23395          controls: true,
23396          src: mediaUrl
23397        })
23398      };
23399      const backgroundClass = (0,external_wp_blockEditor_namespaceObject.getColorClassName)('background-color', backgroundColor);
23400      const className = classnames_default()({
23401        'has-media-on-the-right': 'right' === mediaPosition,
23402        [backgroundClass]: backgroundClass,
23403        'is-stacked-on-mobile': isStackedOnMobile,
23404        [`is-vertically-aligned-$verticalAlignment}`]: verticalAlignment,
23405        'is-image-fill': imageFill
23406      });
23407      const backgroundStyles = imageFill ? imageFillStyles(mediaUrl, focalPoint) : {};
23408      let gridTemplateColumns;
23409  
23410      if (mediaWidth !== DEFAULT_MEDIA_WIDTH) {
23411        gridTemplateColumns = 'right' === mediaPosition ? `auto $mediaWidth}%` : `$mediaWidth}% auto`;
23412      }
23413  
23414      const style = {
23415        backgroundColor: backgroundClass ? undefined : customBackgroundColor,
23416        gridTemplateColumns
23417      };
23418      return (0,external_wp_element_namespaceObject.createElement)("div", {
23419        className: className,
23420        style: style
23421      }, (0,external_wp_element_namespaceObject.createElement)("figure", {
23422        className: "wp-block-media-text__media",
23423        style: backgroundStyles
23424      }, (mediaTypeRenders[mediaType] || external_lodash_namespaceObject.noop)()), (0,external_wp_element_namespaceObject.createElement)("div", {
23425        className: "wp-block-media-text__content"
23426      }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InnerBlocks.Content, null)));
23427    }
23428  
23429  }, {
23430    attributes: { ...baseAttributes,
23431      customBackgroundColor: {
23432        type: 'string'
23433      },
23434      mediaUrl: {
23435        type: 'string',
23436        source: 'attribute',
23437        selector: 'figure video,figure img',
23438        attribute: 'src'
23439      }
23440    },
23441  
23442    save(_ref3) {
23443      let {
23444        attributes
23445      } = _ref3;
23446      const {
23447        backgroundColor,
23448        customBackgroundColor,
23449        isStackedOnMobile,
23450        mediaAlt,
23451        mediaPosition,
23452        mediaType,
23453        mediaUrl,
23454        mediaWidth
23455      } = attributes;
23456      const mediaTypeRenders = {
23457        image: () => (0,external_wp_element_namespaceObject.createElement)("img", {
23458          src: mediaUrl,
23459          alt: mediaAlt
23460        }),
23461        video: () => (0,external_wp_element_namespaceObject.createElement)("video", {
23462          controls: true,
23463          src: mediaUrl
23464        })
23465      };
23466      const backgroundClass = (0,external_wp_blockEditor_namespaceObject.getColorClassName)('background-color', backgroundColor);
23467      const className = classnames_default()({
23468        'has-media-on-the-right': 'right' === mediaPosition,
23469        [backgroundClass]: backgroundClass,
23470        'is-stacked-on-mobile': isStackedOnMobile
23471      });
23472      let gridTemplateColumns;
23473  
23474      if (mediaWidth !== DEFAULT_MEDIA_WIDTH) {
23475        gridTemplateColumns = 'right' === mediaPosition ? `auto $mediaWidth}%` : `$mediaWidth}% auto`;
23476      }
23477  
23478      const style = {
23479        backgroundColor: backgroundClass ? undefined : customBackgroundColor,
23480        gridTemplateColumns
23481      };
23482      return (0,external_wp_element_namespaceObject.createElement)("div", {
23483        className: className,
23484        style: style
23485      }, (0,external_wp_element_namespaceObject.createElement)("figure", {
23486        className: "wp-block-media-text__media"
23487      }, (mediaTypeRenders[mediaType] || external_lodash_namespaceObject.noop)()), (0,external_wp_element_namespaceObject.createElement)("div", {
23488        className: "wp-block-media-text__content"
23489      }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InnerBlocks.Content, null)));
23490    }
23491  
23492  }]);
23493  
23494  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/pull-left.js
23495  
23496  
23497  /**
23498   * WordPress dependencies
23499   */
23500  
23501  const pullLeft = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
23502    xmlns: "http://www.w3.org/2000/svg",
23503    viewBox: "0 0 24 24"
23504  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
23505    d: "M4 18h6V6H4v12zm9-9.5V10h7V8.5h-7zm0 7h7V14h-7v1.5z"
23506  }));
23507  /* harmony default export */ var pull_left = (pullLeft);
23508  
23509  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/pull-right.js
23510  
23511  
23512  /**
23513   * WordPress dependencies
23514   */
23515  
23516  const pullRight = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
23517    xmlns: "http://www.w3.org/2000/svg",
23518    viewBox: "0 0 24 24"
23519  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
23520    d: "M14 6v12h6V6h-6zM4 10h7V8.5H4V10zm0 5.5h7V14H4v1.5z"
23521  }));
23522  /* harmony default export */ var pull_right = (pullRight);
23523  
23524  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/media-text/constants.js
23525  const DEFAULT_MEDIA_SIZE_SLUG = 'full';
23526  
23527  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/media-text/edit.js
23528  
23529  
23530  /**
23531   * External dependencies
23532   */
23533  
23534  
23535  /**
23536   * WordPress dependencies
23537   */
23538  
23539  
23540  
23541  
23542  
23543  
23544  
23545  
23546  
23547  /**
23548   * Internal dependencies
23549   */
23550  
23551  
23552  
23553  /**
23554   * Constants
23555   */
23556  
23557  const media_text_edit_TEMPLATE = [['core/paragraph', {
23558    fontSize: 'large',
23559    placeholder: (0,external_wp_i18n_namespaceObject._x)('Content…', 'content placeholder')
23560  }]]; // this limits the resize to a safe zone to avoid making broken layouts
23561  
23562  const WIDTH_CONSTRAINT_PERCENTAGE = 15;
23563  
23564  const applyWidthConstraints = width => Math.max(WIDTH_CONSTRAINT_PERCENTAGE, Math.min(width, 100 - WIDTH_CONSTRAINT_PERCENTAGE));
23565  
23566  const edit_LINK_DESTINATION_MEDIA = 'media';
23567  const edit_LINK_DESTINATION_ATTACHMENT = 'attachment';
23568  
23569  function getImageSourceUrlBySizeSlug(image, slug) {
23570    var _image$media_details, _image$media_details$, _image$media_details$2;
23571  
23572    // eslint-disable-next-line camelcase
23573    return image === null || image === void 0 ? void 0 : (_image$media_details = image.media_details) === null || _image$media_details === void 0 ? void 0 : (_image$media_details$ = _image$media_details.sizes) === null || _image$media_details$ === void 0 ? void 0 : (_image$media_details$2 = _image$media_details$[slug]) === null || _image$media_details$2 === void 0 ? void 0 : _image$media_details$2.source_url;
23574  }
23575  
23576  function edit_attributesFromMedia(_ref) {
23577    let {
23578      attributes: {
23579        linkDestination,
23580        href
23581      },
23582      setAttributes
23583    } = _ref;
23584    return media => {
23585      if (!media || !media.url) {
23586        setAttributes({
23587          mediaAlt: undefined,
23588          mediaId: undefined,
23589          mediaType: undefined,
23590          mediaUrl: undefined,
23591          mediaLink: undefined,
23592          href: undefined,
23593          focalPoint: undefined
23594        });
23595        return;
23596      }
23597  
23598      if ((0,external_wp_blob_namespaceObject.isBlobURL)(media.url)) {
23599        media.type = (0,external_wp_blob_namespaceObject.getBlobTypeByURL)(media.url);
23600      }
23601  
23602      let mediaType;
23603      let src; // For media selections originated from a file upload.
23604  
23605      if (media.media_type) {
23606        if (media.media_type === 'image') {
23607          mediaType = 'image';
23608        } else {
23609          // only images and videos are accepted so if the media_type is not an image we can assume it is a video.
23610          // video contain the media type of 'file' in the object returned from the rest api.
23611          mediaType = 'video';
23612        }
23613      } else {
23614        // For media selections originated from existing files in the media library.
23615        mediaType = media.type;
23616      }
23617  
23618      if (mediaType === 'image') {
23619        var _media$sizes, _media$sizes$large, _media$media_details, _media$media_details$, _media$media_details$2;
23620  
23621        // Try the "large" size URL, falling back to the "full" size URL below.
23622        src = ((_media$sizes = media.sizes) === null || _media$sizes === void 0 ? void 0 : (_media$sizes$large = _media$sizes.large) === null || _media$sizes$large === void 0 ? void 0 : _media$sizes$large.url) || ( // eslint-disable-next-line camelcase
23623        (_media$media_details = media.media_details) === null || _media$media_details === void 0 ? void 0 : (_media$media_details$ = _media$media_details.sizes) === null || _media$media_details$ === void 0 ? void 0 : (_media$media_details$2 = _media$media_details$.large) === null || _media$media_details$2 === void 0 ? void 0 : _media$media_details$2.source_url);
23624      }
23625  
23626      let newHref = href;
23627  
23628      if (linkDestination === edit_LINK_DESTINATION_MEDIA) {
23629        // Update the media link.
23630        newHref = media.url;
23631      } // Check if the image is linked to the attachment page.
23632  
23633  
23634      if (linkDestination === edit_LINK_DESTINATION_ATTACHMENT) {
23635        // Update the media link.
23636        newHref = media.link;
23637      }
23638  
23639      setAttributes({
23640        mediaAlt: media.alt,
23641        mediaId: media.id,
23642        mediaType,
23643        mediaUrl: src || media.url,
23644        mediaLink: media.link || undefined,
23645        href: newHref,
23646        focalPoint: undefined
23647      });
23648    };
23649  }
23650  
23651  function MediaTextEdit(_ref2) {
23652    let {
23653      attributes,
23654      isSelected,
23655      setAttributes
23656    } = _ref2;
23657    const {
23658      focalPoint,
23659      href,
23660      imageFill,
23661      isStackedOnMobile,
23662      linkClass,
23663      linkDestination,
23664      linkTarget,
23665      mediaAlt,
23666      mediaId,
23667      mediaPosition,
23668      mediaType,
23669      mediaUrl,
23670      mediaWidth,
23671      rel,
23672      verticalAlignment
23673    } = attributes;
23674    const mediaSizeSlug = attributes.mediaSizeSlug || DEFAULT_MEDIA_SIZE_SLUG;
23675    const image = (0,external_wp_data_namespaceObject.useSelect)(select => mediaId && isSelected ? select(external_wp_coreData_namespaceObject.store).getMedia(mediaId, {
23676      context: 'view'
23677    }) : null, [isSelected, mediaId]);
23678    const refMediaContainer = (0,external_wp_element_namespaceObject.useRef)();
23679  
23680    const imperativeFocalPointPreview = value => {
23681      const {
23682        style
23683      } = refMediaContainer.current.resizable;
23684      const {
23685        x,
23686        y
23687      } = value;
23688      style.backgroundPosition = `$x * 100}% $y * 100}%`;
23689    };
23690  
23691    const [temporaryMediaWidth, setTemporaryMediaWidth] = (0,external_wp_element_namespaceObject.useState)(null);
23692    const onSelectMedia = edit_attributesFromMedia({
23693      attributes,
23694      setAttributes
23695    });
23696  
23697    const onSetHref = props => {
23698      setAttributes(props);
23699    };
23700  
23701    const onWidthChange = width => {
23702      setTemporaryMediaWidth(applyWidthConstraints(width));
23703    };
23704  
23705    const commitWidthChange = width => {
23706      setAttributes({
23707        mediaWidth: applyWidthConstraints(width)
23708      });
23709      setTemporaryMediaWidth(applyWidthConstraints(width));
23710    };
23711  
23712    const classNames = classnames_default()({
23713      'has-media-on-the-right': 'right' === mediaPosition,
23714      'is-selected': isSelected,
23715      'is-stacked-on-mobile': isStackedOnMobile,
23716      [`is-vertically-aligned-$verticalAlignment}`]: verticalAlignment,
23717      'is-image-fill': imageFill
23718    });
23719    const widthString = `$temporaryMediaWidth || mediaWidth}%`;
23720    const gridTemplateColumns = 'right' === mediaPosition ? `1fr $widthString}` : `$widthString} 1fr`;
23721    const style = {
23722      gridTemplateColumns,
23723      msGridColumns: gridTemplateColumns
23724    };
23725  
23726    const onMediaAltChange = newMediaAlt => {
23727      setAttributes({
23728        mediaAlt: newMediaAlt
23729      });
23730    };
23731  
23732    const onVerticalAlignmentChange = alignment => {
23733      setAttributes({
23734        verticalAlignment: alignment
23735      });
23736    };
23737  
23738    const imageSizes = (0,external_wp_data_namespaceObject.useSelect)(select => {
23739      const settings = select(external_wp_blockEditor_namespaceObject.store).getSettings();
23740      return settings === null || settings === void 0 ? void 0 : settings.imageSizes;
23741    }, []);
23742    const imageSizeOptions = (0,external_lodash_namespaceObject.map)((0,external_lodash_namespaceObject.filter)(imageSizes, _ref3 => {
23743      let {
23744        slug
23745      } = _ref3;
23746      return getImageSourceUrlBySizeSlug(image, slug);
23747    }), _ref4 => {
23748      let {
23749        name,
23750        slug
23751      } = _ref4;
23752      return {
23753        value: slug,
23754        label: name
23755      };
23756    });
23757  
23758    const updateImage = newMediaSizeSlug => {
23759      const newUrl = getImageSourceUrlBySizeSlug(image, newMediaSizeSlug);
23760  
23761      if (!newUrl) {
23762        return null;
23763      }
23764  
23765      setAttributes({
23766        mediaUrl: newUrl,
23767        mediaSizeSlug: newMediaSizeSlug
23768      });
23769    };
23770  
23771    const mediaTextGeneralSettings = (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
23772      title: (0,external_wp_i18n_namespaceObject.__)('Media & Text settings')
23773    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
23774      label: (0,external_wp_i18n_namespaceObject.__)('Stack on mobile'),
23775      checked: isStackedOnMobile,
23776      onChange: () => setAttributes({
23777        isStackedOnMobile: !isStackedOnMobile
23778      })
23779    }), mediaType === 'image' && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
23780      label: (0,external_wp_i18n_namespaceObject.__)('Crop image to fill entire column'),
23781      checked: imageFill,
23782      onChange: () => setAttributes({
23783        imageFill: !imageFill
23784      })
23785    }), imageFill && mediaUrl && mediaType === 'image' && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.FocalPointPicker, {
23786      label: (0,external_wp_i18n_namespaceObject.__)('Focal point picker'),
23787      url: mediaUrl,
23788      value: focalPoint,
23789      onChange: value => setAttributes({
23790        focalPoint: value
23791      }),
23792      onDragStart: imperativeFocalPointPreview,
23793      onDrag: imperativeFocalPointPreview
23794    }), mediaType === 'image' && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TextareaControl, {
23795      label: (0,external_wp_i18n_namespaceObject.__)('Alt text (alternative text)'),
23796      value: mediaAlt,
23797      onChange: onMediaAltChange,
23798      help: (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ExternalLink, {
23799        href: "https://www.w3.org/WAI/tutorials/images/decision-tree"
23800      }, (0,external_wp_i18n_namespaceObject.__)('Describe the purpose of the image')), (0,external_wp_i18n_namespaceObject.__)('Leave empty if the image is purely decorative.'))
23801    }), mediaType === 'image' && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.__experimentalImageSizeControl, {
23802      onChangeImage: updateImage,
23803      slug: mediaSizeSlug,
23804      imageSizeOptions: imageSizeOptions,
23805      isResizable: false
23806    }), mediaUrl && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.RangeControl, {
23807      label: (0,external_wp_i18n_namespaceObject.__)('Media width'),
23808      value: temporaryMediaWidth || mediaWidth,
23809      onChange: commitWidthChange,
23810      min: WIDTH_CONSTRAINT_PERCENTAGE,
23811      max: 100 - WIDTH_CONSTRAINT_PERCENTAGE
23812    }));
23813    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
23814      className: classNames,
23815      style
23816    });
23817    const innerBlocksProps = (0,external_wp_blockEditor_namespaceObject.useInnerBlocksProps)({
23818      className: 'wp-block-media-text__content'
23819    }, {
23820      template: media_text_edit_TEMPLATE
23821    });
23822    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, mediaTextGeneralSettings), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, {
23823      group: "block"
23824    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockVerticalAlignmentControl, {
23825      onChange: onVerticalAlignmentChange,
23826      value: verticalAlignment
23827    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, {
23828      icon: pull_left,
23829      title: (0,external_wp_i18n_namespaceObject.__)('Show media on left'),
23830      isActive: mediaPosition === 'left',
23831      onClick: () => setAttributes({
23832        mediaPosition: 'left'
23833      })
23834    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, {
23835      icon: pull_right,
23836      title: (0,external_wp_i18n_namespaceObject.__)('Show media on right'),
23837      isActive: mediaPosition === 'right',
23838      onClick: () => setAttributes({
23839        mediaPosition: 'right'
23840      })
23841    }), mediaType === 'image' && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.__experimentalImageURLInputUI, {
23842      url: href || '',
23843      onChangeUrl: onSetHref,
23844      linkDestination: linkDestination,
23845      mediaType: mediaType,
23846      mediaUrl: image && image.source_url,
23847      mediaLink: image && image.link,
23848      linkTarget: linkTarget,
23849      linkClass: linkClass,
23850      rel: rel
23851    })), (0,external_wp_element_namespaceObject.createElement)("div", blockProps, (0,external_wp_element_namespaceObject.createElement)(media_container, {
23852      className: "wp-block-media-text__media",
23853      onSelectMedia: onSelectMedia,
23854      onWidthChange: onWidthChange,
23855      commitWidthChange: commitWidthChange,
23856      ref: refMediaContainer,
23857      focalPoint,
23858      imageFill,
23859      isSelected,
23860      isStackedOnMobile,
23861      mediaAlt,
23862      mediaId,
23863      mediaPosition,
23864      mediaType,
23865      mediaUrl,
23866      mediaWidth
23867    }), (0,external_wp_element_namespaceObject.createElement)("div", innerBlocksProps)));
23868  }
23869  
23870  /* harmony default export */ var media_text_edit = (MediaTextEdit);
23871  
23872  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/media-text/save.js
23873  
23874  
23875  /**
23876   * External dependencies
23877   */
23878  
23879  
23880  /**
23881   * WordPress dependencies
23882   */
23883  
23884  
23885  /**
23886   * Internal dependencies
23887   */
23888  
23889  
23890  
23891  const save_DEFAULT_MEDIA_WIDTH = 50;
23892  function media_text_save_save(_ref) {
23893    let {
23894      attributes
23895    } = _ref;
23896    const {
23897      isStackedOnMobile,
23898      mediaAlt,
23899      mediaPosition,
23900      mediaType,
23901      mediaUrl,
23902      mediaWidth,
23903      mediaId,
23904      verticalAlignment,
23905      imageFill,
23906      focalPoint,
23907      linkClass,
23908      href,
23909      linkTarget,
23910      rel
23911    } = attributes;
23912    const mediaSizeSlug = attributes.mediaSizeSlug || DEFAULT_MEDIA_SIZE_SLUG;
23913    const newRel = (0,external_lodash_namespaceObject.isEmpty)(rel) ? undefined : rel;
23914    const imageClasses = classnames_default()({
23915      [`wp-image-$mediaId}`]: mediaId && mediaType === 'image',
23916      [`size-$mediaSizeSlug}`]: mediaId && mediaType === 'image'
23917    });
23918    let image = (0,external_wp_element_namespaceObject.createElement)("img", {
23919      src: mediaUrl,
23920      alt: mediaAlt,
23921      className: imageClasses || null
23922    });
23923  
23924    if (href) {
23925      image = (0,external_wp_element_namespaceObject.createElement)("a", {
23926        className: linkClass,
23927        href: href,
23928        target: linkTarget,
23929        rel: newRel
23930      }, image);
23931    }
23932  
23933    const mediaTypeRenders = {
23934      image: () => image,
23935      video: () => (0,external_wp_element_namespaceObject.createElement)("video", {
23936        controls: true,
23937        src: mediaUrl
23938      })
23939    };
23940    const className = classnames_default()({
23941      'has-media-on-the-right': 'right' === mediaPosition,
23942      'is-stacked-on-mobile': isStackedOnMobile,
23943      [`is-vertically-aligned-$verticalAlignment}`]: verticalAlignment,
23944      'is-image-fill': imageFill
23945    });
23946    const backgroundStyles = imageFill ? imageFillStyles(mediaUrl, focalPoint) : {};
23947    let gridTemplateColumns;
23948  
23949    if (mediaWidth !== save_DEFAULT_MEDIA_WIDTH) {
23950      gridTemplateColumns = 'right' === mediaPosition ? `auto $mediaWidth}%` : `$mediaWidth}% auto`;
23951    }
23952  
23953    const style = {
23954      gridTemplateColumns
23955    };
23956    return (0,external_wp_element_namespaceObject.createElement)("div", external_wp_blockEditor_namespaceObject.useBlockProps.save({
23957      className,
23958      style
23959    }), (0,external_wp_element_namespaceObject.createElement)("figure", {
23960      className: "wp-block-media-text__media",
23961      style: backgroundStyles
23962    }, (mediaTypeRenders[mediaType] || external_lodash_namespaceObject.noop)()), (0,external_wp_element_namespaceObject.createElement)("div", external_wp_blockEditor_namespaceObject.useInnerBlocksProps.save({
23963      className: 'wp-block-media-text__content'
23964    })));
23965  }
23966  
23967  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/media-text/transforms.js
23968  /**
23969   * WordPress dependencies
23970   */
23971  
23972  const media_text_transforms_transforms = {
23973    from: [{
23974      type: 'block',
23975      blocks: ['core/image'],
23976      transform: _ref => {
23977        let {
23978          alt,
23979          url,
23980          id,
23981          anchor
23982        } = _ref;
23983        return (0,external_wp_blocks_namespaceObject.createBlock)('core/media-text', {
23984          mediaAlt: alt,
23985          mediaId: id,
23986          mediaUrl: url,
23987          mediaType: 'image',
23988          anchor
23989        });
23990      }
23991    }, {
23992      type: 'block',
23993      blocks: ['core/video'],
23994      transform: _ref2 => {
23995        let {
23996          src,
23997          id,
23998          anchor
23999        } = _ref2;
24000        return (0,external_wp_blocks_namespaceObject.createBlock)('core/media-text', {
24001          mediaId: id,
24002          mediaUrl: src,
24003          mediaType: 'video',
24004          anchor
24005        });
24006      }
24007    }],
24008    to: [{
24009      type: 'block',
24010      blocks: ['core/image'],
24011      isMatch: _ref3 => {
24012        let {
24013          mediaType,
24014          mediaUrl
24015        } = _ref3;
24016        return !mediaUrl || mediaType === 'image';
24017      },
24018      transform: _ref4 => {
24019        let {
24020          mediaAlt,
24021          mediaId,
24022          mediaUrl,
24023          anchor
24024        } = _ref4;
24025        return (0,external_wp_blocks_namespaceObject.createBlock)('core/image', {
24026          alt: mediaAlt,
24027          id: mediaId,
24028          url: mediaUrl,
24029          anchor
24030        });
24031      }
24032    }, {
24033      type: 'block',
24034      blocks: ['core/video'],
24035      isMatch: _ref5 => {
24036        let {
24037          mediaType,
24038          mediaUrl
24039        } = _ref5;
24040        return !mediaUrl || mediaType === 'video';
24041      },
24042      transform: _ref6 => {
24043        let {
24044          mediaId,
24045          mediaUrl,
24046          anchor
24047        } = _ref6;
24048        return (0,external_wp_blocks_namespaceObject.createBlock)('core/video', {
24049          id: mediaId,
24050          src: mediaUrl,
24051          anchor
24052        });
24053      }
24054    }]
24055  };
24056  /* harmony default export */ var media_text_transforms = (media_text_transforms_transforms);
24057  
24058  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/media-text/index.js
24059  /**
24060   * WordPress dependencies
24061   */
24062  
24063  
24064  /**
24065   * Internal dependencies
24066   */
24067  
24068  
24069  
24070  const media_text_metadata = {
24071    $schema: "https://schemas.wp.org/trunk/block.json",
24072    apiVersion: 2,
24073    name: "core/media-text",
24074    title: "Media & Text",
24075    category: "media",
24076    description: "Set media and words side-by-side for a richer layout.",
24077    keywords: ["image", "video"],
24078    textdomain: "default",
24079    attributes: {
24080      align: {
24081        type: "string",
24082        "default": "wide"
24083      },
24084      mediaAlt: {
24085        type: "string",
24086        source: "attribute",
24087        selector: "figure img",
24088        attribute: "alt",
24089        "default": ""
24090      },
24091      mediaPosition: {
24092        type: "string",
24093        "default": "left"
24094      },
24095      mediaId: {
24096        type: "number"
24097      },
24098      mediaUrl: {
24099        type: "string",
24100        source: "attribute",
24101        selector: "figure video,figure img",
24102        attribute: "src"
24103      },
24104      mediaLink: {
24105        type: "string"
24106      },
24107      linkDestination: {
24108        type: "string"
24109      },
24110      linkTarget: {
24111        type: "string",
24112        source: "attribute",
24113        selector: "figure a",
24114        attribute: "target"
24115      },
24116      href: {
24117        type: "string",
24118        source: "attribute",
24119        selector: "figure a",
24120        attribute: "href"
24121      },
24122      rel: {
24123        type: "string",
24124        source: "attribute",
24125        selector: "figure a",
24126        attribute: "rel"
24127      },
24128      linkClass: {
24129        type: "string",
24130        source: "attribute",
24131        selector: "figure a",
24132        attribute: "class"
24133      },
24134      mediaType: {
24135        type: "string"
24136      },
24137      mediaWidth: {
24138        type: "number",
24139        "default": 50
24140      },
24141      mediaSizeSlug: {
24142        type: "string"
24143      },
24144      isStackedOnMobile: {
24145        type: "boolean",
24146        "default": true
24147      },
24148      verticalAlignment: {
24149        type: "string"
24150      },
24151      imageFill: {
24152        type: "boolean"
24153      },
24154      focalPoint: {
24155        type: "object"
24156      }
24157    },
24158    supports: {
24159      anchor: true,
24160      align: ["wide", "full"],
24161      html: false,
24162      color: {
24163        gradients: true,
24164        link: true,
24165        __experimentalDefaultControls: {
24166          background: true,
24167          text: true
24168        }
24169      }
24170    },
24171    editorStyle: "wp-block-media-text-editor",
24172    style: "wp-block-media-text"
24173  };
24174  
24175  
24176  const {
24177    name: media_text_name
24178  } = media_text_metadata;
24179  
24180  const media_text_settings = {
24181    icon: media_and_text,
24182    example: {
24183      viewportWidth: 601,
24184      // Columns collapse "@media (max-width: 600px)".
24185      attributes: {
24186        mediaType: 'image',
24187        mediaUrl: 'https://s.w.org/images/core/5.3/Biologia_Centrali-Americana_-_Cantorchilus_semibadius_1902.jpg'
24188      },
24189      innerBlocks: [{
24190        name: 'core/paragraph',
24191        attributes: {
24192          content: (0,external_wp_i18n_namespaceObject.__)('The wren<br>Earns his living<br>Noiselessly.')
24193        }
24194      }, {
24195        name: 'core/paragraph',
24196        attributes: {
24197          content: (0,external_wp_i18n_namespaceObject.__)('— Kobayashi Issa (一茶)')
24198        }
24199      }]
24200    },
24201    transforms: media_text_transforms,
24202    edit: media_text_edit,
24203    save: media_text_save_save,
24204    deprecated: media_text_deprecated
24205  };
24206  
24207  ;// CONCATENATED MODULE: external ["wp","dom"]
24208  var external_wp_dom_namespaceObject = window["wp"]["dom"];
24209  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/missing/edit.js
24210  
24211  
24212  /**
24213   * WordPress dependencies
24214   */
24215  
24216  
24217  
24218  
24219  
24220  
24221  
24222  
24223  function MissingBlockWarning(_ref) {
24224    let {
24225      attributes,
24226      convertToHTML
24227    } = _ref;
24228    const {
24229      originalName,
24230      originalUndelimitedContent
24231    } = attributes;
24232    const hasContent = !!originalUndelimitedContent;
24233    const hasHTMLBlock = (0,external_wp_blocks_namespaceObject.getBlockType)('core/html');
24234    const actions = [];
24235    let messageHTML;
24236  
24237    if (hasContent && hasHTMLBlock) {
24238      messageHTML = (0,external_wp_i18n_namespaceObject.sprintf)(
24239      /* translators: %s: block name */
24240      (0,external_wp_i18n_namespaceObject.__)('Your site doesn’t include support for the "%s" block. You can leave this block intact, convert its content to a Custom HTML block, or remove it entirely.'), originalName);
24241      actions.push((0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
24242        key: "convert",
24243        onClick: convertToHTML,
24244        variant: "primary"
24245      }, (0,external_wp_i18n_namespaceObject.__)('Keep as HTML')));
24246    } else {
24247      messageHTML = (0,external_wp_i18n_namespaceObject.sprintf)(
24248      /* translators: %s: block name */
24249      (0,external_wp_i18n_namespaceObject.__)('Your site doesn’t include support for the "%s" block. You can leave this block intact or remove it entirely.'), originalName);
24250    }
24251  
24252    return (0,external_wp_element_namespaceObject.createElement)("div", (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
24253      className: 'has-warning'
24254    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.Warning, {
24255      actions: actions
24256    }, messageHTML), (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.RawHTML, null, (0,external_wp_dom_namespaceObject.safeHTML)(originalUndelimitedContent)));
24257  }
24258  
24259  const MissingEdit = (0,external_wp_data_namespaceObject.withDispatch)((dispatch, _ref2) => {
24260    let {
24261      clientId,
24262      attributes
24263    } = _ref2;
24264    const {
24265      replaceBlock
24266    } = dispatch(external_wp_blockEditor_namespaceObject.store);
24267    return {
24268      convertToHTML() {
24269        replaceBlock(clientId, (0,external_wp_blocks_namespaceObject.createBlock)('core/html', {
24270          content: attributes.originalUndelimitedContent
24271        }));
24272      }
24273  
24274    };
24275  })(MissingBlockWarning);
24276  /* harmony default export */ var missing_edit = (MissingEdit);
24277  
24278  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/missing/save.js
24279  
24280  
24281  /**
24282   * WordPress dependencies
24283   */
24284  
24285  function missing_save_save(_ref) {
24286    let {
24287      attributes
24288    } = _ref;
24289    // Preserve the missing block's content.
24290    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.RawHTML, null, attributes.originalContent);
24291  }
24292  
24293  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/missing/index.js
24294  /**
24295   * WordPress dependencies
24296   */
24297  
24298  /**
24299   * Internal dependencies
24300   */
24301  
24302  
24303  const missing_metadata = {
24304    $schema: "https://schemas.wp.org/trunk/block.json",
24305    apiVersion: 2,
24306    name: "core/missing",
24307    title: "Unsupported",
24308    category: "text",
24309    description: "Your site doesn\u2019t include support for this block.",
24310    textdomain: "default",
24311    attributes: {
24312      originalName: {
24313        type: "string"
24314      },
24315      originalUndelimitedContent: {
24316        type: "string"
24317      },
24318      originalContent: {
24319        type: "string",
24320        source: "html"
24321      }
24322    },
24323    supports: {
24324      className: false,
24325      customClassName: false,
24326      inserter: false,
24327      html: false,
24328      reusable: false
24329    }
24330  };
24331  
24332  const {
24333    name: missing_name
24334  } = missing_metadata;
24335  
24336  const missing_settings = {
24337    name: missing_name,
24338  
24339    __experimentalLabel(attributes, _ref) {
24340      let {
24341        context
24342      } = _ref;
24343  
24344      if (context === 'accessibility') {
24345        const {
24346          originalName
24347        } = attributes;
24348        const originalBlockType = originalName ? (0,external_wp_blocks_namespaceObject.getBlockType)(originalName) : undefined;
24349  
24350        if (originalBlockType) {
24351          return originalBlockType.settings.title || originalName;
24352        }
24353  
24354        return '';
24355      }
24356    },
24357  
24358    edit: missing_edit,
24359    save: missing_save_save
24360  };
24361  
24362  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/more.js
24363  
24364  
24365  /**
24366   * WordPress dependencies
24367   */
24368  
24369  const more = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
24370    viewBox: "0 0 24 24",
24371    xmlns: "http://www.w3.org/2000/svg"
24372  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
24373    d: "M4 9v1.5h16V9H4zm12 5.5h4V13h-4v1.5zm-6 0h4V13h-4v1.5zm-6 0h4V13H4v1.5z"
24374  }));
24375  /* harmony default export */ var library_more = (more);
24376  
24377  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/more/edit.js
24378  
24379  
24380  /**
24381   * WordPress dependencies
24382   */
24383  
24384  
24385  
24386  
24387  
24388  
24389  const DEFAULT_TEXT = (0,external_wp_i18n_namespaceObject.__)('Read more');
24390  
24391  function MoreEdit(_ref) {
24392    let {
24393      attributes: {
24394        customText,
24395        noTeaser
24396      },
24397      insertBlocksAfter,
24398      setAttributes
24399    } = _ref;
24400  
24401    const onChangeInput = event => {
24402      setAttributes({
24403        customText: event.target.value !== '' ? event.target.value : undefined
24404      });
24405    };
24406  
24407    const onKeyDown = _ref2 => {
24408      let {
24409        keyCode
24410      } = _ref2;
24411  
24412      if (keyCode === external_wp_keycodes_namespaceObject.ENTER) {
24413        insertBlocksAfter([(0,external_wp_blocks_namespaceObject.createBlock)((0,external_wp_blocks_namespaceObject.getDefaultBlockName)())]);
24414      }
24415    };
24416  
24417    const getHideExcerptHelp = checked => checked ? (0,external_wp_i18n_namespaceObject.__)('The excerpt is hidden.') : (0,external_wp_i18n_namespaceObject.__)('The excerpt is visible.');
24418  
24419    const toggleHideExcerpt = () => setAttributes({
24420      noTeaser: !noTeaser
24421    });
24422  
24423    const style = {
24424      width: `${(customText ? customText : DEFAULT_TEXT).length + 1.2}em`
24425    };
24426    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
24427      label: (0,external_wp_i18n_namespaceObject.__)('Hide the excerpt on the full content page'),
24428      checked: !!noTeaser,
24429      onChange: toggleHideExcerpt,
24430      help: getHideExcerptHelp
24431    }))), (0,external_wp_element_namespaceObject.createElement)("div", (0,external_wp_blockEditor_namespaceObject.useBlockProps)(), (0,external_wp_element_namespaceObject.createElement)("div", {
24432      className: "wp-block-more"
24433    }, (0,external_wp_element_namespaceObject.createElement)("input", {
24434      "aria-label": (0,external_wp_i18n_namespaceObject.__)('Read more link text'),
24435      type: "text",
24436      value: customText,
24437      placeholder: DEFAULT_TEXT,
24438      onChange: onChangeInput,
24439      onKeyDown: onKeyDown,
24440      style: style
24441    }))));
24442  }
24443  
24444  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/more/save.js
24445  
24446  
24447  /**
24448   * External dependencies
24449   */
24450  
24451  /**
24452   * WordPress dependencies
24453   */
24454  
24455  
24456  function more_save_save(_ref) {
24457    let {
24458      attributes: {
24459        customText,
24460        noTeaser
24461      }
24462    } = _ref;
24463    const moreTag = customText ? `<!--more $customText}-->` : '<!--more-->';
24464    const noTeaserTag = noTeaser ? '<!--noteaser-->' : '';
24465    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.RawHTML, null, (0,external_lodash_namespaceObject.compact)([moreTag, noTeaserTag]).join('\n'));
24466  }
24467  
24468  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/more/transforms.js
24469  /**
24470   * WordPress dependencies
24471   */
24472  
24473  const more_transforms_transforms = {
24474    from: [{
24475      type: 'raw',
24476      schema: {
24477        'wp-block': {
24478          attributes: ['data-block']
24479        }
24480      },
24481      isMatch: node => node.dataset && node.dataset.block === 'core/more',
24482  
24483      transform(node) {
24484        const {
24485          customText,
24486          noTeaser
24487        } = node.dataset;
24488        const attrs = {}; // Don't copy unless defined and not an empty string.
24489  
24490        if (customText) {
24491          attrs.customText = customText;
24492        } // Special handling for boolean.
24493  
24494  
24495        if (noTeaser === '') {
24496          attrs.noTeaser = true;
24497        }
24498  
24499        return (0,external_wp_blocks_namespaceObject.createBlock)('core/more', attrs);
24500      }
24501  
24502    }]
24503  };
24504  /* harmony default export */ var more_transforms = (more_transforms_transforms);
24505  
24506  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/more/index.js
24507  /**
24508   * WordPress dependencies
24509   */
24510  
24511  /**
24512   * Internal dependencies
24513   */
24514  
24515  
24516  const more_metadata = {
24517    $schema: "https://schemas.wp.org/trunk/block.json",
24518    apiVersion: 2,
24519    name: "core/more",
24520    title: "More",
24521    category: "design",
24522    description: "Content before this block will be shown in the excerpt on your archives page.",
24523    keywords: ["read more"],
24524    textdomain: "default",
24525    attributes: {
24526      customText: {
24527        type: "string"
24528      },
24529      noTeaser: {
24530        type: "boolean",
24531        "default": false
24532      }
24533    },
24534    supports: {
24535      customClassName: false,
24536      className: false,
24537      html: false,
24538      multiple: false
24539    },
24540    editorStyle: "wp-block-more-editor"
24541  };
24542  
24543  
24544  const {
24545    name: more_name
24546  } = more_metadata;
24547  
24548  const more_settings = {
24549    icon: library_more,
24550    example: {},
24551  
24552    __experimentalLabel(attributes, _ref) {
24553      let {
24554        context
24555      } = _ref;
24556  
24557      if (context === 'accessibility') {
24558        return attributes.customText;
24559      }
24560    },
24561  
24562    transforms: more_transforms,
24563    edit: MoreEdit,
24564    save: more_save_save
24565  };
24566  
24567  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/navigation.js
24568  
24569  
24570  /**
24571   * WordPress dependencies
24572   */
24573  
24574  const navigation = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
24575    viewBox: "0 0 24 24",
24576    xmlns: "http://www.w3.org/2000/svg"
24577  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
24578    d: "M12 4c-4.4 0-8 3.6-8 8s3.6 8 8 8 8-3.6 8-8-3.6-8-8-8zm0 14.5c-3.6 0-6.5-2.9-6.5-6.5S8.4 5.5 12 5.5s6.5 2.9 6.5 6.5-2.9 6.5-6.5 6.5zM9 16l4.5-3L15 8.4l-4.5 3L9 16z"
24579  }));
24580  /* harmony default export */ var library_navigation = (navigation);
24581  
24582  ;// CONCATENATED MODULE: external ["wp","a11y"]
24583  var external_wp_a11y_namespaceObject = window["wp"]["a11y"];
24584  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/navigation/use-navigation-menu.js
24585  /**
24586   * WordPress dependencies
24587   */
24588  
24589  
24590  function useNavigationMenu(ref) {
24591    return (0,external_wp_data_namespaceObject.useSelect)(select => {
24592      var _navigationMenu;
24593  
24594      const {
24595        getEntityRecord,
24596        getEditedEntityRecord,
24597        getEntityRecords,
24598        hasFinishedResolution,
24599        isResolving,
24600        canUser
24601      } = select(external_wp_coreData_namespaceObject.store);
24602      const navigationMenuSingleArgs = ['postType', 'wp_navigation', ref];
24603      const rawNavigationMenu = ref ? getEntityRecord(...navigationMenuSingleArgs) : null;
24604      let navigationMenu = ref ? getEditedEntityRecord(...navigationMenuSingleArgs) : null; // getEditedEntityRecord will return the post regardless of status.
24605      // Therefore if the found post is not published then we should ignore it.
24606  
24607      if (((_navigationMenu = navigationMenu) === null || _navigationMenu === void 0 ? void 0 : _navigationMenu.status) !== 'publish') {
24608        navigationMenu = null;
24609      }
24610  
24611      const hasResolvedNavigationMenu = ref ? hasFinishedResolution('getEditedEntityRecord', navigationMenuSingleArgs) : false;
24612      const navigationMenuMultipleArgs = ['postType', 'wp_navigation', {
24613        per_page: -1,
24614        status: 'publish'
24615      }];
24616      const navigationMenus = getEntityRecords(...navigationMenuMultipleArgs);
24617      const canSwitchNavigationMenu = ref ? (navigationMenus === null || navigationMenus === void 0 ? void 0 : navigationMenus.length) > 1 : (navigationMenus === null || navigationMenus === void 0 ? void 0 : navigationMenus.length) > 0;
24618      return {
24619        isNavigationMenuResolved: hasResolvedNavigationMenu,
24620        isNavigationMenuMissing: !ref || hasResolvedNavigationMenu && !rawNavigationMenu,
24621        canSwitchNavigationMenu,
24622        isResolvingNavigationMenus: isResolving('getEntityRecords', navigationMenuMultipleArgs),
24623        hasResolvedNavigationMenus: hasFinishedResolution('getEntityRecords', navigationMenuMultipleArgs),
24624        navigationMenu,
24625        navigationMenus,
24626        canUserUpdateNavigationMenu: ref ? canUser('update', 'navigation', ref) : undefined,
24627        hasResolvedCanUserUpdateNavigationMenu: hasFinishedResolution('canUser', ['update', 'navigation', ref]),
24628        canUserDeleteNavigationMenu: ref ? canUser('delete', 'navigation', ref) : undefined,
24629        hasResolvedCanUserDeleteNavigationMenu: hasFinishedResolution('canUser', ['delete', 'navigation', ref]),
24630        canUserCreateNavigationMenu: canUser('create', 'navigation'),
24631        isResolvingCanUserCreateNavigationMenu: isResolving('canUser', ['create', 'navigation']),
24632        hasResolvedCanUserCreateNavigationMenu: hasFinishedResolution('canUser', ['create', 'navigation'])
24633      };
24634    }, [ref]);
24635  }
24636  
24637  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/navigation/use-navigation-entities.js
24638  /**
24639   * WordPress dependencies
24640   */
24641  
24642  /**
24643   * @typedef {Object} NavigationEntitiesData
24644   * @property {Array|undefined} pages                - a collection of WP Post entity objects of post type "Page".
24645   * @property {boolean}         isResolvingPages     - indicates whether the request to fetch pages is currently resolving.
24646   * @property {boolean}         hasResolvedPages     - indicates whether the request to fetch pages has finished resolving.
24647   * @property {Array|undefined} menus                - a collection of Menu entity objects.
24648   * @property {boolean}         isResolvingMenus     - indicates whether the request to fetch menus is currently resolving.
24649   * @property {boolean}         hasResolvedMenus     - indicates whether the request to fetch menus has finished resolving.
24650   * @property {Array|undefined} menusItems           - a collection of Menu Item entity objects for the current menuId.
24651   * @property {boolean}         hasResolvedMenuItems - indicates whether the request to fetch menuItems has finished resolving.
24652   * @property {boolean}         hasPages             - indicates whether there is currently any data for pages.
24653   * @property {boolean}         hasMenus             - indicates whether there is currently any data for menus.
24654   */
24655  
24656  /**
24657   * Manages fetching and resolution state for all entities required
24658   * for the Navigation block.
24659   *
24660   * @param {number} menuId the menu for which to retrieve menuItem data.
24661   * @return { NavigationEntitiesData } the entity data.
24662   */
24663  
24664  function useNavigationEntities(menuId) {
24665    const {
24666      records: menus,
24667      isResolving: isResolvingMenus,
24668      hasResolved: hasResolvedMenus
24669    } = (0,external_wp_coreData_namespaceObject.__experimentalUseEntityRecords)('root', 'menu', {
24670      per_page: -1,
24671      context: 'view'
24672    });
24673    const {
24674      records: pages,
24675      isResolving: isResolvingPages,
24676      hasResolved: hasResolvedPages
24677    } = (0,external_wp_coreData_namespaceObject.__experimentalUseEntityRecords)('postType', 'page', {
24678      parent: 0,
24679      order: 'asc',
24680      orderby: 'id',
24681      per_page: -1,
24682      context: 'view'
24683    });
24684    const {
24685      records: menuItems,
24686      hasResolved: hasResolvedMenuItems
24687    } = (0,external_wp_coreData_namespaceObject.__experimentalUseEntityRecords)('root', 'menuItem', {
24688      menus: menuId,
24689      per_page: -1,
24690      context: 'view'
24691    }, {
24692      enabled: !!menuId
24693    });
24694    return {
24695      pages,
24696      isResolvingPages,
24697      hasResolvedPages,
24698      hasPages: !!(hasResolvedPages && pages !== null && pages !== void 0 && pages.length),
24699      menus,
24700      isResolvingMenus,
24701      hasResolvedMenus,
24702      hasMenus: !!(hasResolvedMenus && menus !== null && menus !== void 0 && menus.length),
24703      menuItems,
24704      hasResolvedMenuItems
24705    };
24706  }
24707  
24708  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/icon/index.js
24709  /**
24710   * WordPress dependencies
24711   */
24712  
24713  /** @typedef {{icon: JSX.Element, size?: number} & import('@wordpress/primitives').SVGProps} IconProps */
24714  
24715  /**
24716   * Return an SVG icon.
24717   *
24718   * @param {IconProps} props icon is the SVG component to render
24719   *                          size is a number specifiying the icon size in pixels
24720   *                          Other props will be passed to wrapped SVG component
24721   *
24722   * @return {JSX.Element}  Icon component
24723   */
24724  
24725  function Icon(_ref) {
24726    let {
24727      icon,
24728      size = 24,
24729      ...props
24730    } = _ref;
24731    return (0,external_wp_element_namespaceObject.cloneElement)(icon, {
24732      width: size,
24733      height: size,
24734      ...props
24735    });
24736  }
24737  
24738  /* harmony default export */ var icon = (Icon);
24739  
24740  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/navigation/edit/placeholder/placeholder-preview.js
24741  
24742  
24743  /**
24744   * WordPress dependencies
24745   */
24746  
24747  
24748  
24749  const PlaceholderPreview = _ref => {
24750    let {
24751      isVisible = true
24752    } = _ref;
24753    return (0,external_wp_element_namespaceObject.createElement)("div", {
24754      "aria-hidden": !isVisible ? true : undefined,
24755      className: "wp-block-navigation-placeholder__preview"
24756    }, (0,external_wp_element_namespaceObject.createElement)("div", {
24757      className: "wp-block-navigation-placeholder__actions__indicator"
24758    }, (0,external_wp_element_namespaceObject.createElement)(icon, {
24759      icon: library_navigation
24760    }), (0,external_wp_i18n_namespaceObject.__)('Navigation')));
24761  };
24762  
24763  /* harmony default export */ var placeholder_preview = (PlaceholderPreview);
24764  
24765  ;// CONCATENATED MODULE: external ["wp","htmlEntities"]
24766  var external_wp_htmlEntities_namespaceObject = window["wp"]["htmlEntities"];
24767  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/navigation/edit/navigation-menu-selector.js
24768  
24769  
24770  /**
24771   * WordPress dependencies
24772   */
24773  
24774  
24775  
24776  
24777  
24778  /**
24779   * Internal dependencies
24780   */
24781  
24782  
24783  
24784  
24785  function NavigationMenuSelector(_ref, forwardedRef) {
24786    let {
24787      currentMenuId,
24788      onSelect,
24789      onCreateNew,
24790      showManageActions = false,
24791      actionLabel,
24792      toggleProps = {}
24793    } = _ref;
24794  
24795    /* translators: %s: The name of a menu. */
24796    const createActionLabel = (0,external_wp_i18n_namespaceObject.__)("Create from '%s'");
24797  
24798    actionLabel = actionLabel || createActionLabel;
24799    const {
24800      menus: classicMenus
24801    } = useNavigationEntities();
24802    const {
24803      navigationMenus,
24804      canUserCreateNavigationMenu,
24805      canUserUpdateNavigationMenu,
24806      canSwitchNavigationMenu
24807    } = useNavigationMenu();
24808    const handleSelect = (0,external_wp_element_namespaceObject.useCallback)(_onClose => selectedId => {
24809      _onClose();
24810  
24811      onSelect(navigationMenus === null || navigationMenus === void 0 ? void 0 : navigationMenus.find(post => post.id === selectedId));
24812    }, [navigationMenus]);
24813    const handleSelectClassic = (0,external_wp_element_namespaceObject.useCallback)((_onClose, menu) => () => {
24814      _onClose();
24815  
24816      onSelect(menu);
24817    }, []);
24818    const menuChoices = (0,external_wp_element_namespaceObject.useMemo)(() => {
24819      return (navigationMenus === null || navigationMenus === void 0 ? void 0 : navigationMenus.map(_ref2 => {
24820        let {
24821          id,
24822          title
24823        } = _ref2;
24824        const label = (0,external_wp_htmlEntities_namespaceObject.decodeEntities)(title.rendered);
24825        return {
24826          value: id,
24827          label,
24828          ariaLabel: (0,external_wp_i18n_namespaceObject.sprintf)(actionLabel, label)
24829        };
24830      })) || [];
24831    }, [navigationMenus]);
24832    const hasNavigationMenus = !!(navigationMenus !== null && navigationMenus !== void 0 && navigationMenus.length);
24833    const hasClassicMenus = !!(classicMenus !== null && classicMenus !== void 0 && classicMenus.length);
24834    const showNavigationMenus = !!canSwitchNavigationMenu;
24835    const showClassicMenus = !!canUserCreateNavigationMenu;
24836    const hasManagePermissions = canUserCreateNavigationMenu || canUserUpdateNavigationMenu; // Show the selector if:
24837    // - has switch or create permissions and there are block or classic menus.
24838    // - user has create or update permisisons and component should show the menu actions.
24839  
24840    const showSelectMenus = (canSwitchNavigationMenu || canUserCreateNavigationMenu) && (hasNavigationMenus || hasClassicMenus) || hasManagePermissions && showManageActions;
24841  
24842    if (!showSelectMenus) {
24843      return null;
24844    }
24845  
24846    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarDropdownMenu, {
24847      ref: forwardedRef,
24848      label: (0,external_wp_i18n_namespaceObject.__)('Select Menu'),
24849      text: (0,external_wp_i18n_namespaceObject.__)('Select Menu'),
24850      icon: null,
24851      toggleProps: toggleProps
24852    }, _ref3 => {
24853      let {
24854        onClose
24855      } = _ref3;
24856      return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, showNavigationMenus && hasNavigationMenus && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuGroup, {
24857        label: (0,external_wp_i18n_namespaceObject.__)('Menus')
24858      }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItemsChoice, {
24859        value: currentMenuId,
24860        onSelect: handleSelect(onClose),
24861        choices: menuChoices
24862      })), showClassicMenus && hasClassicMenus && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuGroup, {
24863        label: (0,external_wp_i18n_namespaceObject.__)('Classic Menus')
24864      }, classicMenus === null || classicMenus === void 0 ? void 0 : classicMenus.map(menu => {
24865        const label = (0,external_wp_htmlEntities_namespaceObject.decodeEntities)(menu.name);
24866        return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, {
24867          onClick: handleSelectClassic(onClose, menu),
24868          key: menu.id,
24869          "aria-label": (0,external_wp_i18n_namespaceObject.sprintf)(createActionLabel, label)
24870        }, label);
24871      })), showManageActions && hasManagePermissions && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuGroup, {
24872        label: (0,external_wp_i18n_namespaceObject.__)('Tools')
24873      }, canUserCreateNavigationMenu && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, {
24874        onClick: onCreateNew
24875      }, (0,external_wp_i18n_namespaceObject.__)('Create new menu')), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, {
24876        href: (0,external_wp_url_namespaceObject.addQueryArgs)('edit.php', {
24877          post_type: 'wp_navigation'
24878        })
24879      }, (0,external_wp_i18n_namespaceObject.__)('Manage menus'))));
24880    });
24881  }
24882  
24883  /* harmony default export */ var navigation_menu_selector = ((0,external_wp_element_namespaceObject.forwardRef)(NavigationMenuSelector));
24884  
24885  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/navigation/edit/placeholder/index.js
24886  
24887  
24888  /**
24889   * WordPress dependencies
24890   */
24891  
24892  
24893  
24894  
24895  
24896  /**
24897   * Internal dependencies
24898   */
24899  
24900  
24901  
24902  
24903  function NavigationPlaceholder(_ref) {
24904    let {
24905      isSelected,
24906      currentMenuId,
24907      clientId,
24908      canUserCreateNavigationMenu = false,
24909      isResolvingCanUserCreateNavigationMenu,
24910      onFinish,
24911      onCreateEmpty
24912    } = _ref;
24913    const {
24914      isResolvingMenus,
24915      hasResolvedMenus
24916    } = useNavigationEntities();
24917    (0,external_wp_element_namespaceObject.useEffect)(() => {
24918      if (!isSelected) {
24919        return;
24920      }
24921  
24922      if (isResolvingMenus) {
24923        (0,external_wp_a11y_namespaceObject.speak)((0,external_wp_i18n_namespaceObject.__)('Loading Navigation block setup options.'));
24924      }
24925  
24926      if (hasResolvedMenus) {
24927        (0,external_wp_a11y_namespaceObject.speak)((0,external_wp_i18n_namespaceObject.__)('Navigation block setup options ready.'));
24928      }
24929    }, [isResolvingMenus, isSelected]);
24930    const isResolvingActions = isResolvingMenus && isResolvingCanUserCreateNavigationMenu;
24931    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Placeholder, {
24932      className: "wp-block-navigation-placeholder"
24933    }, (0,external_wp_element_namespaceObject.createElement)(placeholder_preview, {
24934      isVisible: !isSelected
24935    }), (0,external_wp_element_namespaceObject.createElement)("div", {
24936      "aria-hidden": !isSelected ? true : undefined,
24937      className: "wp-block-navigation-placeholder__controls"
24938    }, (0,external_wp_element_namespaceObject.createElement)("div", {
24939      className: "wp-block-navigation-placeholder__actions"
24940    }, (0,external_wp_element_namespaceObject.createElement)("div", {
24941      className: "wp-block-navigation-placeholder__actions__indicator"
24942    }, (0,external_wp_element_namespaceObject.createElement)(icon, {
24943      icon: library_navigation
24944    }), " ", (0,external_wp_i18n_namespaceObject.__)('Navigation')), (0,external_wp_element_namespaceObject.createElement)("hr", null), isResolvingActions && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Spinner, null), (0,external_wp_element_namespaceObject.createElement)(navigation_menu_selector, {
24945      currentMenuId: currentMenuId,
24946      clientId: clientId,
24947      onSelect: onFinish,
24948      toggleProps: {
24949        variant: 'tertiary',
24950        iconPosition: 'right',
24951        className: 'wp-block-navigation-placeholder__actions__dropdown'
24952      }
24953    }), (0,external_wp_element_namespaceObject.createElement)("hr", null), canUserCreateNavigationMenu && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
24954      variant: "tertiary",
24955      onClick: onCreateEmpty
24956    }, (0,external_wp_i18n_namespaceObject.__)('Start empty'))))));
24957  }
24958  
24959  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/close.js
24960  
24961  
24962  /**
24963   * WordPress dependencies
24964   */
24965  
24966  const close_close = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
24967    xmlns: "http://www.w3.org/2000/svg",
24968    viewBox: "0 0 24 24"
24969  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
24970    d: "M13 11.8l6.1-6.3-1-1-6.1 6.2-6.1-6.2-1 1 6.1 6.3-6.5 6.7 1 1 6.5-6.6 6.5 6.6 1-1z"
24971  }));
24972  /* harmony default export */ var library_close = (close_close);
24973  
24974  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/navigation/edit/overlay-menu-icon.js
24975  
24976  
24977  /**
24978   * WordPress dependencies
24979   */
24980  
24981  function OverlayMenuIcon() {
24982    return (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
24983      xmlns: "http://www.w3.org/2000/svg",
24984      viewBox: "0 0 24 24",
24985      width: "24",
24986      height: "24",
24987      "aria-hidden": "true",
24988      focusable: "false"
24989    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Rect, {
24990      x: "4",
24991      y: "7.5",
24992      width: "16",
24993      height: "1.5"
24994    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Rect, {
24995      x: "4",
24996      y: "15",
24997      width: "16",
24998      height: "1.5"
24999    }));
25000  }
25001  
25002  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/navigation/edit/responsive-wrapper.js
25003  
25004  
25005  /**
25006   * External dependencies
25007   */
25008  
25009  /**
25010   * WordPress dependencies
25011   */
25012  
25013  
25014  
25015  
25016  /**
25017   * Internal dependencies
25018   */
25019  
25020  
25021  function ResponsiveWrapper(_ref) {
25022    let {
25023      children,
25024      id,
25025      isOpen,
25026      isResponsive,
25027      onToggle,
25028      isHiddenByDefault,
25029      classNames,
25030      styles,
25031      hasIcon
25032    } = _ref;
25033  
25034    if (!isResponsive) {
25035      return children;
25036    }
25037  
25038    const responsiveContainerClasses = classnames_default()('wp-block-navigation__responsive-container', classNames, {
25039      'is-menu-open': isOpen,
25040      'hidden-by-default': isHiddenByDefault
25041    });
25042    const openButtonClasses = classnames_default()('wp-block-navigation__responsive-container-open', {
25043      'always-shown': isHiddenByDefault
25044    });
25045    const modalId = `$id}-modal`;
25046    const dialogProps = {
25047      className: 'wp-block-navigation__responsive-dialog',
25048      ...(isOpen && {
25049        role: 'dialog',
25050        'aria-modal': true,
25051        'aria-label': (0,external_wp_i18n_namespaceObject.__)('Menu')
25052      })
25053    };
25054    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, !isOpen && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
25055      "aria-haspopup": "true",
25056      "aria-label": (0,external_wp_i18n_namespaceObject.__)('Open menu'),
25057      className: openButtonClasses,
25058      onClick: () => onToggle(true)
25059    }, hasIcon && (0,external_wp_element_namespaceObject.createElement)(OverlayMenuIcon, null), !hasIcon && (0,external_wp_element_namespaceObject.createElement)("span", {
25060      className: "wp-block-navigation__toggle_button_label"
25061    }, (0,external_wp_i18n_namespaceObject.__)('Menu'))), (0,external_wp_element_namespaceObject.createElement)("div", {
25062      className: responsiveContainerClasses,
25063      style: styles,
25064      id: modalId
25065    }, (0,external_wp_element_namespaceObject.createElement)("div", {
25066      className: "wp-block-navigation__responsive-close",
25067      tabIndex: "-1"
25068    }, (0,external_wp_element_namespaceObject.createElement)("div", dialogProps, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
25069      className: "wp-block-navigation__responsive-container-close",
25070      "aria-label": (0,external_wp_i18n_namespaceObject.__)('Close menu'),
25071      onClick: () => onToggle(false)
25072    }, (0,external_wp_element_namespaceObject.createElement)(icon, {
25073      icon: library_close
25074    })), (0,external_wp_element_namespaceObject.createElement)("div", {
25075      className: "wp-block-navigation__responsive-container-content",
25076      id: `$modalId}-content`
25077    }, children)))));
25078  }
25079  
25080  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/navigation/edit/inner-blocks.js
25081  
25082  
25083  /**
25084   * WordPress dependencies
25085   */
25086  
25087  
25088  
25089  
25090  /**
25091   * Internal dependencies
25092   */
25093  
25094  
25095  const inner_blocks_ALLOWED_BLOCKS = ['core/navigation-link', 'core/search', 'core/social-links', 'core/page-list', 'core/spacer', 'core/home-link', 'core/site-title', 'core/site-logo', 'core/navigation-submenu'];
25096  const inner_blocks_DEFAULT_BLOCK = {
25097    name: 'core/navigation-link'
25098  };
25099  const LAYOUT = {
25100    type: 'default',
25101    alignments: []
25102  };
25103  function NavigationInnerBlocks(_ref) {
25104    let {
25105      clientId,
25106      hasCustomPlaceholder,
25107      orientation
25108    } = _ref;
25109    const {
25110      isImmediateParentOfSelectedBlock,
25111      selectedBlockHasChildren,
25112      isSelected
25113    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
25114      const {
25115        getBlockCount,
25116        hasSelectedInnerBlock,
25117        getSelectedBlockClientId
25118      } = select(external_wp_blockEditor_namespaceObject.store);
25119      const selectedBlockId = getSelectedBlockClientId();
25120      return {
25121        isImmediateParentOfSelectedBlock: hasSelectedInnerBlock(clientId, false),
25122        selectedBlockHasChildren: !!getBlockCount(selectedBlockId),
25123        // This prop is already available but computing it here ensures it's
25124        // fresh compared to isImmediateParentOfSelectedBlock.
25125        isSelected: selectedBlockId === clientId
25126      };
25127    }, [clientId]);
25128    const [blocks, onInput, onChange] = (0,external_wp_coreData_namespaceObject.useEntityBlockEditor)('postType', 'wp_navigation');
25129    const shouldDirectInsert = (0,external_wp_element_namespaceObject.useMemo)(() => blocks.every(_ref2 => {
25130      let {
25131        name
25132      } = _ref2;
25133      return name === 'core/navigation-link' || name === 'core/navigation-submenu' || name === 'core/page-list';
25134    }), [blocks]); // When the block is selected itself or has a top level item selected that
25135    // doesn't itself have children, show the standard appender. Else show no
25136    // appender.
25137  
25138    const parentOrChildHasSelection = isSelected || isImmediateParentOfSelectedBlock && !selectedBlockHasChildren;
25139    const placeholder = (0,external_wp_element_namespaceObject.useMemo)(() => (0,external_wp_element_namespaceObject.createElement)(placeholder_preview, null), []);
25140    const hasMenuItems = !!(blocks !== null && blocks !== void 0 && blocks.length); // If there is a `ref` attribute pointing to a `wp_navigation` but
25141    // that menu has no **items** (i.e. empty) then show a placeholder.
25142    // The block must also be selected else the placeholder will display
25143    // alongside the appender.
25144  
25145    const showPlaceholder = !hasCustomPlaceholder && !hasMenuItems && !isSelected;
25146    const innerBlocksProps = (0,external_wp_blockEditor_namespaceObject.useInnerBlocksProps)({
25147      className: 'wp-block-navigation__container'
25148    }, {
25149      value: blocks,
25150      onInput,
25151      onChange,
25152      allowedBlocks: inner_blocks_ALLOWED_BLOCKS,
25153      __experimentalDefaultBlock: inner_blocks_DEFAULT_BLOCK,
25154      __experimentalDirectInsert: shouldDirectInsert,
25155      orientation,
25156      // As an exception to other blocks which feature nesting, show
25157      // the block appender even when a child block is selected.
25158      // This should be a temporary fix, to be replaced by improvements to
25159      // the sibling inserter.
25160      // See https://github.com/WordPress/gutenberg/issues/37572.
25161      renderAppender: isSelected || isImmediateParentOfSelectedBlock && !selectedBlockHasChildren || // Show the appender while dragging to allow inserting element between item and the appender.
25162      parentOrChildHasSelection ? external_wp_blockEditor_namespaceObject.InnerBlocks.ButtonBlockAppender : false,
25163      // Template lock set to false here so that the Nav
25164      // Block on the experimental menus screen does not
25165      // inherit templateLock={ 'all' }.
25166      templateLock: false,
25167      __experimentalLayout: LAYOUT,
25168      placeholder: showPlaceholder ? placeholder : undefined
25169    });
25170    return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.__experimentalBlockContentOverlay, {
25171      clientId: clientId,
25172      tagName: 'div',
25173      wrapperProps: innerBlocksProps
25174    });
25175  }
25176  
25177  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/navigation/edit/navigation-menu-name-control.js
25178  
25179  
25180  /**
25181   * WordPress dependencies
25182   */
25183  
25184  
25185  
25186  function NavigationMenuNameControl() {
25187    const [title, updateTitle] = (0,external_wp_coreData_namespaceObject.useEntityProp)('postType', 'wp_navigation', 'title');
25188    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TextControl, {
25189      label: (0,external_wp_i18n_namespaceObject.__)('Menu name'),
25190      value: title,
25191      onChange: updateTitle
25192    });
25193  }
25194  
25195  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/template-part/edit/utils/create-template-part-id.js
25196  /**
25197   * Generates a template part Id based on slug and theme inputs.
25198   *
25199   * @param {string} theme the template part's theme.
25200   * @param {string} slug  the template part's slug
25201   * @return {string|null} the template part's Id.
25202   */
25203  function createTemplatePartId(theme, slug) {
25204    return theme && slug ? theme + '//' + slug : null;
25205  }
25206  
25207  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/navigation/use-template-part-area-label.js
25208  /**
25209   * WordPress dependencies
25210   */
25211  
25212  
25213  
25214  /**
25215   * Internal dependencies
25216   */
25217  // TODO: this util should perhaps be refactored somewhere like core-data.
25218  
25219  
25220  function useTemplatePartAreaLabel(clientId) {
25221    return (0,external_wp_data_namespaceObject.useSelect)(select => {
25222      // Use the lack of a clientId as an opportunity to bypass the rest
25223      // of this hook.
25224      if (!clientId) {
25225        return;
25226      }
25227  
25228      const {
25229        getBlock,
25230        getBlockParentsByBlockName
25231      } = select(external_wp_blockEditor_namespaceObject.store);
25232      const withAscendingResults = true;
25233      const parentTemplatePartClientIds = getBlockParentsByBlockName(clientId, 'core/template-part', withAscendingResults);
25234  
25235      if (!(parentTemplatePartClientIds !== null && parentTemplatePartClientIds !== void 0 && parentTemplatePartClientIds.length)) {
25236        return;
25237      } // FIXME: @wordpress/block-library should not depend on @wordpress/editor.
25238      // Blocks can be loaded into a *non-post* block editor.
25239      // This code is lifted from this file:
25240      // packages/block-library/src/template-part/edit/advanced-controls.js
25241      // eslint-disable-next-line @wordpress/data-no-store-string-literals
25242  
25243  
25244      const definedAreas = select('core/editor').__experimentalGetDefaultTemplatePartAreas();
25245  
25246      const {
25247        getEditedEntityRecord
25248      } = select(external_wp_coreData_namespaceObject.store);
25249  
25250      for (const templatePartClientId of parentTemplatePartClientIds) {
25251        const templatePartBlock = getBlock(templatePartClientId); // The 'area' usually isn't stored on the block, but instead
25252        // on the entity.
25253  
25254        const {
25255          theme,
25256          slug
25257        } = templatePartBlock.attributes;
25258        const templatePartEntityId = createTemplatePartId(theme, slug);
25259        const templatePartEntity = getEditedEntityRecord('postType', 'wp_template_part', templatePartEntityId); // Look up the `label` for the area in the defined areas so
25260        // that an internationalized label can be used.
25261  
25262        if (templatePartEntity !== null && templatePartEntity !== void 0 && templatePartEntity.area) {
25263          var _definedAreas$find;
25264  
25265          return (_definedAreas$find = definedAreas.find(definedArea => definedArea.area !== 'uncategorized' && definedArea.area === templatePartEntity.area)) === null || _definedAreas$find === void 0 ? void 0 : _definedAreas$find.label;
25266        }
25267      }
25268    }, [clientId]);
25269  }
25270  
25271  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/navigation/edit/use-generate-default-navigation-title.js
25272  /**
25273   * WordPress dependencies
25274   */
25275  
25276  
25277  
25278  
25279  
25280  /**
25281   * Internal dependencies
25282   */
25283  
25284  
25285  const DRAFT_MENU_PARAMS = ['postType', 'wp_navigation', {
25286    status: 'draft',
25287    per_page: -1
25288  }];
25289  const PUBLISHED_MENU_PARAMS = ['postType', 'wp_navigation', {
25290    per_page: -1,
25291    status: 'publish'
25292  }];
25293  function useGenerateDefaultNavigationTitle(clientId) {
25294    // The block will be disabled in a block preview, use this as a way of
25295    // avoiding the side-effects of this component for block previews.
25296    const isDisabled = (0,external_wp_element_namespaceObject.useContext)(external_wp_components_namespaceObject.Disabled.Context); // Because we can't conditionally call hooks, pass an undefined client id
25297    // arg to bypass the expensive `useTemplateArea` code. The hook will return
25298    // early.
25299  
25300    const area = useTemplatePartAreaLabel(isDisabled ? undefined : clientId);
25301    const registry = (0,external_wp_data_namespaceObject.useRegistry)();
25302    return (0,external_wp_element_namespaceObject.useCallback)(async () => {
25303      // Ensure other navigation menus have loaded so an
25304      // accurate name can be created.
25305      if (isDisabled) {
25306        return '';
25307      }
25308  
25309      const {
25310        getEntityRecords
25311      } = registry.resolveSelect(external_wp_coreData_namespaceObject.store);
25312      const [draftNavigationMenus, navigationMenus] = await Promise.all([getEntityRecords(...DRAFT_MENU_PARAMS), getEntityRecords(...PUBLISHED_MENU_PARAMS)]);
25313      const title = area ? (0,external_wp_i18n_namespaceObject.sprintf)( // translators: %s: the name of a menu (e.g. Header navigation).
25314      (0,external_wp_i18n_namespaceObject.__)('%s navigation'), area) : // translators: 'navigation' as in website navigation.
25315      (0,external_wp_i18n_namespaceObject.__)('Navigation'); // Determine how many menus start with the automatic title.
25316  
25317      const matchingMenuTitleCount = [...draftNavigationMenus, ...navigationMenus].reduce((count, menu) => {
25318        var _menu$title, _menu$title$raw;
25319  
25320        return menu !== null && menu !== void 0 && (_menu$title = menu.title) !== null && _menu$title !== void 0 && (_menu$title$raw = _menu$title.raw) !== null && _menu$title$raw !== void 0 && _menu$title$raw.startsWith(title) ? count + 1 : count;
25321      }, 0); // Append a number to the end of the title if a menu with
25322      // the same name exists.
25323  
25324      const titleWithCount = matchingMenuTitleCount > 0 ? `$title} $matchingMenuTitleCount + 1}` : title;
25325      return titleWithCount || '';
25326    }, [isDisabled, area]);
25327  }
25328  
25329  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/navigation/edit/use-create-navigation-menu.js
25330  /**
25331   * WordPress dependencies
25332   */
25333  
25334  
25335  
25336  
25337  /**
25338   * Internal dependencies
25339   */
25340  
25341  
25342  const CREATE_NAVIGATION_MENU_SUCCESS = 'success';
25343  const CREATE_NAVIGATION_MENU_ERROR = 'error';
25344  const CREATE_NAVIGATION_MENU_PENDING = 'pending';
25345  const CREATE_NAVIGATION_MENU_IDLE = 'idle';
25346  function useCreateNavigationMenu(clientId) {
25347    const [status, setStatus] = (0,external_wp_element_namespaceObject.useState)(CREATE_NAVIGATION_MENU_IDLE);
25348    const [value, setValue] = (0,external_wp_element_namespaceObject.useState)(null);
25349    const [error, setError] = (0,external_wp_element_namespaceObject.useState)(null);
25350    const {
25351      saveEntityRecord
25352    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_coreData_namespaceObject.store);
25353    const generateDefaultTitle = useGenerateDefaultNavigationTitle(clientId); // This callback uses data from the two placeholder steps and only creates
25354    // a new navigation menu when the user completes the final step.
25355  
25356    const create = (0,external_wp_element_namespaceObject.useCallback)(async function () {
25357      let title = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : null;
25358      let blocks = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];
25359  
25360      // Guard against creating Navigations without a title.
25361      // Note you can pass no title, but if one is passed it must be
25362      // a string otherwise the title may end up being empty.
25363      if (title && typeof title !== 'string') {
25364        setError('Invalid title supplied when creating Navigation Menu.');
25365        setStatus(CREATE_NAVIGATION_MENU_ERROR);
25366        throw new Error(`Value of supplied title argument was not a string.`);
25367      }
25368  
25369      setStatus(CREATE_NAVIGATION_MENU_PENDING);
25370      setValue(null);
25371      setError(null);
25372  
25373      if (!title) {
25374        title = await generateDefaultTitle().catch(err => {
25375          setError(err === null || err === void 0 ? void 0 : err.message);
25376          setStatus(CREATE_NAVIGATION_MENU_ERROR);
25377          throw new Error('Failed to create title when saving new Navigation Menu.', {
25378            cause: err
25379          });
25380        });
25381      }
25382  
25383      const record = {
25384        title,
25385        content: (0,external_wp_blocks_namespaceObject.serialize)(blocks),
25386        status: 'publish'
25387      }; // Return affords ability to await on this function directly
25388  
25389      return saveEntityRecord('postType', 'wp_navigation', record).then(response => {
25390        setValue(response);
25391        setStatus(CREATE_NAVIGATION_MENU_SUCCESS);
25392        return response;
25393      }).catch(err => {
25394        setError(err === null || err === void 0 ? void 0 : err.message);
25395        setStatus(CREATE_NAVIGATION_MENU_ERROR);
25396        throw new Error('Unable to save new Navigation Menu', {
25397          cause: err
25398        });
25399      });
25400    }, [external_wp_blocks_namespaceObject.serialize, saveEntityRecord]);
25401    return {
25402      create,
25403      status,
25404      value,
25405      error
25406    };
25407  }
25408  
25409  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/navigation/edit/unsaved-inner-blocks.js
25410  
25411  
25412  /**
25413   * External dependencies
25414   */
25415  
25416  /**
25417   * WordPress dependencies
25418   */
25419  
25420  
25421  
25422  
25423  
25424  
25425  /**
25426   * Internal dependencies
25427   */
25428  
25429  
25430  
25431  const EMPTY_OBJECT = {};
25432  const unsaved_inner_blocks_DRAFT_MENU_PARAMS = ['postType', 'wp_navigation', {
25433    status: 'draft',
25434    per_page: -1
25435  }];
25436  const unsaved_inner_blocks_DEFAULT_BLOCK = {
25437    name: 'core/navigation-link'
25438  };
25439  const unsaved_inner_blocks_ALLOWED_BLOCKS = ['core/navigation-link', 'core/search', 'core/social-links', 'core/page-list', 'core/spacer', 'core/home-link', 'core/site-title', 'core/site-logo', 'core/navigation-submenu'];
25440  function UnsavedInnerBlocks(_ref) {
25441    let {
25442      blockProps,
25443      blocks,
25444      clientId,
25445      hasSavedUnsavedInnerBlocks,
25446      onSave,
25447      hasSelection
25448    } = _ref;
25449    const originalBlocks = (0,external_wp_element_namespaceObject.useRef)();
25450    (0,external_wp_element_namespaceObject.useEffect)(() => {
25451      // Initially store the uncontrolled inner blocks for
25452      // dirty state comparison.
25453      if (!(originalBlocks !== null && originalBlocks !== void 0 && originalBlocks.current)) {
25454        originalBlocks.current = blocks;
25455      }
25456    }, [blocks]); // If the current inner blocks object is different in any way
25457    // from the original inner blocks from the post content then the
25458    // user has made changes to the inner blocks. At this point the inner
25459    // blocks can be considered "dirty".
25460  
25461    const innerBlocksAreDirty = blocks !== originalBlocks.current;
25462    const shouldDirectInsert = (0,external_wp_element_namespaceObject.useMemo)(() => blocks.every(_ref2 => {
25463      let {
25464        name
25465      } = _ref2;
25466      return name === 'core/navigation-link' || name === 'core/navigation-submenu' || name === 'core/page-list';
25467    }), [blocks]); // The block will be disabled in a block preview, use this as a way of
25468    // avoiding the side-effects of this component for block previews.
25469  
25470    const isDisabled = (0,external_wp_element_namespaceObject.useContext)(external_wp_components_namespaceObject.Disabled.Context);
25471    const savingLock = (0,external_wp_element_namespaceObject.useRef)(false);
25472    const innerBlocksProps = (0,external_wp_blockEditor_namespaceObject.useInnerBlocksProps)(blockProps, {
25473      renderAppender: hasSelection ? undefined : false,
25474      allowedBlocks: unsaved_inner_blocks_ALLOWED_BLOCKS,
25475      __experimentalDefaultBlock: unsaved_inner_blocks_DEFAULT_BLOCK,
25476      __experimentalDirectInsert: shouldDirectInsert
25477    });
25478    const {
25479      isSaving,
25480      draftNavigationMenus,
25481      hasResolvedDraftNavigationMenus
25482    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
25483      if (isDisabled) {
25484        return EMPTY_OBJECT;
25485      }
25486  
25487      const {
25488        getEntityRecords,
25489        hasFinishedResolution,
25490        isSavingEntityRecord
25491      } = select(external_wp_coreData_namespaceObject.store);
25492      return {
25493        isSaving: isSavingEntityRecord('postType', 'wp_navigation'),
25494        draftNavigationMenus: getEntityRecords(...unsaved_inner_blocks_DRAFT_MENU_PARAMS),
25495        hasResolvedDraftNavigationMenus: hasFinishedResolution('getEntityRecords', unsaved_inner_blocks_DRAFT_MENU_PARAMS)
25496      };
25497    }, [isDisabled]);
25498    const {
25499      hasResolvedNavigationMenus,
25500      navigationMenus
25501    } = useNavigationMenu();
25502    const {
25503      create: createNavigationMenu
25504    } = useCreateNavigationMenu(clientId); // Automatically save the uncontrolled blocks.
25505  
25506    (0,external_wp_element_namespaceObject.useEffect)(async () => {
25507      // The block will be disabled when used in a BlockPreview.
25508      // In this case avoid automatic creation of a wp_navigation post.
25509      // Otherwise the user will be spammed with lots of menus!
25510      //
25511      // Also ensure other navigation menus have loaded so an
25512      // accurate name can be created.
25513      //
25514      // Don't try saving when another save is already
25515      // in progress.
25516      //
25517      // And finally only create the menu when the block is selected,
25518      // which is an indication they want to start editing.
25519      if (isDisabled || hasSavedUnsavedInnerBlocks || isSaving || savingLock.current || !hasResolvedDraftNavigationMenus || !hasResolvedNavigationMenus || !hasSelection || !innerBlocksAreDirty) {
25520        return;
25521      }
25522  
25523      savingLock.current = true;
25524      const menu = await createNavigationMenu(null, blocks);
25525      onSave(menu);
25526      savingLock.current = false;
25527    }, [isDisabled, isSaving, hasResolvedDraftNavigationMenus, hasResolvedNavigationMenus, draftNavigationMenus, navigationMenus, hasSelection, createNavigationMenu, blocks]);
25528    const Wrapper = isSaving ? external_wp_components_namespaceObject.Disabled : 'div';
25529    return (0,external_wp_element_namespaceObject.createElement)(Wrapper, {
25530      className: "wp-block-navigation__unsaved-changes"
25531    }, (0,external_wp_element_namespaceObject.createElement)("div", {
25532      className: classnames_default()('wp-block-navigation__unsaved-changes-overlay', {
25533        'is-saving': isSaving
25534      })
25535    }, (0,external_wp_element_namespaceObject.createElement)("div", innerBlocksProps)), isSaving && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Spinner, null));
25536  }
25537  
25538  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/navigation/edit/navigation-menu-delete-control.js
25539  
25540  
25541  /**
25542   * WordPress dependencies
25543   */
25544  
25545  
25546  
25547  
25548  
25549  function NavigationMenuDeleteControl(_ref) {
25550    let {
25551      onDelete
25552    } = _ref;
25553    const [isConfirmModalVisible, setIsConfirmModalVisible] = (0,external_wp_element_namespaceObject.useState)(false);
25554    const id = (0,external_wp_coreData_namespaceObject.useEntityId)('postType', 'wp_navigation');
25555    const [title] = (0,external_wp_coreData_namespaceObject.useEntityProp)('postType', 'wp_navigation', 'title');
25556    const {
25557      deleteEntityRecord
25558    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_coreData_namespaceObject.store);
25559    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
25560      className: "wp-block-navigation-delete-menu-button",
25561      variant: "secondary",
25562      isDestructive: true,
25563      onClick: () => {
25564        setIsConfirmModalVisible(true);
25565      }
25566    }, (0,external_wp_i18n_namespaceObject.__)('Delete menu')), isConfirmModalVisible && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Modal, {
25567      title: (0,external_wp_i18n_namespaceObject.sprintf)(
25568      /* translators: %s: the name of a menu to delete */
25569      (0,external_wp_i18n_namespaceObject.__)('Delete %s'), title),
25570      closeLabel: (0,external_wp_i18n_namespaceObject.__)('Cancel'),
25571      onRequestClose: () => setIsConfirmModalVisible(false)
25572    }, (0,external_wp_element_namespaceObject.createElement)("p", null, (0,external_wp_i18n_namespaceObject.__)('Are you sure you want to delete this navigation menu?')), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Flex, {
25573      justify: "flex-end"
25574    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.FlexItem, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
25575      variant: "secondary",
25576      onClick: () => {
25577        setIsConfirmModalVisible(false);
25578      }
25579    }, (0,external_wp_i18n_namespaceObject.__)('Cancel'))), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.FlexItem, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
25580      variant: "primary",
25581      onClick: () => {
25582        deleteEntityRecord('postType', 'wp_navigation', id, {
25583          force: true
25584        });
25585        onDelete(title);
25586      }
25587    }, (0,external_wp_i18n_namespaceObject.__)('Confirm'))))));
25588  }
25589  
25590  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/navigation/edit/use-navigation-notice.js
25591  /**
25592   * WordPress dependencies
25593   */
25594  
25595  
25596  
25597  
25598  function useNavigationNotice() {
25599    let {
25600      name,
25601      message = ''
25602    } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
25603    const noticeRef = (0,external_wp_element_namespaceObject.useRef)();
25604    const {
25605      createWarningNotice,
25606      removeNotice
25607    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_notices_namespaceObject.store);
25608  
25609    const showNotice = customMsg => {
25610      if (noticeRef.current) {
25611        return;
25612      }
25613  
25614      noticeRef.current = name;
25615      createWarningNotice(customMsg || message, {
25616        id: noticeRef.current,
25617        type: 'snackbar'
25618      });
25619    };
25620  
25621    const hideNotice = () => {
25622      if (!noticeRef.current) {
25623        return;
25624      }
25625  
25626      removeNotice(noticeRef.current);
25627      noticeRef.current = null;
25628    };
25629  
25630    return [showNotice, hideNotice];
25631  }
25632  
25633  /* harmony default export */ var use_navigation_notice = (useNavigationNotice);
25634  
25635  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/navigation/menu-items-to-blocks.js
25636  /**
25637   * External dependencies
25638   */
25639  
25640  /**
25641   * WordPress dependencies
25642   */
25643  
25644  
25645  
25646  /**
25647   * Convert a flat menu item structure to a nested blocks structure.
25648   *
25649   * @param {Object[]} menuItems An array of menu items.
25650   *
25651   * @return {WPBlock[]} An array of blocks.
25652   */
25653  
25654  function menuItemsToBlocks(menuItems) {
25655    if (!menuItems) {
25656      return null;
25657    }
25658  
25659    const menuTree = createDataTree(menuItems);
25660    const blocks = mapMenuItemsToBlocks(menuTree);
25661    return (0,external_wp_hooks_namespaceObject.applyFilters)('blocks.navigation.__unstableMenuItemsToBlocks', blocks, menuItems);
25662  }
25663  /**
25664   * A recursive function that maps menu item nodes to blocks.
25665   *
25666   * @param {WPNavMenuItem[]} menuItems An array of WPNavMenuItem items.
25667   * @return {Object} Object containing innerBlocks and mapping.
25668   */
25669  
25670  function mapMenuItemsToBlocks(menuItems) {
25671    let mapping = {}; // The menuItem should be in menu_order sort order.
25672  
25673    const sortedItems = (0,external_lodash_namespaceObject.sortBy)(menuItems, 'menu_order');
25674    const innerBlocks = sortedItems.map(menuItem => {
25675      var _menuItem$children, _menuItem$children2;
25676  
25677      if (menuItem.type === 'block') {
25678        const [block] = (0,external_wp_blocks_namespaceObject.parse)(menuItem.content.raw);
25679  
25680        if (!block) {
25681          return (0,external_wp_blocks_namespaceObject.createBlock)('core/freeform', {
25682            content: menuItem.content
25683          });
25684        }
25685  
25686        return block;
25687      }
25688  
25689      const attributes = menuItemToBlockAttributes(menuItem); // If there are children recurse to build those nested blocks.
25690  
25691      const {
25692        innerBlocks: nestedBlocks = [],
25693        // alias to avoid shadowing
25694        mapping: nestedMapping = {} // alias to avoid shadowing
25695  
25696      } = (_menuItem$children = menuItem.children) !== null && _menuItem$children !== void 0 && _menuItem$children.length ? mapMenuItemsToBlocks(menuItem.children) : {}; // Update parent mapping with nested mapping.
25697  
25698      mapping = { ...mapping,
25699        ...nestedMapping
25700      };
25701      const blockType = (_menuItem$children2 = menuItem.children) !== null && _menuItem$children2 !== void 0 && _menuItem$children2.length ? 'core/navigation-submenu' : 'core/navigation-link'; // Create block with nested "innerBlocks".
25702  
25703      const block = (0,external_wp_blocks_namespaceObject.createBlock)(blockType, attributes, nestedBlocks); // Create mapping for menuItem -> block.
25704  
25705      mapping[menuItem.id] = block.clientId;
25706      return block;
25707    });
25708    return {
25709      innerBlocks,
25710      mapping
25711    };
25712  }
25713  /**
25714   * A WP nav_menu_item object.
25715   * For more documentation on the individual fields present on a menu item please see:
25716   * https://core.trac.wordpress.org/browser/tags/5.7.1/src/wp-includes/nav-menu.php#L789
25717   *
25718   * Changes made here should also be mirrored in packages/edit-navigation/src/store/utils.js.
25719   *
25720   * @typedef WPNavMenuItem
25721   *
25722   * @property {Object} title       stores the raw and rendered versions of the title/label for this menu item.
25723   * @property {Array}  xfn         the XFN relationships expressed in the link of this menu item.
25724   * @property {Array}  classes     the HTML class attributes for this menu item.
25725   * @property {string} attr_title  the HTML title attribute for this menu item.
25726   * @property {string} object      The type of object originally represented, such as 'category', 'post', or 'attachment'.
25727   * @property {string} object_id   The DB ID of the original object this menu item represents, e.g. ID for posts and term_id for categories.
25728   * @property {string} description The description of this menu item.
25729   * @property {string} url         The URL to which this menu item points.
25730   * @property {string} type        The family of objects originally represented, such as 'post_type' or 'taxonomy'.
25731   * @property {string} target      The target attribute of the link element for this menu item.
25732   */
25733  
25734  /**
25735   * Convert block attributes to menu item.
25736   *
25737   * @param {WPNavMenuItem} menuItem the menu item to be converted to block attributes.
25738   * @return {Object} the block attributes converted from the WPNavMenuItem item.
25739   */
25740  
25741  
25742  function menuItemToBlockAttributes(_ref) {
25743    var _object;
25744  
25745    let {
25746      title: menuItemTitleField,
25747      xfn,
25748      classes,
25749      // eslint-disable-next-line camelcase
25750      attr_title,
25751      object,
25752      // eslint-disable-next-line camelcase
25753      object_id,
25754      description,
25755      url,
25756      type: menuItemTypeField,
25757      target
25758    } = _ref;
25759  
25760    // For historical reasons, the `core/navigation-link` variation type is `tag`
25761    // whereas WP Core expects `post_tag` as the `object` type.
25762    // To avoid writing a block migration we perform a conversion here.
25763    // See also inverse equivalent in `blockAttributesToMenuItem`.
25764    if (object && object === 'post_tag') {
25765      object = 'tag';
25766    }
25767  
25768    return {
25769      label: (menuItemTitleField === null || menuItemTitleField === void 0 ? void 0 : menuItemTitleField.rendered) || '',
25770      ...(((_object = object) === null || _object === void 0 ? void 0 : _object.length) && {
25771        type: object
25772      }),
25773      kind: (menuItemTypeField === null || menuItemTypeField === void 0 ? void 0 : menuItemTypeField.replace('_', '-')) || 'custom',
25774      url: url || '',
25775      ...((xfn === null || xfn === void 0 ? void 0 : xfn.length) && xfn.join(' ').trim() && {
25776        rel: xfn.join(' ').trim()
25777      }),
25778      ...((classes === null || classes === void 0 ? void 0 : classes.length) && classes.join(' ').trim() && {
25779        className: classes.join(' ').trim()
25780      }),
25781  
25782      /* eslint-disable camelcase */
25783      ...((attr_title === null || attr_title === void 0 ? void 0 : attr_title.length) && {
25784        title: attr_title
25785      }),
25786      ...(object_id && 'custom' !== object && {
25787        id: object_id
25788      }),
25789  
25790      /* eslint-enable camelcase */
25791      ...((description === null || description === void 0 ? void 0 : description.length) && {
25792        description
25793      }),
25794      ...(target === '_blank' && {
25795        opensInNewTab: true
25796      })
25797    };
25798  }
25799  /**
25800   * Creates a nested, hierarchical tree representation from unstructured data that
25801   * has an inherent relationship defined between individual items.
25802   *
25803   * For example, by default, each element in the dataset should have an `id` and
25804   * `parent` property where the `parent` property indicates a relationship between
25805   * the current item and another item with a matching `id` properties.
25806   *
25807   * This is useful for building linked lists of data from flat data structures.
25808   *
25809   * @param {Array}  dataset  linked data to be rearranged into a hierarchical tree based on relational fields.
25810   * @param {string} id       the property which uniquely identifies each entry within the array.
25811   * @param {*}      relation the property which identifies how the current item is related to other items in the data (if at all).
25812   * @return {Array} a nested array of parent/child relationships
25813   */
25814  
25815  
25816  function createDataTree(dataset) {
25817    let id = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'id';
25818    let relation = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'parent';
25819    const hashTable = Object.create(null);
25820    const dataTree = [];
25821  
25822    for (const data of dataset) {
25823      hashTable[data[id]] = { ...data,
25824        children: []
25825      };
25826  
25827      if (data[relation]) {
25828        hashTable[data[relation]] = hashTable[data[relation]] || {};
25829        hashTable[data[relation]].children = hashTable[data[relation]].children || [];
25830        hashTable[data[relation]].children.push(hashTable[data[id]]);
25831      } else {
25832        dataTree.push(hashTable[data[id]]);
25833      }
25834    }
25835  
25836    return dataTree;
25837  }
25838  
25839  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/navigation/edit/use-convert-classic-menu-to-block-menu.js
25840  /**
25841   * WordPress dependencies
25842   */
25843  
25844  
25845  
25846  
25847  /**
25848   * Internal dependencies
25849   */
25850  
25851  
25852  
25853  const CLASSIC_MENU_CONVERSION_SUCCESS = 'success';
25854  const CLASSIC_MENU_CONVERSION_ERROR = 'error';
25855  const CLASSIC_MENU_CONVERSION_PENDING = 'pending';
25856  const CLASSIC_MENU_CONVERSION_IDLE = 'idle';
25857  
25858  function useConvertClassicToBlockMenu(clientId) {
25859    const {
25860      create: createNavigationMenu
25861    } = useCreateNavigationMenu(clientId);
25862    const registry = (0,external_wp_data_namespaceObject.useRegistry)();
25863    const [status, setStatus] = (0,external_wp_element_namespaceObject.useState)(CLASSIC_MENU_CONVERSION_IDLE);
25864    const [value, setValue] = (0,external_wp_element_namespaceObject.useState)(null);
25865    const [error, setError] = (0,external_wp_element_namespaceObject.useState)(null);
25866  
25867    async function convertClassicMenuToBlockMenu(menuId, menuName) {
25868      let navigationMenu;
25869      let classicMenuItems; // 1. Fetch the classic Menu items.
25870  
25871      try {
25872        classicMenuItems = await registry.resolveSelect(external_wp_coreData_namespaceObject.store).getMenuItems({
25873          menus: menuId,
25874          per_page: -1,
25875          context: 'view'
25876        });
25877      } catch (err) {
25878        throw new Error((0,external_wp_i18n_namespaceObject.sprintf)( // translators: %s: the name of a menu (e.g. Header navigation).
25879        (0,external_wp_i18n_namespaceObject.__)(`Unable to fetch classic menu "%s" from API.`), menuName), {
25880          cause: err
25881        });
25882      } // Handle offline response which resolves to `null`.
25883  
25884  
25885      if (classicMenuItems === null) {
25886        throw new Error((0,external_wp_i18n_namespaceObject.sprintf)( // translators: %s: the name of a menu (e.g. Header navigation).
25887        (0,external_wp_i18n_namespaceObject.__)(`Unable to fetch classic menu "%s" from API.`), menuName));
25888      } // 2. Convert the classic items into blocks.
25889  
25890  
25891      const {
25892        innerBlocks
25893      } = menuItemsToBlocks(classicMenuItems); // 3. Create the `wp_navigation` Post with the blocks.
25894  
25895      try {
25896        navigationMenu = await createNavigationMenu(menuName, innerBlocks);
25897      } catch (err) {
25898        throw new Error((0,external_wp_i18n_namespaceObject.sprintf)( // translators: %s: the name of a menu (e.g. Header navigation).
25899        (0,external_wp_i18n_namespaceObject.__)(`Unable to create Navigation Menu "%s".`), menuName), {
25900          cause: err
25901        });
25902      }
25903  
25904      return navigationMenu;
25905    }
25906  
25907    const convert = (0,external_wp_element_namespaceObject.useCallback)((menuId, menuName) => {
25908      if (!menuId || !menuName) {
25909        setError('Unable to convert menu. Missing menu details.');
25910        setStatus(CLASSIC_MENU_CONVERSION_ERROR);
25911        return;
25912      }
25913  
25914      setStatus(CLASSIC_MENU_CONVERSION_PENDING);
25915      setValue(null);
25916      setError(null);
25917      convertClassicMenuToBlockMenu(menuId, menuName).then(navMenu => {
25918        setValue(navMenu);
25919        setStatus(CLASSIC_MENU_CONVERSION_SUCCESS);
25920      }).catch(err => {
25921        setError(err === null || err === void 0 ? void 0 : err.message);
25922        setStatus(CLASSIC_MENU_CONVERSION_ERROR); // Rethrow error for debugging.
25923  
25924        throw new Error((0,external_wp_i18n_namespaceObject.sprintf)( // translators: %s: the name of a menu (e.g. Header navigation).
25925        (0,external_wp_i18n_namespaceObject.__)(`Unable to create Navigation Menu "%s".`), menuName), {
25926          cause: err
25927        });
25928      });
25929    }, [clientId]);
25930    return {
25931      convert,
25932      status,
25933      value,
25934      error
25935    };
25936  }
25937  
25938  /* harmony default export */ var use_convert_classic_menu_to_block_menu = (useConvertClassicToBlockMenu);
25939  
25940  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/navigation/edit/index.js
25941  
25942  
25943  /**
25944   * External dependencies
25945   */
25946  
25947  /**
25948   * WordPress dependencies
25949   */
25950  
25951  
25952  
25953  
25954  
25955  
25956  
25957  
25958  /**
25959   * Internal dependencies
25960   */
25961  
25962  
25963  
25964  
25965  
25966  
25967  
25968  
25969  
25970  
25971  
25972  
25973  
25974  
25975  const EMPTY_ARRAY = [];
25976  
25977  function getComputedStyle(node) {
25978    return node.ownerDocument.defaultView.getComputedStyle(node);
25979  }
25980  
25981  function detectColors(colorsDetectionElement, setColor, setBackground) {
25982    if (!colorsDetectionElement) {
25983      return;
25984    }
25985  
25986    setColor(getComputedStyle(colorsDetectionElement).color);
25987    let backgroundColorNode = colorsDetectionElement;
25988    let backgroundColor = getComputedStyle(backgroundColorNode).backgroundColor;
25989  
25990    while (backgroundColor === 'rgba(0, 0, 0, 0)' && backgroundColorNode.parentNode && backgroundColorNode.parentNode.nodeType === backgroundColorNode.parentNode.ELEMENT_NODE) {
25991      backgroundColorNode = backgroundColorNode.parentNode;
25992      backgroundColor = getComputedStyle(backgroundColorNode).backgroundColor;
25993    }
25994  
25995    setBackground(backgroundColor);
25996  }
25997  
25998  function Navigation(_ref) {
25999    var _attributes$style, _attributes$style$typ;
26000  
26001    let {
26002      attributes,
26003      setAttributes,
26004      clientId,
26005      isSelected,
26006      className,
26007      backgroundColor,
26008      setBackgroundColor,
26009      textColor,
26010      setTextColor,
26011      overlayBackgroundColor,
26012      setOverlayBackgroundColor,
26013      overlayTextColor,
26014      setOverlayTextColor,
26015      // These props are used by the navigation editor to override specific
26016      // navigation block settings.
26017      hasSubmenuIndicatorSetting = true,
26018      hasColorSettings = true,
26019      customPlaceholder: CustomPlaceholder = null
26020    } = _ref;
26021    const {
26022      openSubmenusOnClick,
26023      overlayMenu,
26024      showSubmenuIcon,
26025      layout: {
26026        justifyContent,
26027        orientation = 'horizontal',
26028        flexWrap = 'wrap'
26029      } = {},
26030      hasIcon
26031    } = attributes;
26032    const ref = attributes.ref;
26033    const registry = (0,external_wp_data_namespaceObject.useRegistry)();
26034  
26035    const setRef = postId => {
26036      setAttributes({
26037        ref: postId
26038      });
26039    };
26040  
26041    const [hasAlreadyRendered, RecursionProvider] = (0,external_wp_blockEditor_namespaceObject.__experimentalUseNoRecursiveRenders)(`navigationMenu/$ref}`); // Preload classic menus, so that they don't suddenly pop-in when viewing
26042    // the Select Menu dropdown.
26043  
26044    useNavigationEntities();
26045    const [showNavigationMenuDeleteNotice] = use_navigation_notice({
26046      name: 'block-library/core/navigation/delete'
26047    });
26048    const [showNavigationMenuCreateNotice, hideNavigationMenuCreateNotice] = use_navigation_notice({
26049      name: 'block-library/core/navigation/create'
26050    });
26051    const {
26052      create: createNavigationMenu,
26053      status: createNavigationMenuStatus,
26054      error: createNavigationMenuError,
26055      value: createNavigationMenuPost
26056    } = useCreateNavigationMenu(clientId);
26057    const isCreatingNavigationMenu = createNavigationMenuStatus === CREATE_NAVIGATION_MENU_PENDING;
26058    (0,external_wp_element_namespaceObject.useEffect)(() => {
26059      hideNavigationMenuCreateNotice();
26060  
26061      if (createNavigationMenuStatus === CREATE_NAVIGATION_MENU_PENDING) {
26062        (0,external_wp_a11y_namespaceObject.speak)((0,external_wp_i18n_namespaceObject.__)(`Creating Navigation Menu.`));
26063      }
26064  
26065      if (createNavigationMenuStatus === CREATE_NAVIGATION_MENU_SUCCESS) {
26066        setRef(createNavigationMenuPost.id);
26067        selectBlock(clientId);
26068        showNavigationMenuCreateNotice((0,external_wp_i18n_namespaceObject.__)(`Navigation Menu successfully created.`));
26069      }
26070  
26071      if (createNavigationMenuStatus === CREATE_NAVIGATION_MENU_ERROR) {
26072        showNavigationMenuCreateNotice((0,external_wp_i18n_namespaceObject.__)('Failed to create Navigation Menu.'));
26073      }
26074    }, [createNavigationMenu, createNavigationMenuStatus, createNavigationMenuError, createNavigationMenuPost]);
26075    const {
26076      hasUncontrolledInnerBlocks,
26077      uncontrolledInnerBlocks,
26078      isInnerBlockSelected,
26079      hasSubmenus
26080    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
26081      const {
26082        getBlock,
26083        getBlocks,
26084        hasSelectedInnerBlock
26085      } = select(external_wp_blockEditor_namespaceObject.store); // This relies on the fact that `getBlock` won't return controlled
26086      // inner blocks, while `getBlocks` does. It might be more stable to
26087      // introduce a selector like `getUncontrolledInnerBlocks`, just in
26088      // case `getBlock` is fixed.
26089  
26090      const _uncontrolledInnerBlocks = getBlock(clientId).innerBlocks;
26091  
26092      const _hasUncontrolledInnerBlocks = !!(_uncontrolledInnerBlocks !== null && _uncontrolledInnerBlocks !== void 0 && _uncontrolledInnerBlocks.length);
26093  
26094      const _controlledInnerBlocks = _hasUncontrolledInnerBlocks ? EMPTY_ARRAY : getBlocks(clientId);
26095  
26096      const innerBlocks = _hasUncontrolledInnerBlocks ? _uncontrolledInnerBlocks : _controlledInnerBlocks;
26097      return {
26098        hasSubmenus: !!innerBlocks.find(block => block.name === 'core/navigation-submenu'),
26099        hasUncontrolledInnerBlocks: _hasUncontrolledInnerBlocks,
26100        uncontrolledInnerBlocks: _uncontrolledInnerBlocks,
26101        isInnerBlockSelected: hasSelectedInnerBlock(clientId, true)
26102      };
26103    }, [clientId]);
26104    const {
26105      replaceInnerBlocks,
26106      selectBlock,
26107      __unstableMarkNextChangeAsNotPersistent
26108    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_blockEditor_namespaceObject.store);
26109    const [hasSavedUnsavedInnerBlocks, setHasSavedUnsavedInnerBlocks] = (0,external_wp_element_namespaceObject.useState)(false);
26110    const [isResponsiveMenuOpen, setResponsiveMenuVisibility] = (0,external_wp_element_namespaceObject.useState)(false);
26111    const [overlayMenuPreview, setOverlayMenuPreview] = (0,external_wp_element_namespaceObject.useState)(false);
26112    const {
26113      hasResolvedNavigationMenus,
26114      isNavigationMenuResolved,
26115      isNavigationMenuMissing,
26116      navigationMenus,
26117      navigationMenu,
26118      canUserUpdateNavigationMenu,
26119      hasResolvedCanUserUpdateNavigationMenu,
26120      canUserDeleteNavigationMenu,
26121      hasResolvedCanUserDeleteNavigationMenu,
26122      canUserCreateNavigationMenu,
26123      isResolvingCanUserCreateNavigationMenu,
26124      hasResolvedCanUserCreateNavigationMenu
26125    } = useNavigationMenu(ref); // Attempt to retrieve and prioritize any existing navigation menu unless
26126    // a specific ref is allocated or the user is explicitly creating a new menu. The aim is
26127    // for the block to "just work" from a user perspective using existing data.
26128  
26129    (0,external_wp_element_namespaceObject.useEffect)(() => {
26130      if (isCreatingNavigationMenu || ref || !(navigationMenus !== null && navigationMenus !== void 0 && navigationMenus.length) || (navigationMenus === null || navigationMenus === void 0 ? void 0 : navigationMenus.length) > 1) {
26131        return;
26132      }
26133  
26134      setRef(navigationMenus[0].id);
26135    }, [navigationMenus]);
26136    const navRef = (0,external_wp_element_namespaceObject.useRef)();
26137    const isDraftNavigationMenu = (navigationMenu === null || navigationMenu === void 0 ? void 0 : navigationMenu.status) === 'draft';
26138    const {
26139      convert,
26140      status: classicMenuConversionStatus,
26141      error: classicMenuConversionError,
26142      value: classicMenuConversionResult
26143    } = use_convert_classic_menu_to_block_menu(clientId);
26144    const isConvertingClassicMenu = classicMenuConversionStatus === CLASSIC_MENU_CONVERSION_PENDING; // The standard HTML5 tag for the block wrapper.
26145  
26146    const TagName = 'nav'; // "placeholder" shown if:
26147    // - there is no ref attribute pointing to a Navigation Post.
26148    // - there is no classic menu conversion process in progress.
26149    // - there is no menu creation process in progress.
26150    // - there are no uncontrolled blocks.
26151  
26152    const isPlaceholder = !ref && !isCreatingNavigationMenu && !isConvertingClassicMenu && hasResolvedNavigationMenus && !hasUncontrolledInnerBlocks;
26153    const isEntityAvailable = !isNavigationMenuMissing && isNavigationMenuResolved; // "loading" state:
26154    // - there is a menu creation process in progress.
26155    // - there is a classic menu conversion process in progress.
26156    // OR
26157    // - there is a ref attribute pointing to a Navigation Post
26158    // - the Navigation Post isn't available (hasn't resolved) yet.
26159  
26160    const isLoading = !hasResolvedNavigationMenus || isCreatingNavigationMenu || isConvertingClassicMenu || !!(ref && !isEntityAvailable && !isConvertingClassicMenu);
26161    const textDecoration = (_attributes$style = attributes.style) === null || _attributes$style === void 0 ? void 0 : (_attributes$style$typ = _attributes$style.typography) === null || _attributes$style$typ === void 0 ? void 0 : _attributes$style$typ.textDecoration;
26162    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
26163      ref: navRef,
26164      className: classnames_default()(className, {
26165        'items-justified-right': justifyContent === 'right',
26166        'items-justified-space-between': justifyContent === 'space-between',
26167        'items-justified-left': justifyContent === 'left',
26168        'items-justified-center': justifyContent === 'center',
26169        'is-vertical': orientation === 'vertical',
26170        'no-wrap': flexWrap === 'nowrap',
26171        'is-responsive': 'never' !== overlayMenu,
26172        'has-text-color': !!textColor.color || !!(textColor !== null && textColor !== void 0 && textColor.class),
26173        [(0,external_wp_blockEditor_namespaceObject.getColorClassName)('color', textColor === null || textColor === void 0 ? void 0 : textColor.slug)]: !!(textColor !== null && textColor !== void 0 && textColor.slug),
26174        'has-background': !!backgroundColor.color || backgroundColor.class,
26175        [(0,external_wp_blockEditor_namespaceObject.getColorClassName)('background-color', backgroundColor === null || backgroundColor === void 0 ? void 0 : backgroundColor.slug)]: !!(backgroundColor !== null && backgroundColor !== void 0 && backgroundColor.slug),
26176        [`has-text-decoration-$textDecoration}`]: textDecoration
26177      }),
26178      style: {
26179        color: !(textColor !== null && textColor !== void 0 && textColor.slug) && (textColor === null || textColor === void 0 ? void 0 : textColor.color),
26180        backgroundColor: !(backgroundColor !== null && backgroundColor !== void 0 && backgroundColor.slug) && (backgroundColor === null || backgroundColor === void 0 ? void 0 : backgroundColor.color)
26181      }
26182    });
26183    const overlayClassnames = classnames_default()({
26184      'has-text-color': !!overlayTextColor.color || !!(overlayTextColor !== null && overlayTextColor !== void 0 && overlayTextColor.class),
26185      [(0,external_wp_blockEditor_namespaceObject.getColorClassName)('color', overlayTextColor === null || overlayTextColor === void 0 ? void 0 : overlayTextColor.slug)]: !!(overlayTextColor !== null && overlayTextColor !== void 0 && overlayTextColor.slug),
26186      'has-background': !!overlayBackgroundColor.color || (overlayBackgroundColor === null || overlayBackgroundColor === void 0 ? void 0 : overlayBackgroundColor.class),
26187      [(0,external_wp_blockEditor_namespaceObject.getColorClassName)('background-color', overlayBackgroundColor === null || overlayBackgroundColor === void 0 ? void 0 : overlayBackgroundColor.slug)]: !!(overlayBackgroundColor !== null && overlayBackgroundColor !== void 0 && overlayBackgroundColor.slug)
26188    });
26189    const overlayStyles = {
26190      color: !(overlayTextColor !== null && overlayTextColor !== void 0 && overlayTextColor.slug) && (overlayTextColor === null || overlayTextColor === void 0 ? void 0 : overlayTextColor.color),
26191      backgroundColor: !(overlayBackgroundColor !== null && overlayBackgroundColor !== void 0 && overlayBackgroundColor.slug) && (overlayBackgroundColor === null || overlayBackgroundColor === void 0 ? void 0 : overlayBackgroundColor.color) && overlayBackgroundColor.color
26192    }; // Turn on contrast checker for web only since it's not supported on mobile yet.
26193  
26194    const enableContrastChecking = external_wp_element_namespaceObject.Platform.OS === 'web';
26195    const [detectedBackgroundColor, setDetectedBackgroundColor] = (0,external_wp_element_namespaceObject.useState)();
26196    const [detectedColor, setDetectedColor] = (0,external_wp_element_namespaceObject.useState)();
26197    const [detectedOverlayBackgroundColor, setDetectedOverlayBackgroundColor] = (0,external_wp_element_namespaceObject.useState)();
26198    const [detectedOverlayColor, setDetectedOverlayColor] = (0,external_wp_element_namespaceObject.useState)();
26199    const [showClassicMenuConversionErrorNotice, hideClassicMenuConversionErrorNotice] = use_navigation_notice({
26200      name: 'block-library/core/navigation/classic-menu-conversion/error'
26201    });
26202  
26203    function handleUpdateMenu(menuId) {
26204      setRef(menuId);
26205      selectBlock(clientId);
26206    }
26207  
26208    (0,external_wp_element_namespaceObject.useEffect)(() => {
26209      if (classicMenuConversionStatus === CLASSIC_MENU_CONVERSION_PENDING) {
26210        (0,external_wp_a11y_namespaceObject.speak)((0,external_wp_i18n_namespaceObject.__)('Classic menu importing.'));
26211      }
26212  
26213      if (classicMenuConversionStatus === CLASSIC_MENU_CONVERSION_SUCCESS && classicMenuConversionResult) {
26214        handleUpdateMenu(classicMenuConversionResult === null || classicMenuConversionResult === void 0 ? void 0 : classicMenuConversionResult.id);
26215        hideClassicMenuConversionErrorNotice();
26216        (0,external_wp_a11y_namespaceObject.speak)((0,external_wp_i18n_namespaceObject.__)('Classic menu imported successfully.'));
26217      }
26218  
26219      if (classicMenuConversionStatus === CLASSIC_MENU_CONVERSION_ERROR) {
26220        showClassicMenuConversionErrorNotice(classicMenuConversionError);
26221        (0,external_wp_a11y_namespaceObject.speak)((0,external_wp_i18n_namespaceObject.__)('Classic menu import failed.'));
26222      }
26223    }, [classicMenuConversionStatus, classicMenuConversionResult, classicMenuConversionError]); // Spacer block needs orientation from context. This is a patch until
26224    // https://github.com/WordPress/gutenberg/issues/36197 is addressed.
26225  
26226    (0,external_wp_element_namespaceObject.useEffect)(() => {
26227      if (orientation) {
26228        __unstableMarkNextChangeAsNotPersistent();
26229  
26230        setAttributes({
26231          orientation
26232        });
26233      }
26234    }, [orientation]);
26235    (0,external_wp_element_namespaceObject.useEffect)(() => {
26236      var _navRef$current;
26237  
26238      if (!enableContrastChecking) {
26239        return;
26240      }
26241  
26242      detectColors(navRef.current, setDetectedColor, setDetectedBackgroundColor);
26243      const subMenuElement = (_navRef$current = navRef.current) === null || _navRef$current === void 0 ? void 0 : _navRef$current.querySelector('[data-type="core/navigation-link"] [data-type="core/navigation-link"]');
26244  
26245      if (subMenuElement) {
26246        detectColors(subMenuElement, setDetectedOverlayColor, setDetectedOverlayBackgroundColor);
26247      }
26248    });
26249    const [showCantEditNotice, hideCantEditNotice] = use_navigation_notice({
26250      name: 'block-library/core/navigation/permissions/update',
26251      message: (0,external_wp_i18n_namespaceObject.__)('You do not have permission to edit this Menu. Any changes made will not be saved.')
26252    });
26253    const [showCantCreateNotice, hideCantCreateNotice] = use_navigation_notice({
26254      name: 'block-library/core/navigation/permissions/create',
26255      message: (0,external_wp_i18n_namespaceObject.__)('You do not have permission to create Navigation Menus.')
26256    });
26257    (0,external_wp_element_namespaceObject.useEffect)(() => {
26258      if (!isSelected && !isInnerBlockSelected) {
26259        hideCantEditNotice();
26260        hideCantCreateNotice();
26261      }
26262  
26263      if (isSelected || isInnerBlockSelected) {
26264        if (hasResolvedCanUserUpdateNavigationMenu && !canUserUpdateNavigationMenu) {
26265          showCantEditNotice();
26266        }
26267  
26268        if (!ref && hasResolvedCanUserCreateNavigationMenu && !canUserCreateNavigationMenu) {
26269          showCantCreateNotice();
26270        }
26271      }
26272    }, [isSelected, isInnerBlockSelected, canUserUpdateNavigationMenu, hasResolvedCanUserUpdateNavigationMenu, canUserCreateNavigationMenu, hasResolvedCanUserCreateNavigationMenu, ref]);
26273    const navigationSelectorRef = (0,external_wp_element_namespaceObject.useRef)();
26274    const [shouldFocusNavigationSelector, setShouldFocusNavigationSelector] = (0,external_wp_element_namespaceObject.useState)(false);
26275    const handleSelectNavigation = (0,external_wp_element_namespaceObject.useCallback)(navPostOrClassicMenu => {
26276      if (!navPostOrClassicMenu) {
26277        return;
26278      }
26279  
26280      const isClassicMenu = navPostOrClassicMenu.hasOwnProperty('auto_add');
26281  
26282      if (isClassicMenu) {
26283        convert(navPostOrClassicMenu.id, navPostOrClassicMenu.name);
26284      } else {
26285        handleUpdateMenu(navPostOrClassicMenu.id);
26286      }
26287  
26288      setShouldFocusNavigationSelector(true);
26289    }, [convert, handleUpdateMenu]); // Focus support after menu selection.
26290  
26291    (0,external_wp_element_namespaceObject.useEffect)(() => {
26292      var _navigationSelectorRe;
26293  
26294      if (isDraftNavigationMenu || !isEntityAvailable || !shouldFocusNavigationSelector) {
26295        return;
26296      }
26297  
26298      navigationSelectorRef === null || navigationSelectorRef === void 0 ? void 0 : (_navigationSelectorRe = navigationSelectorRef.current) === null || _navigationSelectorRe === void 0 ? void 0 : _navigationSelectorRe.focus();
26299      setShouldFocusNavigationSelector(false);
26300    }, [isDraftNavigationMenu, isEntityAvailable, shouldFocusNavigationSelector]);
26301    const resetToEmptyBlock = (0,external_wp_element_namespaceObject.useCallback)(() => {
26302      registry.batch(() => {
26303        setAttributes({
26304          ref: undefined
26305        });
26306  
26307        if (!ref) {
26308          replaceInnerBlocks(clientId, []);
26309        }
26310      });
26311    }, [clientId, ref]); // If the block has inner blocks, but no menu id, then these blocks are either:
26312    // - inserted via a pattern.
26313    // - inserted directly via Code View (or otherwise).
26314    // - from an older version of navigation block added before the block used a wp_navigation entity.
26315    // Consider this state as 'unsaved' and offer an uncontrolled version of inner blocks,
26316    // that automatically saves the menu as an entity when changes are made to the inner blocks.
26317  
26318    const hasUnsavedBlocks = hasUncontrolledInnerBlocks && !isEntityAvailable;
26319  
26320    if (hasUnsavedBlocks) {
26321      return (0,external_wp_element_namespaceObject.createElement)(TagName, blockProps, (0,external_wp_element_namespaceObject.createElement)(ResponsiveWrapper, {
26322        id: clientId,
26323        onToggle: setResponsiveMenuVisibility,
26324        isOpen: isResponsiveMenuOpen,
26325        isResponsive: 'never' !== overlayMenu,
26326        isHiddenByDefault: 'always' === overlayMenu,
26327        classNames: overlayClassnames,
26328        styles: overlayStyles
26329      }, (0,external_wp_element_namespaceObject.createElement)(UnsavedInnerBlocks, {
26330        blockProps: blockProps,
26331        blocks: uncontrolledInnerBlocks,
26332        clientId: clientId,
26333        navigationMenus: navigationMenus,
26334        hasSelection: isSelected || isInnerBlockSelected,
26335        hasSavedUnsavedInnerBlocks: hasSavedUnsavedInnerBlocks,
26336        onSave: post => {
26337          // Set some state used as a guard to prevent the creation of multiple posts.
26338          setHasSavedUnsavedInnerBlocks(true); // Switch to using the wp_navigation entity.
26339  
26340          setRef(post.id);
26341          showNavigationMenuCreateNotice((0,external_wp_i18n_namespaceObject.__)(`New Navigation Menu created.`));
26342        }
26343      })));
26344    } // Show a warning if the selected menu is no longer available.
26345    // TODO - the user should be able to select a new one?
26346  
26347  
26348    if (ref && isNavigationMenuMissing) {
26349      return (0,external_wp_element_namespaceObject.createElement)("div", blockProps, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.Warning, null, (0,external_wp_i18n_namespaceObject.__)('Navigation menu has been deleted or is unavailable. '), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
26350        onClick: resetToEmptyBlock,
26351        variant: "link"
26352      }, (0,external_wp_i18n_namespaceObject.__)('Create a new menu?'))));
26353    }
26354  
26355    if (isEntityAvailable && hasAlreadyRendered) {
26356      return (0,external_wp_element_namespaceObject.createElement)("div", blockProps, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.Warning, null, (0,external_wp_i18n_namespaceObject.__)('Block cannot be rendered inside itself.')));
26357    }
26358  
26359    const PlaceholderComponent = CustomPlaceholder ? CustomPlaceholder : NavigationPlaceholder;
26360    const isResponsive = 'never' !== overlayMenu;
26361    const overlayMenuPreviewClasses = classnames_default()('wp-block-navigation__overlay-menu-preview', {
26362      open: overlayMenuPreview
26363    });
26364  
26365    if (isPlaceholder) {
26366      return (0,external_wp_element_namespaceObject.createElement)(TagName, blockProps, (0,external_wp_element_namespaceObject.createElement)(PlaceholderComponent, {
26367        isSelected: isSelected,
26368        currentMenuId: ref,
26369        clientId: clientId,
26370        canUserCreateNavigationMenu: canUserCreateNavigationMenu,
26371        isResolvingCanUserCreateNavigationMenu: isResolvingCanUserCreateNavigationMenu,
26372        onFinish: handleSelectNavigation,
26373        onCreateEmpty: () => createNavigationMenu('', [])
26374      }));
26375    }
26376  
26377    return (0,external_wp_element_namespaceObject.createElement)(external_wp_coreData_namespaceObject.EntityProvider, {
26378      kind: "postType",
26379      type: "wp_navigation",
26380      id: ref
26381    }, (0,external_wp_element_namespaceObject.createElement)(RecursionProvider, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, null, !isDraftNavigationMenu && isEntityAvailable && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarGroup, {
26382      className: "wp-block-navigation__toolbar-menu-selector"
26383    }, (0,external_wp_element_namespaceObject.createElement)(navigation_menu_selector, {
26384      ref: navigationSelectorRef,
26385      currentMenuId: ref,
26386      clientId: clientId,
26387      onSelect: handleSelectNavigation,
26388      onCreateNew: resetToEmptyBlock
26389      /* translators: %s: The name of a menu. */
26390      ,
26391      actionLabel: (0,external_wp_i18n_namespaceObject.__)("Switch to '%s'"),
26392      showManageActions: true
26393    }))), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, hasSubmenuIndicatorSetting && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
26394      title: (0,external_wp_i18n_namespaceObject.__)('Display')
26395    }, isResponsive && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
26396      className: overlayMenuPreviewClasses,
26397      onClick: () => {
26398        setOverlayMenuPreview(!overlayMenuPreview);
26399      }
26400    }, hasIcon && (0,external_wp_element_namespaceObject.createElement)(OverlayMenuIcon, null), !hasIcon && (0,external_wp_element_namespaceObject.createElement)("span", null, (0,external_wp_i18n_namespaceObject.__)('Menu'))), overlayMenuPreview && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
26401      label: (0,external_wp_i18n_namespaceObject.__)('Show icon button'),
26402      help: (0,external_wp_i18n_namespaceObject.__)('Configure the visual appearance of the button opening the overlay menu.'),
26403      onChange: value => setAttributes({
26404        hasIcon: value
26405      }),
26406      checked: hasIcon
26407    }), (0,external_wp_element_namespaceObject.createElement)("h3", null, (0,external_wp_i18n_namespaceObject.__)('Overlay Menu')), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalToggleGroupControl, {
26408      label: (0,external_wp_i18n_namespaceObject.__)('Configure overlay menu'),
26409      value: overlayMenu,
26410      help: (0,external_wp_i18n_namespaceObject.__)('Collapses the navigation options in a menu icon opening an overlay.'),
26411      onChange: value => setAttributes({
26412        overlayMenu: value
26413      }),
26414      isBlock: true,
26415      hideLabelFromVision: true
26416    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalToggleGroupControlOption, {
26417      value: "never",
26418      label: (0,external_wp_i18n_namespaceObject.__)('Off')
26419    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalToggleGroupControlOption, {
26420      value: "mobile",
26421      label: (0,external_wp_i18n_namespaceObject.__)('Mobile')
26422    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalToggleGroupControlOption, {
26423      value: "always",
26424      label: (0,external_wp_i18n_namespaceObject.__)('Always')
26425    })), hasSubmenus && (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)("h3", null, (0,external_wp_i18n_namespaceObject.__)('Submenus')), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
26426      checked: openSubmenusOnClick,
26427      onChange: value => {
26428        setAttributes({
26429          openSubmenusOnClick: value,
26430          ...(value && {
26431            showSubmenuIcon: true
26432          }) // Make sure arrows are shown when we toggle this on.
26433  
26434        });
26435      },
26436      label: (0,external_wp_i18n_namespaceObject.__)('Open on click')
26437    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
26438      checked: showSubmenuIcon,
26439      onChange: value => {
26440        setAttributes({
26441          showSubmenuIcon: value
26442        });
26443      },
26444      disabled: attributes.openSubmenusOnClick,
26445      label: (0,external_wp_i18n_namespaceObject.__)('Show arrow')
26446    }))), hasColorSettings && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.PanelColorSettings, {
26447      __experimentalHasMultipleOrigins: true,
26448      __experimentalIsRenderedInSidebar: true,
26449      title: (0,external_wp_i18n_namespaceObject.__)('Color'),
26450      initialOpen: false,
26451      colorSettings: [{
26452        value: textColor.color,
26453        onChange: setTextColor,
26454        label: (0,external_wp_i18n_namespaceObject.__)('Text')
26455      }, {
26456        value: backgroundColor.color,
26457        onChange: setBackgroundColor,
26458        label: (0,external_wp_i18n_namespaceObject.__)('Background')
26459      }, {
26460        value: overlayTextColor.color,
26461        onChange: setOverlayTextColor,
26462        label: (0,external_wp_i18n_namespaceObject.__)('Submenu & overlay text')
26463      }, {
26464        value: overlayBackgroundColor.color,
26465        onChange: setOverlayBackgroundColor,
26466        label: (0,external_wp_i18n_namespaceObject.__)('Submenu & overlay background')
26467      }]
26468    }, enableContrastChecking && (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.ContrastChecker, {
26469      backgroundColor: detectedBackgroundColor,
26470      textColor: detectedColor
26471    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.ContrastChecker, {
26472      backgroundColor: detectedOverlayBackgroundColor,
26473      textColor: detectedOverlayColor
26474    })))), isEntityAvailable && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, {
26475      __experimentalGroup: "advanced"
26476    }, hasResolvedCanUserUpdateNavigationMenu && canUserUpdateNavigationMenu && (0,external_wp_element_namespaceObject.createElement)(NavigationMenuNameControl, null), hasResolvedCanUserDeleteNavigationMenu && canUserDeleteNavigationMenu && (0,external_wp_element_namespaceObject.createElement)(NavigationMenuDeleteControl, {
26477      onDelete: function () {
26478        let deletedMenuTitle = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
26479        resetToEmptyBlock();
26480        showNavigationMenuDeleteNotice((0,external_wp_i18n_namespaceObject.sprintf)( // translators: %s: the name of a menu (e.g. Header navigation).
26481        (0,external_wp_i18n_namespaceObject.__)('Navigation menu %s successfully deleted.'), deletedMenuTitle));
26482      }
26483    })), isLoading && (0,external_wp_element_namespaceObject.createElement)(TagName, blockProps, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Spinner, {
26484      className: "wp-block-navigation__loading-indicator"
26485    })), !isLoading && (0,external_wp_element_namespaceObject.createElement)(TagName, blockProps, (0,external_wp_element_namespaceObject.createElement)(ResponsiveWrapper, {
26486      id: clientId,
26487      onToggle: setResponsiveMenuVisibility,
26488      label: (0,external_wp_i18n_namespaceObject.__)('Menu'),
26489      hasIcon: hasIcon,
26490      isOpen: isResponsiveMenuOpen,
26491      isResponsive: isResponsive,
26492      isHiddenByDefault: 'always' === overlayMenu,
26493      classNames: overlayClassnames,
26494      styles: overlayStyles
26495    }, isEntityAvailable && (0,external_wp_element_namespaceObject.createElement)(NavigationInnerBlocks, {
26496      clientId: clientId,
26497      hasCustomPlaceholder: !!CustomPlaceholder,
26498      orientation: orientation
26499    })))));
26500  }
26501  
26502  /* harmony default export */ var navigation_edit = ((0,external_wp_blockEditor_namespaceObject.withColors)({
26503    textColor: 'color'
26504  }, {
26505    backgroundColor: 'color'
26506  }, {
26507    overlayBackgroundColor: 'color'
26508  }, {
26509    overlayTextColor: 'color'
26510  })(Navigation));
26511  
26512  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/navigation/save.js
26513  
26514  
26515  /**
26516   * WordPress dependencies
26517   */
26518  
26519  function navigation_save_save(_ref) {
26520    let {
26521      attributes
26522    } = _ref;
26523  
26524    if (attributes.ref) {
26525      // Avoid rendering inner blocks when a ref is defined.
26526      // When this id is defined the inner blocks are loaded from the
26527      // `wp_navigation` entity rather than the hard-coded block html.
26528      return;
26529    }
26530  
26531    return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InnerBlocks.Content, null);
26532  }
26533  
26534  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/navigation/deprecated.js
26535  
26536  
26537  /**
26538   * External dependencies
26539   */
26540  
26541  /**
26542   * WordPress dependencies
26543   */
26544  
26545  
26546  
26547  /**
26548   * Internal dependencies
26549   */
26550  
26551  
26552  const TYPOGRAPHY_PRESET_DEPRECATION_MAP = {
26553    fontStyle: 'var:preset|font-style|',
26554    fontWeight: 'var:preset|font-weight|',
26555    textDecoration: 'var:preset|text-decoration|',
26556    textTransform: 'var:preset|text-transform|'
26557  };
26558  
26559  const migrateIdToRef = _ref => {
26560    let {
26561      navigationMenuId,
26562      ...attributes
26563    } = _ref;
26564    return { ...attributes,
26565      ref: navigationMenuId
26566    };
26567  };
26568  
26569  const deprecated_migrateWithLayout = attributes => {
26570    if (!!attributes.layout) {
26571      return attributes;
26572    }
26573  
26574    const {
26575      itemsJustification,
26576      orientation,
26577      ...updatedAttributes
26578    } = attributes;
26579  
26580    if (itemsJustification || orientation) {
26581      Object.assign(updatedAttributes, {
26582        layout: {
26583          type: 'flex',
26584          ...(itemsJustification && {
26585            justifyContent: itemsJustification
26586          }),
26587          ...(orientation && {
26588            orientation
26589          })
26590        }
26591      });
26592    }
26593  
26594    return updatedAttributes;
26595  };
26596  
26597  const navigation_deprecated_v6 = {
26598    attributes: {
26599      navigationMenuId: {
26600        type: 'number'
26601      },
26602      textColor: {
26603        type: 'string'
26604      },
26605      customTextColor: {
26606        type: 'string'
26607      },
26608      rgbTextColor: {
26609        type: 'string'
26610      },
26611      backgroundColor: {
26612        type: 'string'
26613      },
26614      customBackgroundColor: {
26615        type: 'string'
26616      },
26617      rgbBackgroundColor: {
26618        type: 'string'
26619      },
26620      showSubmenuIcon: {
26621        type: 'boolean',
26622        default: true
26623      },
26624      openSubmenusOnClick: {
26625        type: 'boolean',
26626        default: false
26627      },
26628      overlayMenu: {
26629        type: 'string',
26630        default: 'mobile'
26631      },
26632      __unstableLocation: {
26633        type: 'string'
26634      },
26635      overlayBackgroundColor: {
26636        type: 'string'
26637      },
26638      customOverlayBackgroundColor: {
26639        type: 'string'
26640      },
26641      overlayTextColor: {
26642        type: 'string'
26643      },
26644      customOverlayTextColor: {
26645        type: 'string'
26646      }
26647    },
26648    supports: {
26649      align: ['wide', 'full'],
26650      anchor: true,
26651      html: false,
26652      inserter: true,
26653      typography: {
26654        fontSize: true,
26655        lineHeight: true,
26656        __experimentalFontStyle: true,
26657        __experimentalFontWeight: true,
26658        __experimentalTextTransform: true,
26659        __experimentalFontFamily: true,
26660        __experimentalTextDecoration: true,
26661        __experimentalDefaultControls: {
26662          fontSize: true
26663        }
26664      },
26665      spacing: {
26666        blockGap: true,
26667        units: ['px', 'em', 'rem', 'vh', 'vw'],
26668        __experimentalDefaultControls: {
26669          blockGap: true
26670        }
26671      },
26672      __experimentalLayout: {
26673        allowSwitching: false,
26674        allowInheriting: false,
26675        default: {
26676          type: 'flex'
26677        }
26678      }
26679    },
26680  
26681    save() {
26682      return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InnerBlocks.Content, null);
26683    },
26684  
26685    isEligible: _ref2 => {
26686      let {
26687        navigationMenuId
26688      } = _ref2;
26689      return !!navigationMenuId;
26690    },
26691    migrate: migrateIdToRef
26692  };
26693  const navigation_deprecated_v5 = {
26694    attributes: {
26695      navigationMenuId: {
26696        type: 'number'
26697      },
26698      orientation: {
26699        type: 'string',
26700        default: 'horizontal'
26701      },
26702      textColor: {
26703        type: 'string'
26704      },
26705      customTextColor: {
26706        type: 'string'
26707      },
26708      rgbTextColor: {
26709        type: 'string'
26710      },
26711      backgroundColor: {
26712        type: 'string'
26713      },
26714      customBackgroundColor: {
26715        type: 'string'
26716      },
26717      rgbBackgroundColor: {
26718        type: 'string'
26719      },
26720      itemsJustification: {
26721        type: 'string'
26722      },
26723      showSubmenuIcon: {
26724        type: 'boolean',
26725        default: true
26726      },
26727      openSubmenusOnClick: {
26728        type: 'boolean',
26729        default: false
26730      },
26731      overlayMenu: {
26732        type: 'string',
26733        default: 'never'
26734      },
26735      __unstableLocation: {
26736        type: 'string'
26737      },
26738      overlayBackgroundColor: {
26739        type: 'string'
26740      },
26741      customOverlayBackgroundColor: {
26742        type: 'string'
26743      },
26744      overlayTextColor: {
26745        type: 'string'
26746      },
26747      customOverlayTextColor: {
26748        type: 'string'
26749      }
26750    },
26751    supports: {
26752      align: ['wide', 'full'],
26753      anchor: true,
26754      html: false,
26755      inserter: true,
26756      typography: {
26757        fontSize: true,
26758        lineHeight: true,
26759        __experimentalFontStyle: true,
26760        __experimentalFontWeight: true,
26761        __experimentalTextTransform: true,
26762        __experimentalFontFamily: true,
26763        __experimentalTextDecoration: true,
26764        __experimentalDefaultControls: {
26765          fontSize: true
26766        }
26767      },
26768      spacing: {
26769        blockGap: true,
26770        units: ['px', 'em', 'rem', 'vh', 'vw'],
26771        __experimentalDefaultControls: {
26772          blockGap: true
26773        }
26774      }
26775    },
26776  
26777    save() {
26778      return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InnerBlocks.Content, null);
26779    },
26780  
26781    isEligible: _ref3 => {
26782      let {
26783        itemsJustification,
26784        orientation
26785      } = _ref3;
26786      return !!itemsJustification || !!orientation;
26787    },
26788    migrate: (0,external_wp_compose_namespaceObject.compose)(migrateIdToRef, deprecated_migrateWithLayout)
26789  };
26790  const navigation_deprecated_v4 = {
26791    attributes: {
26792      orientation: {
26793        type: 'string',
26794        default: 'horizontal'
26795      },
26796      textColor: {
26797        type: 'string'
26798      },
26799      customTextColor: {
26800        type: 'string'
26801      },
26802      rgbTextColor: {
26803        type: 'string'
26804      },
26805      backgroundColor: {
26806        type: 'string'
26807      },
26808      customBackgroundColor: {
26809        type: 'string'
26810      },
26811      rgbBackgroundColor: {
26812        type: 'string'
26813      },
26814      itemsJustification: {
26815        type: 'string'
26816      },
26817      showSubmenuIcon: {
26818        type: 'boolean',
26819        default: true
26820      },
26821      openSubmenusOnClick: {
26822        type: 'boolean',
26823        default: false
26824      },
26825      overlayMenu: {
26826        type: 'string',
26827        default: 'never'
26828      },
26829      __unstableLocation: {
26830        type: 'string'
26831      },
26832      overlayBackgroundColor: {
26833        type: 'string'
26834      },
26835      customOverlayBackgroundColor: {
26836        type: 'string'
26837      },
26838      overlayTextColor: {
26839        type: 'string'
26840      },
26841      customOverlayTextColor: {
26842        type: 'string'
26843      }
26844    },
26845    supports: {
26846      align: ['wide', 'full'],
26847      anchor: true,
26848      html: false,
26849      inserter: true,
26850      typography: {
26851        fontSize: true,
26852        lineHeight: true,
26853        __experimentalFontStyle: true,
26854        __experimentalFontWeight: true,
26855        __experimentalTextTransform: true,
26856        __experimentalFontFamily: true,
26857        __experimentalTextDecoration: true
26858      },
26859      spacing: {
26860        blockGap: true,
26861        units: ['px', 'em', 'rem', 'vh', 'vw'],
26862        __experimentalDefaultControls: {
26863          blockGap: true
26864        }
26865      }
26866    },
26867  
26868    save() {
26869      return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InnerBlocks.Content, null);
26870    },
26871  
26872    migrate: (0,external_wp_compose_namespaceObject.compose)(migrateIdToRef, deprecated_migrateWithLayout, migrate_font_family),
26873  
26874    isEligible(_ref4) {
26875      var _style$typography;
26876  
26877      let {
26878        style
26879      } = _ref4;
26880      return style === null || style === void 0 ? void 0 : (_style$typography = style.typography) === null || _style$typography === void 0 ? void 0 : _style$typography.fontFamily;
26881    }
26882  
26883  };
26884  
26885  const migrateIsResponsive = function (attributes) {
26886    delete attributes.isResponsive;
26887    return { ...attributes,
26888      overlayMenu: 'mobile'
26889    };
26890  };
26891  
26892  const migrateTypographyPresets = function (attributes) {
26893    return { ...attributes,
26894      style: { ...attributes.style,
26895        typography: (0,external_lodash_namespaceObject.mapValues)(attributes.style.typography, (value, key) => {
26896          const prefix = TYPOGRAPHY_PRESET_DEPRECATION_MAP[key];
26897  
26898          if (prefix && value.startsWith(prefix)) {
26899            const newValue = value.slice(prefix.length);
26900  
26901            if ('textDecoration' === key && 'strikethrough' === newValue) {
26902              return 'line-through';
26903            }
26904  
26905            return newValue;
26906          }
26907  
26908          return value;
26909        })
26910      }
26911    };
26912  };
26913  
26914  const navigation_deprecated_deprecated = [navigation_deprecated_v6, navigation_deprecated_v5, navigation_deprecated_v4, // Remove `isResponsive` attribute.
26915  {
26916    attributes: {
26917      orientation: {
26918        type: 'string',
26919        default: 'horizontal'
26920      },
26921      textColor: {
26922        type: 'string'
26923      },
26924      customTextColor: {
26925        type: 'string'
26926      },
26927      rgbTextColor: {
26928        type: 'string'
26929      },
26930      backgroundColor: {
26931        type: 'string'
26932      },
26933      customBackgroundColor: {
26934        type: 'string'
26935      },
26936      rgbBackgroundColor: {
26937        type: 'string'
26938      },
26939      itemsJustification: {
26940        type: 'string'
26941      },
26942      showSubmenuIcon: {
26943        type: 'boolean',
26944        default: true
26945      },
26946      openSubmenusOnClick: {
26947        type: 'boolean',
26948        default: false
26949      },
26950      isResponsive: {
26951        type: 'boolean',
26952        default: 'false'
26953      },
26954      __unstableLocation: {
26955        type: 'string'
26956      },
26957      overlayBackgroundColor: {
26958        type: 'string'
26959      },
26960      customOverlayBackgroundColor: {
26961        type: 'string'
26962      },
26963      overlayTextColor: {
26964        type: 'string'
26965      },
26966      customOverlayTextColor: {
26967        type: 'string'
26968      }
26969    },
26970    supports: {
26971      align: ['wide', 'full'],
26972      anchor: true,
26973      html: false,
26974      inserter: true,
26975      typography: {
26976        fontSize: true,
26977        lineHeight: true,
26978        __experimentalFontStyle: true,
26979        __experimentalFontWeight: true,
26980        __experimentalTextTransform: true,
26981        __experimentalFontFamily: true,
26982        __experimentalTextDecoration: true
26983      }
26984    },
26985  
26986    isEligible(attributes) {
26987      return attributes.isResponsive;
26988    },
26989  
26990    migrate: (0,external_wp_compose_namespaceObject.compose)(migrateIdToRef, deprecated_migrateWithLayout, migrate_font_family, migrateIsResponsive),
26991  
26992    save() {
26993      return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InnerBlocks.Content, null);
26994    }
26995  
26996  }, {
26997    attributes: {
26998      orientation: {
26999        type: 'string'
27000      },
27001      textColor: {
27002        type: 'string'
27003      },
27004      customTextColor: {
27005        type: 'string'
27006      },
27007      rgbTextColor: {
27008        type: 'string'
27009      },
27010      backgroundColor: {
27011        type: 'string'
27012      },
27013      customBackgroundColor: {
27014        type: 'string'
27015      },
27016      rgbBackgroundColor: {
27017        type: 'string'
27018      },
27019      itemsJustification: {
27020        type: 'string'
27021      },
27022      showSubmenuIcon: {
27023        type: 'boolean',
27024        default: true
27025      }
27026    },
27027    supports: {
27028      align: ['wide', 'full'],
27029      anchor: true,
27030      html: false,
27031      inserter: true,
27032      fontSize: true,
27033      __experimentalFontStyle: true,
27034      __experimentalFontWeight: true,
27035      __experimentalTextTransform: true,
27036      color: true,
27037      __experimentalFontFamily: true,
27038      __experimentalTextDecoration: true
27039    },
27040  
27041    save() {
27042      return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InnerBlocks.Content, null);
27043    },
27044  
27045    isEligible(attributes) {
27046      if (!attributes.style || !attributes.style.typography) {
27047        return false;
27048      }
27049  
27050      for (const styleAttribute in TYPOGRAPHY_PRESET_DEPRECATION_MAP) {
27051        const attributeValue = attributes.style.typography[styleAttribute];
27052  
27053        if (attributeValue && attributeValue.startsWith(TYPOGRAPHY_PRESET_DEPRECATION_MAP[styleAttribute])) {
27054          return true;
27055        }
27056      }
27057  
27058      return false;
27059    },
27060  
27061    migrate: (0,external_wp_compose_namespaceObject.compose)(migrateIdToRef, deprecated_migrateWithLayout, migrate_font_family, migrateTypographyPresets)
27062  }, {
27063    attributes: {
27064      className: {
27065        type: 'string'
27066      },
27067      textColor: {
27068        type: 'string'
27069      },
27070      rgbTextColor: {
27071        type: 'string'
27072      },
27073      backgroundColor: {
27074        type: 'string'
27075      },
27076      rgbBackgroundColor: {
27077        type: 'string'
27078      },
27079      fontSize: {
27080        type: 'string'
27081      },
27082      customFontSize: {
27083        type: 'number'
27084      },
27085      itemsJustification: {
27086        type: 'string'
27087      },
27088      showSubmenuIcon: {
27089        type: 'boolean'
27090      }
27091    },
27092  
27093    isEligible(attribute) {
27094      return attribute.rgbTextColor || attribute.rgbBackgroundColor;
27095    },
27096  
27097    supports: {
27098      align: ['wide', 'full'],
27099      anchor: true,
27100      html: false,
27101      inserter: true
27102    },
27103    migrate: (0,external_wp_compose_namespaceObject.compose)(migrateIdToRef, attributes => {
27104      return { ...(0,external_lodash_namespaceObject.omit)(attributes, ['rgbTextColor', 'rgbBackgroundColor']),
27105        customTextColor: attributes.textColor ? undefined : attributes.rgbTextColor,
27106        customBackgroundColor: attributes.backgroundColor ? undefined : attributes.rgbBackgroundColor
27107      };
27108    }),
27109  
27110    save() {
27111      return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InnerBlocks.Content, null);
27112    }
27113  
27114  }];
27115  /* harmony default export */ var navigation_deprecated = (navigation_deprecated_deprecated);
27116  
27117  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/navigation/index.js
27118  /**
27119   * WordPress dependencies
27120   */
27121  
27122  
27123  /**
27124   * Internal dependencies
27125   */
27126  
27127  const navigation_metadata = {
27128    $schema: "https://schemas.wp.org/trunk/block.json",
27129    apiVersion: 2,
27130    name: "core/navigation",
27131    title: "Navigation",
27132    category: "theme",
27133    description: "A collection of blocks that allow visitors to get around your site.",
27134    keywords: ["menu", "navigation", "links"],
27135    textdomain: "default",
27136    attributes: {
27137      ref: {
27138        type: "number"
27139      },
27140      textColor: {
27141        type: "string"
27142      },
27143      customTextColor: {
27144        type: "string"
27145      },
27146      rgbTextColor: {
27147        type: "string"
27148      },
27149      backgroundColor: {
27150        type: "string"
27151      },
27152      customBackgroundColor: {
27153        type: "string"
27154      },
27155      rgbBackgroundColor: {
27156        type: "string"
27157      },
27158      showSubmenuIcon: {
27159        type: "boolean",
27160        "default": true
27161      },
27162      openSubmenusOnClick: {
27163        type: "boolean",
27164        "default": false
27165      },
27166      overlayMenu: {
27167        type: "string",
27168        "default": "mobile"
27169      },
27170      hasIcon: {
27171        type: "boolean",
27172        "default": true
27173      },
27174      __unstableLocation: {
27175        type: "string"
27176      },
27177      overlayBackgroundColor: {
27178        type: "string"
27179      },
27180      customOverlayBackgroundColor: {
27181        type: "string"
27182      },
27183      overlayTextColor: {
27184        type: "string"
27185      },
27186      customOverlayTextColor: {
27187        type: "string"
27188      },
27189      maxNestingLevel: {
27190        type: "number",
27191        "default": 5
27192      }
27193    },
27194    providesContext: {
27195      textColor: "textColor",
27196      customTextColor: "customTextColor",
27197      backgroundColor: "backgroundColor",
27198      customBackgroundColor: "customBackgroundColor",
27199      overlayTextColor: "overlayTextColor",
27200      customOverlayTextColor: "customOverlayTextColor",
27201      overlayBackgroundColor: "overlayBackgroundColor",
27202      customOverlayBackgroundColor: "customOverlayBackgroundColor",
27203      fontSize: "fontSize",
27204      customFontSize: "customFontSize",
27205      showSubmenuIcon: "showSubmenuIcon",
27206      openSubmenusOnClick: "openSubmenusOnClick",
27207      style: "style",
27208      orientation: "orientation",
27209      maxNestingLevel: "maxNestingLevel"
27210    },
27211    supports: {
27212      align: ["wide", "full"],
27213      anchor: true,
27214      html: false,
27215      inserter: true,
27216      typography: {
27217        fontSize: true,
27218        lineHeight: true,
27219        __experimentalFontStyle: true,
27220        __experimentalFontWeight: true,
27221        __experimentalTextTransform: true,
27222        __experimentalFontFamily: true,
27223        __experimentalTextDecoration: true,
27224        __experimentalSkipSerialization: ["textDecoration"],
27225        __experimentalDefaultControls: {
27226          fontSize: true
27227        }
27228      },
27229      spacing: {
27230        blockGap: true,
27231        units: ["px", "em", "rem", "vh", "vw"],
27232        __experimentalDefaultControls: {
27233          blockGap: true
27234        }
27235      },
27236      __experimentalLayout: {
27237        allowSwitching: false,
27238        allowInheriting: false,
27239        allowVerticalAlignment: false,
27240        "default": {
27241          type: "flex"
27242        }
27243      }
27244    },
27245    viewScript: "file:./view.min.js",
27246    editorStyle: "wp-block-navigation-editor",
27247    style: "wp-block-navigation"
27248  };
27249  
27250  
27251  
27252  const {
27253    name: navigation_name
27254  } = navigation_metadata;
27255  
27256  const navigation_settings = {
27257    icon: library_navigation,
27258    example: {
27259      innerBlocks: [{
27260        name: 'core/navigation-link',
27261        attributes: {
27262          // translators: 'Home' as in a website's home page.
27263          label: (0,external_wp_i18n_namespaceObject.__)('Home'),
27264          url: 'https://make.wordpress.org/'
27265        }
27266      }, {
27267        name: 'core/navigation-link',
27268        attributes: {
27269          // translators: 'About' as in a website's about page.
27270          label: (0,external_wp_i18n_namespaceObject.__)('About'),
27271          url: 'https://make.wordpress.org/'
27272        }
27273      }, {
27274        name: 'core/navigation-link',
27275        attributes: {
27276          // translators: 'Contact' as in a website's contact page.
27277          label: (0,external_wp_i18n_namespaceObject.__)('Contact'),
27278          url: 'https://make.wordpress.org/'
27279        }
27280      }]
27281    },
27282    edit: navigation_edit,
27283    save: navigation_save_save,
27284    deprecated: navigation_deprecated
27285  };
27286  
27287  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/custom-link.js
27288  
27289  
27290  /**
27291   * WordPress dependencies
27292   */
27293  
27294  const customLink = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
27295    xmlns: "https://www.w3.org/2000/svg",
27296    viewBox: "0 0 24 24"
27297  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
27298    d: "M12.5 14.5h-1V16h1c2.2 0 4-1.8 4-4s-1.8-4-4-4h-1v1.5h1c1.4 0 2.5 1.1 2.5 2.5s-1.1 2.5-2.5 2.5zm-4 1.5v-1.5h-1C6.1 14.5 5 13.4 5 12s1.1-2.5 2.5-2.5h1V8h-1c-2.2 0-4 1.8-4 4s1.8 4 4 4h1zm-1-3.2h5v-1.5h-5v1.5zM18 4H9c-1.1 0-2 .9-2 2v.5h1.5V6c0-.3.2-.5.5-.5h9c.3 0 .5.2.5.5v12c0 .3-.2.5-.5.5H9c-.3 0-.5-.2-.5-.5v-.5H7v.5c0 1.1.9 2 2 2h9c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2z"
27299  }));
27300  /* harmony default export */ var custom_link = (customLink);
27301  
27302  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/add-submenu.js
27303  
27304  
27305  /**
27306   * WordPress dependencies
27307   */
27308  
27309  const addSubmenu = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
27310    xmlns: "http://www.w3.org/2000/svg",
27311    viewBox: "0 0 24 24"
27312  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
27313    d: "M2 12c0 3.6 2.4 5.5 6 5.5h.5V19l3-2.5-3-2.5v2H8c-2.5 0-4.5-1.5-4.5-4s2-4.5 4.5-4.5h3.5V6H8c-3.6 0-6 2.4-6 6zm19.5-1h-8v1.5h8V11zm0 5h-8v1.5h8V16zm0-10h-8v1.5h8V6z"
27314  }));
27315  /* harmony default export */ var add_submenu = (addSubmenu);
27316  
27317  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/navigation-link/edit.js
27318  
27319  
27320  /**
27321   * External dependencies
27322   */
27323  
27324  
27325  /**
27326   * WordPress dependencies
27327   */
27328  
27329  
27330  
27331  
27332  
27333  
27334  
27335  
27336  
27337  
27338  
27339  
27340  /**
27341   * Internal dependencies
27342   */
27343  
27344  const {
27345    name: edit_name
27346  } = {
27347    $schema: "https://schemas.wp.org/trunk/block.json",
27348    apiVersion: 2,
27349    name: "core/navigation-link",
27350    title: "Custom Link",
27351    category: "design",
27352    parent: ["core/navigation"],
27353    description: "Add a page, link, or another item to your navigation.",
27354    textdomain: "default",
27355    attributes: {
27356      label: {
27357        type: "string"
27358      },
27359      type: {
27360        type: "string"
27361      },
27362      description: {
27363        type: "string"
27364      },
27365      rel: {
27366        type: "string"
27367      },
27368      id: {
27369        type: "number"
27370      },
27371      opensInNewTab: {
27372        type: "boolean",
27373        "default": false
27374      },
27375      url: {
27376        type: "string"
27377      },
27378      title: {
27379        type: "string"
27380      },
27381      kind: {
27382        type: "string"
27383      },
27384      isTopLevelLink: {
27385        type: "boolean"
27386      }
27387    },
27388    usesContext: ["textColor", "customTextColor", "backgroundColor", "customBackgroundColor", "overlayTextColor", "customOverlayTextColor", "overlayBackgroundColor", "customOverlayBackgroundColor", "fontSize", "customFontSize", "showSubmenuIcon", "maxNestingLevel", "style"],
27389    supports: {
27390      reusable: false,
27391      html: false,
27392      __experimentalSlashInserter: true
27393    },
27394    editorStyle: "wp-block-navigation-link-editor",
27395    style: "wp-block-navigation-link"
27396  };
27397  /**
27398   * A React hook to determine if it's dragging within the target element.
27399   *
27400   * @typedef {import('@wordpress/element').RefObject} RefObject
27401   *
27402   * @param {RefObject<HTMLElement>} elementRef The target elementRef object.
27403   *
27404   * @return {boolean} Is dragging within the target element.
27405   */
27406  
27407  const useIsDraggingWithin = elementRef => {
27408    const [isDraggingWithin, setIsDraggingWithin] = (0,external_wp_element_namespaceObject.useState)(false);
27409    (0,external_wp_element_namespaceObject.useEffect)(() => {
27410      const {
27411        ownerDocument
27412      } = elementRef.current;
27413  
27414      function handleDragStart(event) {
27415        // Check the first time when the dragging starts.
27416        handleDragEnter(event);
27417      } // Set to false whenever the user cancel the drag event by either releasing the mouse or press Escape.
27418  
27419  
27420      function handleDragEnd() {
27421        setIsDraggingWithin(false);
27422      }
27423  
27424      function handleDragEnter(event) {
27425        // Check if the current target is inside the item element.
27426        if (elementRef.current.contains(event.target)) {
27427          setIsDraggingWithin(true);
27428        } else {
27429          setIsDraggingWithin(false);
27430        }
27431      } // Bind these events to the document to catch all drag events.
27432      // Ideally, we can also use `event.relatedTarget`, but sadly that
27433      // doesn't work in Safari.
27434  
27435  
27436      ownerDocument.addEventListener('dragstart', handleDragStart);
27437      ownerDocument.addEventListener('dragend', handleDragEnd);
27438      ownerDocument.addEventListener('dragenter', handleDragEnter);
27439      return () => {
27440        ownerDocument.removeEventListener('dragstart', handleDragStart);
27441        ownerDocument.removeEventListener('dragend', handleDragEnd);
27442        ownerDocument.removeEventListener('dragenter', handleDragEnter);
27443      };
27444    }, []);
27445    return isDraggingWithin;
27446  };
27447  /**
27448   * Given the Link block's type attribute, return the query params to give to
27449   * /wp/v2/search.
27450   *
27451   * @param {string} type Link block's type attribute.
27452   * @param {string} kind Link block's entity of kind (post-type|taxonomy)
27453   * @return {{ type?: string, subtype?: string }} Search query params.
27454   */
27455  
27456  
27457  function getSuggestionsQuery(type, kind) {
27458    switch (type) {
27459      case 'post':
27460      case 'page':
27461        return {
27462          type: 'post',
27463          subtype: type
27464        };
27465  
27466      case 'category':
27467        return {
27468          type: 'term',
27469          subtype: 'category'
27470        };
27471  
27472      case 'tag':
27473        return {
27474          type: 'term',
27475          subtype: 'post_tag'
27476        };
27477  
27478      case 'post_format':
27479        return {
27480          type: 'post-format'
27481        };
27482  
27483      default:
27484        if (kind === 'taxonomy') {
27485          return {
27486            type: 'term',
27487            subtype: type
27488          };
27489        }
27490  
27491        if (kind === 'post-type') {
27492          return {
27493            type: 'post',
27494            subtype: type
27495          };
27496        }
27497  
27498        return {};
27499    }
27500  }
27501  /**
27502   * Determine the colors for a menu.
27503   *
27504   * Order of priority is:
27505   * 1: Overlay custom colors (if submenu)
27506   * 2: Overlay theme colors (if submenu)
27507   * 3: Custom colors
27508   * 4: Theme colors
27509   * 5: Global styles
27510   *
27511   * @param {Object}  context
27512   * @param {boolean} isSubMenu
27513   */
27514  
27515  
27516  function getColors(context, isSubMenu) {
27517    var _style$color, _style$color2;
27518  
27519    const {
27520      textColor,
27521      customTextColor,
27522      backgroundColor,
27523      customBackgroundColor,
27524      overlayTextColor,
27525      customOverlayTextColor,
27526      overlayBackgroundColor,
27527      customOverlayBackgroundColor,
27528      style
27529    } = context;
27530    const colors = {};
27531  
27532    if (isSubMenu && !!customOverlayTextColor) {
27533      colors.customTextColor = customOverlayTextColor;
27534    } else if (isSubMenu && !!overlayTextColor) {
27535      colors.textColor = overlayTextColor;
27536    } else if (!!customTextColor) {
27537      colors.customTextColor = customTextColor;
27538    } else if (!!textColor) {
27539      colors.textColor = textColor;
27540    } else if (!!(style !== null && style !== void 0 && (_style$color = style.color) !== null && _style$color !== void 0 && _style$color.text)) {
27541      colors.customTextColor = style.color.text;
27542    }
27543  
27544    if (isSubMenu && !!customOverlayBackgroundColor) {
27545      colors.customBackgroundColor = customOverlayBackgroundColor;
27546    } else if (isSubMenu && !!overlayBackgroundColor) {
27547      colors.backgroundColor = overlayBackgroundColor;
27548    } else if (!!customBackgroundColor) {
27549      colors.customBackgroundColor = customBackgroundColor;
27550    } else if (!!backgroundColor) {
27551      colors.backgroundColor = backgroundColor;
27552    } else if (!!(style !== null && style !== void 0 && (_style$color2 = style.color) !== null && _style$color2 !== void 0 && _style$color2.background)) {
27553      colors.customTextColor = style.color.background;
27554    }
27555  
27556    return colors;
27557  }
27558  /**
27559   * @typedef {'post-type'|'custom'|'taxonomy'|'post-type-archive'} WPNavigationLinkKind
27560   */
27561  
27562  /**
27563   * Navigation Link Block Attributes
27564   *
27565   * @typedef {Object} WPNavigationLinkBlockAttributes
27566   *
27567   * @property {string}               [label]         Link text.
27568   * @property {WPNavigationLinkKind} [kind]          Kind is used to differentiate between term and post ids to check post draft status.
27569   * @property {string}               [type]          The type such as post, page, tag, category and other custom types.
27570   * @property {string}               [rel]           The relationship of the linked URL.
27571   * @property {number}               [id]            A post or term id.
27572   * @property {boolean}              [opensInNewTab] Sets link target to _blank when true.
27573   * @property {string}               [url]           Link href.
27574   * @property {string}               [title]         Link title attribute.
27575   */
27576  
27577  /**
27578   * Link Control onChange handler that updates block attributes when a setting is changed.
27579   *
27580   * @param {Object}                          updatedValue    New block attributes to update.
27581   * @param {Function}                        setAttributes   Block attribute update function.
27582   * @param {WPNavigationLinkBlockAttributes} blockAttributes Current block attributes.
27583   *
27584   */
27585  
27586  
27587  const updateNavigationLinkBlockAttributes = function () {
27588    let updatedValue = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
27589    let setAttributes = arguments.length > 1 ? arguments[1] : undefined;
27590    let blockAttributes = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
27591    const {
27592      label: originalLabel = '',
27593      kind: originalKind = '',
27594      type: originalType = ''
27595    } = blockAttributes;
27596    const {
27597      title = '',
27598      // the title of any provided Post.
27599      url = '',
27600      opensInNewTab,
27601      id,
27602      kind: newKind = originalKind,
27603      type: newType = originalType
27604    } = updatedValue;
27605    const normalizedTitle = title.replace(/http(s?):\/\//gi, '');
27606    const normalizedURL = url.replace(/http(s?):\/\//gi, '');
27607    const escapeTitle = title !== '' && normalizedTitle !== normalizedURL && originalLabel !== title;
27608    const label = escapeTitle ? (0,external_lodash_namespaceObject.escape)(title) : originalLabel || (0,external_lodash_namespaceObject.escape)(normalizedURL); // In https://github.com/WordPress/gutenberg/pull/24670 we decided to use "tag" in favor of "post_tag"
27609  
27610    const type = newType === 'post_tag' ? 'tag' : newType.replace('-', '_');
27611    const isBuiltInType = ['post', 'page', 'tag', 'category'].indexOf(type) > -1;
27612    const isCustomLink = !newKind && !isBuiltInType || newKind === 'custom';
27613    const kind = isCustomLink ? 'custom' : newKind;
27614    setAttributes({ // Passed `url` may already be encoded. To prevent double encoding, decodeURI is executed to revert to the original string.
27615      ...(url && {
27616        url: encodeURI((0,external_wp_url_namespaceObject.safeDecodeURI)(url))
27617      }),
27618      ...(label && {
27619        label
27620      }),
27621      ...(undefined !== opensInNewTab && {
27622        opensInNewTab
27623      }),
27624      ...(id && Number.isInteger(id) && {
27625        id
27626      }),
27627      ...(kind && {
27628        kind
27629      }),
27630      ...(type && type !== 'URL' && {
27631        type
27632      })
27633    });
27634  };
27635  
27636  const useIsInvalidLink = (kind, type, id) => {
27637    const isPostType = kind === 'post-type' || type === 'post' || type === 'page';
27638    const hasId = Number.isInteger(id);
27639    const postStatus = (0,external_wp_data_namespaceObject.useSelect)(select => {
27640      var _getEntityRecord;
27641  
27642      if (!isPostType) {
27643        return null;
27644      }
27645  
27646      const {
27647        getEntityRecord
27648      } = select(external_wp_coreData_namespaceObject.store);
27649      return (_getEntityRecord = getEntityRecord('postType', type, id)) === null || _getEntityRecord === void 0 ? void 0 : _getEntityRecord.status;
27650    }, [isPostType, type, id]); // Check Navigation Link validity if:
27651    // 1. Link is 'post-type'.
27652    // 2. It has an id.
27653    // 3. It's neither null, nor undefined, as valid items might be either of those while loading.
27654    // If those conditions are met, check if
27655    // 1. The post status is published.
27656    // 2. The Navigation Link item has no label.
27657    // If either of those is true, invalidate.
27658  
27659    const isInvalid = isPostType && hasId && postStatus && 'trash' === postStatus;
27660    const isDraft = 'draft' === postStatus;
27661    return [isInvalid, isDraft];
27662  };
27663  
27664  const useMissingText = type => {
27665    let missingText = '';
27666  
27667    switch (type) {
27668      case 'post':
27669        /* translators: label for missing post in navigation link block */
27670        missingText = (0,external_wp_i18n_namespaceObject.__)('Select post');
27671        break;
27672  
27673      case 'page':
27674        /* translators: label for missing page in navigation link block */
27675        missingText = (0,external_wp_i18n_namespaceObject.__)('Select page');
27676        break;
27677  
27678      case 'category':
27679        /* translators: label for missing category in navigation link block */
27680        missingText = (0,external_wp_i18n_namespaceObject.__)('Select category');
27681        break;
27682  
27683      case 'tag':
27684        /* translators: label for missing tag in navigation link block */
27685        missingText = (0,external_wp_i18n_namespaceObject.__)('Select tag');
27686        break;
27687  
27688      default:
27689        /* translators: label for missing values in navigation link block */
27690        missingText = (0,external_wp_i18n_namespaceObject.__)('Add link');
27691    }
27692  
27693    return missingText;
27694  };
27695  /**
27696   * Removes HTML from a given string.
27697   * Note the does not provide XSS protection or otherwise attempt
27698   * to filter strings with malicious intent.
27699   *
27700   * See also: https://github.com/WordPress/gutenberg/pull/35539
27701   *
27702   * @param {string} html the string from which HTML should be removed.
27703   * @return {string} the "cleaned" string.
27704   */
27705  
27706  
27707  function navStripHTML(html) {
27708    const doc = document.implementation.createHTMLDocument('');
27709    doc.body.innerHTML = html;
27710    return doc.body.textContent || '';
27711  }
27712  /**
27713   * Add transforms to Link Control
27714   */
27715  
27716  
27717  function LinkControlTransforms(_ref) {
27718    let {
27719      clientId,
27720      replace
27721    } = _ref;
27722    const {
27723      getBlock,
27724      blockTransforms
27725    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
27726      const {
27727        getBlock: _getBlock,
27728        getBlockRootClientId,
27729        getBlockTransformItems
27730      } = select(external_wp_blockEditor_namespaceObject.store);
27731      return {
27732        getBlock: _getBlock,
27733        blockTransforms: getBlockTransformItems([_getBlock(clientId)], getBlockRootClientId(clientId))
27734      };
27735    }, [clientId]);
27736    const featuredBlocks = ['core/site-logo', 'core/social-links', 'core/search'];
27737    const transforms = blockTransforms.filter(item => {
27738      return featuredBlocks.includes(item.name);
27739    });
27740  
27741    if (!(transforms !== null && transforms !== void 0 && transforms.length)) {
27742      return null;
27743    }
27744  
27745    return (0,external_wp_element_namespaceObject.createElement)("div", {
27746      className: "link-control-transform"
27747    }, (0,external_wp_element_namespaceObject.createElement)("h3", {
27748      className: "link-control-transform__subheading"
27749    }, (0,external_wp_i18n_namespaceObject.__)('Transform')), (0,external_wp_element_namespaceObject.createElement)("div", {
27750      className: "link-control-transform__items"
27751    }, transforms.map((item, index) => {
27752      return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
27753        key: `transform-$index}`,
27754        onClick: () => replace(clientId, (0,external_wp_blocks_namespaceObject.switchToBlockType)(getBlock(clientId), item.name)),
27755        className: "link-control-transform__item"
27756      }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockIcon, {
27757        icon: item.icon
27758      }), item.title);
27759    })));
27760  }
27761  
27762  function NavigationLinkEdit(_ref2) {
27763    let {
27764      attributes,
27765      isSelected,
27766      setAttributes,
27767      insertBlocksAfter,
27768      mergeBlocks,
27769      onReplace,
27770      context,
27771      clientId
27772    } = _ref2;
27773    const {
27774      id,
27775      label,
27776      type,
27777      opensInNewTab,
27778      url,
27779      description,
27780      rel,
27781      title,
27782      kind
27783    } = attributes;
27784    const [isInvalid, isDraft] = useIsInvalidLink(kind, type, id);
27785    const {
27786      maxNestingLevel
27787    } = context;
27788    const link = {
27789      url,
27790      opensInNewTab,
27791      title: label && navStripHTML(label) // don't allow HTML to display inside the <LinkControl>
27792  
27793    };
27794    const {
27795      saveEntityRecord
27796    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_coreData_namespaceObject.store);
27797    const {
27798      replaceBlock,
27799      __unstableMarkNextChangeAsNotPersistent
27800    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_blockEditor_namespaceObject.store);
27801    const [isLinkOpen, setIsLinkOpen] = (0,external_wp_element_namespaceObject.useState)(false);
27802    const listItemRef = (0,external_wp_element_namespaceObject.useRef)(null);
27803    const isDraggingWithin = useIsDraggingWithin(listItemRef);
27804  
27805    const itemLabelPlaceholder = (0,external_wp_i18n_namespaceObject.__)('Add link…');
27806  
27807    const ref = (0,external_wp_element_namespaceObject.useRef)();
27808    const {
27809      innerBlocks,
27810      isAtMaxNesting,
27811      isTopLevelLink,
27812      isParentOfSelectedBlock,
27813      hasChildren,
27814      userCanCreatePages,
27815      userCanCreatePosts
27816    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
27817      const {
27818        getBlocks,
27819        getBlockCount,
27820        getBlockName,
27821        getBlockRootClientId,
27822        hasSelectedInnerBlock,
27823        getBlockParentsByBlockName
27824      } = select(external_wp_blockEditor_namespaceObject.store);
27825      return {
27826        innerBlocks: getBlocks(clientId),
27827        isAtMaxNesting: getBlockParentsByBlockName(clientId, [edit_name, 'core/navigation-submenu']).length >= maxNestingLevel,
27828        isTopLevelLink: getBlockName(getBlockRootClientId(clientId)) === 'core/navigation',
27829        isParentOfSelectedBlock: hasSelectedInnerBlock(clientId, true),
27830        hasChildren: !!getBlockCount(clientId),
27831        userCanCreatePages: select(external_wp_coreData_namespaceObject.store).canUser('create', 'pages'),
27832        userCanCreatePosts: select(external_wp_coreData_namespaceObject.store).canUser('create', 'posts')
27833      };
27834    }, [clientId]);
27835    (0,external_wp_element_namespaceObject.useEffect)(() => {
27836      // This side-effect should not create an undo level as those should
27837      // only be created via user interactions. Mark this change as
27838      // not persistent to avoid undo level creation.
27839      // See https://github.com/WordPress/gutenberg/issues/34564.
27840      __unstableMarkNextChangeAsNotPersistent();
27841  
27842      setAttributes({
27843        isTopLevelLink
27844      });
27845    }, [isTopLevelLink]);
27846    /**
27847     * Transform to submenu block.
27848     */
27849  
27850    function transformToSubmenu() {
27851      const newSubmenu = (0,external_wp_blocks_namespaceObject.createBlock)('core/navigation-submenu', attributes, innerBlocks);
27852      replaceBlock(clientId, newSubmenu);
27853    }
27854  
27855    (0,external_wp_element_namespaceObject.useEffect)(() => {
27856      // Show the LinkControl on mount if the URL is empty
27857      // ( When adding a new menu item)
27858      // This can't be done in the useState call because it conflicts
27859      // with the autofocus behavior of the BlockListBlock component.
27860      if (!url) {
27861        setIsLinkOpen(true);
27862      } // If block has inner blocks, transform to Submenu.
27863  
27864  
27865      if (hasChildren) {
27866        transformToSubmenu();
27867      }
27868    }, []);
27869    /**
27870     * The hook shouldn't be necessary but due to a focus loss happening
27871     * when selecting a suggestion in the link popover, we force close on block unselection.
27872     */
27873  
27874    (0,external_wp_element_namespaceObject.useEffect)(() => {
27875      if (!isSelected) {
27876        setIsLinkOpen(false);
27877      }
27878    }, [isSelected]); // If the LinkControl popover is open and the URL has changed, close the LinkControl and focus the label text.
27879  
27880    (0,external_wp_element_namespaceObject.useEffect)(() => {
27881      if (isLinkOpen && url) {
27882        // Does this look like a URL and have something TLD-ish?
27883        if ((0,external_wp_url_namespaceObject.isURL)((0,external_wp_url_namespaceObject.prependHTTP)(label)) && /^.+\.[a-z]+/.test(label)) {
27884          // Focus and select the label text.
27885          selectLabelText();
27886        } else {
27887          // Focus it (but do not select).
27888          (0,external_wp_dom_namespaceObject.placeCaretAtHorizontalEdge)(ref.current, true);
27889        }
27890      }
27891    }, [url]);
27892    /**
27893     * Focus the Link label text and select it.
27894     */
27895  
27896    function selectLabelText() {
27897      ref.current.focus();
27898      const {
27899        ownerDocument
27900      } = ref.current;
27901      const {
27902        defaultView
27903      } = ownerDocument;
27904      const selection = defaultView.getSelection();
27905      const range = ownerDocument.createRange(); // Get the range of the current ref contents so we can add this range to the selection.
27906  
27907      range.selectNodeContents(ref.current);
27908      selection.removeAllRanges();
27909      selection.addRange(range);
27910    }
27911    /**
27912     * Removes the current link if set.
27913     */
27914  
27915  
27916    function removeLink() {
27917      // Reset all attributes that comprise the link.
27918      setAttributes({
27919        url: '',
27920        label: '',
27921        id: '',
27922        kind: '',
27923        type: ''
27924      }); // Close the link editing UI.
27925  
27926      setIsLinkOpen(false);
27927    }
27928  
27929    let userCanCreate = false;
27930  
27931    if (!type || type === 'page') {
27932      userCanCreate = userCanCreatePages;
27933    } else if (type === 'post') {
27934      userCanCreate = userCanCreatePosts;
27935    }
27936  
27937    async function handleCreate(pageTitle) {
27938      const postType = type || 'page';
27939      const page = await saveEntityRecord('postType', postType, {
27940        title: pageTitle,
27941        status: 'draft'
27942      });
27943      return {
27944        id: page.id,
27945        type: postType,
27946        title: page.title.rendered,
27947        url: page.link,
27948        kind: 'post-type'
27949      };
27950    }
27951  
27952    const {
27953      textColor,
27954      customTextColor,
27955      backgroundColor,
27956      customBackgroundColor
27957    } = getColors(context, !isTopLevelLink);
27958  
27959    function onKeyDown(event) {
27960      if (external_wp_keycodes_namespaceObject.isKeyboardEvent.primary(event, 'k') || !url && event.keyCode === external_wp_keycodes_namespaceObject.ENTER) {
27961        setIsLinkOpen(true);
27962      }
27963    }
27964  
27965    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
27966      ref: listItemRef,
27967      className: classnames_default()('wp-block-navigation-item', {
27968        'is-editing': isSelected || isParentOfSelectedBlock,
27969        'is-dragging-within': isDraggingWithin,
27970        'has-link': !!url,
27971        'has-child': hasChildren,
27972        'has-text-color': !!textColor || !!customTextColor,
27973        [(0,external_wp_blockEditor_namespaceObject.getColorClassName)('color', textColor)]: !!textColor,
27974        'has-background': !!backgroundColor || customBackgroundColor,
27975        [(0,external_wp_blockEditor_namespaceObject.getColorClassName)('background-color', backgroundColor)]: !!backgroundColor
27976      }),
27977      style: {
27978        color: !textColor && customTextColor,
27979        backgroundColor: !backgroundColor && customBackgroundColor
27980      },
27981      onKeyDown
27982    });
27983  
27984    if (!url || isInvalid || isDraft) {
27985      blockProps.onClick = () => setIsLinkOpen(true);
27986    }
27987  
27988    const classes = classnames_default()('wp-block-navigation-item__content', {
27989      'wp-block-navigation-link__placeholder': !url || isInvalid || isDraft
27990    });
27991    const missingText = useMissingText(type, isInvalid, isDraft);
27992    /* translators: Whether the navigation link is Invalid or a Draft. */
27993  
27994    const placeholderText = `($isInvalid ? (0,external_wp_i18n_namespaceObject.__)('Invalid') : (0,external_wp_i18n_namespaceObject.__)('Draft')})`;
27995    const tooltipText = isInvalid || isDraft ? (0,external_wp_i18n_namespaceObject.__)('This item has been deleted, or is a draft') : (0,external_wp_i18n_namespaceObject.__)('This item is missing a link');
27996    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarGroup, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, {
27997      name: "link",
27998      icon: library_link,
27999      title: (0,external_wp_i18n_namespaceObject.__)('Link'),
28000      shortcut: external_wp_keycodes_namespaceObject.displayShortcut.primary('k'),
28001      onClick: () => setIsLinkOpen(true)
28002    }), !isAtMaxNesting && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, {
28003      name: "submenu",
28004      icon: add_submenu,
28005      title: (0,external_wp_i18n_namespaceObject.__)('Add submenu'),
28006      onClick: transformToSubmenu
28007    }))), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
28008      title: (0,external_wp_i18n_namespaceObject.__)('Link settings')
28009    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TextareaControl, {
28010      value: description || '',
28011      onChange: descriptionValue => {
28012        setAttributes({
28013          description: descriptionValue
28014        });
28015      },
28016      label: (0,external_wp_i18n_namespaceObject.__)('Description'),
28017      help: (0,external_wp_i18n_namespaceObject.__)('The description will be displayed in the menu if the current theme supports it.')
28018    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TextControl, {
28019      value: title || '',
28020      onChange: titleValue => {
28021        setAttributes({
28022          title: titleValue
28023        });
28024      },
28025      label: (0,external_wp_i18n_namespaceObject.__)('Link title'),
28026      autoComplete: "off"
28027    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TextControl, {
28028      value: rel || '',
28029      onChange: relValue => {
28030        setAttributes({
28031          rel: relValue
28032        });
28033      },
28034      label: (0,external_wp_i18n_namespaceObject.__)('Link rel'),
28035      autoComplete: "off"
28036    }))), (0,external_wp_element_namespaceObject.createElement)("div", blockProps, (0,external_wp_element_namespaceObject.createElement)("a", {
28037      className: classes
28038    }, !url ? (0,external_wp_element_namespaceObject.createElement)("div", {
28039      className: "wp-block-navigation-link__placeholder-text"
28040    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Tooltip, {
28041      position: "top center",
28042      text: tooltipText
28043    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)("span", null, missingText), (0,external_wp_element_namespaceObject.createElement)("span", {
28044      className: "wp-block-navigation-link__missing_text-tooltip"
28045    }, tooltipText)))) : (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, !isInvalid && !isDraft && (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText, {
28046      ref: ref,
28047      identifier: "label",
28048      className: "wp-block-navigation-item__label",
28049      value: label,
28050      onChange: labelValue => setAttributes({
28051        label: labelValue
28052      }),
28053      onMerge: mergeBlocks,
28054      onReplace: onReplace,
28055      __unstableOnSplitAtEnd: () => insertBlocksAfter((0,external_wp_blocks_namespaceObject.createBlock)('core/navigation-link')),
28056      "aria-label": (0,external_wp_i18n_namespaceObject.__)('Navigation link text'),
28057      placeholder: itemLabelPlaceholder,
28058      withoutInteractiveFormatting: true,
28059      allowedFormats: ['core/bold', 'core/italic', 'core/image', 'core/strikethrough'],
28060      onClick: () => {
28061        if (!url) {
28062          setIsLinkOpen(true);
28063        }
28064      }
28065    }), description && (0,external_wp_element_namespaceObject.createElement)("span", {
28066      className: "wp-block-navigation-item__description"
28067    }, description)), (isInvalid || isDraft) && (0,external_wp_element_namespaceObject.createElement)("div", {
28068      className: "wp-block-navigation-link__placeholder-text wp-block-navigation-link__label"
28069    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.KeyboardShortcuts, {
28070      shortcuts: {
28071        enter: () => isSelected && setIsLinkOpen(true)
28072      }
28073    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Tooltip, {
28074      position: "top center",
28075      text: tooltipText
28076    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)("span", null,
28077    /* Trim to avoid trailing white space when the placeholder text is not present */
28078    `$label} $placeholderText}`.trim()), (0,external_wp_element_namespaceObject.createElement)("span", {
28079      className: "wp-block-navigation-link__missing_text-tooltip"
28080    }, tooltipText))))), isLinkOpen && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Popover, {
28081      position: "bottom center",
28082      onClose: () => setIsLinkOpen(false),
28083      anchorRef: listItemRef.current
28084    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.__experimentalLinkControl, {
28085      hasTextControl: true,
28086      hasRichPreviews: true,
28087      className: "wp-block-navigation-link__inline-link-input",
28088      value: link,
28089      showInitialSuggestions: true,
28090      withCreateSuggestion: userCanCreate,
28091      createSuggestion: handleCreate,
28092      createSuggestionButtonText: searchTerm => {
28093        let format;
28094  
28095        if (type === 'post') {
28096          /* translators: %s: search term. */
28097          format = (0,external_wp_i18n_namespaceObject.__)('Create draft post: <mark>%s</mark>');
28098        } else {
28099          /* translators: %s: search term. */
28100          format = (0,external_wp_i18n_namespaceObject.__)('Create draft page: <mark>%s</mark>');
28101        }
28102  
28103        return (0,external_wp_element_namespaceObject.createInterpolateElement)((0,external_wp_i18n_namespaceObject.sprintf)(format, searchTerm), {
28104          mark: (0,external_wp_element_namespaceObject.createElement)("mark", null)
28105        });
28106      },
28107      noDirectEntry: !!type,
28108      noURLSuggestion: !!type,
28109      suggestionsQuery: getSuggestionsQuery(type, kind),
28110      onChange: updatedValue => updateNavigationLinkBlockAttributes(updatedValue, setAttributes, attributes),
28111      onRemove: removeLink,
28112      renderControlBottom: !url ? () => (0,external_wp_element_namespaceObject.createElement)(LinkControlTransforms, {
28113        clientId: clientId,
28114        replace: replaceBlock
28115      }) : null
28116    })))));
28117  }
28118  
28119  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/navigation-link/save.js
28120  
28121  
28122  /**
28123   * WordPress dependencies
28124   */
28125  
28126  function navigation_link_save_save() {
28127    return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InnerBlocks.Content, null);
28128  }
28129  
28130  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/post-title.js
28131  
28132  
28133  /**
28134   * WordPress dependencies
28135   */
28136  
28137  const postTitle = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
28138    viewBox: "0 0 24 24",
28139    xmlns: "http://www.w3.org/2000/svg"
28140  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
28141    d: "M4 14.5h16V16H4zM4 18.5h9V20H4zM4 4h3c2 0 3 .86 3 2.583 0 .891-.253 1.554-.76 1.988-.505.435-1.24.652-2.204.652H5.542V12H4V4zm2.855 4c.53 0 .924-.114 1.18-.343.266-.228.398-.579.398-1.051 0-.473-.132-.82-.397-1.04-.265-.229-.67-.343-1.217-.343H5.542V8h1.313z"
28142  }));
28143  /* harmony default export */ var post_title = (postTitle);
28144  
28145  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/page.js
28146  
28147  
28148  /**
28149   * WordPress dependencies
28150   */
28151  
28152  const page = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
28153    xmlns: "http://www.w3.org/2000/svg",
28154    viewBox: "0 0 24 24"
28155  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
28156    d: "M7 5.5h10a.5.5 0 01.5.5v12a.5.5 0 01-.5.5H7a.5.5 0 01-.5-.5V6a.5.5 0 01.5-.5zM17 4H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V6a2 2 0 00-2-2zm-1 3.75H8v1.5h8v-1.5zM8 11h8v1.5H8V11zm6 3.25H8v1.5h6v-1.5z"
28157  }));
28158  /* harmony default export */ var library_page = (page);
28159  
28160  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/tag.js
28161  
28162  
28163  /**
28164   * WordPress dependencies
28165   */
28166  
28167  const tag = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
28168    xmlns: "http://www.w3.org/2000/svg",
28169    viewBox: "0 0 24 24"
28170  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
28171    d: "M20.1 11.2l-6.7-6.7c-.1-.1-.3-.2-.5-.2H5c-.4-.1-.8.3-.8.7v7.8c0 .2.1.4.2.5l6.7 6.7c.2.2.5.4.7.5s.6.2.9.2c.3 0 .6-.1.9-.2.3-.1.5-.3.8-.5l5.6-5.6c.4-.4.7-1 .7-1.6.1-.6-.2-1.2-.6-1.6zM19 13.4L13.4 19c-.1.1-.2.1-.3.2-.2.1-.4.1-.6 0-.1 0-.2-.1-.3-.2l-6.5-6.5V5.8h6.8l6.5 6.5c.2.2.2.4.2.6 0 .1 0 .3-.2.5zM9 8c-.6 0-1 .4-1 1s.4 1 1 1 1-.4 1-1-.4-1-1-1z"
28172  }));
28173  /* harmony default export */ var library_tag = (tag);
28174  
28175  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/custom-post-type.js
28176  
28177  
28178  /**
28179   * WordPress dependencies
28180   */
28181  
28182  const customPostType = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
28183    xmlns: "http://www.w3.org/2000/svg",
28184    viewBox: "0 0 24 24"
28185  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
28186    d: "M4 20h9v-1.5H4V20zm0-5.5V16h16v-1.5H4zm.8-4l.7.7 2-2V12h1V9.2l2 2 .7-.7-2-2H12v-1H9.2l2-2-.7-.7-2 2V4h-1v2.8l-2-2-.7.7 2 2H4v1h2.8l-2 2z"
28187  }));
28188  /* harmony default export */ var custom_post_type = (customPostType);
28189  
28190  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/navigation-link/fallback-variations.js
28191  /**
28192   * WordPress dependencies
28193   */
28194  
28195   // FALLBACK: this is only used when the server does not understand the variations property in the
28196  // register_block_type call. see navigation-link/index.php.
28197  // Delete this file when supported WP ranges understand the `variations` property when passed to
28198  // register_block_type in index.php.
28199  
28200  const fallbackVariations = [{
28201    name: 'link',
28202    isDefault: true,
28203    title: (0,external_wp_i18n_namespaceObject.__)('Custom Link'),
28204    description: (0,external_wp_i18n_namespaceObject.__)('A link to a custom URL.'),
28205    attributes: {}
28206  }, {
28207    name: 'post',
28208    icon: post_title,
28209    title: (0,external_wp_i18n_namespaceObject.__)('Post Link'),
28210    description: (0,external_wp_i18n_namespaceObject.__)('A link to a post.'),
28211    attributes: {
28212      type: 'post',
28213      kind: 'post-type'
28214    }
28215  }, {
28216    name: 'page',
28217    icon: library_page,
28218    title: (0,external_wp_i18n_namespaceObject.__)('Page Link'),
28219    description: (0,external_wp_i18n_namespaceObject.__)('A link to a page.'),
28220    attributes: {
28221      type: 'page',
28222      kind: 'post-type'
28223    }
28224  }, {
28225    name: 'category',
28226    icon: library_category,
28227    title: (0,external_wp_i18n_namespaceObject.__)('Category Link'),
28228    description: (0,external_wp_i18n_namespaceObject.__)('A link to a category.'),
28229    attributes: {
28230      type: 'category',
28231      kind: 'taxonomy'
28232    }
28233  }, {
28234    name: 'tag',
28235    icon: library_tag,
28236    title: (0,external_wp_i18n_namespaceObject.__)('Tag Link'),
28237    description: (0,external_wp_i18n_namespaceObject.__)('A link to a tag.'),
28238    attributes: {
28239      type: 'tag',
28240      kind: 'taxonomy'
28241    }
28242  }];
28243  /**
28244   * Add `isActive` function to all `navigation link` variations, if not defined.
28245   * `isActive` function is used to find a variation match from a created
28246   *  Block by providing its attributes.
28247   */
28248  
28249  fallbackVariations.forEach(variation => {
28250    if (variation.isActive) return;
28251  
28252    variation.isActive = (blockAttributes, variationAttributes) => blockAttributes.type === variationAttributes.type;
28253  });
28254  /* harmony default export */ var fallback_variations = (fallbackVariations);
28255  
28256  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/navigation-link/hooks.js
28257  /**
28258   * WordPress dependencies
28259   */
28260  
28261  /**
28262   * Internal dependencies
28263   */
28264  
28265  
28266  
28267  function getIcon(variationName) {
28268    switch (variationName) {
28269      case 'post':
28270        return post_title;
28271  
28272      case 'page':
28273        return library_page;
28274  
28275      case 'tag':
28276        return library_tag;
28277  
28278      case 'category':
28279        return library_category;
28280  
28281      default:
28282        return custom_post_type;
28283    }
28284  }
28285  
28286  function enhanceNavigationLinkVariations(settings, name) {
28287    if (name !== 'core/navigation-link') {
28288      return settings;
28289    } // Fallback handling may be deleted after supported WP ranges understand the `variations`
28290    // property when passed to register_block_type in index.php.
28291  
28292  
28293    if (!settings.variations) {
28294      return { ...settings,
28295        variations: fallback_variations
28296      };
28297    } // Otherwise decorate server passed variations with an icon and isActive function.
28298  
28299  
28300    if (settings.variations) {
28301      const isActive = (blockAttributes, variationAttributes) => {
28302        return blockAttributes.type === variationAttributes.type;
28303      };
28304  
28305      const variations = settings.variations.map(variation => {
28306        return { ...variation,
28307          ...(!variation.icon && {
28308            icon: getIcon(variation.name)
28309          }),
28310          ...(!variation.isActive && {
28311            isActive
28312          })
28313        };
28314      });
28315      return { ...settings,
28316        variations
28317      };
28318    }
28319  
28320    return settings;
28321  }
28322  
28323  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/navigation-link/transforms.js
28324  /**
28325   * WordPress dependencies
28326   */
28327  
28328  const navigation_link_transforms_transforms = {
28329    from: [{
28330      type: 'block',
28331      blocks: ['core/site-logo'],
28332      transform: () => {
28333        return (0,external_wp_blocks_namespaceObject.createBlock)('core/navigation-link');
28334      }
28335    }, {
28336      type: 'block',
28337      blocks: ['core/spacer'],
28338      transform: () => {
28339        return (0,external_wp_blocks_namespaceObject.createBlock)('core/navigation-link');
28340      }
28341    }, {
28342      type: 'block',
28343      blocks: ['core/home-link'],
28344      transform: () => {
28345        return (0,external_wp_blocks_namespaceObject.createBlock)('core/navigation-link');
28346      }
28347    }, {
28348      type: 'block',
28349      blocks: ['core/social-links'],
28350      transform: () => {
28351        return (0,external_wp_blocks_namespaceObject.createBlock)('core/navigation-link');
28352      }
28353    }, {
28354      type: 'block',
28355      blocks: ['core/search'],
28356      transform: () => {
28357        return (0,external_wp_blocks_namespaceObject.createBlock)('core/navigation-link');
28358      }
28359    }],
28360    to: [{
28361      type: 'block',
28362      blocks: ['core/navigation-submenu'],
28363      transform: (attributes, innerBlocks) => (0,external_wp_blocks_namespaceObject.createBlock)('core/navigation-submenu', attributes, innerBlocks)
28364    }, {
28365      type: 'block',
28366      blocks: ['core/spacer'],
28367      transform: () => {
28368        return (0,external_wp_blocks_namespaceObject.createBlock)('core/spacer');
28369      }
28370    }, {
28371      type: 'block',
28372      blocks: ['core/site-logo'],
28373      transform: () => {
28374        return (0,external_wp_blocks_namespaceObject.createBlock)('core/site-logo');
28375      }
28376    }, {
28377      type: 'block',
28378      blocks: ['core/home-link'],
28379      transform: () => {
28380        return (0,external_wp_blocks_namespaceObject.createBlock)('core/home-link');
28381      }
28382    }, {
28383      type: 'block',
28384      blocks: ['core/social-links'],
28385      transform: () => {
28386        return (0,external_wp_blocks_namespaceObject.createBlock)('core/social-links');
28387      }
28388    }, {
28389      type: 'block',
28390      blocks: ['core/search'],
28391      transform: () => {
28392        return (0,external_wp_blocks_namespaceObject.createBlock)('core/search', {
28393          showLabel: false,
28394          buttonUseIcon: true,
28395          buttonPosition: 'button-inside'
28396        });
28397      }
28398    }]
28399  };
28400  /* harmony default export */ var navigation_link_transforms = (navigation_link_transforms_transforms);
28401  
28402  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/navigation-link/index.js
28403  
28404  
28405  /**
28406   * WordPress dependencies
28407   */
28408  
28409  
28410  
28411  
28412  /**
28413   * Internal dependencies
28414   */
28415  
28416  const navigation_link_metadata = {
28417    $schema: "https://schemas.wp.org/trunk/block.json",
28418    apiVersion: 2,
28419    name: "core/navigation-link",
28420    title: "Custom Link",
28421    category: "design",
28422    parent: ["core/navigation"],
28423    description: "Add a page, link, or another item to your navigation.",
28424    textdomain: "default",
28425    attributes: {
28426      label: {
28427        type: "string"
28428      },
28429      type: {
28430        type: "string"
28431      },
28432      description: {
28433        type: "string"
28434      },
28435      rel: {
28436        type: "string"
28437      },
28438      id: {
28439        type: "number"
28440      },
28441      opensInNewTab: {
28442        type: "boolean",
28443        "default": false
28444      },
28445      url: {
28446        type: "string"
28447      },
28448      title: {
28449        type: "string"
28450      },
28451      kind: {
28452        type: "string"
28453      },
28454      isTopLevelLink: {
28455        type: "boolean"
28456      }
28457    },
28458    usesContext: ["textColor", "customTextColor", "backgroundColor", "customBackgroundColor", "overlayTextColor", "customOverlayTextColor", "overlayBackgroundColor", "customOverlayBackgroundColor", "fontSize", "customFontSize", "showSubmenuIcon", "maxNestingLevel", "style"],
28459    supports: {
28460      reusable: false,
28461      html: false,
28462      __experimentalSlashInserter: true
28463    },
28464    editorStyle: "wp-block-navigation-link-editor",
28465    style: "wp-block-navigation-link"
28466  };
28467  
28468  
28469  
28470  
28471  const {
28472    name: navigation_link_name
28473  } = navigation_link_metadata;
28474  
28475  const navigation_link_settings = {
28476    icon: custom_link,
28477    __experimentalLabel: _ref => {
28478      let {
28479        label
28480      } = _ref;
28481      return label;
28482    },
28483  
28484    merge(leftAttributes, _ref2) {
28485      let {
28486        label: rightLabel = ''
28487      } = _ref2;
28488      return { ...leftAttributes,
28489        label: leftAttributes.label + rightLabel
28490      };
28491    },
28492  
28493    edit: NavigationLinkEdit,
28494    save: navigation_link_save_save,
28495    example: {
28496      attributes: {
28497        label: (0,external_wp_i18n_namespaceObject._x)('Example Link', 'navigation link preview example'),
28498        url: 'https://example.com'
28499      }
28500    },
28501    deprecated: [{
28502      isEligible(attributes) {
28503        return attributes.nofollow;
28504      },
28505  
28506      attributes: {
28507        label: {
28508          type: 'string'
28509        },
28510        type: {
28511          type: 'string'
28512        },
28513        nofollow: {
28514          type: 'boolean'
28515        },
28516        description: {
28517          type: 'string'
28518        },
28519        id: {
28520          type: 'number'
28521        },
28522        opensInNewTab: {
28523          type: 'boolean',
28524          default: false
28525        },
28526        url: {
28527          type: 'string'
28528        }
28529      },
28530  
28531      migrate(_ref3) {
28532        let {
28533          nofollow,
28534          ...rest
28535        } = _ref3;
28536        return {
28537          rel: nofollow ? 'nofollow' : '',
28538          ...rest
28539        };
28540      },
28541  
28542      save() {
28543        return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InnerBlocks.Content, null);
28544      }
28545  
28546    }],
28547    transforms: navigation_link_transforms
28548  }; // importing this file includes side effects. This is whitelisted in block-library/package.json under sideEffects
28549  
28550  (0,external_wp_hooks_namespaceObject.addFilter)('blocks.registerBlockType', 'core/navigation-link', enhanceNavigationLinkVariations);
28551  
28552  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/remove-submenu.js
28553  
28554  
28555  /**
28556   * WordPress dependencies
28557   */
28558  
28559  const removeSubmenu = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
28560    xmlns: "http://www.w3.org/2000/svg",
28561    viewBox: "0 0 24 24"
28562  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
28563    fillRule: "evenodd",
28564    clipRule: "evenodd",
28565    d: "m13.955 20.748 8-17.5-.91-.416L19.597 6H13.5v1.5h5.411l-1.6 3.5H13.5v1.5h3.126l-1.6 3.5H13.5l.028 1.5h.812l-1.295 2.832.91.416ZM17.675 16l-.686 1.5h4.539L21.5 16h-3.825Zm2.286-5-.686 1.5H21.5V11h-1.54ZM2 12c0 3.58 2.42 5.5 6 5.5h.5V19l3-2.5-3-2.5v2H8c-2.48 0-4.5-1.52-4.5-4S5.52 7.5 8 7.5h3.5V6H8c-3.58 0-6 2.42-6 6Z"
28566  }));
28567  /* harmony default export */ var remove_submenu = (removeSubmenu);
28568  
28569  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/navigation-submenu/icons.js
28570  
28571  
28572  /**
28573   * WordPress dependencies
28574   */
28575  
28576  const ItemSubmenuIcon = () => (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, {
28577    xmlns: "http://www.w3.org/2000/svg",
28578    width: "12",
28579    height: "12",
28580    viewBox: "0 0 12 12",
28581    fill: "none"
28582  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
28583    d: "M1.50002 4L6.00002 8L10.5 4",
28584    strokeWidth: "1.5"
28585  }));
28586  
28587  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/navigation-submenu/edit.js
28588  
28589  
28590  /**
28591   * External dependencies
28592   */
28593  
28594  
28595  /**
28596   * WordPress dependencies
28597   */
28598  
28599  
28600  
28601  
28602  
28603  
28604  
28605  
28606  
28607  
28608  
28609  
28610  
28611  /**
28612   * Internal dependencies
28613   */
28614  
28615  
28616  const {
28617    name: navigation_submenu_edit_name
28618  } = {
28619    $schema: "https://schemas.wp.org/trunk/block.json",
28620    apiVersion: 2,
28621    name: "core/navigation-submenu",
28622    title: "Submenu",
28623    category: "design",
28624    parent: ["core/navigation"],
28625    description: "Add a submenu to your navigation.",
28626    textdomain: "default",
28627    attributes: {
28628      label: {
28629        type: "string"
28630      },
28631      type: {
28632        type: "string"
28633      },
28634      description: {
28635        type: "string"
28636      },
28637      rel: {
28638        type: "string"
28639      },
28640      id: {
28641        type: "number"
28642      },
28643      opensInNewTab: {
28644        type: "boolean",
28645        "default": false
28646      },
28647      url: {
28648        type: "string"
28649      },
28650      title: {
28651        type: "string"
28652      },
28653      kind: {
28654        type: "string"
28655      },
28656      isTopLevelItem: {
28657        type: "boolean"
28658      }
28659    },
28660    usesContext: ["textColor", "customTextColor", "backgroundColor", "customBackgroundColor", "overlayTextColor", "customOverlayTextColor", "overlayBackgroundColor", "customOverlayBackgroundColor", "fontSize", "customFontSize", "showSubmenuIcon", "maxNestingLevel", "openSubmenusOnClick", "style"],
28661    supports: {
28662      reusable: false,
28663      html: false
28664    },
28665    editorStyle: "wp-block-navigation-submenu-editor",
28666    style: "wp-block-navigation-submenu"
28667  };
28668  const navigation_submenu_edit_ALLOWED_BLOCKS = ['core/navigation-link', 'core/navigation-submenu'];
28669  const edit_DEFAULT_BLOCK = {
28670    name: 'core/navigation-link'
28671  };
28672  /**
28673   * A React hook to determine if it's dragging within the target element.
28674   *
28675   * @typedef {import('@wordpress/element').RefObject} RefObject
28676   *
28677   * @param {RefObject<HTMLElement>} elementRef The target elementRef object.
28678   *
28679   * @return {boolean} Is dragging within the target element.
28680   */
28681  
28682  const edit_useIsDraggingWithin = elementRef => {
28683    const [isDraggingWithin, setIsDraggingWithin] = (0,external_wp_element_namespaceObject.useState)(false);
28684    (0,external_wp_element_namespaceObject.useEffect)(() => {
28685      const {
28686        ownerDocument
28687      } = elementRef.current;
28688  
28689      function handleDragStart(event) {
28690        // Check the first time when the dragging starts.
28691        handleDragEnter(event);
28692      } // Set to false whenever the user cancel the drag event by either releasing the mouse or press Escape.
28693  
28694  
28695      function handleDragEnd() {
28696        setIsDraggingWithin(false);
28697      }
28698  
28699      function handleDragEnter(event) {
28700        // Check if the current target is inside the item element.
28701        if (elementRef.current.contains(event.target)) {
28702          setIsDraggingWithin(true);
28703        } else {
28704          setIsDraggingWithin(false);
28705        }
28706      } // Bind these events to the document to catch all drag events.
28707      // Ideally, we can also use `event.relatedTarget`, but sadly that
28708      // doesn't work in Safari.
28709  
28710  
28711      ownerDocument.addEventListener('dragstart', handleDragStart);
28712      ownerDocument.addEventListener('dragend', handleDragEnd);
28713      ownerDocument.addEventListener('dragenter', handleDragEnter);
28714      return () => {
28715        ownerDocument.removeEventListener('dragstart', handleDragStart);
28716        ownerDocument.removeEventListener('dragend', handleDragEnd);
28717        ownerDocument.removeEventListener('dragenter', handleDragEnter);
28718      };
28719    }, []);
28720    return isDraggingWithin;
28721  };
28722  /**
28723   * Given the Link block's type attribute, return the query params to give to
28724   * /wp/v2/search.
28725   *
28726   * @param {string} type Link block's type attribute.
28727   * @param {string} kind Link block's entity of kind (post-type|taxonomy)
28728   * @return {{ type?: string, subtype?: string }} Search query params.
28729   */
28730  
28731  
28732  function edit_getSuggestionsQuery(type, kind) {
28733    switch (type) {
28734      case 'post':
28735      case 'page':
28736        return {
28737          type: 'post',
28738          subtype: type
28739        };
28740  
28741      case 'category':
28742        return {
28743          type: 'term',
28744          subtype: 'category'
28745        };
28746  
28747      case 'tag':
28748        return {
28749          type: 'term',
28750          subtype: 'post_tag'
28751        };
28752  
28753      case 'post_format':
28754        return {
28755          type: 'post-format'
28756        };
28757  
28758      default:
28759        if (kind === 'taxonomy') {
28760          return {
28761            type: 'term',
28762            subtype: type
28763          };
28764        }
28765  
28766        if (kind === 'post-type') {
28767          return {
28768            type: 'post',
28769            subtype: type
28770          };
28771        }
28772  
28773        return {};
28774    }
28775  }
28776  /**
28777   * Determine the colors for a menu.
28778   *
28779   * Order of priority is:
28780   * 1: Overlay custom colors (if submenu)
28781   * 2: Overlay theme colors (if submenu)
28782   * 3: Custom colors
28783   * 4: Theme colors
28784   * 5: Global styles
28785   *
28786   * @param {Object}  context
28787   * @param {boolean} isSubMenu
28788   */
28789  
28790  
28791  function edit_getColors(context, isSubMenu) {
28792    var _style$color, _style$color2;
28793  
28794    const {
28795      textColor,
28796      customTextColor,
28797      backgroundColor,
28798      customBackgroundColor,
28799      overlayTextColor,
28800      customOverlayTextColor,
28801      overlayBackgroundColor,
28802      customOverlayBackgroundColor,
28803      style
28804    } = context;
28805    const colors = {};
28806  
28807    if (isSubMenu && !!customOverlayTextColor) {
28808      colors.customTextColor = customOverlayTextColor;
28809    } else if (isSubMenu && !!overlayTextColor) {
28810      colors.textColor = overlayTextColor;
28811    } else if (!!customTextColor) {
28812      colors.customTextColor = customTextColor;
28813    } else if (!!textColor) {
28814      colors.textColor = textColor;
28815    } else if (!!(style !== null && style !== void 0 && (_style$color = style.color) !== null && _style$color !== void 0 && _style$color.text)) {
28816      colors.customTextColor = style.color.text;
28817    }
28818  
28819    if (isSubMenu && !!customOverlayBackgroundColor) {
28820      colors.customBackgroundColor = customOverlayBackgroundColor;
28821    } else if (isSubMenu && !!overlayBackgroundColor) {
28822      colors.backgroundColor = overlayBackgroundColor;
28823    } else if (!!customBackgroundColor) {
28824      colors.customBackgroundColor = customBackgroundColor;
28825    } else if (!!backgroundColor) {
28826      colors.backgroundColor = backgroundColor;
28827    } else if (!!(style !== null && style !== void 0 && (_style$color2 = style.color) !== null && _style$color2 !== void 0 && _style$color2.background)) {
28828      colors.customTextColor = style.color.background;
28829    }
28830  
28831    return colors;
28832  }
28833  /**
28834   * @typedef {'post-type'|'custom'|'taxonomy'|'post-type-archive'} WPNavigationLinkKind
28835   */
28836  
28837  /**
28838   * Navigation Link Block Attributes
28839   *
28840   * @typedef {Object} WPNavigationLinkBlockAttributes
28841   *
28842   * @property {string}               [label]         Link text.
28843   * @property {WPNavigationLinkKind} [kind]          Kind is used to differentiate between term and post ids to check post draft status.
28844   * @property {string}               [type]          The type such as post, page, tag, category and other custom types.
28845   * @property {string}               [rel]           The relationship of the linked URL.
28846   * @property {number}               [id]            A post or term id.
28847   * @property {boolean}              [opensInNewTab] Sets link target to _blank when true.
28848   * @property {string}               [url]           Link href.
28849   * @property {string}               [title]         Link title attribute.
28850   */
28851  
28852  /**
28853   * Link Control onChange handler that updates block attributes when a setting is changed.
28854   *
28855   * @param {Object}                          updatedValue    New block attributes to update.
28856   * @param {Function}                        setAttributes   Block attribute update function.
28857   * @param {WPNavigationLinkBlockAttributes} blockAttributes Current block attributes.
28858   *
28859   */
28860  
28861  
28862  const edit_updateNavigationLinkBlockAttributes = function () {
28863    let updatedValue = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
28864    let setAttributes = arguments.length > 1 ? arguments[1] : undefined;
28865    let blockAttributes = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
28866    const {
28867      label: originalLabel = '',
28868      kind: originalKind = '',
28869      type: originalType = ''
28870    } = blockAttributes;
28871    const {
28872      title = '',
28873      url = '',
28874      opensInNewTab,
28875      id,
28876      kind: newKind = originalKind,
28877      type: newType = originalType
28878    } = updatedValue;
28879    const normalizedTitle = title.replace(/http(s?):\/\//gi, '');
28880    const normalizedURL = url.replace(/http(s?):\/\//gi, '');
28881    const escapeTitle = title !== '' && normalizedTitle !== normalizedURL && originalLabel !== title;
28882    const label = escapeTitle ? (0,external_lodash_namespaceObject.escape)(title) : originalLabel || (0,external_lodash_namespaceObject.escape)(normalizedURL); // In https://github.com/WordPress/gutenberg/pull/24670 we decided to use "tag" in favor of "post_tag"
28883  
28884    const type = newType === 'post_tag' ? 'tag' : newType.replace('-', '_');
28885    const isBuiltInType = ['post', 'page', 'tag', 'category'].indexOf(type) > -1;
28886    const isCustomLink = !newKind && !isBuiltInType || newKind === 'custom';
28887    const kind = isCustomLink ? 'custom' : newKind;
28888    setAttributes({ // Passed `url` may already be encoded. To prevent double encoding, decodeURI is executed to revert to the original string.
28889      ...(url && {
28890        url: encodeURI((0,external_wp_url_namespaceObject.safeDecodeURI)(url))
28891      }),
28892      ...(label && {
28893        label
28894      }),
28895      ...(undefined !== opensInNewTab && {
28896        opensInNewTab
28897      }),
28898      ...(id && Number.isInteger(id) && {
28899        id
28900      }),
28901      ...(kind && {
28902        kind
28903      }),
28904      ...(type && type !== 'URL' && {
28905        type
28906      })
28907    });
28908  };
28909  function NavigationSubmenuEdit(_ref) {
28910    let {
28911      attributes,
28912      isSelected,
28913      setAttributes,
28914      mergeBlocks,
28915      onReplace,
28916      context,
28917      clientId
28918    } = _ref;
28919    const {
28920      label,
28921      type,
28922      opensInNewTab,
28923      url,
28924      description,
28925      rel,
28926      title,
28927      kind
28928    } = attributes;
28929    const link = {
28930      url,
28931      opensInNewTab
28932    };
28933    const {
28934      showSubmenuIcon,
28935      maxNestingLevel,
28936      openSubmenusOnClick
28937    } = context;
28938    const {
28939      saveEntityRecord
28940    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_coreData_namespaceObject.store);
28941    const {
28942      __unstableMarkNextChangeAsNotPersistent,
28943      replaceBlock
28944    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_blockEditor_namespaceObject.store);
28945    const [isLinkOpen, setIsLinkOpen] = (0,external_wp_element_namespaceObject.useState)(false);
28946    const listItemRef = (0,external_wp_element_namespaceObject.useRef)(null);
28947    const isDraggingWithin = edit_useIsDraggingWithin(listItemRef);
28948  
28949    const itemLabelPlaceholder = (0,external_wp_i18n_namespaceObject.__)('Add text…');
28950  
28951    const ref = (0,external_wp_element_namespaceObject.useRef)();
28952    const {
28953      isAtMaxNesting,
28954      isTopLevelItem,
28955      isParentOfSelectedBlock,
28956      isImmediateParentOfSelectedBlock,
28957      hasChildren,
28958      selectedBlockHasChildren,
28959      userCanCreatePages,
28960      userCanCreatePosts,
28961      onlyDescendantIsEmptyLink
28962    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
28963      const {
28964        hasSelectedInnerBlock,
28965        getSelectedBlockClientId,
28966        getBlockParentsByBlockName,
28967        getBlock,
28968        getBlockCount,
28969        getBlockOrder
28970      } = select(external_wp_blockEditor_namespaceObject.store);
28971  
28972      let _onlyDescendantIsEmptyLink;
28973  
28974      const selectedBlockId = getSelectedBlockClientId();
28975      const selectedBlockChildren = getBlockOrder(selectedBlockId); // Check for a single descendant in the submenu. If that block
28976      // is a link block in a "placeholder" state with no label then
28977      // we can consider as an "empty" link.
28978  
28979      if ((selectedBlockChildren === null || selectedBlockChildren === void 0 ? void 0 : selectedBlockChildren.length) === 1) {
28980        var _singleBlock$attribut;
28981  
28982        const singleBlock = getBlock(selectedBlockChildren[0]);
28983        _onlyDescendantIsEmptyLink = (singleBlock === null || singleBlock === void 0 ? void 0 : singleBlock.name) === 'core/navigation-link' && !(singleBlock !== null && singleBlock !== void 0 && (_singleBlock$attribut = singleBlock.attributes) !== null && _singleBlock$attribut !== void 0 && _singleBlock$attribut.label);
28984      }
28985  
28986      return {
28987        isAtMaxNesting: getBlockParentsByBlockName(clientId, navigation_submenu_edit_name).length >= maxNestingLevel,
28988        isTopLevelItem: getBlockParentsByBlockName(clientId, navigation_submenu_edit_name).length === 0,
28989        isParentOfSelectedBlock: hasSelectedInnerBlock(clientId, true),
28990        isImmediateParentOfSelectedBlock: hasSelectedInnerBlock(clientId, false),
28991        hasChildren: !!getBlockCount(clientId),
28992        selectedBlockHasChildren: !!(selectedBlockChildren !== null && selectedBlockChildren !== void 0 && selectedBlockChildren.length),
28993        userCanCreatePages: select(external_wp_coreData_namespaceObject.store).canUser('create', 'pages'),
28994        userCanCreatePosts: select(external_wp_coreData_namespaceObject.store).canUser('create', 'posts'),
28995        onlyDescendantIsEmptyLink: _onlyDescendantIsEmptyLink
28996      };
28997    }, [clientId]); // Show the LinkControl on mount if the URL is empty
28998    // ( When adding a new menu item)
28999    // This can't be done in the useState call because it conflicts
29000    // with the autofocus behavior of the BlockListBlock component.
29001  
29002    (0,external_wp_element_namespaceObject.useEffect)(() => {
29003      if (!openSubmenusOnClick && !url) {
29004        setIsLinkOpen(true);
29005      }
29006    }, []); // Store the colors from context as attributes for rendering.
29007  
29008    (0,external_wp_element_namespaceObject.useEffect)(() => {
29009      // This side-effect should not create an undo level as those should
29010      // only be created via user interactions. Mark this change as
29011      // not persistent to avoid undo level creation.
29012      // See https://github.com/WordPress/gutenberg/issues/34564.
29013      __unstableMarkNextChangeAsNotPersistent();
29014  
29015      setAttributes({
29016        isTopLevelItem
29017      });
29018    }, [isTopLevelItem]);
29019    /**
29020     * The hook shouldn't be necessary but due to a focus loss happening
29021     * when selecting a suggestion in the link popover, we force close on block unselection.
29022     */
29023  
29024    (0,external_wp_element_namespaceObject.useEffect)(() => {
29025      if (!isSelected) {
29026        setIsLinkOpen(false);
29027      }
29028    }, [isSelected]); // If the LinkControl popover is open and the URL has changed, close the LinkControl and focus the label text.
29029  
29030    (0,external_wp_element_namespaceObject.useEffect)(() => {
29031      if (isLinkOpen && url) {
29032        // Does this look like a URL and have something TLD-ish?
29033        if ((0,external_wp_url_namespaceObject.isURL)((0,external_wp_url_namespaceObject.prependHTTP)(label)) && /^.+\.[a-z]+/.test(label)) {
29034          // Focus and select the label text.
29035          selectLabelText();
29036        } else {
29037          // Focus it (but do not select).
29038          (0,external_wp_dom_namespaceObject.placeCaretAtHorizontalEdge)(ref.current, true);
29039        }
29040      }
29041    }, [url]);
29042    /**
29043     * Focus the Link label text and select it.
29044     */
29045  
29046    function selectLabelText() {
29047      ref.current.focus();
29048      const {
29049        ownerDocument
29050      } = ref.current;
29051      const {
29052        defaultView
29053      } = ownerDocument;
29054      const selection = defaultView.getSelection();
29055      const range = ownerDocument.createRange(); // Get the range of the current ref contents so we can add this range to the selection.
29056  
29057      range.selectNodeContents(ref.current);
29058      selection.removeAllRanges();
29059      selection.addRange(range);
29060    }
29061  
29062    let userCanCreate = false;
29063  
29064    if (!type || type === 'page') {
29065      userCanCreate = userCanCreatePages;
29066    } else if (type === 'post') {
29067      userCanCreate = userCanCreatePosts;
29068    }
29069  
29070    async function handleCreate(pageTitle) {
29071      const postType = type || 'page';
29072      const page = await saveEntityRecord('postType', postType, {
29073        title: pageTitle,
29074        status: 'draft'
29075      });
29076      return {
29077        id: page.id,
29078        type: postType,
29079        title: page.title.rendered,
29080        url: page.link,
29081        kind: 'post-type'
29082      };
29083    }
29084  
29085    const {
29086      textColor,
29087      customTextColor,
29088      backgroundColor,
29089      customBackgroundColor
29090    } = edit_getColors(context, !isTopLevelItem);
29091  
29092    function onKeyDown(event) {
29093      if (external_wp_keycodes_namespaceObject.isKeyboardEvent.primary(event, 'k')) {
29094        setIsLinkOpen(true);
29095      }
29096    }
29097  
29098    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
29099      ref: listItemRef,
29100      className: classnames_default()('wp-block-navigation-item', {
29101        'is-editing': isSelected || isParentOfSelectedBlock,
29102        'is-dragging-within': isDraggingWithin,
29103        'has-link': !!url,
29104        'has-child': hasChildren,
29105        'has-text-color': !!textColor || !!customTextColor,
29106        [(0,external_wp_blockEditor_namespaceObject.getColorClassName)('color', textColor)]: !!textColor,
29107        'has-background': !!backgroundColor || customBackgroundColor,
29108        [(0,external_wp_blockEditor_namespaceObject.getColorClassName)('background-color', backgroundColor)]: !!backgroundColor,
29109        'open-on-click': openSubmenusOnClick
29110      }),
29111      style: {
29112        color: !textColor && customTextColor,
29113        backgroundColor: !backgroundColor && customBackgroundColor
29114      },
29115      onKeyDown
29116    }); // Always use overlay colors for submenus.
29117  
29118    const innerBlocksColors = edit_getColors(context, true);
29119    const allowedBlocks = isAtMaxNesting ? (0,external_lodash_namespaceObject.without)(navigation_submenu_edit_ALLOWED_BLOCKS, 'core/navigation-submenu') : navigation_submenu_edit_ALLOWED_BLOCKS;
29120    const innerBlocksProps = (0,external_wp_blockEditor_namespaceObject.useInnerBlocksProps)({
29121      className: classnames_default()('wp-block-navigation__submenu-container', {
29122        'is-parent-of-selected-block': isParentOfSelectedBlock,
29123        'has-text-color': !!(innerBlocksColors.textColor || innerBlocksColors.customTextColor),
29124        [`has-$innerBlocksColors.textColor}-color`]: !!innerBlocksColors.textColor,
29125        'has-background': !!(innerBlocksColors.backgroundColor || innerBlocksColors.customBackgroundColor),
29126        [`has-$innerBlocksColors.backgroundColor}-background-color`]: !!innerBlocksColors.backgroundColor
29127      }),
29128      style: {
29129        color: innerBlocksColors.customTextColor,
29130        backgroundColor: innerBlocksColors.customBackgroundColor
29131      }
29132    }, {
29133      allowedBlocks,
29134      __experimentalDefaultBlock: edit_DEFAULT_BLOCK,
29135      __experimentalDirectInsert: true,
29136      // Ensure block toolbar is not too far removed from item
29137      // being edited.
29138      // see: https://github.com/WordPress/gutenberg/pull/34615.
29139      __experimentalCaptureToolbars: true,
29140      renderAppender: isSelected || isImmediateParentOfSelectedBlock && !selectedBlockHasChildren || // Show the appender while dragging to allow inserting element between item and the appender.
29141      hasChildren ? external_wp_blockEditor_namespaceObject.InnerBlocks.ButtonBlockAppender : false
29142    });
29143    const ParentElement = openSubmenusOnClick ? 'button' : 'a';
29144  
29145    function transformToLink() {
29146      const newLinkBlock = (0,external_wp_blocks_namespaceObject.createBlock)('core/navigation-link', attributes);
29147      replaceBlock(clientId, newLinkBlock);
29148    }
29149  
29150    const canConvertToLink = !selectedBlockHasChildren || onlyDescendantIsEmptyLink;
29151    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarGroup, null, !openSubmenusOnClick && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, {
29152      name: "link",
29153      icon: library_link,
29154      title: (0,external_wp_i18n_namespaceObject.__)('Link'),
29155      shortcut: external_wp_keycodes_namespaceObject.displayShortcut.primary('k'),
29156      onClick: () => setIsLinkOpen(true)
29157    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, {
29158      name: "revert",
29159      icon: remove_submenu,
29160      title: (0,external_wp_i18n_namespaceObject.__)('Convert to Link'),
29161      onClick: transformToLink,
29162      className: "wp-block-navigation__submenu__revert",
29163      isDisabled: !canConvertToLink
29164    }))), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
29165      title: (0,external_wp_i18n_namespaceObject.__)('Link settings')
29166    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TextareaControl, {
29167      value: description || '',
29168      onChange: descriptionValue => {
29169        setAttributes({
29170          description: descriptionValue
29171        });
29172      },
29173      label: (0,external_wp_i18n_namespaceObject.__)('Description'),
29174      help: (0,external_wp_i18n_namespaceObject.__)('The description will be displayed in the menu if the current theme supports it.')
29175    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TextControl, {
29176      value: title || '',
29177      onChange: titleValue => {
29178        setAttributes({
29179          title: titleValue
29180        });
29181      },
29182      label: (0,external_wp_i18n_namespaceObject.__)('Link title'),
29183      autoComplete: "off"
29184    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TextControl, {
29185      value: rel || '',
29186      onChange: relValue => {
29187        setAttributes({
29188          rel: relValue
29189        });
29190      },
29191      label: (0,external_wp_i18n_namespaceObject.__)('Link rel'),
29192      autoComplete: "off"
29193    }))), (0,external_wp_element_namespaceObject.createElement)("div", blockProps, (0,external_wp_element_namespaceObject.createElement)(ParentElement, {
29194      className: "wp-block-navigation-item__content"
29195    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText, {
29196      ref: ref,
29197      identifier: "label",
29198      className: "wp-block-navigation-item__label",
29199      value: label,
29200      onChange: labelValue => setAttributes({
29201        label: labelValue
29202      }),
29203      onMerge: mergeBlocks,
29204      onReplace: onReplace,
29205      "aria-label": (0,external_wp_i18n_namespaceObject.__)('Navigation link text'),
29206      placeholder: itemLabelPlaceholder,
29207      withoutInteractiveFormatting: true,
29208      allowedFormats: ['core/bold', 'core/italic', 'core/image', 'core/strikethrough'],
29209      onClick: () => {
29210        if (!openSubmenusOnClick && !url) {
29211          setIsLinkOpen(true);
29212        }
29213      }
29214    }), !openSubmenusOnClick && isLinkOpen && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Popover, {
29215      position: "bottom center",
29216      onClose: () => setIsLinkOpen(false),
29217      anchorRef: listItemRef.current
29218    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.__experimentalLinkControl, {
29219      className: "wp-block-navigation-link__inline-link-input",
29220      value: link,
29221      showInitialSuggestions: true,
29222      withCreateSuggestion: userCanCreate,
29223      createSuggestion: handleCreate,
29224      createSuggestionButtonText: searchTerm => {
29225        let format;
29226  
29227        if (type === 'post') {
29228          /* translators: %s: search term. */
29229          format = (0,external_wp_i18n_namespaceObject.__)('Create draft post: <mark>%s</mark>');
29230        } else {
29231          /* translators: %s: search term. */
29232          format = (0,external_wp_i18n_namespaceObject.__)('Create draft page: <mark>%s</mark>');
29233        }
29234  
29235        return (0,external_wp_element_namespaceObject.createInterpolateElement)((0,external_wp_i18n_namespaceObject.sprintf)(format, searchTerm), {
29236          mark: (0,external_wp_element_namespaceObject.createElement)("mark", null)
29237        });
29238      },
29239      noDirectEntry: !!type,
29240      noURLSuggestion: !!type,
29241      suggestionsQuery: edit_getSuggestionsQuery(type, kind),
29242      onChange: updatedValue => edit_updateNavigationLinkBlockAttributes(updatedValue, setAttributes, attributes),
29243      onRemove: () => {
29244        setAttributes({
29245          url: ''
29246        });
29247        (0,external_wp_a11y_namespaceObject.speak)((0,external_wp_i18n_namespaceObject.__)('Link removed.'), 'assertive');
29248      }
29249    }))), (showSubmenuIcon || openSubmenusOnClick) && (0,external_wp_element_namespaceObject.createElement)("span", {
29250      className: "wp-block-navigation__submenu-icon"
29251    }, (0,external_wp_element_namespaceObject.createElement)(ItemSubmenuIcon, null)), (0,external_wp_element_namespaceObject.createElement)("div", innerBlocksProps)));
29252  }
29253  
29254  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/navigation-submenu/save.js
29255  
29256  
29257  /**
29258   * WordPress dependencies
29259   */
29260  
29261  function navigation_submenu_save_save() {
29262    return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InnerBlocks.Content, null);
29263  }
29264  
29265  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/navigation-submenu/transforms.js
29266  /**
29267   * WordPress dependencies
29268   */
29269  
29270  const navigation_submenu_transforms_transforms = {
29271    to: [{
29272      type: 'block',
29273      blocks: ['core/navigation-link'],
29274      isMatch: (attributes, block) => {
29275        var _block$innerBlocks;
29276  
29277        return (block === null || block === void 0 ? void 0 : (_block$innerBlocks = block.innerBlocks) === null || _block$innerBlocks === void 0 ? void 0 : _block$innerBlocks.length) === 0;
29278      },
29279      transform: attributes => (0,external_wp_blocks_namespaceObject.createBlock)('core/navigation-link', attributes)
29280    }, {
29281      type: 'block',
29282      blocks: ['core/spacer'],
29283      isMatch: (attributes, block) => {
29284        var _block$innerBlocks2;
29285  
29286        return (block === null || block === void 0 ? void 0 : (_block$innerBlocks2 = block.innerBlocks) === null || _block$innerBlocks2 === void 0 ? void 0 : _block$innerBlocks2.length) === 0;
29287      },
29288      transform: () => {
29289        return (0,external_wp_blocks_namespaceObject.createBlock)('core/spacer');
29290      }
29291    }, {
29292      type: 'block',
29293      blocks: ['core/site-logo'],
29294      isMatch: (attributes, block) => {
29295        var _block$innerBlocks3;
29296  
29297        return (block === null || block === void 0 ? void 0 : (_block$innerBlocks3 = block.innerBlocks) === null || _block$innerBlocks3 === void 0 ? void 0 : _block$innerBlocks3.length) === 0;
29298      },
29299      transform: () => {
29300        return (0,external_wp_blocks_namespaceObject.createBlock)('core/site-logo');
29301      }
29302    }, {
29303      type: 'block',
29304      blocks: ['core/home-link'],
29305      isMatch: (attributes, block) => {
29306        var _block$innerBlocks4;
29307  
29308        return (block === null || block === void 0 ? void 0 : (_block$innerBlocks4 = block.innerBlocks) === null || _block$innerBlocks4 === void 0 ? void 0 : _block$innerBlocks4.length) === 0;
29309      },
29310      transform: () => {
29311        return (0,external_wp_blocks_namespaceObject.createBlock)('core/home-link');
29312      }
29313    }, {
29314      type: 'block',
29315      blocks: ['core/social-links'],
29316      isMatch: (attributes, block) => {
29317        var _block$innerBlocks5;
29318  
29319        return (block === null || block === void 0 ? void 0 : (_block$innerBlocks5 = block.innerBlocks) === null || _block$innerBlocks5 === void 0 ? void 0 : _block$innerBlocks5.length) === 0;
29320      },
29321      transform: () => {
29322        return (0,external_wp_blocks_namespaceObject.createBlock)('core/social-links');
29323      }
29324    }, {
29325      type: 'block',
29326      blocks: ['core/search'],
29327      isMatch: (attributes, block) => {
29328        var _block$innerBlocks6;
29329  
29330        return (block === null || block === void 0 ? void 0 : (_block$innerBlocks6 = block.innerBlocks) === null || _block$innerBlocks6 === void 0 ? void 0 : _block$innerBlocks6.length) === 0;
29331      },
29332      transform: () => {
29333        return (0,external_wp_blocks_namespaceObject.createBlock)('core/search');
29334      }
29335    }]
29336  };
29337  /* harmony default export */ var navigation_submenu_transforms = (navigation_submenu_transforms_transforms);
29338  
29339  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/navigation-submenu/index.js
29340  /**
29341   * WordPress dependencies
29342   */
29343  
29344  /**
29345   * Internal dependencies
29346   */
29347  
29348  const navigation_submenu_metadata = {
29349    $schema: "https://schemas.wp.org/trunk/block.json",
29350    apiVersion: 2,
29351    name: "core/navigation-submenu",
29352    title: "Submenu",
29353    category: "design",
29354    parent: ["core/navigation"],
29355    description: "Add a submenu to your navigation.",
29356    textdomain: "default",
29357    attributes: {
29358      label: {
29359        type: "string"
29360      },
29361      type: {
29362        type: "string"
29363      },
29364      description: {
29365        type: "string"
29366      },
29367      rel: {
29368        type: "string"
29369      },
29370      id: {
29371        type: "number"
29372      },
29373      opensInNewTab: {
29374        type: "boolean",
29375        "default": false
29376      },
29377      url: {
29378        type: "string"
29379      },
29380      title: {
29381        type: "string"
29382      },
29383      kind: {
29384        type: "string"
29385      },
29386      isTopLevelItem: {
29387        type: "boolean"
29388      }
29389    },
29390    usesContext: ["textColor", "customTextColor", "backgroundColor", "customBackgroundColor", "overlayTextColor", "customOverlayTextColor", "overlayBackgroundColor", "customOverlayBackgroundColor", "fontSize", "customFontSize", "showSubmenuIcon", "maxNestingLevel", "openSubmenusOnClick", "style"],
29391    supports: {
29392      reusable: false,
29393      html: false
29394    },
29395    editorStyle: "wp-block-navigation-submenu-editor",
29396    style: "wp-block-navigation-submenu"
29397  };
29398  
29399  
29400  
29401  const {
29402    name: navigation_submenu_name
29403  } = navigation_submenu_metadata;
29404  
29405  const navigation_submenu_settings = {
29406    icon: add_submenu,
29407    __experimentalLabel: _ref => {
29408      let {
29409        label
29410      } = _ref;
29411      return label;
29412    },
29413    edit: NavigationSubmenuEdit,
29414    save: navigation_submenu_save_save,
29415    transforms: navigation_submenu_transforms
29416  };
29417  
29418  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/page-break.js
29419  
29420  
29421  /**
29422   * WordPress dependencies
29423   */
29424  
29425  const pageBreak = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
29426    xmlns: "http://www.w3.org/2000/svg",
29427    viewBox: "0 0 24 24"
29428  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
29429    d: "M7.8 6c0-.7.6-1.2 1.2-1.2h6c.7 0 1.2.6 1.2 1.2v3h1.5V6c0-1.5-1.2-2.8-2.8-2.8H9C7.5 3.2 6.2 4.5 6.2 6v3h1.5V6zm8.4 11c0 .7-.6 1.2-1.2 1.2H9c-.7 0-1.2-.6-1.2-1.2v-3H6.2v3c0 1.5 1.2 2.8 2.8 2.8h6c1.5 0 2.8-1.2 2.8-2.8v-3h-1.5v3zM4 11v1h16v-1H4z"
29430  }));
29431  /* harmony default export */ var page_break = (pageBreak);
29432  
29433  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/nextpage/edit.js
29434  
29435  
29436  /**
29437   * WordPress dependencies
29438   */
29439  
29440  
29441  function NextPageEdit() {
29442    return (0,external_wp_element_namespaceObject.createElement)("div", (0,external_wp_blockEditor_namespaceObject.useBlockProps)(), (0,external_wp_element_namespaceObject.createElement)("div", {
29443      className: "wp-block-nextpage"
29444    }, (0,external_wp_element_namespaceObject.createElement)("span", null, (0,external_wp_i18n_namespaceObject.__)('Page break'))));
29445  }
29446  
29447  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/nextpage/save.js
29448  
29449  
29450  /**
29451   * WordPress dependencies
29452   */
29453  
29454  function nextpage_save_save() {
29455    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.RawHTML, null, '<!--nextpage-->');
29456  }
29457  
29458  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/nextpage/transforms.js
29459  /**
29460   * WordPress dependencies
29461   */
29462  
29463  const nextpage_transforms_transforms = {
29464    from: [{
29465      type: 'raw',
29466      schema: {
29467        'wp-block': {
29468          attributes: ['data-block']
29469        }
29470      },
29471      isMatch: node => node.dataset && node.dataset.block === 'core/nextpage',
29472  
29473      transform() {
29474        return (0,external_wp_blocks_namespaceObject.createBlock)('core/nextpage', {});
29475      }
29476  
29477    }]
29478  };
29479  /* harmony default export */ var nextpage_transforms = (nextpage_transforms_transforms);
29480  
29481  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/nextpage/index.js
29482  /**
29483   * WordPress dependencies
29484   */
29485  
29486  /**
29487   * Internal dependencies
29488   */
29489  
29490  
29491  const nextpage_metadata = {
29492    $schema: "https://schemas.wp.org/trunk/block.json",
29493    apiVersion: 2,
29494    name: "core/nextpage",
29495    title: "Page Break",
29496    category: "design",
29497    description: "Separate your content into a multi-page experience.",
29498    keywords: ["next page", "pagination"],
29499    parent: ["core/post-content"],
29500    textdomain: "default",
29501    supports: {
29502      customClassName: false,
29503      className: false,
29504      html: false
29505    },
29506    editorStyle: "wp-block-nextpage-editor"
29507  };
29508  
29509  
29510  const {
29511    name: nextpage_name
29512  } = nextpage_metadata;
29513  
29514  const nextpage_settings = {
29515    icon: page_break,
29516    example: {},
29517    transforms: nextpage_transforms,
29518    edit: NextPageEdit,
29519    save: nextpage_save_save
29520  };
29521  
29522  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/pattern/edit.js
29523  
29524  
29525  /**
29526   * WordPress dependencies
29527   */
29528  
29529  
29530  
29531  
29532  const PatternEdit = _ref => {
29533    let {
29534      attributes,
29535      clientId
29536    } = _ref;
29537    const selectedPattern = (0,external_wp_data_namespaceObject.useSelect)(select => select(external_wp_blockEditor_namespaceObject.store).__experimentalGetParsedPattern(attributes.slug), [attributes.slug]);
29538    const {
29539      replaceBlocks,
29540      __unstableMarkNextChangeAsNotPersistent
29541    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_blockEditor_namespaceObject.store); // Run this effect when the component loads.
29542    // This adds the Pattern's contents to the post.
29543    // This change won't be saved.
29544    // It will continue to pull from the pattern file unless changes are made to its respective template part.
29545  
29546    (0,external_wp_element_namespaceObject.useEffect)(() => {
29547      if (selectedPattern !== null && selectedPattern !== void 0 && selectedPattern.blocks) {
29548        __unstableMarkNextChangeAsNotPersistent();
29549  
29550        replaceBlocks(clientId, selectedPattern.blocks);
29551      }
29552    }, [selectedPattern === null || selectedPattern === void 0 ? void 0 : selectedPattern.blocks]);
29553    const props = (0,external_wp_blockEditor_namespaceObject.useBlockProps)();
29554    return (0,external_wp_element_namespaceObject.createElement)("div", props);
29555  };
29556  
29557  /* harmony default export */ var pattern_edit = (PatternEdit);
29558  
29559  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/pattern/index.js
29560  /**
29561   * Internal dependencies
29562   */
29563  const pattern_metadata = {
29564    $schema: "https://schemas.wp.org/trunk/block.json",
29565    apiVersion: 2,
29566    name: "core/pattern",
29567    title: "Pattern",
29568    category: "theme",
29569    description: "Show a block pattern.",
29570    supports: {
29571      html: false,
29572      inserter: false
29573    },
29574    textdomain: "default",
29575    attributes: {
29576      slug: {
29577        type: "string"
29578      }
29579    }
29580  };
29581  
29582  const {
29583    name: pattern_name
29584  } = pattern_metadata;
29585  
29586  const pattern_settings = {
29587    edit: pattern_edit
29588  };
29589  
29590  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/pages.js
29591  
29592  
29593  /**
29594   * WordPress dependencies
29595   */
29596  
29597  const pages = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
29598    xmlns: "http://www.w3.org/2000/svg",
29599    viewBox: "0 0 24 24"
29600  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
29601    d: "M7 13.8h6v-1.5H7v1.5zM18 16V4c0-1.1-.9-2-2-2H6c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h10c1.1 0 2-.9 2-2zM5.5 16V4c0-.3.2-.5.5-.5h10c.3 0 .5.2.5.5v12c0 .3-.2.5-.5.5H6c-.3 0-.5-.2-.5-.5zM7 10.5h8V9H7v1.5zm0-3.3h8V5.8H7v1.4zM20.2 6v13c0 .7-.6 1.2-1.2 1.2H8v1.5h11c1.5 0 2.7-1.2 2.7-2.8V6h-1.5z"
29602  }));
29603  /* harmony default export */ var library_pages = (pages);
29604  
29605  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/page-list/convert-to-links-modal.js
29606  
29607  
29608  /**
29609   * WordPress dependencies
29610   */
29611  
29612  
29613  
29614  
29615  
29616  
29617  const PAGE_FIELDS = ['id', 'title', 'link', 'type', 'parent'];
29618  const MAX_PAGE_COUNT = 100;
29619  const convertSelectedBlockToNavigationLinks = _ref => {
29620    let {
29621      pages,
29622      clientId,
29623      replaceBlock,
29624      createBlock
29625    } = _ref;
29626    return () => {
29627      if (!pages) {
29628        return;
29629      }
29630  
29631      const linkMap = {};
29632      const navigationLinks = [];
29633      pages.forEach(_ref2 => {
29634        var _linkMap$id$innerBloc, _linkMap$id;
29635  
29636        let {
29637          id,
29638          title,
29639          link: url,
29640          type,
29641          parent
29642        } = _ref2;
29643        // See if a placeholder exists. This is created if children appear before parents in list.
29644        const innerBlocks = (_linkMap$id$innerBloc = (_linkMap$id = linkMap[id]) === null || _linkMap$id === void 0 ? void 0 : _linkMap$id.innerBlocks) !== null && _linkMap$id$innerBloc !== void 0 ? _linkMap$id$innerBloc : [];
29645        linkMap[id] = createBlock('core/navigation-link', {
29646          id,
29647          label: title.rendered,
29648          url,
29649          type,
29650          kind: 'post-type'
29651        }, innerBlocks);
29652  
29653        if (!parent) {
29654          navigationLinks.push(linkMap[id]);
29655        } else {
29656          if (!linkMap[parent]) {
29657            // Use a placeholder if the child appears before parent in list.
29658            linkMap[parent] = {
29659              innerBlocks: []
29660            };
29661          }
29662  
29663          const parentLinkInnerBlocks = linkMap[parent].innerBlocks;
29664          parentLinkInnerBlocks.push(linkMap[id]);
29665        }
29666      }); // Transform all links with innerBlocks into Submenus. This can't be done
29667      // sooner because page objects have no information on their children.
29668  
29669      const transformSubmenus = listOfLinks => {
29670        listOfLinks.forEach((block, index, listOfLinksArray) => {
29671          const {
29672            attributes,
29673            innerBlocks
29674          } = block;
29675  
29676          if (innerBlocks.length !== 0) {
29677            transformSubmenus(innerBlocks);
29678            const transformedBlock = createBlock('core/navigation-submenu', attributes, innerBlocks);
29679            listOfLinksArray[index] = transformedBlock;
29680          }
29681        });
29682      };
29683  
29684      transformSubmenus(navigationLinks);
29685      replaceBlock(clientId, navigationLinks);
29686    };
29687  };
29688  function ConvertToLinksModal(_ref3) {
29689    let {
29690      onClose,
29691      clientId
29692    } = _ref3;
29693    const {
29694      records: pages,
29695      hasResolved: pagesFinished
29696    } = (0,external_wp_coreData_namespaceObject.__experimentalUseEntityRecords)('postType', 'page', {
29697      per_page: MAX_PAGE_COUNT,
29698      _fields: PAGE_FIELDS,
29699      // TODO: When https://core.trac.wordpress.org/ticket/39037 REST API support for multiple orderby
29700      // values is resolved, update 'orderby' to [ 'menu_order', 'post_title' ] to provide a consistent
29701      // sort.
29702      orderby: 'menu_order',
29703      order: 'asc'
29704    });
29705    const {
29706      replaceBlock
29707    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_blockEditor_namespaceObject.store);
29708    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Modal, {
29709      closeLabel: (0,external_wp_i18n_namespaceObject.__)('Close'),
29710      onRequestClose: onClose,
29711      title: (0,external_wp_i18n_namespaceObject.__)('Convert to links'),
29712      className: 'wp-block-page-list-modal',
29713      aria: {
29714        describedby: 'wp-block-page-list-modal__description'
29715      }
29716    }, (0,external_wp_element_namespaceObject.createElement)("p", {
29717      id: 'wp-block-page-list-modal__description'
29718    }, (0,external_wp_i18n_namespaceObject.__)('To edit this navigation menu, convert it to single page links. This allows you to add, re-order, remove items, or edit their labels.')), (0,external_wp_element_namespaceObject.createElement)("p", null, (0,external_wp_i18n_namespaceObject.__)("Note: if you add new pages to your site, you'll need to add them to your navigation menu.")), (0,external_wp_element_namespaceObject.createElement)("div", {
29719      className: "wp-block-page-list-modal-buttons"
29720    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
29721      variant: "tertiary",
29722      onClick: onClose
29723    }, (0,external_wp_i18n_namespaceObject.__)('Cancel')), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
29724      variant: "primary",
29725      disabled: !pagesFinished,
29726      onClick: convertSelectedBlockToNavigationLinks({
29727        pages,
29728        replaceBlock,
29729        clientId,
29730        createBlock: external_wp_blocks_namespaceObject.createBlock
29731      })
29732    }, (0,external_wp_i18n_namespaceObject.__)('Convert'))));
29733  }
29734  
29735  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/navigation-link/icons.js
29736  
29737  
29738  /**
29739   * WordPress dependencies
29740   */
29741  
29742  const icons_ItemSubmenuIcon = () => (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, {
29743    xmlns: "http://www.w3.org/2000/svg",
29744    width: "12",
29745    height: "12",
29746    viewBox: "0 0 12 12",
29747    fill: "none"
29748  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
29749    d: "M1.50002 4L6.00002 8L10.5 4",
29750    strokeWidth: "1.5"
29751  }));
29752  
29753  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/page-list/edit.js
29754  
29755  
29756  /**
29757   * External dependencies
29758   */
29759  
29760  
29761  /**
29762   * WordPress dependencies
29763   */
29764  
29765  
29766  
29767  
29768  
29769  
29770  
29771  /**
29772   * Internal dependencies
29773   */
29774  
29775  
29776   // We only show the edit option when page count is <= MAX_PAGE_COUNT
29777  // Performance of Navigation Links is not good past this value.
29778  
29779  const edit_MAX_PAGE_COUNT = 100;
29780  function PageListEdit(_ref) {
29781    var _context$style;
29782  
29783    let {
29784      context,
29785      clientId
29786    } = _ref;
29787    const {
29788      pagesByParentId,
29789      totalPages,
29790      hasResolvedPages
29791    } = usePageData();
29792    const isNavigationChild = ('showSubmenuIcon' in context);
29793    const allowConvertToLinks = isNavigationChild && totalPages <= edit_MAX_PAGE_COUNT;
29794    const [isOpen, setOpen] = (0,external_wp_element_namespaceObject.useState)(false);
29795  
29796    const openModal = () => setOpen(true);
29797  
29798    const closeModal = () => setOpen(false);
29799  
29800    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
29801      className: classnames_default()('wp-block-page-list', {
29802        'has-text-color': !!context.textColor,
29803        [(0,external_wp_blockEditor_namespaceObject.getColorClassName)('color', context.textColor)]: !!context.textColor,
29804        'has-background': !!context.backgroundColor,
29805        [(0,external_wp_blockEditor_namespaceObject.getColorClassName)('background-color', context.backgroundColor)]: !!context.backgroundColor
29806      }),
29807      style: { ...((_context$style = context.style) === null || _context$style === void 0 ? void 0 : _context$style.color)
29808      }
29809    });
29810    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, allowConvertToLinks && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, {
29811      group: "other"
29812    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, {
29813      title: (0,external_wp_i18n_namespaceObject.__)('Edit'),
29814      onClick: openModal
29815    }, (0,external_wp_i18n_namespaceObject.__)('Edit'))), allowConvertToLinks && isOpen && (0,external_wp_element_namespaceObject.createElement)(ConvertToLinksModal, {
29816      onClose: closeModal,
29817      clientId: clientId
29818    }), !hasResolvedPages && (0,external_wp_element_namespaceObject.createElement)("div", blockProps, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Spinner, null)), hasResolvedPages && totalPages === null && (0,external_wp_element_namespaceObject.createElement)("div", blockProps, (0,external_wp_element_namespaceObject.createElement)("div", blockProps, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Notice, {
29819      status: 'warning',
29820      isDismissible: false
29821    }, (0,external_wp_i18n_namespaceObject.__)('Page List: Cannot retrieve Pages.')))), totalPages === 0 && (0,external_wp_element_namespaceObject.createElement)("div", blockProps, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Notice, {
29822      status: 'info',
29823      isDismissible: false
29824    }, (0,external_wp_i18n_namespaceObject.__)('Page List: Cannot retrieve Pages.'))), totalPages > 0 && (0,external_wp_element_namespaceObject.createElement)("ul", blockProps, (0,external_wp_element_namespaceObject.createElement)(PageItems, {
29825      context: context,
29826      pagesByParentId: pagesByParentId
29827    })));
29828  }
29829  
29830  function useFrontPageId() {
29831    return (0,external_wp_data_namespaceObject.useSelect)(select => {
29832      const site = select(external_wp_coreData_namespaceObject.store).getEntityRecord('root', 'site');
29833      return (site === null || site === void 0 ? void 0 : site.show_on_front) === 'page' && (site === null || site === void 0 ? void 0 : site.page_on_front);
29834    }, []);
29835  }
29836  
29837  function usePageData() {
29838    const {
29839      records: pages,
29840      hasResolved: hasResolvedPages
29841    } = (0,external_wp_coreData_namespaceObject.__experimentalUseEntityRecords)('postType', 'page', {
29842      orderby: 'menu_order',
29843      order: 'asc',
29844      _fields: ['id', 'link', 'parent', 'title', 'menu_order'],
29845      per_page: -1
29846    });
29847    return (0,external_wp_element_namespaceObject.useMemo)(() => {
29848      var _pages$length;
29849  
29850      // TODO: Once the REST API supports passing multiple values to
29851      // 'orderby', this can be removed.
29852      // https://core.trac.wordpress.org/ticket/39037
29853      const sortedPages = (0,external_lodash_namespaceObject.sortBy)(pages, ['menu_order', 'title.rendered']);
29854      const pagesByParentId = sortedPages.reduce((accumulator, page) => {
29855        const {
29856          parent
29857        } = page;
29858  
29859        if (accumulator.has(parent)) {
29860          accumulator.get(parent).push(page);
29861        } else {
29862          accumulator.set(parent, [page]);
29863        }
29864  
29865        return accumulator;
29866      }, new Map());
29867      return {
29868        pagesByParentId,
29869        hasResolvedPages,
29870        totalPages: (_pages$length = pages === null || pages === void 0 ? void 0 : pages.length) !== null && _pages$length !== void 0 ? _pages$length : null
29871      };
29872    }, [pages, hasResolvedPages]);
29873  }
29874  
29875  const PageItems = (0,external_wp_element_namespaceObject.memo)(function PageItems(_ref2) {
29876    let {
29877      context,
29878      pagesByParentId,
29879      parentId = 0,
29880      depth = 0
29881    } = _ref2;
29882    const pages = pagesByParentId.get(parentId);
29883    const frontPageId = useFrontPageId();
29884  
29885    if (!(pages !== null && pages !== void 0 && pages.length)) {
29886      return [];
29887    }
29888  
29889    return pages.map(page => {
29890      var _page$title, _page$title2;
29891  
29892      const hasChildren = pagesByParentId.has(page.id);
29893      const isNavigationChild = ('showSubmenuIcon' in context);
29894      return (0,external_wp_element_namespaceObject.createElement)("li", {
29895        key: page.id,
29896        className: classnames_default()('wp-block-pages-list__item', {
29897          'has-child': hasChildren,
29898          'wp-block-navigation-item': isNavigationChild,
29899          'open-on-click': context.openSubmenusOnClick,
29900          'open-on-hover-click': !context.openSubmenusOnClick && context.showSubmenuIcon,
29901          'menu-item-home': page.id === frontPageId
29902        })
29903      }, hasChildren && context.openSubmenusOnClick ? (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)("button", {
29904        className: "wp-block-navigation-item__content wp-block-navigation-submenu__toggle",
29905        "aria-expanded": "false"
29906      }, (_page$title = page.title) === null || _page$title === void 0 ? void 0 : _page$title.rendered), (0,external_wp_element_namespaceObject.createElement)("span", {
29907        className: "wp-block-page-list__submenu-icon wp-block-navigation__submenu-icon"
29908      }, (0,external_wp_element_namespaceObject.createElement)(icons_ItemSubmenuIcon, null))) : (0,external_wp_element_namespaceObject.createElement)("a", {
29909        className: classnames_default()('wp-block-pages-list__item__link', {
29910          'wp-block-navigation-item__content': isNavigationChild
29911        }),
29912        href: page.link
29913      }, (_page$title2 = page.title) === null || _page$title2 === void 0 ? void 0 : _page$title2.rendered), hasChildren && (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, !context.openSubmenusOnClick && context.showSubmenuIcon && (0,external_wp_element_namespaceObject.createElement)("button", {
29914        className: "wp-block-navigation-item__content wp-block-navigation-submenu__toggle wp-block-page-list__submenu-icon wp-block-navigation__submenu-icon",
29915        "aria-expanded": "false"
29916      }, (0,external_wp_element_namespaceObject.createElement)(icons_ItemSubmenuIcon, null)), (0,external_wp_element_namespaceObject.createElement)("ul", {
29917        className: classnames_default()('submenu-container', {
29918          'wp-block-navigation__submenu-container': isNavigationChild
29919        })
29920      }, (0,external_wp_element_namespaceObject.createElement)(PageItems, {
29921        context: context,
29922        pagesByParentId: pagesByParentId,
29923        parentId: page.id,
29924        depth: depth + 1
29925      }))));
29926    });
29927  });
29928  
29929  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/page-list/index.js
29930  /**
29931   * WordPress dependencies
29932   */
29933  
29934  /**
29935   * Internal dependencies
29936   */
29937  
29938  const page_list_metadata = {
29939    $schema: "https://schemas.wp.org/trunk/block.json",
29940    apiVersion: 2,
29941    name: "core/page-list",
29942    title: "Page List",
29943    category: "widgets",
29944    description: "Display a list of all pages.",
29945    keywords: ["menu", "navigation"],
29946    textdomain: "default",
29947    attributes: {
29948      __unstableMaxPages: {
29949        type: "number"
29950      }
29951    },
29952    usesContext: ["textColor", "customTextColor", "backgroundColor", "customBackgroundColor", "overlayTextColor", "customOverlayTextColor", "overlayBackgroundColor", "customOverlayBackgroundColor", "fontSize", "customFontSize", "showSubmenuIcon", "style", "openSubmenusOnClick"],
29953    supports: {
29954      reusable: false,
29955      html: false
29956    },
29957    editorStyle: "wp-block-page-list-editor",
29958    style: "wp-block-page-list"
29959  };
29960  
29961  const {
29962    name: page_list_name
29963  } = page_list_metadata;
29964  
29965  const page_list_settings = {
29966    icon: library_pages,
29967    example: {},
29968    edit: PageListEdit
29969  };
29970  
29971  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/paragraph.js
29972  
29973  
29974  /**
29975   * WordPress dependencies
29976   */
29977  
29978  const paragraph = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
29979    xmlns: "http://www.w3.org/2000/svg",
29980    viewBox: "0 0 24 24"
29981  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
29982    d: "M18.3 4H9.9v-.1l-.9.2c-2.3.4-4 2.4-4 4.8s1.7 4.4 4 4.8l.7.1V20h1.5V5.5h2.9V20h1.5V5.5h2.7V4z"
29983  }));
29984  /* harmony default export */ var library_paragraph = (paragraph);
29985  
29986  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/paragraph/deprecated.js
29987  
29988  
29989  /**
29990   * External dependencies
29991   */
29992  
29993  
29994  /**
29995   * WordPress dependencies
29996   */
29997  
29998  
29999  
30000  const supports = {
30001    className: false
30002  };
30003  const paragraph_deprecated_blockAttributes = {
30004    align: {
30005      type: 'string'
30006    },
30007    content: {
30008      type: 'string',
30009      source: 'html',
30010      selector: 'p',
30011      default: ''
30012    },
30013    dropCap: {
30014      type: 'boolean',
30015      default: false
30016    },
30017    placeholder: {
30018      type: 'string'
30019    },
30020    textColor: {
30021      type: 'string'
30022    },
30023    backgroundColor: {
30024      type: 'string'
30025    },
30026    fontSize: {
30027      type: 'string'
30028    },
30029    direction: {
30030      type: 'string',
30031      enum: ['ltr', 'rtl']
30032    },
30033    style: {
30034      type: 'object'
30035    }
30036  };
30037  
30038  const migrateCustomColorsAndFontSizes = attributes => {
30039    if (!attributes.customTextColor && !attributes.customBackgroundColor && !attributes.customFontSize) {
30040      return attributes;
30041    }
30042  
30043    const style = {};
30044  
30045    if (attributes.customTextColor || attributes.customBackgroundColor) {
30046      style.color = {};
30047    }
30048  
30049    if (attributes.customTextColor) {
30050      style.color.text = attributes.customTextColor;
30051    }
30052  
30053    if (attributes.customBackgroundColor) {
30054      style.color.background = attributes.customBackgroundColor;
30055    }
30056  
30057    if (attributes.customFontSize) {
30058      style.typography = {
30059        fontSize: attributes.customFontSize
30060      };
30061    }
30062  
30063    return { ...(0,external_lodash_namespaceObject.omit)(attributes, ['customTextColor', 'customBackgroundColor', 'customFontSize']),
30064      style
30065    };
30066  };
30067  
30068  const paragraph_deprecated_deprecated = [{
30069    supports,
30070    attributes: { ...(0,external_lodash_namespaceObject.omit)(paragraph_deprecated_blockAttributes, ['style']),
30071      customTextColor: {
30072        type: 'string'
30073      },
30074      customBackgroundColor: {
30075        type: 'string'
30076      },
30077      customFontSize: {
30078        type: 'number'
30079      }
30080    },
30081    migrate: migrateCustomColorsAndFontSizes,
30082  
30083    save(_ref) {
30084      let {
30085        attributes
30086      } = _ref;
30087      const {
30088        align,
30089        content,
30090        dropCap,
30091        backgroundColor,
30092        textColor,
30093        customBackgroundColor,
30094        customTextColor,
30095        fontSize,
30096        customFontSize,
30097        direction
30098      } = attributes;
30099      const textClass = (0,external_wp_blockEditor_namespaceObject.getColorClassName)('color', textColor);
30100      const backgroundClass = (0,external_wp_blockEditor_namespaceObject.getColorClassName)('background-color', backgroundColor);
30101      const fontSizeClass = (0,external_wp_blockEditor_namespaceObject.getFontSizeClass)(fontSize);
30102      const className = classnames_default()({
30103        'has-text-color': textColor || customTextColor,
30104        'has-background': backgroundColor || customBackgroundColor,
30105        'has-drop-cap': dropCap,
30106        [`has-text-align-$align}`]: align,
30107        [fontSizeClass]: fontSizeClass,
30108        [textClass]: textClass,
30109        [backgroundClass]: backgroundClass
30110      });
30111      const styles = {
30112        backgroundColor: backgroundClass ? undefined : customBackgroundColor,
30113        color: textClass ? undefined : customTextColor,
30114        fontSize: fontSizeClass ? undefined : customFontSize
30115      };
30116      return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
30117        tagName: "p",
30118        style: styles,
30119        className: className ? className : undefined,
30120        value: content,
30121        dir: direction
30122      });
30123    }
30124  
30125  }, {
30126    supports,
30127    attributes: { ...(0,external_lodash_namespaceObject.omit)(paragraph_deprecated_blockAttributes, ['style']),
30128      customTextColor: {
30129        type: 'string'
30130      },
30131      customBackgroundColor: {
30132        type: 'string'
30133      },
30134      customFontSize: {
30135        type: 'number'
30136      }
30137    },
30138    migrate: migrateCustomColorsAndFontSizes,
30139  
30140    save(_ref2) {
30141      let {
30142        attributes
30143      } = _ref2;
30144      const {
30145        align,
30146        content,
30147        dropCap,
30148        backgroundColor,
30149        textColor,
30150        customBackgroundColor,
30151        customTextColor,
30152        fontSize,
30153        customFontSize,
30154        direction
30155      } = attributes;
30156      const textClass = (0,external_wp_blockEditor_namespaceObject.getColorClassName)('color', textColor);
30157      const backgroundClass = (0,external_wp_blockEditor_namespaceObject.getColorClassName)('background-color', backgroundColor);
30158      const fontSizeClass = (0,external_wp_blockEditor_namespaceObject.getFontSizeClass)(fontSize);
30159      const className = classnames_default()({
30160        'has-text-color': textColor || customTextColor,
30161        'has-background': backgroundColor || customBackgroundColor,
30162        'has-drop-cap': dropCap,
30163        [fontSizeClass]: fontSizeClass,
30164        [textClass]: textClass,
30165        [backgroundClass]: backgroundClass
30166      });
30167      const styles = {
30168        backgroundColor: backgroundClass ? undefined : customBackgroundColor,
30169        color: textClass ? undefined : customTextColor,
30170        fontSize: fontSizeClass ? undefined : customFontSize,
30171        textAlign: align
30172      };
30173      return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
30174        tagName: "p",
30175        style: styles,
30176        className: className ? className : undefined,
30177        value: content,
30178        dir: direction
30179      });
30180    }
30181  
30182  }, {
30183    supports,
30184    attributes: { ...(0,external_lodash_namespaceObject.omit)(paragraph_deprecated_blockAttributes, ['style']),
30185      customTextColor: {
30186        type: 'string'
30187      },
30188      customBackgroundColor: {
30189        type: 'string'
30190      },
30191      customFontSize: {
30192        type: 'number'
30193      },
30194      width: {
30195        type: 'string'
30196      }
30197    },
30198    migrate: migrateCustomColorsAndFontSizes,
30199  
30200    save(_ref3) {
30201      let {
30202        attributes
30203      } = _ref3;
30204      const {
30205        width,
30206        align,
30207        content,
30208        dropCap,
30209        backgroundColor,
30210        textColor,
30211        customBackgroundColor,
30212        customTextColor,
30213        fontSize,
30214        customFontSize
30215      } = attributes;
30216      const textClass = (0,external_wp_blockEditor_namespaceObject.getColorClassName)('color', textColor);
30217      const backgroundClass = (0,external_wp_blockEditor_namespaceObject.getColorClassName)('background-color', backgroundColor);
30218      const fontSizeClass = fontSize && `is-$fontSize}-text`;
30219      const className = classnames_default()({
30220        [`align$width}`]: width,
30221        'has-background': backgroundColor || customBackgroundColor,
30222        'has-drop-cap': dropCap,
30223        [fontSizeClass]: fontSizeClass,
30224        [textClass]: textClass,
30225        [backgroundClass]: backgroundClass
30226      });
30227      const styles = {
30228        backgroundColor: backgroundClass ? undefined : customBackgroundColor,
30229        color: textClass ? undefined : customTextColor,
30230        fontSize: fontSizeClass ? undefined : customFontSize,
30231        textAlign: align
30232      };
30233      return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
30234        tagName: "p",
30235        style: styles,
30236        className: className ? className : undefined,
30237        value: content
30238      });
30239    }
30240  
30241  }, {
30242    supports,
30243    attributes: (0,external_lodash_namespaceObject.omit)({ ...paragraph_deprecated_blockAttributes,
30244      fontSize: {
30245        type: 'number'
30246      }
30247    }, ['style']),
30248  
30249    save(_ref4) {
30250      let {
30251        attributes
30252      } = _ref4;
30253      const {
30254        width,
30255        align,
30256        content,
30257        dropCap,
30258        backgroundColor,
30259        textColor,
30260        fontSize
30261      } = attributes;
30262      const className = classnames_default()({
30263        [`align$width}`]: width,
30264        'has-background': backgroundColor,
30265        'has-drop-cap': dropCap
30266      });
30267      const styles = {
30268        backgroundColor,
30269        color: textColor,
30270        fontSize,
30271        textAlign: align
30272      };
30273      return (0,external_wp_element_namespaceObject.createElement)("p", {
30274        style: styles,
30275        className: className ? className : undefined
30276      }, content);
30277    },
30278  
30279    migrate(attributes) {
30280      return migrateCustomColorsAndFontSizes((0,external_lodash_namespaceObject.omit)({ ...attributes,
30281        customFontSize: (0,external_lodash_namespaceObject.isFinite)(attributes.fontSize) ? attributes.fontSize : undefined,
30282        customTextColor: attributes.textColor && '#' === attributes.textColor[0] ? attributes.textColor : undefined,
30283        customBackgroundColor: attributes.backgroundColor && '#' === attributes.backgroundColor[0] ? attributes.backgroundColor : undefined
30284      }), ['fontSize', 'textColor', 'backgroundColor', 'style']);
30285    }
30286  
30287  }, {
30288    supports,
30289    attributes: { ...paragraph_deprecated_blockAttributes,
30290      content: {
30291        type: 'string',
30292        source: 'html',
30293        default: ''
30294      }
30295    },
30296  
30297    save(_ref5) {
30298      let {
30299        attributes
30300      } = _ref5;
30301      return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.RawHTML, null, attributes.content);
30302    },
30303  
30304    migrate(attributes) {
30305      return attributes;
30306    }
30307  
30308  }];
30309  /* harmony default export */ var paragraph_deprecated = (paragraph_deprecated_deprecated);
30310  
30311  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/format-ltr.js
30312  
30313  
30314  /**
30315   * WordPress dependencies
30316   */
30317  
30318  const formatLtr = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
30319    xmlns: "http://www.w3.org/2000/svg",
30320    viewBox: "-2 -2 24 24"
30321  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
30322    d: "M5.52 2h7.43c.55 0 1 .45 1 1s-.45 1-1 1h-1v13c0 .55-.45 1-1 1s-1-.45-1-1V5c0-.55-.45-1-1-1s-1 .45-1 1v12c0 .55-.45 1-1 1s-1-.45-1-1v-5.96h-.43C3.02 11.04 1 9.02 1 6.52S3.02 2 5.52 2zM14 14l5-4-5-4v8z"
30323  }));
30324  /* harmony default export */ var format_ltr = (formatLtr);
30325  
30326  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/paragraph/edit.js
30327  
30328  
30329  
30330  /**
30331   * External dependencies
30332   */
30333  
30334  /**
30335   * WordPress dependencies
30336   */
30337  
30338  
30339  
30340  
30341  
30342  
30343  const paragraph_edit_name = 'core/paragraph';
30344  
30345  function ParagraphRTLControl(_ref) {
30346    let {
30347      direction,
30348      setDirection
30349    } = _ref;
30350    return (0,external_wp_i18n_namespaceObject.isRTL)() && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarDropdownMenu, {
30351      controls: [{
30352        icon: format_ltr,
30353        title: (0,external_wp_i18n_namespaceObject._x)('Left to right', 'editor button'),
30354        isActive: direction === 'ltr',
30355  
30356        onClick() {
30357          setDirection(direction === 'ltr' ? undefined : 'ltr');
30358        }
30359  
30360      }]
30361    });
30362  }
30363  
30364  function ParagraphBlock(_ref2) {
30365    let {
30366      attributes,
30367      mergeBlocks,
30368      onReplace,
30369      onRemove,
30370      setAttributes,
30371      clientId
30372    } = _ref2;
30373    const {
30374      align,
30375      content,
30376      direction,
30377      dropCap,
30378      placeholder
30379    } = attributes;
30380    const isDropCapFeatureEnabled = (0,external_wp_blockEditor_namespaceObject.useSetting)('typography.dropCap');
30381    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
30382      className: classnames_default()({
30383        'has-drop-cap': dropCap,
30384        [`has-text-align-$align}`]: align
30385      }),
30386      style: {
30387        direction
30388      }
30389    });
30390    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, {
30391      group: "block"
30392    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.AlignmentControl, {
30393      value: align,
30394      onChange: newAlign => setAttributes({
30395        align: newAlign
30396      })
30397    }), (0,external_wp_element_namespaceObject.createElement)(ParagraphRTLControl, {
30398      direction: direction,
30399      setDirection: newDirection => setAttributes({
30400        direction: newDirection
30401      })
30402    })), isDropCapFeatureEnabled && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, {
30403      __experimentalGroup: "typography"
30404    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalToolsPanelItem, {
30405      hasValue: () => !!dropCap,
30406      label: (0,external_wp_i18n_namespaceObject.__)('Drop cap'),
30407      onDeselect: () => setAttributes({
30408        dropCap: undefined
30409      }),
30410      resetAllFilter: () => ({
30411        dropCap: undefined
30412      }),
30413      panelId: clientId
30414    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
30415      label: (0,external_wp_i18n_namespaceObject.__)('Drop cap'),
30416      checked: !!dropCap,
30417      onChange: () => setAttributes({
30418        dropCap: !dropCap
30419      }),
30420      help: dropCap ? (0,external_wp_i18n_namespaceObject.__)('Showing large initial letter.') : (0,external_wp_i18n_namespaceObject.__)('Toggle to show a large initial letter.')
30421    }))), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText, _extends({
30422      identifier: "content",
30423      tagName: "p"
30424    }, blockProps, {
30425      value: content,
30426      onChange: newContent => setAttributes({
30427        content: newContent
30428      }),
30429      onSplit: (value, isOriginal) => {
30430        let newAttributes;
30431  
30432        if (isOriginal || value) {
30433          newAttributes = { ...attributes,
30434            content: value
30435          };
30436        }
30437  
30438        const block = (0,external_wp_blocks_namespaceObject.createBlock)(paragraph_edit_name, newAttributes);
30439  
30440        if (isOriginal) {
30441          block.clientId = clientId;
30442        }
30443  
30444        return block;
30445      },
30446      onMerge: mergeBlocks,
30447      onReplace: onReplace,
30448      onRemove: onRemove,
30449      "aria-label": content ? (0,external_wp_i18n_namespaceObject.__)('Paragraph block') : (0,external_wp_i18n_namespaceObject.__)('Empty block; start writing or type forward slash to choose a block'),
30450      "data-empty": content ? false : true,
30451      placeholder: placeholder || (0,external_wp_i18n_namespaceObject.__)('Type / to choose a block'),
30452      __unstableEmbedURLOnPaste: true,
30453      __unstableAllowPrefixTransformations: true
30454    })));
30455  }
30456  
30457  /* harmony default export */ var paragraph_edit = (ParagraphBlock);
30458  
30459  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/paragraph/save.js
30460  
30461  
30462  /**
30463   * External dependencies
30464   */
30465  
30466  /**
30467   * WordPress dependencies
30468   */
30469  
30470  
30471  function paragraph_save_save(_ref) {
30472    let {
30473      attributes
30474    } = _ref;
30475    const {
30476      align,
30477      content,
30478      dropCap,
30479      direction
30480    } = attributes;
30481    const className = classnames_default()({
30482      'has-drop-cap': dropCap,
30483      [`has-text-align-$align}`]: align
30484    });
30485    return (0,external_wp_element_namespaceObject.createElement)("p", external_wp_blockEditor_namespaceObject.useBlockProps.save({
30486      className,
30487      dir: direction
30488    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
30489      value: content
30490    }));
30491  }
30492  
30493  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/paragraph/transforms.js
30494  /**
30495   * WordPress dependencies
30496   */
30497  
30498  /**
30499   * Internal dependencies
30500   */
30501  
30502  const {
30503    name: paragraph_transforms_name
30504  } = {
30505    $schema: "https://schemas.wp.org/trunk/block.json",
30506    apiVersion: 2,
30507    name: "core/paragraph",
30508    title: "Paragraph",
30509    category: "text",
30510    description: "Start with the basic building block of all narrative.",
30511    keywords: ["text"],
30512    textdomain: "default",
30513    attributes: {
30514      align: {
30515        type: "string"
30516      },
30517      content: {
30518        type: "string",
30519        source: "html",
30520        selector: "p",
30521        "default": "",
30522        __experimentalRole: "content"
30523      },
30524      dropCap: {
30525        type: "boolean",
30526        "default": false
30527      },
30528      placeholder: {
30529        type: "string"
30530      },
30531      direction: {
30532        type: "string",
30533        "enum": ["ltr", "rtl"]
30534      }
30535    },
30536    supports: {
30537      anchor: true,
30538      className: false,
30539      color: {
30540        link: true,
30541        __experimentalDefaultControls: {
30542          background: true,
30543          text: true
30544        }
30545      },
30546      typography: {
30547        fontSize: true,
30548        lineHeight: true,
30549        __experimentalFontStyle: true,
30550        __experimentalFontWeight: true,
30551        __experimentalLetterSpacing: true,
30552        __experimentalTextTransform: true,
30553        __experimentalDefaultControls: {
30554          fontSize: true
30555        }
30556      },
30557      __experimentalSelector: "p",
30558      __unstablePasteTextInline: true
30559    },
30560    editorStyle: "wp-block-paragraph-editor",
30561    style: "wp-block-paragraph"
30562  };
30563  const paragraph_transforms_transforms = {
30564    from: [{
30565      type: 'raw',
30566      // Paragraph is a fallback and should be matched last.
30567      priority: 20,
30568      selector: 'p',
30569      schema: _ref => {
30570        let {
30571          phrasingContentSchema,
30572          isPaste
30573        } = _ref;
30574        return {
30575          p: {
30576            children: phrasingContentSchema,
30577            attributes: isPaste ? [] : ['style', 'id']
30578          }
30579        };
30580      },
30581  
30582      transform(node) {
30583        const attributes = (0,external_wp_blocks_namespaceObject.getBlockAttributes)(paragraph_transforms_name, node.outerHTML);
30584        const {
30585          textAlign
30586        } = node.style || {};
30587  
30588        if (textAlign === 'left' || textAlign === 'center' || textAlign === 'right') {
30589          attributes.align = textAlign;
30590        }
30591  
30592        return (0,external_wp_blocks_namespaceObject.createBlock)(paragraph_transforms_name, attributes);
30593      }
30594  
30595    }]
30596  };
30597  /* harmony default export */ var paragraph_transforms = (paragraph_transforms_transforms);
30598  
30599  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/paragraph/index.js
30600  /**
30601   * External dependencies
30602   */
30603  
30604  /**
30605   * WordPress dependencies
30606   */
30607  
30608  
30609  
30610  /**
30611   * Internal dependencies
30612   */
30613  
30614  
30615  
30616  const paragraph_metadata = {
30617    $schema: "https://schemas.wp.org/trunk/block.json",
30618    apiVersion: 2,
30619    name: "core/paragraph",
30620    title: "Paragraph",
30621    category: "text",
30622    description: "Start with the basic building block of all narrative.",
30623    keywords: ["text"],
30624    textdomain: "default",
30625    attributes: {
30626      align: {
30627        type: "string"
30628      },
30629      content: {
30630        type: "string",
30631        source: "html",
30632        selector: "p",
30633        "default": "",
30634        __experimentalRole: "content"
30635      },
30636      dropCap: {
30637        type: "boolean",
30638        "default": false
30639      },
30640      placeholder: {
30641        type: "string"
30642      },
30643      direction: {
30644        type: "string",
30645        "enum": ["ltr", "rtl"]
30646      }
30647    },
30648    supports: {
30649      anchor: true,
30650      className: false,
30651      color: {
30652        link: true,
30653        __experimentalDefaultControls: {
30654          background: true,
30655          text: true
30656        }
30657      },
30658      typography: {
30659        fontSize: true,
30660        lineHeight: true,
30661        __experimentalFontStyle: true,
30662        __experimentalFontWeight: true,
30663        __experimentalLetterSpacing: true,
30664        __experimentalTextTransform: true,
30665        __experimentalDefaultControls: {
30666          fontSize: true
30667        }
30668      },
30669      __experimentalSelector: "p",
30670      __unstablePasteTextInline: true
30671    },
30672    editorStyle: "wp-block-paragraph-editor",
30673    style: "wp-block-paragraph"
30674  };
30675  
30676  
30677  const {
30678    name: paragraph_name
30679  } = paragraph_metadata;
30680  
30681  const paragraph_settings = {
30682    icon: library_paragraph,
30683    example: {
30684      attributes: {
30685        content: (0,external_wp_i18n_namespaceObject.__)('In a village of La Mancha, the name of which I have no desire to call to mind, there lived not long since one of those gentlemen that keep a lance in the lance-rack, an old buckler, a lean hack, and a greyhound for coursing.'),
30686        style: {
30687          typography: {
30688            fontSize: 28
30689          }
30690        },
30691        dropCap: true
30692      }
30693    },
30694  
30695    __experimentalLabel(attributes, _ref) {
30696      let {
30697        context
30698      } = _ref;
30699  
30700      if (context === 'accessibility') {
30701        const {
30702          content
30703        } = attributes;
30704        return (0,external_lodash_namespaceObject.isEmpty)(content) ? (0,external_wp_i18n_namespaceObject.__)('Empty') : content;
30705      }
30706    },
30707  
30708    transforms: paragraph_transforms,
30709    deprecated: paragraph_deprecated,
30710  
30711    merge(attributes, attributesToMerge) {
30712      return {
30713        content: (attributes.content || '') + (attributesToMerge.content || '')
30714      };
30715    },
30716  
30717    edit: paragraph_edit,
30718    save: paragraph_save_save
30719  };
30720  
30721  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/post-author/edit.js
30722  
30723  
30724  /**
30725   * External dependencies
30726   */
30727  
30728  
30729  /**
30730   * WordPress dependencies
30731   */
30732  
30733  
30734  
30735  
30736  
30737  
30738  
30739  function PostAuthorEdit(_ref) {
30740    let {
30741      isSelected,
30742      context: {
30743        postType,
30744        postId,
30745        queryId
30746      },
30747      attributes,
30748      setAttributes
30749    } = _ref;
30750    const isDescendentOfQueryLoop = Number.isFinite(queryId);
30751    const {
30752      authorId,
30753      authorDetails,
30754      authors
30755    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
30756      var _getEditedEntityRecor;
30757  
30758      const {
30759        getEditedEntityRecord,
30760        getUser,
30761        getUsers
30762      } = select(external_wp_coreData_namespaceObject.store);
30763  
30764      const _authorId = (_getEditedEntityRecor = getEditedEntityRecord('postType', postType, postId)) === null || _getEditedEntityRecor === void 0 ? void 0 : _getEditedEntityRecor.author;
30765  
30766      return {
30767        authorId: _authorId,
30768        authorDetails: _authorId ? getUser(_authorId) : null,
30769        authors: getUsers({
30770          who: 'authors'
30771        })
30772      };
30773    }, [postType, postId]);
30774    const {
30775      editEntityRecord
30776    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_coreData_namespaceObject.store);
30777    const {
30778      textAlign,
30779      showAvatar,
30780      showBio,
30781      byline
30782    } = attributes;
30783    const avatarSizes = [];
30784  
30785    if (authorDetails) {
30786      (0,external_lodash_namespaceObject.forEach)(authorDetails.avatar_urls, (url, size) => {
30787        avatarSizes.push({
30788          value: size,
30789          label: `$size} x $size}`
30790        });
30791      });
30792    }
30793  
30794    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
30795      className: classnames_default()({
30796        [`has-text-align-$textAlign}`]: textAlign
30797      })
30798    });
30799    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
30800      title: (0,external_wp_i18n_namespaceObject.__)('Author Settings')
30801    }, !isDescendentOfQueryLoop && !!(authors !== null && authors !== void 0 && authors.length) && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SelectControl, {
30802      label: (0,external_wp_i18n_namespaceObject.__)('Author'),
30803      value: authorId,
30804      options: authors.map(_ref2 => {
30805        let {
30806          id,
30807          name
30808        } = _ref2;
30809        return {
30810          value: id,
30811          label: name
30812        };
30813      }),
30814      onChange: nextAuthorId => {
30815        editEntityRecord('postType', postType, postId, {
30816          author: nextAuthorId
30817        });
30818      }
30819    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
30820      label: (0,external_wp_i18n_namespaceObject.__)('Show avatar'),
30821      checked: showAvatar,
30822      onChange: () => setAttributes({
30823        showAvatar: !showAvatar
30824      })
30825    }), showAvatar && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SelectControl, {
30826      label: (0,external_wp_i18n_namespaceObject.__)('Avatar size'),
30827      value: attributes.avatarSize,
30828      options: avatarSizes,
30829      onChange: size => {
30830        setAttributes({
30831          avatarSize: Number(size)
30832        });
30833      }
30834    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
30835      label: (0,external_wp_i18n_namespaceObject.__)('Show bio'),
30836      checked: showBio,
30837      onChange: () => setAttributes({
30838        showBio: !showBio
30839      })
30840    }))), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, {
30841      group: "block"
30842    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.AlignmentControl, {
30843      value: textAlign,
30844      onChange: nextAlign => {
30845        setAttributes({
30846          textAlign: nextAlign
30847        });
30848      }
30849    })), (0,external_wp_element_namespaceObject.createElement)("div", blockProps, showAvatar && authorDetails && (0,external_wp_element_namespaceObject.createElement)("div", {
30850      className: "wp-block-post-author__avatar"
30851    }, (0,external_wp_element_namespaceObject.createElement)("img", {
30852      width: attributes.avatarSize,
30853      src: authorDetails.avatar_urls[attributes.avatarSize],
30854      alt: authorDetails.name
30855    })), (0,external_wp_element_namespaceObject.createElement)("div", {
30856      className: "wp-block-post-author__content"
30857    }, (!external_wp_blockEditor_namespaceObject.RichText.isEmpty(byline) || isSelected) && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText, {
30858      className: "wp-block-post-author__byline",
30859      multiline: false,
30860      "aria-label": (0,external_wp_i18n_namespaceObject.__)('Post author byline text'),
30861      placeholder: (0,external_wp_i18n_namespaceObject.__)('Write byline…'),
30862      value: byline,
30863      onChange: value => setAttributes({
30864        byline: value
30865      })
30866    }), (0,external_wp_element_namespaceObject.createElement)("p", {
30867      className: "wp-block-post-author__name"
30868    }, (authorDetails === null || authorDetails === void 0 ? void 0 : authorDetails.name) || (0,external_wp_i18n_namespaceObject.__)('Post Author')), showBio && (0,external_wp_element_namespaceObject.createElement)("p", {
30869      className: "wp-block-post-author__bio"
30870    }, authorDetails === null || authorDetails === void 0 ? void 0 : authorDetails.description))));
30871  }
30872  
30873  /* harmony default export */ var post_author_edit = (PostAuthorEdit);
30874  
30875  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/post-author.js
30876  
30877  
30878  /**
30879   * WordPress dependencies
30880   */
30881  
30882  const postAuthor = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
30883    viewBox: "0 0 24 24",
30884    xmlns: "http://www.w3.org/2000/svg"
30885  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
30886    d: "M10 4.5a1 1 0 11-2 0 1 1 0 012 0zm1.5 0a2.5 2.5 0 11-5 0 2.5 2.5 0 015 0zm2.25 7.5v-1A2.75 2.75 0 0011 8.25H7A2.75 2.75 0 004.25 11v1h1.5v-1c0-.69.56-1.25 1.25-1.25h4c.69 0 1.25.56 1.25 1.25v1h1.5zM4 20h9v-1.5H4V20zm16-4H4v-1.5h16V16z",
30887    fillRule: "evenodd",
30888    clipRule: "evenodd"
30889  }));
30890  /* harmony default export */ var post_author = (postAuthor);
30891  
30892  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/post-author/index.js
30893  /**
30894   * Internal dependencies
30895   */
30896  const post_author_metadata = {
30897    $schema: "https://schemas.wp.org/trunk/block.json",
30898    apiVersion: 2,
30899    name: "core/post-author",
30900    title: "Post Author",
30901    category: "theme",
30902    description: "Display post author details such as name, avatar, and bio.",
30903    textdomain: "default",
30904    attributes: {
30905      textAlign: {
30906        type: "string"
30907      },
30908      avatarSize: {
30909        type: "number",
30910        "default": 48
30911      },
30912      showAvatar: {
30913        type: "boolean",
30914        "default": true
30915      },
30916      showBio: {
30917        type: "boolean"
30918      },
30919      byline: {
30920        type: "string"
30921      }
30922    },
30923    usesContext: ["postType", "postId", "queryId"],
30924    supports: {
30925      html: false,
30926      spacing: {
30927        margin: true,
30928        padding: true
30929      },
30930      typography: {
30931        fontSize: true,
30932        lineHeight: true,
30933        __experimentalFontStyle: true,
30934        __experimentalFontWeight: true,
30935        __experimentalLetterSpacing: true,
30936        __experimentalTextTransform: true,
30937        __experimentalDefaultControls: {
30938          fontSize: true
30939        }
30940      },
30941      color: {
30942        gradients: true,
30943        link: true,
30944        __experimentalDuotone: ".wp-block-post-author__avatar img",
30945        __experimentalDefaultControls: {
30946          background: true,
30947          text: true
30948        }
30949      }
30950    },
30951    editorStyle: "wp-block-post-author-editor",
30952    style: "wp-block-post-author"
30953  };
30954  
30955  /**
30956   * WordPress dependencies
30957   */
30958  
30959  
30960  const {
30961    name: post_author_name
30962  } = post_author_metadata;
30963  
30964  const post_author_settings = {
30965    icon: post_author,
30966    edit: post_author_edit
30967  };
30968  
30969  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/post-author-biography/edit.js
30970  
30971  
30972  /**
30973   * External dependencies
30974   */
30975  
30976  /**
30977   * WordPress dependencies
30978   */
30979  
30980  
30981  
30982  
30983  
30984  
30985  function PostAuthorBiographyEdit(_ref) {
30986    let {
30987      context: {
30988        postType,
30989        postId
30990      },
30991      attributes: {
30992        textAlign
30993      },
30994      setAttributes
30995    } = _ref;
30996    const {
30997      authorDetails
30998    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
30999      var _getEditedEntityRecor;
31000  
31001      const {
31002        getEditedEntityRecord,
31003        getUser
31004      } = select(external_wp_coreData_namespaceObject.store);
31005  
31006      const _authorId = (_getEditedEntityRecor = getEditedEntityRecord('postType', postType, postId)) === null || _getEditedEntityRecor === void 0 ? void 0 : _getEditedEntityRecor.author;
31007  
31008      return {
31009        authorDetails: _authorId ? getUser(_authorId) : null
31010      };
31011    }, [postType, postId]);
31012    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
31013      className: classnames_default()({
31014        [`has-text-align-$textAlign}`]: textAlign
31015      })
31016    });
31017  
31018    const displayAuthorBiography = (authorDetails === null || authorDetails === void 0 ? void 0 : authorDetails.description) || (0,external_wp_i18n_namespaceObject.__)('Author Biography');
31019  
31020    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, {
31021      group: "block"
31022    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.AlignmentControl, {
31023      value: textAlign,
31024      onChange: nextAlign => {
31025        setAttributes({
31026          textAlign: nextAlign
31027        });
31028      }
31029    })), (0,external_wp_element_namespaceObject.createElement)("div", blockProps, " ", displayAuthorBiography, " "));
31030  }
31031  
31032  /* harmony default export */ var post_author_biography_edit = (PostAuthorBiographyEdit);
31033  
31034  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/post-author-biography/index.js
31035  /**
31036   * Internal dependencies
31037   */
31038  const post_author_biography_metadata = {
31039    $schema: "https://schemas.wp.org/trunk/block.json",
31040    apiVersion: 2,
31041    name: "core/post-author-biography",
31042    title: "Post Author Biography",
31043    category: "theme",
31044    description: "The author biography.",
31045    textdomain: "default",
31046    attributes: {
31047      textAlign: {
31048        type: "string"
31049      }
31050    },
31051    usesContext: ["postType", "postId"],
31052    supports: {
31053      spacing: {
31054        margin: true,
31055        padding: true
31056      },
31057      color: {
31058        gradients: true,
31059        link: true,
31060        __experimentalDefaultControls: {
31061          background: true,
31062          text: true
31063        }
31064      },
31065      typography: {
31066        fontSize: true,
31067        lineHeight: true,
31068        __experimentalFontFamily: true,
31069        __experimentalFontWeight: true,
31070        __experimentalFontStyle: true,
31071        __experimentalTextTransform: true,
31072        __experimentalLetterSpacing: true,
31073        __experimentalDefaultControls: {
31074          fontSize: true
31075        }
31076      }
31077    }
31078  };
31079  
31080  /**
31081   * WordPress dependencies
31082   */
31083  
31084  
31085  const {
31086    name: post_author_biography_name
31087  } = post_author_biography_metadata;
31088  
31089  const post_author_biography_settings = {
31090    icon: post_author,
31091    edit: post_author_biography_edit
31092  };
31093  
31094  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/post-comments/edit.js
31095  
31096  
31097  /**
31098   * External dependencies
31099   */
31100  
31101  /**
31102   * WordPress dependencies
31103   */
31104  
31105  
31106  
31107  
31108  
31109  
31110  function PostCommentsEdit(_ref) {
31111    let {
31112      attributes: {
31113        textAlign
31114      },
31115      setAttributes,
31116      context: {
31117        postType,
31118        postId
31119      }
31120    } = _ref;
31121    let [postTitle] = (0,external_wp_coreData_namespaceObject.useEntityProp)('postType', postType, 'title', postId);
31122    postTitle = postTitle || (0,external_wp_i18n_namespaceObject.__)('Post Title');
31123    const [commentStatus] = (0,external_wp_coreData_namespaceObject.useEntityProp)('postType', postType, 'comment_status', postId);
31124    const {
31125      avatarURL,
31126      defaultCommentStatus
31127    } = (0,external_wp_data_namespaceObject.useSelect)(select => select(external_wp_blockEditor_namespaceObject.store).getSettings().__experimentalDiscussionSettings);
31128    const isSiteEditor = postType === undefined || postId === undefined;
31129    const postTypeSupportsComments = (0,external_wp_data_namespaceObject.useSelect)(select => {
31130      var _select$getPostType;
31131  
31132      return postType ? !!((_select$getPostType = select(external_wp_coreData_namespaceObject.store).getPostType(postType)) !== null && _select$getPostType !== void 0 && _select$getPostType.supports.comments) : false;
31133    });
31134  
31135    let warning = (0,external_wp_i18n_namespaceObject.__)('Post Comments block: This is just a placeholder, not a real comment. The final styling may differ because it also depends on the current theme. For better compatibility with the Block Editor, please consider replacing this block with the "Comments Query Loop" block.');
31136  
31137    let showPlacholder = true;
31138  
31139    if (!isSiteEditor && 'open' !== commentStatus) {
31140      if ('closed' === commentStatus) {
31141        warning = (0,external_wp_i18n_namespaceObject.sprintf)(
31142        /* translators: 1: Post type (i.e. "post", "page") */
31143        (0,external_wp_i18n_namespaceObject.__)('Post Comments block: Comments to this %s are not allowed.'), postType);
31144        showPlacholder = false;
31145      } else if (!postTypeSupportsComments) {
31146        warning = (0,external_wp_i18n_namespaceObject.sprintf)(
31147        /* translators: 1: Post type (i.e. "post", "page") */
31148        (0,external_wp_i18n_namespaceObject.__)('Post Comments block: Comments for this post type (%s) are not enabled.'), postType);
31149        showPlacholder = false;
31150      } else if ('open' !== defaultCommentStatus) {
31151        warning = (0,external_wp_i18n_namespaceObject.__)('Post Comments block: Comments are not enabled.');
31152        showPlacholder = false;
31153      }
31154    }
31155  
31156    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
31157      className: classnames_default()({
31158        [`has-text-align-$textAlign}`]: textAlign
31159      })
31160    });
31161    const disabledRef = (0,external_wp_compose_namespaceObject.__experimentalUseDisabled)();
31162    const textareaId = (0,external_wp_compose_namespaceObject.useInstanceId)(PostCommentsEdit);
31163    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, {
31164      group: "block"
31165    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.AlignmentControl, {
31166      value: textAlign,
31167      onChange: nextAlign => {
31168        setAttributes({
31169          textAlign: nextAlign
31170        });
31171      }
31172    })), (0,external_wp_element_namespaceObject.createElement)("div", blockProps, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.Warning, null, warning), showPlacholder && (0,external_wp_element_namespaceObject.createElement)("div", {
31173      className: "wp-block-post-comments__placeholder",
31174      ref: disabledRef
31175    }, (0,external_wp_element_namespaceObject.createElement)("h3", null, (0,external_wp_i18n_namespaceObject.__)('One response to'), " \u201C", postTitle, "\u201D"), (0,external_wp_element_namespaceObject.createElement)("div", {
31176      className: "navigation"
31177    }, (0,external_wp_element_namespaceObject.createElement)("div", {
31178      className: "alignleft"
31179    }, (0,external_wp_element_namespaceObject.createElement)("a", {
31180      href: "#top"
31181    }, "\xAB ", (0,external_wp_i18n_namespaceObject.__)('Older Comments'))), (0,external_wp_element_namespaceObject.createElement)("div", {
31182      className: "alignright"
31183    }, (0,external_wp_element_namespaceObject.createElement)("a", {
31184      href: "#top"
31185    }, (0,external_wp_i18n_namespaceObject.__)('Newer Comments'), " \xBB"))), (0,external_wp_element_namespaceObject.createElement)("ol", {
31186      className: "commentlist"
31187    }, (0,external_wp_element_namespaceObject.createElement)("li", {
31188      className: "comment even thread-even depth-1"
31189    }, (0,external_wp_element_namespaceObject.createElement)("article", {
31190      className: "comment-body"
31191    }, (0,external_wp_element_namespaceObject.createElement)("footer", {
31192      className: "comment-meta"
31193    }, (0,external_wp_element_namespaceObject.createElement)("div", {
31194      className: "comment-author vcard"
31195    }, (0,external_wp_element_namespaceObject.createElement)("img", {
31196      alt: "Commenter Avatar",
31197      src: avatarURL,
31198      className: "avatar avatar-32 photo",
31199      height: "32",
31200      width: "32",
31201      loading: "lazy"
31202    }), (0,external_wp_element_namespaceObject.createElement)("b", {
31203      className: "fn"
31204    }, (0,external_wp_element_namespaceObject.createElement)("a", {
31205      href: "#top",
31206      className: "url"
31207    }, (0,external_wp_i18n_namespaceObject.__)('A WordPress Commenter'))), ' ', (0,external_wp_element_namespaceObject.createElement)("span", {
31208      className: "says"
31209    }, (0,external_wp_i18n_namespaceObject.__)('says'), ":")), (0,external_wp_element_namespaceObject.createElement)("div", {
31210      className: "comment-metadata"
31211    }, (0,external_wp_element_namespaceObject.createElement)("a", {
31212      href: "#top"
31213    }, (0,external_wp_element_namespaceObject.createElement)("time", {
31214      dateTime: "2000-01-01T00:00:00+00:00"
31215    }, (0,external_wp_i18n_namespaceObject.__)('January 1, 2000 at 00:00 am'))), ' ', (0,external_wp_element_namespaceObject.createElement)("span", {
31216      className: "edit-link"
31217    }, (0,external_wp_element_namespaceObject.createElement)("a", {
31218      className: "comment-edit-link",
31219      href: "#top"
31220    }, (0,external_wp_i18n_namespaceObject.__)('Edit'))))), (0,external_wp_element_namespaceObject.createElement)("div", {
31221      className: "comment-content"
31222    }, (0,external_wp_element_namespaceObject.createElement)("p", null, (0,external_wp_i18n_namespaceObject.__)('Hi, this is a comment.'), (0,external_wp_element_namespaceObject.createElement)("br", null), (0,external_wp_i18n_namespaceObject.__)('To get started with moderating, editing, and deleting comments, please visit the Comments screen in the dashboard.'), (0,external_wp_element_namespaceObject.createElement)("br", null), (0,external_wp_i18n_namespaceObject.__)('Commenter avatars come from'), ' ', (0,external_wp_element_namespaceObject.createElement)("a", {
31223      href: "https://gravatar.com/"
31224    }, "Gravatar"), ".")), (0,external_wp_element_namespaceObject.createElement)("div", {
31225      className: "reply"
31226    }, (0,external_wp_element_namespaceObject.createElement)("a", {
31227      className: "comment-reply-link",
31228      href: "#top",
31229      "aria-label": "Reply to A WordPress Commenter"
31230    }, (0,external_wp_i18n_namespaceObject.__)('Reply')))))), (0,external_wp_element_namespaceObject.createElement)("div", {
31231      className: "navigation"
31232    }, (0,external_wp_element_namespaceObject.createElement)("div", {
31233      className: "alignleft"
31234    }, (0,external_wp_element_namespaceObject.createElement)("a", {
31235      href: "#top"
31236    }, "\xAB ", (0,external_wp_i18n_namespaceObject.__)('Older Comments'))), (0,external_wp_element_namespaceObject.createElement)("div", {
31237      className: "alignright"
31238    }, (0,external_wp_element_namespaceObject.createElement)("a", {
31239      href: "#top"
31240    }, (0,external_wp_i18n_namespaceObject.__)('Newer Comments'), " \xBB"))), (0,external_wp_element_namespaceObject.createElement)("div", {
31241      className: "comment-respond"
31242    }, (0,external_wp_element_namespaceObject.createElement)("h3", {
31243      className: "comment-reply-title"
31244    }, (0,external_wp_i18n_namespaceObject.__)('Leave a Reply')), (0,external_wp_element_namespaceObject.createElement)("form", {
31245      className: "comment-form",
31246      noValidate: true
31247    }, (0,external_wp_element_namespaceObject.createElement)("p", {
31248      className: "comment-form-comment"
31249    }, (0,external_wp_element_namespaceObject.createElement)("label", {
31250      htmlFor: `comment-$textareaId}`
31251    }, (0,external_wp_i18n_namespaceObject.__)('Comment'), ' ', (0,external_wp_element_namespaceObject.createElement)("span", {
31252      className: "required"
31253    }, "*")), (0,external_wp_element_namespaceObject.createElement)("textarea", {
31254      id: `comment-$textareaId}`,
31255      name: "comment",
31256      cols: "45",
31257      rows: "8",
31258      required: true
31259    })), (0,external_wp_element_namespaceObject.createElement)("p", {
31260      className: "form-submit wp-block-button"
31261    }, (0,external_wp_element_namespaceObject.createElement)("input", {
31262      name: "submit",
31263      type: "submit",
31264      className: "submit wp-block-button__link",
31265      value: (0,external_wp_i18n_namespaceObject.__)('Post Comment')
31266    })))))));
31267  }
31268  
31269  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/post-comments/index.js
31270  /**
31271   * WordPress dependencies
31272   */
31273  
31274  /**
31275   * Internal dependencies
31276   */
31277  
31278  const post_comments_metadata = {
31279    $schema: "https://schemas.wp.org/trunk/block.json",
31280    apiVersion: 2,
31281    name: "core/post-comments",
31282    title: "Post Comments (deprecated)",
31283    category: "theme",
31284    description: "This block is deprecated. Please use the Comments Query Loop block instead.",
31285    textdomain: "default",
31286    attributes: {
31287      textAlign: {
31288        type: "string"
31289      }
31290    },
31291    usesContext: ["postId", "postType"],
31292    supports: {
31293      html: false,
31294      align: ["wide", "full"],
31295      typography: {
31296        fontSize: true,
31297        lineHeight: true,
31298        __experimentalFontStyle: true,
31299        __experimentalFontWeight: true,
31300        __experimentalLetterSpacing: true,
31301        __experimentalTextTransform: true,
31302        __experimentalDefaultControls: {
31303          fontSize: true
31304        }
31305      },
31306      color: {
31307        gradients: true,
31308        link: true,
31309        __experimentalDefaultControls: {
31310          background: true,
31311          text: true
31312        }
31313      },
31314      inserter: false
31315    },
31316    style: ["wp-block-post-comments", "wp-block-buttons", "wp-block-button"],
31317    editorStyle: "wp-block-post-comments-editor"
31318  };
31319  
31320  const {
31321    name: post_comments_name
31322  } = post_comments_metadata;
31323  
31324  const post_comments_settings = {
31325    icon: post_comments,
31326    edit: PostCommentsEdit
31327  };
31328  
31329  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/post-comments-form.js
31330  
31331  
31332  /**
31333   * WordPress dependencies
31334   */
31335  
31336  const postCommentsForm = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
31337    xmlns: "http://www.w3.org/2000/svg",
31338    viewBox: "0 0 24 24"
31339  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
31340    d: "M13 8H4v1.5h9V8zM4 4v1.5h16V4H4zm9 8H5c-.6 0-1 .4-1 1v8.3c0 .3.2.7.6.8.1.1.2.1.3.1.2 0 .5-.1.6-.3l1.8-1.8H13c.6 0 1-.4 1-1V13c0-.6-.4-1-1-1zm-.5 6.6H6.7l-1.2 1.2v-6.3h7v5.1z"
31341  }));
31342  /* harmony default export */ var post_comments_form = (postCommentsForm);
31343  
31344  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/post-comments-form/edit.js
31345  
31346  
31347  /**
31348   * External dependencies
31349   */
31350  
31351  /**
31352   * WordPress dependencies
31353   */
31354  
31355  
31356  
31357  
31358  
31359  function PostCommentsFormEdit(_ref) {
31360    let {
31361      attributes,
31362      context,
31363      setAttributes
31364    } = _ref;
31365    const {
31366      textAlign
31367    } = attributes;
31368    const {
31369      postId,
31370      postType
31371    } = context;
31372    const [commentStatus] = (0,external_wp_coreData_namespaceObject.useEntityProp)('postType', postType, 'comment_status', postId);
31373    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
31374      className: classnames_default()({
31375        [`has-text-align-$textAlign}`]: textAlign
31376      })
31377    });
31378    const isInSiteEditor = postType === undefined || postId === undefined;
31379    const disabledFormRef = (0,external_wp_compose_namespaceObject.__experimentalUseDisabled)();
31380    const instanceId = (0,external_wp_compose_namespaceObject.useInstanceId)(PostCommentsFormEdit);
31381    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, {
31382      group: "block"
31383    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.AlignmentControl, {
31384      value: textAlign,
31385      onChange: nextAlign => {
31386        setAttributes({
31387          textAlign: nextAlign
31388        });
31389      }
31390    })), (0,external_wp_element_namespaceObject.createElement)("div", blockProps, !commentStatus && !isInSiteEditor && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.Warning, null, (0,external_wp_i18n_namespaceObject.__)('Post Comments Form block: comments are not enabled for this post type.')), 'open' !== commentStatus && !isInSiteEditor && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.Warning, null, (0,external_wp_i18n_namespaceObject.sprintf)(
31391    /* translators: 1: Post type (i.e. "post", "page") */
31392    (0,external_wp_i18n_namespaceObject.__)('Post Comments Form block: comments to this %s are not allowed.'), postType)), ('open' === commentStatus || isInSiteEditor) && (0,external_wp_element_namespaceObject.createElement)("div", null, (0,external_wp_element_namespaceObject.createElement)("h3", null, (0,external_wp_i18n_namespaceObject.__)('Leave a Reply')), (0,external_wp_element_namespaceObject.createElement)("form", {
31393      noValidate: true,
31394      className: "comment-form",
31395      ref: disabledFormRef
31396    }, (0,external_wp_element_namespaceObject.createElement)("p", null, (0,external_wp_element_namespaceObject.createElement)("label", {
31397      htmlFor: `comment-$instanceId}`
31398    }, (0,external_wp_i18n_namespaceObject.__)('Comment')), (0,external_wp_element_namespaceObject.createElement)("textarea", {
31399      id: `comment-$instanceId}`,
31400      name: "comment",
31401      cols: "45",
31402      rows: "8"
31403    })), (0,external_wp_element_namespaceObject.createElement)("p", null, (0,external_wp_element_namespaceObject.createElement)("input", {
31404      name: "submit",
31405      className: "submit wp-block-button__link",
31406      label: (0,external_wp_i18n_namespaceObject.__)('Post Comment'),
31407      value: (0,external_wp_i18n_namespaceObject.__)('Post Comment'),
31408      readOnly: true
31409    }))))));
31410  }
31411  
31412  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/post-comments-form/index.js
31413  /**
31414   * WordPress dependencies
31415   */
31416  
31417  /**
31418   * Internal dependencies
31419   */
31420  
31421  const post_comments_form_metadata = {
31422    $schema: "https://schemas.wp.org/trunk/block.json",
31423    apiVersion: 2,
31424    name: "core/post-comments-form",
31425    title: "Post Comments Form",
31426    category: "theme",
31427    description: "Display a post's comments form.",
31428    textdomain: "default",
31429    attributes: {
31430      textAlign: {
31431        type: "string"
31432      }
31433    },
31434    usesContext: ["postId", "postType"],
31435    supports: {
31436      html: false,
31437      color: {
31438        gradients: true,
31439        link: true,
31440        __experimentalDefaultControls: {
31441          background: true,
31442          text: true
31443        }
31444      },
31445      typography: {
31446        fontSize: true,
31447        lineHeight: true,
31448        __experimentalFontStyle: true,
31449        __experimentalFontWeight: true,
31450        __experimentalLetterSpacing: true,
31451        __experimentalTextTransform: true,
31452        __experimentalDefaultControls: {
31453          fontSize: true
31454        }
31455      }
31456    },
31457    editorStyle: "wp-block-post-comments-form-editor",
31458    style: ["wp-block-post-comments-form", "wp-block-buttons", "wp-block-button"]
31459  };
31460  
31461  const {
31462    name: post_comments_form_name
31463  } = post_comments_form_metadata;
31464  
31465  const post_comments_form_settings = {
31466    icon: post_comments_form,
31467    edit: PostCommentsFormEdit
31468  };
31469  
31470  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/post-content.js
31471  
31472  
31473  /**
31474   * WordPress dependencies
31475   */
31476  
31477  const postContent = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
31478    xmlns: "https://www.w3.org/2000/svg",
31479    viewBox: "0 0 24 24"
31480  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
31481    d: "M4 20h16v-1.5H4V20zm0-4.8h16v-1.5H4v1.5zm0-6.4v1.5h16V8.8H4zM16 4H4v1.5h12V4z"
31482  }));
31483  /* harmony default export */ var post_content = (postContent);
31484  
31485  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/utils/hooks.js
31486  /**
31487   * WordPress dependencies
31488   */
31489  
31490  
31491  /**
31492   * Returns whether the current user can edit the given entity.
31493   *
31494   * @param {string} kind     Entity kind.
31495   * @param {string} name     Entity name.
31496   * @param {string} recordId Record's id.
31497   */
31498  
31499  function useCanEditEntity(kind, name, recordId) {
31500    return (0,external_wp_data_namespaceObject.useSelect)(select => select(external_wp_coreData_namespaceObject.store).canUserEditEntityRecord(kind, name, recordId), [kind, name, recordId]);
31501  }
31502  /* harmony default export */ var hooks = ({
31503    useCanEditEntity
31504  });
31505  
31506  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/post-content/edit.js
31507  
31508  
31509  
31510  /**
31511   * WordPress dependencies
31512   */
31513  
31514  
31515  
31516  
31517  /**
31518   * Internal dependencies
31519   */
31520  
31521  
31522  
31523  function ReadOnlyContent(_ref) {
31524    let {
31525      userCanEdit,
31526      postType,
31527      postId
31528    } = _ref;
31529    const [,, content] = (0,external_wp_coreData_namespaceObject.useEntityProp)('postType', postType, 'content', postId);
31530    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)();
31531    return content !== null && content !== void 0 && content.protected && !userCanEdit ? (0,external_wp_element_namespaceObject.createElement)("div", blockProps, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.Warning, null, (0,external_wp_i18n_namespaceObject.__)('This content is password protected.'))) : (0,external_wp_element_namespaceObject.createElement)("div", _extends({}, blockProps, {
31532      dangerouslySetInnerHTML: {
31533        __html: content === null || content === void 0 ? void 0 : content.rendered
31534      }
31535    }));
31536  }
31537  
31538  function EditableContent(_ref2) {
31539    let {
31540      layout,
31541      context = {}
31542    } = _ref2;
31543    const {
31544      postType,
31545      postId
31546    } = context;
31547    const themeSupportsLayout = (0,external_wp_data_namespaceObject.useSelect)(select => {
31548      var _getSettings;
31549  
31550      const {
31551        getSettings
31552      } = select(external_wp_blockEditor_namespaceObject.store);
31553      return (_getSettings = getSettings()) === null || _getSettings === void 0 ? void 0 : _getSettings.supportsLayout;
31554    }, []);
31555    const defaultLayout = (0,external_wp_blockEditor_namespaceObject.useSetting)('layout') || {};
31556    const usedLayout = !!layout && layout.inherit ? defaultLayout : layout;
31557    const [blocks, onInput, onChange] = (0,external_wp_coreData_namespaceObject.useEntityBlockEditor)('postType', postType, {
31558      id: postId
31559    });
31560    const props = (0,external_wp_blockEditor_namespaceObject.useInnerBlocksProps)((0,external_wp_blockEditor_namespaceObject.useBlockProps)({
31561      className: 'entry-content'
31562    }), {
31563      value: blocks,
31564      onInput,
31565      onChange,
31566      __experimentalLayout: themeSupportsLayout ? usedLayout : undefined
31567    });
31568    return (0,external_wp_element_namespaceObject.createElement)("div", props);
31569  }
31570  
31571  function Content(props) {
31572    const {
31573      context: {
31574        queryId,
31575        postType,
31576        postId
31577      } = {}
31578    } = props;
31579    const isDescendentOfQueryLoop = Number.isFinite(queryId);
31580    const userCanEdit = useCanEditEntity('postType', postType, postId);
31581    const isEditable = userCanEdit && !isDescendentOfQueryLoop;
31582    return isEditable ? (0,external_wp_element_namespaceObject.createElement)(EditableContent, props) : (0,external_wp_element_namespaceObject.createElement)(ReadOnlyContent, {
31583      userCanEdit: userCanEdit,
31584      postType: postType,
31585      postId: postId
31586    });
31587  }
31588  
31589  function edit_Placeholder() {
31590    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)();
31591    return (0,external_wp_element_namespaceObject.createElement)("div", blockProps, (0,external_wp_element_namespaceObject.createElement)("p", null, (0,external_wp_i18n_namespaceObject.__)('This is the Post Content block, it will display all the blocks in any single post or page.')), (0,external_wp_element_namespaceObject.createElement)("p", null, (0,external_wp_i18n_namespaceObject.__)('That might be a simple arrangement like consecutive paragraphs in a blog post, or a more elaborate composition that includes image galleries, videos, tables, columns, and any other block types.')), (0,external_wp_element_namespaceObject.createElement)("p", null, (0,external_wp_i18n_namespaceObject.__)('If there are any Custom Post Types registered at your site, the Post Content block can display the contents of those entries as well.')));
31592  }
31593  
31594  function RecursionError() {
31595    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)();
31596    return (0,external_wp_element_namespaceObject.createElement)("div", blockProps, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.Warning, null, (0,external_wp_i18n_namespaceObject.__)('Block cannot be rendered inside itself.')));
31597  }
31598  
31599  function PostContentEdit(_ref3) {
31600    let {
31601      context,
31602      attributes
31603    } = _ref3;
31604    const {
31605      postId: contextPostId,
31606      postType: contextPostType
31607    } = context;
31608    const {
31609      layout = {}
31610    } = attributes;
31611    const [hasAlreadyRendered, RecursionProvider] = (0,external_wp_blockEditor_namespaceObject.__experimentalUseNoRecursiveRenders)(contextPostId);
31612  
31613    if (contextPostId && contextPostType && hasAlreadyRendered) {
31614      return (0,external_wp_element_namespaceObject.createElement)(RecursionError, null);
31615    }
31616  
31617    return (0,external_wp_element_namespaceObject.createElement)(RecursionProvider, null, contextPostId && contextPostType ? (0,external_wp_element_namespaceObject.createElement)(Content, {
31618      context: context,
31619      layout: layout
31620    }) : (0,external_wp_element_namespaceObject.createElement)(edit_Placeholder, null));
31621  }
31622  
31623  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/post-content/index.js
31624  /**
31625   * WordPress dependencies
31626   */
31627  
31628  /**
31629   * Internal dependencies
31630   */
31631  
31632  const post_content_metadata = {
31633    $schema: "https://schemas.wp.org/trunk/block.json",
31634    apiVersion: 2,
31635    name: "core/post-content",
31636    title: "Post Content",
31637    category: "theme",
31638    description: "Displays the contents of a post or page.",
31639    textdomain: "default",
31640    usesContext: ["postId", "postType", "queryId"],
31641    supports: {
31642      align: ["wide", "full"],
31643      html: false,
31644      __experimentalLayout: true
31645    },
31646    editorStyle: "wp-block-post-content-editor"
31647  };
31648  
31649  const {
31650    name: post_content_name
31651  } = post_content_metadata;
31652  
31653  const post_content_settings = {
31654    icon: post_content,
31655    edit: PostContentEdit
31656  };
31657  
31658  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/post-date/edit.js
31659  
31660  
31661  /**
31662   * External dependencies
31663   */
31664  
31665  /**
31666   * WordPress dependencies
31667   */
31668  
31669  
31670  
31671  
31672  
31673  
31674  
31675  
31676  
31677  
31678  function PostDateEdit(_ref) {
31679    let {
31680      attributes: {
31681        textAlign,
31682        format,
31683        isLink
31684      },
31685      context: {
31686        postId,
31687        postType: postTypeSlug,
31688        queryId
31689      },
31690      setAttributes
31691    } = _ref;
31692    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
31693      className: classnames_default()({
31694        [`has-text-align-$textAlign}`]: textAlign
31695      })
31696    });
31697    const timeRef = (0,external_wp_element_namespaceObject.useRef)();
31698    const isDescendentOfQueryLoop = Number.isFinite(queryId);
31699    const dateSettings = (0,external_wp_date_namespaceObject.__experimentalGetSettings)();
31700    const [siteFormat = dateSettings.formats.date] = (0,external_wp_coreData_namespaceObject.useEntityProp)('root', 'site', 'date_format');
31701    const [siteTimeFormat = dateSettings.formats.time] = (0,external_wp_coreData_namespaceObject.useEntityProp)('root', 'site', 'time_format');
31702    const [date, setDate] = (0,external_wp_coreData_namespaceObject.useEntityProp)('postType', postTypeSlug, 'date', postId);
31703    const postType = (0,external_wp_data_namespaceObject.useSelect)(select => postTypeSlug ? select(external_wp_coreData_namespaceObject.store).getPostType(postTypeSlug) : null, [postTypeSlug]);
31704    let postDate = date ? (0,external_wp_element_namespaceObject.createElement)("time", {
31705      dateTime: (0,external_wp_date_namespaceObject.dateI18n)('c', date),
31706      ref: timeRef
31707    }, (0,external_wp_date_namespaceObject.dateI18n)(format || siteFormat, date)) : (0,external_wp_i18n_namespaceObject.__)('Post Date');
31708  
31709    if (isLink && date) {
31710      postDate = (0,external_wp_element_namespaceObject.createElement)("a", {
31711        href: "#post-date-pseudo-link",
31712        onClick: event => event.preventDefault()
31713      }, postDate);
31714    }
31715  
31716    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, {
31717      group: "block"
31718    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.AlignmentControl, {
31719      value: textAlign,
31720      onChange: nextAlign => {
31721        setAttributes({
31722          textAlign: nextAlign
31723        });
31724      }
31725    }), date && !isDescendentOfQueryLoop && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarGroup, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Dropdown, {
31726      popoverProps: {
31727        anchorRef: timeRef.current
31728      },
31729      renderContent: () => (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.DateTimePicker, {
31730        currentDate: date,
31731        onChange: setDate,
31732        is12Hour: is12HourFormat(siteTimeFormat)
31733      }),
31734      renderToggle: _ref2 => {
31735        let {
31736          isOpen,
31737          onToggle
31738        } = _ref2;
31739  
31740        const openOnArrowDown = event => {
31741          if (!isOpen && event.keyCode === external_wp_keycodes_namespaceObject.DOWN) {
31742            event.preventDefault();
31743            onToggle();
31744          }
31745        };
31746  
31747        return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, {
31748          "aria-expanded": isOpen,
31749          icon: library_edit,
31750          title: (0,external_wp_i18n_namespaceObject.__)('Change Date'),
31751          onClick: onToggle,
31752          onKeyDown: openOnArrowDown
31753        });
31754      }
31755    }))), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
31756      title: (0,external_wp_i18n_namespaceObject.__)('Settings')
31757    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.__experimentalDateFormatPicker, {
31758      format: format,
31759      defaultFormat: siteFormat,
31760      onChange: nextFormat => setAttributes({
31761        format: nextFormat
31762      })
31763    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
31764      label: postType !== null && postType !== void 0 && postType.labels.singular_name ? (0,external_wp_i18n_namespaceObject.sprintf)( // translators: %s: Name of the post type e.g: "post".
31765      (0,external_wp_i18n_namespaceObject.__)('Link to %s'), postType.labels.singular_name.toLowerCase()) : (0,external_wp_i18n_namespaceObject.__)('Link to post'),
31766      onChange: () => setAttributes({
31767        isLink: !isLink
31768      }),
31769      checked: isLink
31770    }))), (0,external_wp_element_namespaceObject.createElement)("div", blockProps, postDate));
31771  }
31772  function is12HourFormat(format) {
31773    // To know if the time format is a 12 hour time, look for any of the 12 hour
31774    // format characters: 'a', 'A', 'g', and 'h'. The character must be
31775    // unescaped, i.e. not preceded by a '\'. Coincidentally, 'aAgh' is how I
31776    // feel when working with regular expressions.
31777    // https://www.php.net/manual/en/datetime.format.php
31778    return /(?:^|[^\\])[aAgh]/.test(format);
31779  }
31780  
31781  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/post-date/deprecated.js
31782  /**
31783   * Internal dependencies
31784   */
31785  
31786  const post_date_deprecated_v1 = {
31787    attributes: {
31788      textAlign: {
31789        type: 'string'
31790      },
31791      format: {
31792        type: 'string'
31793      },
31794      isLink: {
31795        type: 'boolean',
31796        default: false
31797      }
31798    },
31799    supports: {
31800      html: false,
31801      color: {
31802        gradients: true,
31803        link: true
31804      },
31805      typography: {
31806        fontSize: true,
31807        lineHeight: true,
31808        __experimentalFontFamily: true,
31809        __experimentalFontWeight: true,
31810        __experimentalFontStyle: true,
31811        __experimentalTextTransform: true,
31812        __experimentalLetterSpacing: true
31813      }
31814    },
31815  
31816    save() {
31817      return null;
31818    },
31819  
31820    migrate: migrate_font_family,
31821  
31822    isEligible(_ref) {
31823      var _style$typography;
31824  
31825      let {
31826        style
31827      } = _ref;
31828      return style === null || style === void 0 ? void 0 : (_style$typography = style.typography) === null || _style$typography === void 0 ? void 0 : _style$typography.fontFamily;
31829    }
31830  
31831  };
31832  /**
31833   * New deprecations need to be placed first
31834   * for them to have higher priority.
31835   *
31836   * Old deprecations may need to be updated as well.
31837   *
31838   * See block-deprecation.md
31839   */
31840  
31841  /* harmony default export */ var post_date_deprecated = ([post_date_deprecated_v1]);
31842  
31843  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/post-date/index.js
31844  /**
31845   * WordPress dependencies
31846   */
31847  
31848  /**
31849   * Internal dependencies
31850   */
31851  
31852  const post_date_metadata = {
31853    $schema: "https://schemas.wp.org/trunk/block.json",
31854    apiVersion: 2,
31855    name: "core/post-date",
31856    title: "Post Date",
31857    category: "theme",
31858    description: "Add the date of this post.",
31859    textdomain: "default",
31860    attributes: {
31861      textAlign: {
31862        type: "string"
31863      },
31864      format: {
31865        type: "string"
31866      },
31867      isLink: {
31868        type: "boolean",
31869        "default": false
31870      }
31871    },
31872    usesContext: ["postId", "postType", "queryId"],
31873    supports: {
31874      html: false,
31875      color: {
31876        gradients: true,
31877        link: true,
31878        __experimentalDefaultControls: {
31879          background: true,
31880          text: true,
31881          link: true
31882        }
31883      },
31884      typography: {
31885        fontSize: true,
31886        lineHeight: true,
31887        __experimentalFontFamily: true,
31888        __experimentalFontWeight: true,
31889        __experimentalFontStyle: true,
31890        __experimentalTextTransform: true,
31891        __experimentalLetterSpacing: true,
31892        __experimentalDefaultControls: {
31893          fontSize: true
31894        }
31895      }
31896    }
31897  };
31898  
31899  
31900  const {
31901    name: post_date_name
31902  } = post_date_metadata;
31903  
31904  const post_date_settings = {
31905    icon: post_date,
31906    edit: PostDateEdit,
31907    deprecated: post_date_deprecated
31908  };
31909  
31910  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/post-excerpt.js
31911  
31912  
31913  /**
31914   * WordPress dependencies
31915   */
31916  
31917  const postExcerpt = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
31918    xmlns: "http://www.w3.org/2000/svg",
31919    viewBox: "0 0 24 24"
31920  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
31921    d: "M12.75 9.333c0 .521-.102.977-.327 1.354-.23.386-.555.628-.893.774-.545.234-1.183.227-1.544.222l-.12-.001v-1.5h.123c.414.001.715.002.948-.099a.395.395 0 00.199-.166c.05-.083.114-.253.114-.584V7.2H8.8V4h3.95v5.333zM7.95 9.333c0 .521-.102.977-.327 1.354-.23.386-.555.628-.893.774-.545.234-1.183.227-1.544.222l-.12-.001v-1.5h.123c.414.001.715.002.948-.099a.394.394 0 00.198-.166c.05-.083.115-.253.115-.584V7.2H4V4h3.95v5.333zM13 20H4v-1.5h9V20zM20 16H4v-1.5h16V16z"
31922  }));
31923  /* harmony default export */ var post_excerpt = (postExcerpt);
31924  
31925  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/post-excerpt/edit.js
31926  
31927  
31928  /**
31929   * External dependencies
31930   */
31931  
31932  /**
31933   * WordPress dependencies
31934   */
31935  
31936  
31937  
31938  
31939  
31940  
31941  /**
31942   * Internal dependencies
31943   */
31944  
31945  
31946  function PostExcerptEditor(_ref) {
31947    let {
31948      attributes: {
31949        textAlign,
31950        moreText,
31951        showMoreOnNewLine
31952      },
31953      setAttributes,
31954      isSelected,
31955      context: {
31956        postId,
31957        postType,
31958        queryId
31959      }
31960    } = _ref;
31961    const isDescendentOfQueryLoop = Number.isFinite(queryId);
31962    const userCanEdit = useCanEditEntity('postType', postType, postId);
31963    const isEditable = userCanEdit && !isDescendentOfQueryLoop;
31964    const [rawExcerpt, setExcerpt, {
31965      rendered: renderedExcerpt,
31966      protected: isProtected
31967    } = {}] = (0,external_wp_coreData_namespaceObject.useEntityProp)('postType', postType, 'excerpt', postId);
31968    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
31969      className: classnames_default()({
31970        [`has-text-align-$textAlign}`]: textAlign
31971      })
31972    });
31973    /**
31974     * When excerpt is editable, strip the html tags from
31975     * rendered excerpt. This will be used if the entity's
31976     * excerpt has been produced from the content.
31977     */
31978  
31979    const strippedRenderedExcerpt = (0,external_wp_element_namespaceObject.useMemo)(() => {
31980      if (!renderedExcerpt) return '';
31981      const document = new window.DOMParser().parseFromString(renderedExcerpt, 'text/html');
31982      return document.body.textContent || document.body.innerText || '';
31983    }, [renderedExcerpt]);
31984  
31985    if (!postType || !postId) {
31986      return (0,external_wp_element_namespaceObject.createElement)("div", blockProps, (0,external_wp_element_namespaceObject.createElement)("p", null, (0,external_wp_i18n_namespaceObject.__)('This is the Post Excerpt block, it will display the excerpt from single posts.')), (0,external_wp_element_namespaceObject.createElement)("p", null, (0,external_wp_i18n_namespaceObject.__)('If there are any Custom Post Types with support for excerpts, the Post Excerpt block can display the excerpts of those entries as well.')));
31987    }
31988  
31989    if (isProtected && !userCanEdit) {
31990      return (0,external_wp_element_namespaceObject.createElement)("div", blockProps, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.Warning, null, (0,external_wp_i18n_namespaceObject.__)('There is no excerpt because this is a protected post.')));
31991    }
31992  
31993    const readMoreLink = (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText, {
31994      className: "wp-block-post-excerpt__more-link",
31995      tagName: "a",
31996      "aria-label": (0,external_wp_i18n_namespaceObject.__)('"Read more" link text'),
31997      placeholder: (0,external_wp_i18n_namespaceObject.__)('Add "read more" link text'),
31998      value: moreText,
31999      onChange: newMoreText => setAttributes({
32000        moreText: newMoreText
32001      }),
32002      withoutInteractiveFormatting: true
32003    });
32004    const excerptClassName = classnames_default()('wp-block-post-excerpt__excerpt', {
32005      'is-inline': !showMoreOnNewLine
32006    });
32007    const excerptContent = isEditable ? (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText, {
32008      className: excerptClassName,
32009      "aria-label": (0,external_wp_i18n_namespaceObject.__)('Post excerpt text'),
32010      value: rawExcerpt || strippedRenderedExcerpt || (isSelected ? '' : (0,external_wp_i18n_namespaceObject.__)('No post excerpt found')),
32011      onChange: setExcerpt,
32012      tagName: "p"
32013    }) : (0,external_wp_element_namespaceObject.createElement)("p", {
32014      className: excerptClassName
32015    }, strippedRenderedExcerpt || (0,external_wp_i18n_namespaceObject.__)('No post excerpt found'));
32016    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.AlignmentToolbar, {
32017      value: textAlign,
32018      onChange: newAlign => setAttributes({
32019        textAlign: newAlign
32020      })
32021    })), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
32022      title: (0,external_wp_i18n_namespaceObject.__)('Post Excerpt Settings')
32023    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
32024      label: (0,external_wp_i18n_namespaceObject.__)('Show link on new line'),
32025      checked: showMoreOnNewLine,
32026      onChange: newShowMoreOnNewLine => setAttributes({
32027        showMoreOnNewLine: newShowMoreOnNewLine
32028      })
32029    }))), (0,external_wp_element_namespaceObject.createElement)("div", blockProps, excerptContent, !showMoreOnNewLine && ' ', showMoreOnNewLine ? (0,external_wp_element_namespaceObject.createElement)("p", {
32030      className: "wp-block-post-excerpt__more-text"
32031    }, readMoreLink) : readMoreLink));
32032  }
32033  
32034  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/post-excerpt/transforms.js
32035  /**
32036   * WordPress dependencies
32037   */
32038  
32039  const post_excerpt_transforms_transforms = {
32040    from: [{
32041      type: 'block',
32042      blocks: ['core/post-content'],
32043      transform: () => (0,external_wp_blocks_namespaceObject.createBlock)('core/post-excerpt')
32044    }],
32045    to: [{
32046      type: 'block',
32047      blocks: ['core/post-content'],
32048      transform: () => (0,external_wp_blocks_namespaceObject.createBlock)('core/post-content')
32049    }]
32050  };
32051  /* harmony default export */ var post_excerpt_transforms = (post_excerpt_transforms_transforms);
32052  
32053  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/post-excerpt/index.js
32054  /**
32055   * WordPress dependencies
32056   */
32057  
32058  /**
32059   * Internal dependencies
32060   */
32061  
32062  const post_excerpt_metadata = {
32063    $schema: "https://schemas.wp.org/trunk/block.json",
32064    apiVersion: 2,
32065    name: "core/post-excerpt",
32066    title: "Post Excerpt",
32067    category: "theme",
32068    description: "Display a post's excerpt.",
32069    textdomain: "default",
32070    attributes: {
32071      textAlign: {
32072        type: "string"
32073      },
32074      moreText: {
32075        type: "string"
32076      },
32077      showMoreOnNewLine: {
32078        type: "boolean",
32079        "default": true
32080      }
32081    },
32082    usesContext: ["postId", "postType", "queryId"],
32083    supports: {
32084      html: false,
32085      color: {
32086        gradients: true,
32087        link: true,
32088        __experimentalDefaultControls: {
32089          background: true,
32090          text: true,
32091          link: true
32092        }
32093      },
32094      spacing: {
32095        margin: true,
32096        padding: true
32097      },
32098      typography: {
32099        fontSize: true,
32100        lineHeight: true,
32101        __experimentalFontStyle: true,
32102        __experimentalFontWeight: true,
32103        __experimentalLetterSpacing: true,
32104        __experimentalTextTransform: true,
32105        __experimentalDefaultControls: {
32106          fontSize: true
32107        }
32108      }
32109    },
32110    editorStyle: "wp-block-post-excerpt-editor",
32111    style: "wp-block-post-excerpt"
32112  };
32113  
32114  
32115  const {
32116    name: post_excerpt_name
32117  } = post_excerpt_metadata;
32118  
32119  const post_excerpt_settings = {
32120    icon: post_excerpt,
32121    transforms: post_excerpt_transforms,
32122    edit: PostExcerptEditor
32123  };
32124  
32125  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/post-featured-image/dimension-controls.js
32126  
32127  
32128  /**
32129   * WordPress dependencies
32130   */
32131  
32132  
32133  
32134  const SCALE_OPTIONS = (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalToggleGroupControlOption, {
32135    value: "cover",
32136    label: (0,external_wp_i18n_namespaceObject._x)('Cover', 'Scale option for Image dimension control')
32137  }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalToggleGroupControlOption, {
32138    value: "contain",
32139    label: (0,external_wp_i18n_namespaceObject._x)('Contain', 'Scale option for Image dimension control')
32140  }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalToggleGroupControlOption, {
32141    value: "fill",
32142    label: (0,external_wp_i18n_namespaceObject._x)('Fill', 'Scale option for Image dimension control')
32143  }));
32144  const DEFAULT_SCALE = 'cover';
32145  const DEFAULT_SIZE = 'full';
32146  const scaleHelp = {
32147    cover: (0,external_wp_i18n_namespaceObject.__)('Image is scaled and cropped to fill the entire space without being distorted.'),
32148    contain: (0,external_wp_i18n_namespaceObject.__)('Image is scaled to fill the space without clipping nor distorting.'),
32149    fill: (0,external_wp_i18n_namespaceObject.__)('Image will be stretched and distorted to completely fill the space.')
32150  };
32151  
32152  const DimensionControls = _ref => {
32153    let {
32154      clientId,
32155      attributes: {
32156        width,
32157        height,
32158        scale,
32159        sizeSlug
32160      },
32161      setAttributes,
32162      imageSizeOptions = []
32163    } = _ref;
32164    const defaultUnits = ['px', '%', 'vw', 'em', 'rem'];
32165    const units = (0,external_wp_components_namespaceObject.__experimentalUseCustomUnits)({
32166      availableUnits: (0,external_wp_blockEditor_namespaceObject.useSetting)('spacing.units') || defaultUnits
32167    });
32168  
32169    const onDimensionChange = (dimension, nextValue) => {
32170      const parsedValue = parseFloat(nextValue);
32171      /**
32172       * If we have no value set and we change the unit,
32173       * we don't want to set the attribute, as it would
32174       * end up having the unit as value without any number.
32175       */
32176  
32177      if (isNaN(parsedValue) && nextValue) return;
32178      setAttributes({
32179        [dimension]: parsedValue < 0 ? '0' : nextValue
32180      });
32181    };
32182  
32183    const scaleLabel = (0,external_wp_i18n_namespaceObject._x)('Scale', 'Image scaling options');
32184  
32185    return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, {
32186      __experimentalGroup: "dimensions"
32187    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalToolsPanelItem, {
32188      className: "single-column",
32189      hasValue: () => !!height,
32190      label: (0,external_wp_i18n_namespaceObject.__)('Height'),
32191      onDeselect: () => setAttributes({
32192        height: undefined
32193      }),
32194      resetAllFilter: () => ({
32195        height: undefined
32196      }),
32197      isShownByDefault: true,
32198      panelId: clientId
32199    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalUnitControl, {
32200      label: (0,external_wp_i18n_namespaceObject.__)('Height'),
32201      labelPosition: "top",
32202      value: height || '',
32203      min: 0,
32204      onChange: nextHeight => onDimensionChange('height', nextHeight),
32205      units: units
32206    })), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalToolsPanelItem, {
32207      className: "single-column",
32208      hasValue: () => !!width,
32209      label: (0,external_wp_i18n_namespaceObject.__)('Width'),
32210      onDeselect: () => setAttributes({
32211        width: undefined
32212      }),
32213      resetAllFilter: () => ({
32214        width: undefined
32215      }),
32216      isShownByDefault: true,
32217      panelId: clientId
32218    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalUnitControl, {
32219      label: (0,external_wp_i18n_namespaceObject.__)('Width'),
32220      labelPosition: "top",
32221      value: width || '',
32222      min: 0,
32223      onChange: nextWidth => onDimensionChange('width', nextWidth),
32224      units: units
32225    })), !!height && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalToolsPanelItem, {
32226      hasValue: () => !!scale && scale !== DEFAULT_SCALE,
32227      label: scaleLabel,
32228      onDeselect: () => setAttributes({
32229        scale: DEFAULT_SCALE
32230      }),
32231      resetAllFilter: () => ({
32232        scale: DEFAULT_SCALE
32233      }),
32234      isShownByDefault: true,
32235      panelId: clientId
32236    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalToggleGroupControl, {
32237      label: scaleLabel,
32238      value: scale,
32239      help: scaleHelp[scale],
32240      onChange: value => setAttributes({
32241        scale: value
32242      }),
32243      isBlock: true
32244    }, SCALE_OPTIONS)), !!imageSizeOptions.length && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalToolsPanelItem, {
32245      hasValue: () => !!sizeSlug,
32246      label: (0,external_wp_i18n_namespaceObject.__)('Image size'),
32247      onDeselect: () => setAttributes({
32248        sizeSlug: undefined
32249      }),
32250      resetAllFilter: () => ({
32251        sizeSlug: undefined
32252      }),
32253      isShownByDefault: false,
32254      panelId: clientId
32255    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SelectControl, {
32256      label: (0,external_wp_i18n_namespaceObject.__)('Image size'),
32257      value: sizeSlug || DEFAULT_SIZE,
32258      options: imageSizeOptions,
32259      onChange: nextSizeSlug => setAttributes({
32260        sizeSlug: nextSizeSlug
32261      }),
32262      help: (0,external_wp_i18n_namespaceObject.__)('Select the size of the source image.')
32263    })));
32264  };
32265  
32266  /* harmony default export */ var dimension_controls = (DimensionControls);
32267  
32268  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/post-featured-image/edit.js
32269  
32270  
32271  /**
32272   * WordPress dependencies
32273   */
32274  
32275  
32276  
32277  
32278  
32279  
32280  
32281  
32282  /**
32283   * Internal dependencies
32284   */
32285  
32286  
32287  const placeholderIllustration = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
32288    className: "components-placeholder__illustration",
32289    fill: "none",
32290    xmlns: "http://www.w3.org/2000/svg",
32291    viewBox: "0 0 60 60",
32292    preserveAspectRatio: "none"
32293  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
32294    vectorEffect: "non-scaling-stroke",
32295    d: "M60 60 0 0"
32296  }));
32297  const post_featured_image_edit_ALLOWED_MEDIA_TYPES = ['image'];
32298  const placeholderChip = (0,external_wp_element_namespaceObject.createElement)("div", {
32299    className: "wp-block-post-featured-image__placeholder"
32300  }, placeholderIllustration);
32301  
32302  function getMediaSourceUrlBySizeSlug(media, slug) {
32303    var _media$media_details, _media$media_details$, _media$media_details$2;
32304  
32305    return (media === null || media === void 0 ? void 0 : (_media$media_details = media.media_details) === null || _media$media_details === void 0 ? void 0 : (_media$media_details$ = _media$media_details.sizes) === null || _media$media_details$ === void 0 ? void 0 : (_media$media_details$2 = _media$media_details$[slug]) === null || _media$media_details$2 === void 0 ? void 0 : _media$media_details$2.source_url) || (media === null || media === void 0 ? void 0 : media.source_url);
32306  }
32307  
32308  function PostFeaturedImageDisplay(_ref) {
32309    let {
32310      clientId,
32311      attributes,
32312      setAttributes,
32313      context: {
32314        postId,
32315        postType: postTypeSlug,
32316        queryId
32317      }
32318    } = _ref;
32319    const isDescendentOfQueryLoop = Number.isFinite(queryId);
32320    const {
32321      isLink,
32322      height,
32323      width,
32324      scale,
32325      sizeSlug
32326    } = attributes;
32327    const [featuredImage, setFeaturedImage] = (0,external_wp_coreData_namespaceObject.useEntityProp)('postType', postTypeSlug, 'featured_media', postId);
32328    const {
32329      media,
32330      postType
32331    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
32332      const {
32333        getMedia,
32334        getPostType
32335      } = select(external_wp_coreData_namespaceObject.store);
32336      return {
32337        media: featuredImage && getMedia(featuredImage, {
32338          context: 'view'
32339        }),
32340        postType: postTypeSlug && getPostType(postTypeSlug)
32341      };
32342    }, [featuredImage, postTypeSlug]);
32343    const mediaUrl = getMediaSourceUrlBySizeSlug(media, sizeSlug);
32344    const imageSizes = (0,external_wp_data_namespaceObject.useSelect)(select => select(external_wp_blockEditor_namespaceObject.store).getSettings().imageSizes, []);
32345    const imageSizeOptions = imageSizes.filter(_ref2 => {
32346      var _media$media_details2, _media$media_details3, _media$media_details4;
32347  
32348      let {
32349        slug
32350      } = _ref2;
32351      return media === null || media === void 0 ? void 0 : (_media$media_details2 = media.media_details) === null || _media$media_details2 === void 0 ? void 0 : (_media$media_details3 = _media$media_details2.sizes) === null || _media$media_details3 === void 0 ? void 0 : (_media$media_details4 = _media$media_details3[slug]) === null || _media$media_details4 === void 0 ? void 0 : _media$media_details4.source_url;
32352    }).map(_ref3 => {
32353      let {
32354        name,
32355        slug
32356      } = _ref3;
32357      return {
32358        value: slug,
32359        label: name
32360      };
32361    });
32362    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
32363      style: {
32364        width,
32365        height
32366      }
32367    });
32368  
32369    const placeholder = content => {
32370      return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Placeholder, {
32371        className: "block-editor-media-placeholder"
32372      }, placeholderIllustration, content);
32373    };
32374  
32375    const onSelectImage = value => {
32376      if (value !== null && value !== void 0 && value.id) {
32377        setFeaturedImage(value.id);
32378      }
32379    };
32380  
32381    const {
32382      createErrorNotice
32383    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_notices_namespaceObject.store);
32384  
32385    const onUploadError = message => {
32386      createErrorNotice(message[2], {
32387        type: 'snackbar'
32388      });
32389    };
32390  
32391    const controls = (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(dimension_controls, {
32392      clientId: clientId,
32393      attributes: attributes,
32394      setAttributes: setAttributes,
32395      imageSizeOptions: imageSizeOptions
32396    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
32397      title: (0,external_wp_i18n_namespaceObject.__)('Link settings')
32398    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
32399      label: postType !== null && postType !== void 0 && postType.labels.singular_name ? (0,external_wp_i18n_namespaceObject.sprintf)( // translators: %s: Name of the post type e.g: "post".
32400      (0,external_wp_i18n_namespaceObject.__)('Link to %s'), postType.labels.singular_name.toLowerCase()) : (0,external_wp_i18n_namespaceObject.__)('Link to post'),
32401      onChange: () => setAttributes({
32402        isLink: !isLink
32403      }),
32404      checked: isLink
32405    }))));
32406    let image;
32407  
32408    if (!featuredImage && isDescendentOfQueryLoop) {
32409      return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, controls, (0,external_wp_element_namespaceObject.createElement)("div", blockProps, placeholderChip));
32410    }
32411  
32412    const label = (0,external_wp_i18n_namespaceObject.__)('Add a featured image');
32413  
32414    if (!featuredImage) {
32415      image = (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.MediaPlaceholder, {
32416        onSelect: onSelectImage,
32417        accept: "image/*",
32418        allowedTypes: post_featured_image_edit_ALLOWED_MEDIA_TYPES,
32419        onError: onUploadError,
32420        placeholder: placeholder,
32421        mediaLibraryButton: _ref4 => {
32422          let {
32423            open
32424          } = _ref4;
32425          return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
32426            icon: library_upload,
32427            variant: "primary",
32428            label: label,
32429            showTooltip: true,
32430            tooltipPosition: "top center",
32431            onClick: () => {
32432              open();
32433            }
32434          });
32435        }
32436      });
32437    } else {
32438      // We have a Featured image so show a Placeholder if is loading.
32439      image = !media ? placeholderChip : (0,external_wp_element_namespaceObject.createElement)("img", {
32440        src: mediaUrl,
32441        alt: media.alt_text ? (0,external_wp_i18n_namespaceObject.sprintf)( // translators: %s: The image's alt text.
32442        (0,external_wp_i18n_namespaceObject.__)('Featured image: %s'), media.alt_text) : (0,external_wp_i18n_namespaceObject.__)('Featured image'),
32443        style: {
32444          height,
32445          objectFit: height && scale
32446        }
32447      });
32448    }
32449  
32450    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, controls, !!media && !isDescendentOfQueryLoop && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, {
32451      group: "other"
32452    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.MediaReplaceFlow, {
32453      mediaId: featuredImage,
32454      mediaURL: mediaUrl,
32455      allowedTypes: post_featured_image_edit_ALLOWED_MEDIA_TYPES,
32456      accept: "image/*",
32457      onSelect: onSelectImage,
32458      onError: onUploadError
32459    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, {
32460      onClick: () => setFeaturedImage(0)
32461    }, (0,external_wp_i18n_namespaceObject.__)('Reset')))), (0,external_wp_element_namespaceObject.createElement)("figure", blockProps, image));
32462  }
32463  
32464  function PostFeaturedImageEdit(props) {
32465    var _props$context;
32466  
32467    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)();
32468  
32469    if (!((_props$context = props.context) !== null && _props$context !== void 0 && _props$context.postId)) {
32470      return (0,external_wp_element_namespaceObject.createElement)("div", blockProps, placeholderChip);
32471    }
32472  
32473    return (0,external_wp_element_namespaceObject.createElement)(PostFeaturedImageDisplay, props);
32474  }
32475  
32476  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/post-featured-image/index.js
32477  /**
32478   * WordPress dependencies
32479   */
32480  
32481  /**
32482   * Internal dependencies
32483   */
32484  
32485  const post_featured_image_metadata = {
32486    $schema: "https://schemas.wp.org/trunk/block.json",
32487    apiVersion: 2,
32488    name: "core/post-featured-image",
32489    title: "Post Featured Image",
32490    category: "theme",
32491    description: "Display a post's featured image.",
32492    textdomain: "default",
32493    attributes: {
32494      isLink: {
32495        type: "boolean",
32496        "default": false
32497      },
32498      width: {
32499        type: "string"
32500      },
32501      height: {
32502        type: "string"
32503      },
32504      scale: {
32505        type: "string",
32506        "default": "cover"
32507      },
32508      sizeSlug: {
32509        type: "string"
32510      }
32511    },
32512    usesContext: ["postId", "postType", "queryId"],
32513    supports: {
32514      align: ["left", "right", "center", "wide", "full"],
32515      color: {
32516        __experimentalDuotone: "img, .wp-block-post-featured-image__placeholder, .components-placeholder__illustration, .components-placeholder::before",
32517        text: false,
32518        background: false
32519      },
32520      html: false,
32521      spacing: {
32522        margin: true,
32523        padding: true
32524      }
32525    },
32526    editorStyle: "wp-block-post-featured-image-editor",
32527    style: "wp-block-post-featured-image"
32528  };
32529  
32530  const {
32531    name: post_featured_image_name
32532  } = post_featured_image_metadata;
32533  
32534  const post_featured_image_settings = {
32535    icon: post_featured_image,
32536    edit: PostFeaturedImageEdit
32537  };
32538  
32539  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/post-navigation-link/edit.js
32540  
32541  
32542  /**
32543   * External dependencies
32544   */
32545  
32546  /**
32547   * WordPress dependencies
32548   */
32549  
32550  
32551  
32552  
32553  function PostNavigationLinkEdit(_ref) {
32554    let {
32555      attributes: {
32556        type,
32557        label,
32558        showTitle,
32559        textAlign,
32560        linkLabel
32561      },
32562      setAttributes
32563    } = _ref;
32564    const isNext = type === 'next';
32565    let placeholder = isNext ? (0,external_wp_i18n_namespaceObject.__)('Next') : (0,external_wp_i18n_namespaceObject.__)('Previous');
32566  
32567    if (showTitle) {
32568      /* translators: Label before for next and previous post. There is a space after the colon. */
32569      placeholder = isNext ? (0,external_wp_i18n_namespaceObject.__)('Next: ') : (0,external_wp_i18n_namespaceObject.__)('Previous: ');
32570    }
32571  
32572    const ariaLabel = isNext ? (0,external_wp_i18n_namespaceObject.__)('Next post') : (0,external_wp_i18n_namespaceObject.__)('Previous post');
32573    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
32574      className: classnames_default()({
32575        [`has-text-align-$textAlign}`]: textAlign
32576      })
32577    });
32578    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
32579      label: (0,external_wp_i18n_namespaceObject.__)('Display the title as a link'),
32580      help: (0,external_wp_i18n_namespaceObject.__)('If you have entered a custom label, it will be prepended before the title.'),
32581      checked: !!showTitle,
32582      onChange: () => setAttributes({
32583        showTitle: !showTitle
32584      })
32585    }), showTitle && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
32586      label: (0,external_wp_i18n_namespaceObject.__)('Include the label as part of the link'),
32587      checked: !!linkLabel,
32588      onChange: () => setAttributes({
32589        linkLabel: !linkLabel
32590      })
32591    }))), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.AlignmentToolbar, {
32592      value: textAlign,
32593      onChange: nextAlign => {
32594        setAttributes({
32595          textAlign: nextAlign
32596        });
32597      }
32598    })), (0,external_wp_element_namespaceObject.createElement)("div", blockProps, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText, {
32599      tagName: "a",
32600      "aria-label": ariaLabel,
32601      placeholder: placeholder,
32602      value: label,
32603      allowedFormats: ['core/bold', 'core/italic'],
32604      onChange: newLabel => setAttributes({
32605        label: newLabel
32606      })
32607    }), showTitle && (0,external_wp_element_namespaceObject.createElement)("a", {
32608      href: "#post-navigation-pseudo-link",
32609      onClick: event => event.preventDefault()
32610    }, (0,external_wp_i18n_namespaceObject.__)('An example title'))));
32611  }
32612  
32613  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/next.js
32614  
32615  
32616  /**
32617   * WordPress dependencies
32618   */
32619  
32620  const next = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
32621    xmlns: "http://www.w3.org/2000/svg",
32622    viewBox: "0 0 24 24"
32623  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
32624    d: "M6.6 6L5.4 7l4.5 5-4.5 5 1.1 1 5.5-6-5.4-6zm6 0l-1.1 1 4.5 5-4.5 5 1.1 1 5.5-6-5.5-6z"
32625  }));
32626  /* harmony default export */ var library_next = (next);
32627  
32628  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/previous.js
32629  
32630  
32631  /**
32632   * WordPress dependencies
32633   */
32634  
32635  const previous = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
32636    xmlns: "http://www.w3.org/2000/svg",
32637    viewBox: "0 0 24 24"
32638  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
32639    d: "M11.6 7l-1.1-1L5 12l5.5 6 1.1-1L7 12l4.6-5zm6 0l-1.1-1-5.5 6 5.5 6 1.1-1-4.6-5 4.6-5z"
32640  }));
32641  /* harmony default export */ var library_previous = (previous);
32642  
32643  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/post-navigation-link/variations.js
32644  /**
32645   * WordPress dependencies
32646   */
32647  
32648  
32649  const post_navigation_link_variations_variations = [{
32650    isDefault: true,
32651    name: 'post-next',
32652    title: (0,external_wp_i18n_namespaceObject.__)('Next post'),
32653    description: (0,external_wp_i18n_namespaceObject.__)('Displays the post link that follows the current post.'),
32654    icon: library_next,
32655    attributes: {
32656      type: 'next'
32657    },
32658    scope: ['inserter', 'transform']
32659  }, {
32660    name: 'post-previous',
32661    title: (0,external_wp_i18n_namespaceObject.__)('Previous post'),
32662    description: (0,external_wp_i18n_namespaceObject.__)('Displays the post link that precedes the current post.'),
32663    icon: library_previous,
32664    attributes: {
32665      type: 'previous'
32666    },
32667    scope: ['inserter', 'transform']
32668  }];
32669  /**
32670   * Add `isActive` function to all `post-navigation-link` variations, if not defined.
32671   * `isActive` function is used to find a variation match from a created
32672   *  Block by providing its attributes.
32673   */
32674  
32675  post_navigation_link_variations_variations.forEach(variation => {
32676    if (variation.isActive) return;
32677  
32678    variation.isActive = (blockAttributes, variationAttributes) => blockAttributes.type === variationAttributes.type;
32679  });
32680  /* harmony default export */ var post_navigation_link_variations = (post_navigation_link_variations_variations);
32681  
32682  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/post-navigation-link/index.js
32683  /**
32684   * Internal dependencies
32685   */
32686  const post_navigation_link_metadata = {
32687    $schema: "https://schemas.wp.org/trunk/block.json",
32688    apiVersion: 2,
32689    name: "core/post-navigation-link",
32690    title: "Post Navigation Link",
32691    category: "theme",
32692    description: "Displays the next or previous post link that is adjacent to the current post.",
32693    textdomain: "default",
32694    attributes: {
32695      textAlign: {
32696        type: "string"
32697      },
32698      type: {
32699        type: "string",
32700        "default": "next"
32701      },
32702      label: {
32703        type: "string"
32704      },
32705      showTitle: {
32706        type: "boolean",
32707        "default": false
32708      },
32709      linkLabel: {
32710        type: "boolean",
32711        "default": false
32712      }
32713    },
32714    supports: {
32715      reusable: false,
32716      html: false,
32717      typography: {
32718        fontSize: true,
32719        lineHeight: true,
32720        __experimentalFontStyle: true,
32721        __experimentalFontWeight: true,
32722        __experimentalLetterSpacing: true,
32723        __experimentalTextTransform: true,
32724        __experimentalDefaultControls: {
32725          fontSize: true
32726        }
32727      }
32728    }
32729  };
32730  
32731  
32732  const {
32733    name: post_navigation_link_name
32734  } = post_navigation_link_metadata;
32735  
32736  const post_navigation_link_settings = {
32737    edit: PostNavigationLinkEdit,
32738    variations: post_navigation_link_variations
32739  };
32740  
32741  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/post-template/edit.js
32742  
32743  
32744  
32745  /**
32746   * External dependencies
32747   */
32748  
32749  /**
32750   * WordPress dependencies
32751   */
32752  
32753  
32754  
32755  
32756  
32757  
32758  
32759  const post_template_edit_TEMPLATE = [['core/post-title'], ['core/post-date'], ['core/post-excerpt']];
32760  
32761  function PostTemplateInnerBlocks() {
32762    const innerBlocksProps = (0,external_wp_blockEditor_namespaceObject.useInnerBlocksProps)({
32763      className: 'wp-block-post'
32764    }, {
32765      template: post_template_edit_TEMPLATE
32766    });
32767    return (0,external_wp_element_namespaceObject.createElement)("li", innerBlocksProps);
32768  }
32769  
32770  function PostTemplateBlockPreview(_ref) {
32771    let {
32772      blocks,
32773      blockContextId,
32774      isHidden,
32775      setActiveBlockContextId
32776    } = _ref;
32777    const blockPreviewProps = (0,external_wp_blockEditor_namespaceObject.__experimentalUseBlockPreview)({
32778      blocks,
32779      props: {
32780        className: 'wp-block-post'
32781      }
32782    });
32783  
32784    const handleOnClick = () => {
32785      setActiveBlockContextId(blockContextId);
32786    };
32787  
32788    const style = {
32789      display: isHidden ? 'none' : undefined
32790    };
32791    return (0,external_wp_element_namespaceObject.createElement)("li", _extends({}, blockPreviewProps, {
32792      tabIndex: 0 // eslint-disable-next-line jsx-a11y/no-noninteractive-element-to-interactive-role
32793      ,
32794      role: "button",
32795      onClick: handleOnClick,
32796      onKeyPress: handleOnClick,
32797      style: style
32798    }));
32799  }
32800  
32801  const MemoizedPostTemplateBlockPreview = (0,external_wp_element_namespaceObject.memo)(PostTemplateBlockPreview);
32802  function PostTemplateEdit(_ref2) {
32803    let {
32804      clientId,
32805      context: {
32806        query: {
32807          perPage,
32808          offset,
32809          postType,
32810          order,
32811          orderBy,
32812          author,
32813          search,
32814          exclude,
32815          sticky,
32816          inherit,
32817          taxQuery
32818        } = {},
32819        queryContext = [{
32820          page: 1
32821        }],
32822        templateSlug,
32823        displayLayout: {
32824          type: layoutType = 'flex',
32825          columns = 1
32826        } = {}
32827      }
32828    } = _ref2;
32829    const [{
32830      page
32831    }] = queryContext;
32832    const [activeBlockContextId, setActiveBlockContextId] = (0,external_wp_element_namespaceObject.useState)();
32833    const {
32834      posts,
32835      blocks
32836    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
32837      const {
32838        getEntityRecords,
32839        getTaxonomies
32840      } = select(external_wp_coreData_namespaceObject.store);
32841      const {
32842        getBlocks
32843      } = select(external_wp_blockEditor_namespaceObject.store);
32844      const taxonomies = getTaxonomies({
32845        type: postType,
32846        per_page: -1,
32847        context: 'view'
32848      });
32849      const query = {
32850        offset: perPage ? perPage * (page - 1) + offset : 0,
32851        order,
32852        orderby: orderBy
32853      };
32854  
32855      if (taxQuery) {
32856        // We have to build the tax query for the REST API and use as
32857        // keys the taxonomies `rest_base` with the `term ids` as values.
32858        const builtTaxQuery = Object.entries(taxQuery).reduce((accumulator, _ref3) => {
32859          let [taxonomySlug, terms] = _ref3;
32860          const taxonomy = taxonomies === null || taxonomies === void 0 ? void 0 : taxonomies.find(_ref4 => {
32861            let {
32862              slug
32863            } = _ref4;
32864            return slug === taxonomySlug;
32865          });
32866  
32867          if (taxonomy !== null && taxonomy !== void 0 && taxonomy.rest_base) {
32868            accumulator[taxonomy === null || taxonomy === void 0 ? void 0 : taxonomy.rest_base] = terms;
32869          }
32870  
32871          return accumulator;
32872        }, {});
32873  
32874        if (!!Object.keys(builtTaxQuery).length) {
32875          Object.assign(query, builtTaxQuery);
32876        }
32877      }
32878  
32879      if (perPage) {
32880        query.per_page = perPage;
32881      }
32882  
32883      if (author) {
32884        query.author = author;
32885      }
32886  
32887      if (search) {
32888        query.search = search;
32889      }
32890  
32891      if (exclude !== null && exclude !== void 0 && exclude.length) {
32892        query.exclude = exclude;
32893      } // If sticky is not set, it will return all posts in the results.
32894      // If sticky is set to `only`, it will limit the results to sticky posts only.
32895      // If it is anything else, it will exclude sticky posts from results. For the record the value stored is `exclude`.
32896  
32897  
32898      if (sticky) {
32899        query.sticky = sticky === 'only';
32900      } // If `inherit` is truthy, adjust conditionally the query to create a better preview.
32901  
32902  
32903      if (inherit) {
32904        // Change the post-type if needed.
32905        if (templateSlug !== null && templateSlug !== void 0 && templateSlug.startsWith('archive-')) {
32906          query.postType = templateSlug.replace('archive-', '');
32907          postType = query.postType;
32908        }
32909      }
32910  
32911      return {
32912        posts: getEntityRecords('postType', postType, query),
32913        blocks: getBlocks(clientId)
32914      };
32915    }, [perPage, page, offset, order, orderBy, clientId, author, search, postType, exclude, sticky, inherit, templateSlug, taxQuery]);
32916    const blockContexts = (0,external_wp_element_namespaceObject.useMemo)(() => posts === null || posts === void 0 ? void 0 : posts.map(post => ({
32917      postType: post.type,
32918      postId: post.id
32919    })), [posts]);
32920    const hasLayoutFlex = layoutType === 'flex' && columns > 1;
32921    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
32922      className: classnames_default()({
32923        'is-flex-container': hasLayoutFlex,
32924        [`columns-$columns}`]: hasLayoutFlex
32925      })
32926    });
32927  
32928    if (!posts) {
32929      return (0,external_wp_element_namespaceObject.createElement)("p", blockProps, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Spinner, null));
32930    }
32931  
32932    if (!posts.length) {
32933      return (0,external_wp_element_namespaceObject.createElement)("p", blockProps, " ", (0,external_wp_i18n_namespaceObject.__)('No results found.'));
32934    } // To avoid flicker when switching active block contexts, a preview is rendered
32935    // for each block context, but the preview for the active block context is hidden.
32936    // This ensures that when it is displayed again, the cached rendering of the
32937    // block preview is used, instead of having to re-render the preview from scratch.
32938  
32939  
32940    return (0,external_wp_element_namespaceObject.createElement)("ul", blockProps, blockContexts && blockContexts.map(blockContext => {
32941      var _blockContexts$, _blockContexts$2;
32942  
32943      return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockContextProvider, {
32944        key: blockContext.postId,
32945        value: blockContext
32946      }, blockContext.postId === (activeBlockContextId || ((_blockContexts$ = blockContexts[0]) === null || _blockContexts$ === void 0 ? void 0 : _blockContexts$.postId)) ? (0,external_wp_element_namespaceObject.createElement)(PostTemplateInnerBlocks, null) : null, (0,external_wp_element_namespaceObject.createElement)(MemoizedPostTemplateBlockPreview, {
32947        blocks: blocks,
32948        blockContextId: blockContext.postId,
32949        setActiveBlockContextId: setActiveBlockContextId,
32950        isHidden: blockContext.postId === (activeBlockContextId || ((_blockContexts$2 = blockContexts[0]) === null || _blockContexts$2 === void 0 ? void 0 : _blockContexts$2.postId))
32951      }));
32952    }));
32953  }
32954  
32955  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/post-template/save.js
32956  
32957  
32958  /**
32959   * WordPress dependencies
32960   */
32961  
32962  function PostTemplateSave() {
32963    return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InnerBlocks.Content, null);
32964  }
32965  
32966  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/post-template/index.js
32967  /**
32968   * WordPress dependencies
32969   */
32970  
32971  /**
32972   * Internal dependencies
32973   */
32974  
32975  const post_template_metadata = {
32976    $schema: "https://schemas.wp.org/trunk/block.json",
32977    apiVersion: 2,
32978    name: "core/post-template",
32979    title: "Post Template",
32980    category: "theme",
32981    parent: ["core/query"],
32982    description: "Contains the block elements used to render a post, like the title, date, featured image, content or excerpt, and more.",
32983    textdomain: "default",
32984    usesContext: ["queryId", "query", "queryContext", "displayLayout", "templateSlug"],
32985    supports: {
32986      reusable: false,
32987      html: false,
32988      align: true,
32989      __experimentalLayout: {
32990        allowEditing: false
32991      }
32992    },
32993    style: "wp-block-post-template",
32994    editorStyle: "wp-block-post-template-editor"
32995  };
32996  
32997  
32998  const {
32999    name: post_template_name
33000  } = post_template_metadata;
33001  
33002  const post_template_settings = {
33003    icon: library_layout,
33004    edit: PostTemplateEdit,
33005    save: PostTemplateSave
33006  };
33007  
33008  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/post-terms/use-post-terms.js
33009  /**
33010   * WordPress dependencies
33011   */
33012  
33013  
33014  function usePostTerms(_ref) {
33015    var _term$visibility2;
33016  
33017    let {
33018      postId,
33019      postType,
33020      term
33021    } = _ref;
33022    const {
33023      rest_base: restBase,
33024      slug
33025    } = term;
33026    const [termIds] = (0,external_wp_coreData_namespaceObject.useEntityProp)('postType', postType, restBase, postId);
33027    return (0,external_wp_data_namespaceObject.useSelect)(select => {
33028      var _term$visibility;
33029  
33030      const visible = term === null || term === void 0 ? void 0 : (_term$visibility = term.visibility) === null || _term$visibility === void 0 ? void 0 : _term$visibility.publicly_queryable;
33031  
33032      if (!visible) {
33033        return {
33034          postTerms: [],
33035          _isLoading: false,
33036          hasPostTerms: false
33037        };
33038      }
33039  
33040      if (!termIds) {
33041        var _term$postTerms;
33042  
33043        // Waiting for post terms to be fetched.
33044        return {
33045          isLoading: term === null || term === void 0 ? void 0 : (_term$postTerms = term.postTerms) === null || _term$postTerms === void 0 ? void 0 : _term$postTerms.includes(postType)
33046        };
33047      }
33048  
33049      if (!termIds.length) {
33050        return {
33051          isLoading: false
33052        };
33053      }
33054  
33055      const {
33056        getEntityRecords,
33057        isResolving
33058      } = select(external_wp_coreData_namespaceObject.store);
33059      const taxonomyArgs = ['taxonomy', slug, {
33060        include: termIds,
33061        context: 'view'
33062      }];
33063      const terms = getEntityRecords(...taxonomyArgs);
33064  
33065      const _isLoading = isResolving('getEntityRecords', taxonomyArgs);
33066  
33067      return {
33068        postTerms: terms,
33069        isLoading: _isLoading,
33070        hasPostTerms: !!(terms !== null && terms !== void 0 && terms.length)
33071      };
33072    }, [termIds, term === null || term === void 0 ? void 0 : (_term$visibility2 = term.visibility) === null || _term$visibility2 === void 0 ? void 0 : _term$visibility2.publicly_queryable]);
33073  }
33074  
33075  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/post-terms/edit.js
33076  
33077  
33078  /**
33079   * External dependencies
33080   */
33081  
33082  
33083  /**
33084   * WordPress dependencies
33085   */
33086  
33087  
33088  
33089  
33090  
33091  
33092  /**
33093   * Internal dependencies
33094   */
33095  
33096  
33097  function PostTermsEdit(_ref) {
33098    var _selectedTerm$labels;
33099  
33100    let {
33101      attributes,
33102      clientId,
33103      context,
33104      setAttributes
33105    } = _ref;
33106    const {
33107      term,
33108      textAlign,
33109      separator
33110    } = attributes;
33111    const {
33112      postId,
33113      postType
33114    } = context;
33115    const selectedTerm = (0,external_wp_data_namespaceObject.useSelect)(select => {
33116      var _taxonomy$visibility;
33117  
33118      if (!term) return {};
33119      const {
33120        getTaxonomy
33121      } = select(external_wp_coreData_namespaceObject.store);
33122      const taxonomy = getTaxonomy(term);
33123      return taxonomy !== null && taxonomy !== void 0 && (_taxonomy$visibility = taxonomy.visibility) !== null && _taxonomy$visibility !== void 0 && _taxonomy$visibility.publicly_queryable ? taxonomy : {};
33124    }, [term]);
33125    const {
33126      postTerms,
33127      hasPostTerms,
33128      isLoading
33129    } = usePostTerms({
33130      postId,
33131      postType,
33132      term: selectedTerm
33133    });
33134    const hasPost = postId && postType;
33135    const blockInformation = (0,external_wp_blockEditor_namespaceObject.useBlockDisplayInformation)(clientId);
33136    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
33137      className: classnames_default()({
33138        [`has-text-align-$textAlign}`]: textAlign,
33139        [`taxonomy-$term}`]: term
33140      })
33141    });
33142  
33143    if (!hasPost || !term) {
33144      return (0,external_wp_element_namespaceObject.createElement)("div", blockProps, blockInformation.title);
33145    }
33146  
33147    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.AlignmentToolbar, {
33148      value: textAlign,
33149      onChange: nextAlign => {
33150        setAttributes({
33151          textAlign: nextAlign
33152        });
33153      }
33154    })), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, {
33155      __experimentalGroup: "advanced"
33156    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TextControl, {
33157      autoComplete: "off",
33158      label: (0,external_wp_i18n_namespaceObject.__)('Separator'),
33159      value: separator || '',
33160      onChange: nextValue => {
33161        setAttributes({
33162          separator: nextValue
33163        });
33164      },
33165      help: (0,external_wp_i18n_namespaceObject.__)('Enter character(s) used to separate terms.')
33166    })), (0,external_wp_element_namespaceObject.createElement)("div", blockProps, isLoading && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Spinner, null), !isLoading && hasPostTerms && postTerms.map(postTerm => (0,external_wp_element_namespaceObject.createElement)("a", {
33167      key: postTerm.id,
33168      href: postTerm.link,
33169      onClick: event => event.preventDefault()
33170    }, (0,external_lodash_namespaceObject.unescape)(postTerm.name))).reduce((prev, curr) => (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, prev, (0,external_wp_element_namespaceObject.createElement)("span", {
33171      className: "wp-block-post-terms__separator"
33172    }, separator || ' '), curr)), !isLoading && !hasPostTerms && ((selectedTerm === null || selectedTerm === void 0 ? void 0 : (_selectedTerm$labels = selectedTerm.labels) === null || _selectedTerm$labels === void 0 ? void 0 : _selectedTerm$labels.no_terms) || (0,external_wp_i18n_namespaceObject.__)('Term items not found.'))));
33173  }
33174  
33175  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/post-categories.js
33176  
33177  
33178  /**
33179   * WordPress dependencies
33180   */
33181  
33182  const postCategories = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
33183    viewBox: "0 0 24 24",
33184    xmlns: "http://www.w3.org/2000/svg"
33185  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
33186    d: "M20 4H4v1.5h16V4zm-2 9h-3c-1.1 0-2 .9-2 2v3c0 1.1.9 2 2 2h3c1.1 0 2-.9 2-2v-3c0-1.1-.9-2-2-2zm.5 5c0 .3-.2.5-.5.5h-3c-.3 0-.5-.2-.5-.5v-3c0-.3.2-.5.5-.5h3c.3 0 .5.2.5.5v3zM4 9.5h9V8H4v1.5zM9 13H6c-1.1 0-2 .9-2 2v3c0 1.1.9 2 2 2h3c1.1 0 2-.9 2-2v-3c0-1.1-.9-2-2-2zm.5 5c0 .3-.2.5-.5.5H6c-.3 0-.5-.2-.5-.5v-3c0-.3.2-.5.5-.5h3c.3 0 .5.2.5.5v3z",
33187    fillRule: "evenodd",
33188    clipRule: "evenodd"
33189  }));
33190  /* harmony default export */ var post_categories = (postCategories);
33191  
33192  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/post-terms.js
33193  
33194  
33195  /**
33196   * WordPress dependencies
33197   */
33198  
33199  const postTerms = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
33200    viewBox: "0 0 24 24",
33201    xmlns: "http://www.w3.org/2000/svg"
33202  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
33203    d: "M8.1 12.3c.1.1.3.3.5.3.2.1.4.1.6.1.2 0 .4 0 .6-.1.2-.1.4-.2.5-.3l3-3c.3-.3.5-.7.5-1.1 0-.4-.2-.8-.5-1.1L9.7 3.5c-.1-.2-.3-.3-.5-.3H5c-.4 0-.8.4-.8.8v4.2c0 .2.1.4.2.5l3.7 3.6zM5.8 4.8h3.1l3.4 3.4v.1l-3 3 .5.5-.7-.5-3.3-3.4V4.8zM4 20h9v-1.5H4V20zm0-5.5V16h16v-1.5H4z"
33204  }));
33205  /* harmony default export */ var post_terms = (postTerms);
33206  
33207  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/post-terms/variations.js
33208  /**
33209   * WordPress dependencies
33210   */
33211  
33212  
33213  const post_terms_variations_variations = [{
33214    name: 'category',
33215    title: (0,external_wp_i18n_namespaceObject.__)('Post Categories'),
33216    description: (0,external_wp_i18n_namespaceObject.__)("Display a post's categories."),
33217    icon: post_categories,
33218    isDefault: true,
33219    attributes: {
33220      term: 'category'
33221    },
33222    isActive: blockAttributes => blockAttributes.term === 'category'
33223  }, {
33224    name: 'post_tag',
33225    title: (0,external_wp_i18n_namespaceObject.__)('Post Tags'),
33226    description: (0,external_wp_i18n_namespaceObject.__)("Display a post's tags."),
33227    icon: post_terms,
33228    attributes: {
33229      term: 'post_tag'
33230    },
33231    isActive: blockAttributes => blockAttributes.term === 'post_tag'
33232  }];
33233  /* harmony default export */ var post_terms_variations = (post_terms_variations_variations);
33234  
33235  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/post-terms/index.js
33236  /**
33237   * Internal dependencies
33238   */
33239  const post_terms_metadata = {
33240    $schema: "https://schemas.wp.org/trunk/block.json",
33241    apiVersion: 2,
33242    name: "core/post-terms",
33243    title: "Post Terms",
33244    category: "theme",
33245    description: "Post terms.",
33246    textdomain: "default",
33247    attributes: {
33248      term: {
33249        type: "string"
33250      },
33251      textAlign: {
33252        type: "string"
33253      },
33254      separator: {
33255        type: "string",
33256        "default": ", "
33257      }
33258    },
33259    usesContext: ["postId", "postType"],
33260    supports: {
33261      html: false,
33262      color: {
33263        gradients: true,
33264        link: true,
33265        __experimentalDefaultControls: {
33266          background: true,
33267          text: true,
33268          link: true
33269        }
33270      },
33271      typography: {
33272        lineHeight: true,
33273        fontSize: true,
33274        __experimentalFontStyle: true,
33275        __experimentalFontWeight: true,
33276        __experimentalLetterSpacing: true,
33277        __experimentalTextTransform: true,
33278        __experimentalDefaultControls: {
33279          fontSize: true
33280        }
33281      }
33282    },
33283    style: "wp-block-post-terms"
33284  };
33285  
33286  
33287  /**
33288   * WordPress dependencies
33289   */
33290  
33291  
33292  const {
33293    name: post_terms_name
33294  } = post_terms_metadata;
33295  
33296  const post_terms_settings = {
33297    icon: post_terms,
33298    variations: post_terms_variations,
33299    edit: PostTermsEdit
33300  };
33301  
33302  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/post-title/edit.js
33303  
33304  
33305  
33306  /**
33307   * External dependencies
33308   */
33309  
33310  /**
33311   * WordPress dependencies
33312   */
33313  
33314  
33315  
33316  
33317  
33318  /**
33319   * Internal dependencies
33320   */
33321  
33322  
33323  
33324  function PostTitleEdit(_ref) {
33325    let {
33326      attributes: {
33327        level,
33328        textAlign,
33329        isLink,
33330        rel,
33331        linkTarget
33332      },
33333      setAttributes,
33334      context: {
33335        postType,
33336        postId,
33337        queryId
33338      }
33339    } = _ref;
33340    const TagName = 0 === level ? 'p' : 'h' + level;
33341    const isDescendentOfQueryLoop = Number.isFinite(queryId);
33342    const userCanEdit = useCanEditEntity('postType', postType, postId);
33343    const [rawTitle = '', setTitle, fullTitle] = (0,external_wp_coreData_namespaceObject.useEntityProp)('postType', postType, 'title', postId);
33344    const [link] = (0,external_wp_coreData_namespaceObject.useEntityProp)('postType', postType, 'link', postId);
33345    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
33346      className: classnames_default()({
33347        [`has-text-align-$textAlign}`]: textAlign
33348      })
33349    });
33350    let titleElement = (0,external_wp_element_namespaceObject.createElement)(TagName, blockProps, (0,external_wp_i18n_namespaceObject.__)('Post Title'));
33351  
33352    if (postType && postId) {
33353      titleElement = userCanEdit && !isDescendentOfQueryLoop ? (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.PlainText, _extends({
33354        tagName: TagName,
33355        placeholder: (0,external_wp_i18n_namespaceObject.__)('No Title'),
33356        value: rawTitle,
33357        onChange: setTitle,
33358        __experimentalVersion: 2
33359      }, blockProps)) : (0,external_wp_element_namespaceObject.createElement)(TagName, _extends({}, blockProps, {
33360        dangerouslySetInnerHTML: {
33361          __html: fullTitle === null || fullTitle === void 0 ? void 0 : fullTitle.rendered
33362        }
33363      }));
33364    }
33365  
33366    if (isLink && postType && postId) {
33367      titleElement = userCanEdit && !isDescendentOfQueryLoop ? (0,external_wp_element_namespaceObject.createElement)(TagName, blockProps, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.PlainText, {
33368        tagName: "a",
33369        href: link,
33370        target: linkTarget,
33371        rel: rel,
33372        placeholder: !rawTitle.length ? (0,external_wp_i18n_namespaceObject.__)('No Title') : null,
33373        value: rawTitle,
33374        onChange: setTitle,
33375        __experimentalVersion: 2
33376      })) : (0,external_wp_element_namespaceObject.createElement)(TagName, blockProps, (0,external_wp_element_namespaceObject.createElement)("a", {
33377        href: link,
33378        target: linkTarget,
33379        rel: rel,
33380        onClick: event => event.preventDefault(),
33381        dangerouslySetInnerHTML: {
33382          __html: fullTitle === null || fullTitle === void 0 ? void 0 : fullTitle.rendered
33383        }
33384      }));
33385    }
33386  
33387    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, {
33388      group: "block"
33389    }, (0,external_wp_element_namespaceObject.createElement)(HeadingLevelDropdown, {
33390      selectedLevel: level,
33391      onChange: newLevel => setAttributes({
33392        level: newLevel
33393      })
33394    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.AlignmentControl, {
33395      value: textAlign,
33396      onChange: nextAlign => {
33397        setAttributes({
33398          textAlign: nextAlign
33399        });
33400      }
33401    })), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
33402      title: (0,external_wp_i18n_namespaceObject.__)('Link settings')
33403    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
33404      label: (0,external_wp_i18n_namespaceObject.__)('Make title a link'),
33405      onChange: () => setAttributes({
33406        isLink: !isLink
33407      }),
33408      checked: isLink
33409    }), isLink && (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
33410      label: (0,external_wp_i18n_namespaceObject.__)('Open in new tab'),
33411      onChange: value => setAttributes({
33412        linkTarget: value ? '_blank' : '_self'
33413      }),
33414      checked: linkTarget === '_blank'
33415    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TextControl, {
33416      label: (0,external_wp_i18n_namespaceObject.__)('Link rel'),
33417      value: rel,
33418      onChange: newRel => setAttributes({
33419        rel: newRel
33420      })
33421    })))), titleElement);
33422  }
33423  
33424  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/post-title/deprecated.js
33425  /**
33426   * Internal dependencies
33427   */
33428  
33429  const post_title_deprecated_v1 = {
33430    attributes: {
33431      textAlign: {
33432        type: 'string'
33433      },
33434      level: {
33435        type: 'number',
33436        default: 2
33437      },
33438      isLink: {
33439        type: 'boolean',
33440        default: false
33441      },
33442      rel: {
33443        type: 'string',
33444        attribute: 'rel',
33445        default: ''
33446      },
33447      linkTarget: {
33448        type: 'string',
33449        default: '_self'
33450      }
33451    },
33452    supports: {
33453      align: ['wide', 'full'],
33454      html: false,
33455      color: {
33456        gradients: true,
33457        link: true
33458      },
33459      spacing: {
33460        margin: true
33461      },
33462      typography: {
33463        fontSize: true,
33464        lineHeight: true,
33465        __experimentalFontFamily: true,
33466        __experimentalFontWeight: true,
33467        __experimentalFontStyle: true,
33468        __experimentalTextTransform: true
33469      }
33470    },
33471  
33472    save() {
33473      return null;
33474    },
33475  
33476    migrate: migrate_font_family,
33477  
33478    isEligible(_ref) {
33479      var _style$typography;
33480  
33481      let {
33482        style
33483      } = _ref;
33484      return style === null || style === void 0 ? void 0 : (_style$typography = style.typography) === null || _style$typography === void 0 ? void 0 : _style$typography.fontFamily;
33485    }
33486  
33487  };
33488  /**
33489   * New deprecations need to be placed first
33490   * for them to have higher priority.
33491   *
33492   * Old deprecations may need to be updated as well.
33493   *
33494   * See block-deprecation.md
33495   */
33496  
33497  /* harmony default export */ var post_title_deprecated = ([post_title_deprecated_v1]);
33498  
33499  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/post-title/index.js
33500  /**
33501   * WordPress dependencies
33502   */
33503  
33504  /**
33505   * Internal dependencies
33506   */
33507  
33508  const post_title_metadata = {
33509    $schema: "https://schemas.wp.org/trunk/block.json",
33510    apiVersion: 2,
33511    name: "core/post-title",
33512    title: "Post Title",
33513    category: "theme",
33514    description: "Displays the title of a post, page, or any other content-type.",
33515    textdomain: "default",
33516    usesContext: ["postId", "postType", "queryId"],
33517    attributes: {
33518      textAlign: {
33519        type: "string"
33520      },
33521      level: {
33522        type: "number",
33523        "default": 2
33524      },
33525      isLink: {
33526        type: "boolean",
33527        "default": false
33528      },
33529      rel: {
33530        type: "string",
33531        attribute: "rel",
33532        "default": ""
33533      },
33534      linkTarget: {
33535        type: "string",
33536        "default": "_self"
33537      }
33538    },
33539    supports: {
33540      align: ["wide", "full"],
33541      html: false,
33542      color: {
33543        gradients: true,
33544        link: true,
33545        __experimentalDefaultControls: {
33546          background: true,
33547          text: true,
33548          link: true
33549        }
33550      },
33551      spacing: {
33552        margin: true
33553      },
33554      typography: {
33555        fontSize: true,
33556        lineHeight: true,
33557        __experimentalFontFamily: true,
33558        __experimentalFontWeight: true,
33559        __experimentalFontStyle: true,
33560        __experimentalTextTransform: true,
33561        __experimentalLetterSpacing: true,
33562        __experimentalDefaultControls: {
33563          fontSize: true,
33564          fontAppearance: true,
33565          textTransform: true
33566        }
33567      }
33568    },
33569    style: "wp-block-post-title"
33570  };
33571  
33572  
33573  const {
33574    name: post_title_name
33575  } = post_title_metadata;
33576  
33577  const post_title_settings = {
33578    icon: post_title,
33579    edit: PostTitleEdit,
33580    deprecated: post_title_deprecated
33581  };
33582  
33583  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/preformatted.js
33584  
33585  
33586  /**
33587   * WordPress dependencies
33588   */
33589  
33590  const preformatted = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
33591    viewBox: "0 0 24 24",
33592    xmlns: "http://www.w3.org/2000/svg"
33593  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
33594    d: "M18 4H6c-1.1 0-2 .9-2 2v12c0 1.1.9 2 2 2h12c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zm.5 14c0 .3-.2.5-.5.5H6c-.3 0-.5-.2-.5-.5V6c0-.3.2-.5.5-.5h12c.3 0 .5.2.5.5v12zM7 16.5h6V15H7v1.5zm4-4h6V11h-6v1.5zM9 11H7v1.5h2V11zm6 5.5h2V15h-2v1.5z"
33595  }));
33596  /* harmony default export */ var library_preformatted = (preformatted);
33597  
33598  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/preformatted/edit.js
33599  
33600  
33601  
33602  /**
33603   * WordPress dependencies
33604   */
33605  
33606  
33607  function PreformattedEdit(_ref) {
33608    let {
33609      attributes,
33610      mergeBlocks,
33611      setAttributes,
33612      onRemove,
33613      style
33614    } = _ref;
33615    const {
33616      content
33617    } = attributes;
33618    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
33619      style
33620    });
33621    return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText, _extends({
33622      tagName: "pre",
33623      identifier: "content",
33624      preserveWhiteSpace: true,
33625      value: content,
33626      onChange: nextContent => {
33627        setAttributes({
33628          content: nextContent
33629        });
33630      },
33631      onRemove: onRemove,
33632      "aria-label": (0,external_wp_i18n_namespaceObject.__)('Preformatted text'),
33633      placeholder: (0,external_wp_i18n_namespaceObject.__)('Write preformatted text…'),
33634      onMerge: mergeBlocks
33635    }, blockProps, {
33636      __unstablePastePlainText: true
33637    }));
33638  }
33639  
33640  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/preformatted/save.js
33641  
33642  
33643  /**
33644   * WordPress dependencies
33645   */
33646  
33647  function preformatted_save_save(_ref) {
33648    let {
33649      attributes
33650    } = _ref;
33651    const {
33652      content
33653    } = attributes;
33654    return (0,external_wp_element_namespaceObject.createElement)("pre", external_wp_blockEditor_namespaceObject.useBlockProps.save(), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
33655      value: content
33656    }));
33657  }
33658  
33659  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/preformatted/transforms.js
33660  /**
33661   * WordPress dependencies
33662   */
33663  
33664  const preformatted_transforms_transforms = {
33665    from: [{
33666      type: 'block',
33667      blocks: ['core/code', 'core/paragraph'],
33668      transform: _ref => {
33669        let {
33670          content,
33671          anchor
33672        } = _ref;
33673        return (0,external_wp_blocks_namespaceObject.createBlock)('core/preformatted', {
33674          content,
33675          anchor
33676        });
33677      }
33678    }, {
33679      type: 'raw',
33680      isMatch: node => node.nodeName === 'PRE' && !(node.children.length === 1 && node.firstChild.nodeName === 'CODE'),
33681      schema: _ref2 => {
33682        let {
33683          phrasingContentSchema
33684        } = _ref2;
33685        return {
33686          pre: {
33687            children: phrasingContentSchema
33688          }
33689        };
33690      }
33691    }],
33692    to: [{
33693      type: 'block',
33694      blocks: ['core/paragraph'],
33695      transform: attributes => (0,external_wp_blocks_namespaceObject.createBlock)('core/paragraph', attributes)
33696    }, {
33697      type: 'block',
33698      blocks: ['core/code'],
33699      transform: attributes => (0,external_wp_blocks_namespaceObject.createBlock)('core/code', attributes)
33700    }]
33701  };
33702  /* harmony default export */ var preformatted_transforms = (preformatted_transforms_transforms);
33703  
33704  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/preformatted/index.js
33705  /**
33706   * WordPress dependencies
33707   */
33708  
33709  
33710  /**
33711   * Internal dependencies
33712   */
33713  
33714  
33715  const preformatted_metadata = {
33716    $schema: "https://schemas.wp.org/trunk/block.json",
33717    apiVersion: 2,
33718    name: "core/preformatted",
33719    title: "Preformatted",
33720    category: "text",
33721    description: "Add text that respects your spacing and tabs, and also allows styling.",
33722    textdomain: "default",
33723    attributes: {
33724      content: {
33725        type: "string",
33726        source: "html",
33727        selector: "pre",
33728        "default": "",
33729        __unstablePreserveWhiteSpace: true,
33730        __experimentalRole: "content"
33731      }
33732    },
33733    supports: {
33734      anchor: true,
33735      color: {
33736        gradients: true,
33737        __experimentalDefaultControls: {
33738          background: true,
33739          text: true
33740        }
33741      },
33742      typography: {
33743        fontSize: true,
33744        lineHeight: true,
33745        __experimentalFontStyle: true,
33746        __experimentalFontWeight: true,
33747        __experimentalLetterSpacing: true,
33748        __experimentalTextTransform: true,
33749        __experimentalDefaultControls: {
33750          fontSize: true
33751        }
33752      }
33753    },
33754    style: "wp-block-preformatted"
33755  };
33756  
33757  
33758  const {
33759    name: preformatted_name
33760  } = preformatted_metadata;
33761  
33762  const preformatted_settings = {
33763    icon: library_preformatted,
33764    example: {
33765      attributes: {
33766        /* eslint-disable @wordpress/i18n-no-collapsible-whitespace */
33767        // translators: Sample content for the Preformatted block. Can be replaced with a more locale-adequate work.
33768        content: (0,external_wp_i18n_namespaceObject.__)('EXT. XANADU - FAINT DAWN - 1940 (MINIATURE)\nWindow, very small in the distance, illuminated.\nAll around this is an almost totally black screen. Now, as the camera moves slowly towards the window which is almost a postage stamp in the frame, other forms appear;')
33769        /* eslint-enable @wordpress/i18n-no-collapsible-whitespace */
33770  
33771      }
33772    },
33773    transforms: preformatted_transforms,
33774    edit: PreformattedEdit,
33775    save: preformatted_save_save,
33776  
33777    merge(attributes, attributesToMerge) {
33778      return {
33779        content: attributes.content + attributesToMerge.content
33780      };
33781    }
33782  
33783  };
33784  
33785  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/pullquote.js
33786  
33787  
33788  /**
33789   * WordPress dependencies
33790   */
33791  
33792  const pullquote = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
33793    viewBox: "0 0 24 24",
33794    xmlns: "http://www.w3.org/2000/svg"
33795  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
33796    d: "M18 8H6c-1.1 0-2 .9-2 2v4c0 1.1.9 2 2 2h12c1.1 0 2-.9 2-2v-4c0-1.1-.9-2-2-2zm.5 6c0 .3-.2.5-.5.5H6c-.3 0-.5-.2-.5-.5v-4c0-.3.2-.5.5-.5h12c.3 0 .5.2.5.5v4zM4 4v1.5h16V4H4zm0 16h16v-1.5H4V20z"
33797  }));
33798  /* harmony default export */ var library_pullquote = (pullquote);
33799  
33800  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/pullquote/shared.js
33801  const SOLID_COLOR_CLASS = `is-style-solid-color`;
33802  
33803  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/pullquote/deprecated.js
33804  
33805  
33806  /**
33807   * External dependencies
33808   */
33809  
33810  
33811  /**
33812   * WordPress dependencies
33813   */
33814  
33815  
33816  
33817  /**
33818   * Internal dependencies
33819   */
33820  
33821  
33822  const pullquote_deprecated_blockAttributes = {
33823    value: {
33824      type: 'string',
33825      source: 'html',
33826      selector: 'blockquote',
33827      multiline: 'p'
33828    },
33829    citation: {
33830      type: 'string',
33831      source: 'html',
33832      selector: 'cite',
33833      default: ''
33834    },
33835    mainColor: {
33836      type: 'string'
33837    },
33838    customMainColor: {
33839      type: 'string'
33840    },
33841    textColor: {
33842      type: 'string'
33843    },
33844    customTextColor: {
33845      type: 'string'
33846    }
33847  };
33848  
33849  function parseBorderColor(styleString) {
33850    if (!styleString) {
33851      return;
33852    }
33853  
33854    const matches = styleString.match(/border-color:([^;]+)[;]?/);
33855  
33856    if (matches && matches[1]) {
33857      return matches[1];
33858    }
33859  } // TODO: this is ripe for a bit of a clean up according to the example in https://developer.wordpress.org/block-editor/reference-guides/block-api/block-deprecation/#example
33860  
33861  
33862  const pullquote_deprecated_deprecated = [{
33863    attributes: { ...pullquote_deprecated_blockAttributes
33864    },
33865  
33866    save(_ref) {
33867      let {
33868        attributes
33869      } = _ref;
33870      const {
33871        mainColor,
33872        customMainColor,
33873        customTextColor,
33874        textColor,
33875        value,
33876        citation,
33877        className
33878      } = attributes;
33879      const isSolidColorStyle = (0,external_lodash_namespaceObject.includes)(className, SOLID_COLOR_CLASS);
33880      let figureClasses, figureStyles; // Is solid color style
33881  
33882      if (isSolidColorStyle) {
33883        const backgroundClass = (0,external_wp_blockEditor_namespaceObject.getColorClassName)('background-color', mainColor);
33884        figureClasses = classnames_default()({
33885          'has-background': backgroundClass || customMainColor,
33886          [backgroundClass]: backgroundClass
33887        });
33888        figureStyles = {
33889          backgroundColor: backgroundClass ? undefined : customMainColor
33890        }; // Is normal style and a custom color is being used ( we can set a style directly with its value)
33891      } else if (customMainColor) {
33892        figureStyles = {
33893          borderColor: customMainColor
33894        };
33895      }
33896  
33897      const blockquoteTextColorClass = (0,external_wp_blockEditor_namespaceObject.getColorClassName)('color', textColor);
33898      const blockquoteClasses = classnames_default()({
33899        'has-text-color': textColor || customTextColor,
33900        [blockquoteTextColorClass]: blockquoteTextColorClass
33901      });
33902      const blockquoteStyles = blockquoteTextColorClass ? undefined : {
33903        color: customTextColor
33904      };
33905      return (0,external_wp_element_namespaceObject.createElement)("figure", external_wp_blockEditor_namespaceObject.useBlockProps.save({
33906        className: figureClasses,
33907        style: figureStyles
33908      }), (0,external_wp_element_namespaceObject.createElement)("blockquote", {
33909        className: blockquoteClasses,
33910        style: blockquoteStyles
33911      }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
33912        value: value,
33913        multiline: true
33914      }), !external_wp_blockEditor_namespaceObject.RichText.isEmpty(citation) && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
33915        tagName: "cite",
33916        value: citation
33917      })));
33918    },
33919  
33920    migrate(_ref2) {
33921      let {
33922        className,
33923        mainColor,
33924        customMainColor,
33925        customTextColor,
33926        ...attributes
33927      } = _ref2;
33928      const isSolidColorStyle = (0,external_lodash_namespaceObject.includes)(className, SOLID_COLOR_CLASS);
33929      let style;
33930  
33931      if (customMainColor) {
33932        if (!isSolidColorStyle) {
33933          // Block supports: Set style.border.color if a deprecated block has a default style and a `customMainColor` attribute.
33934          style = {
33935            border: {
33936              color: customMainColor
33937            }
33938          };
33939        } else {
33940          // Block supports: Set style.color.background if a deprecated block has a solid style and a `customMainColor` attribute.
33941          style = {
33942            color: {
33943              background: customMainColor
33944            }
33945          };
33946        }
33947      } // Block supports: Set style.color.text if a deprecated block has a `customTextColor` attribute.
33948  
33949  
33950      if (customTextColor && style) {
33951        style.color = { ...style.color,
33952          text: customTextColor
33953        };
33954      }
33955  
33956      return {
33957        className,
33958        backgroundColor: isSolidColorStyle ? mainColor : undefined,
33959        borderColor: isSolidColorStyle ? undefined : mainColor,
33960        textAlign: isSolidColorStyle ? 'left' : undefined,
33961        style,
33962        ...attributes
33963      };
33964    }
33965  
33966  }, {
33967    attributes: { ...pullquote_deprecated_blockAttributes,
33968      // figureStyle is an attribute that never existed.
33969      // We are using it as a way to access the styles previously applied to the figure.
33970      figureStyle: {
33971        source: 'attribute',
33972        selector: 'figure',
33973        attribute: 'style'
33974      }
33975    },
33976  
33977    save(_ref3) {
33978      let {
33979        attributes
33980      } = _ref3;
33981      const {
33982        mainColor,
33983        customMainColor,
33984        textColor,
33985        customTextColor,
33986        value,
33987        citation,
33988        className,
33989        figureStyle
33990      } = attributes;
33991      const isSolidColorStyle = (0,external_lodash_namespaceObject.includes)(className, SOLID_COLOR_CLASS);
33992      let figureClasses, figureStyles; // Is solid color style
33993  
33994      if (isSolidColorStyle) {
33995        const backgroundClass = (0,external_wp_blockEditor_namespaceObject.getColorClassName)('background-color', mainColor);
33996        figureClasses = classnames_default()({
33997          'has-background': backgroundClass || customMainColor,
33998          [backgroundClass]: backgroundClass
33999        });
34000        figureStyles = {
34001          backgroundColor: backgroundClass ? undefined : customMainColor
34002        }; // Is normal style and a custom color is being used ( we can set a style directly with its value)
34003      } else if (customMainColor) {
34004        figureStyles = {
34005          borderColor: customMainColor
34006        }; // If normal style and a named color are being used, we need to retrieve the color value to set the style,
34007        // as there is no expectation that themes create classes that set border colors.
34008      } else if (mainColor) {
34009        // Previously here we queried the color settings to know the color value
34010        // of a named color. This made the save function impure and the block was refactored,
34011        // because meanwhile a change in the editor made it impossible to query color settings in the save function.
34012        // Here instead of querying the color settings to know the color value, we retrieve the value
34013        // directly from the style previously serialized.
34014        const borderColor = parseBorderColor(figureStyle);
34015        figureStyles = {
34016          borderColor
34017        };
34018      }
34019  
34020      const blockquoteTextColorClass = (0,external_wp_blockEditor_namespaceObject.getColorClassName)('color', textColor);
34021      const blockquoteClasses = (textColor || customTextColor) && classnames_default()('has-text-color', {
34022        [blockquoteTextColorClass]: blockquoteTextColorClass
34023      });
34024      const blockquoteStyles = blockquoteTextColorClass ? undefined : {
34025        color: customTextColor
34026      };
34027      return (0,external_wp_element_namespaceObject.createElement)("figure", {
34028        className: figureClasses,
34029        style: figureStyles
34030      }, (0,external_wp_element_namespaceObject.createElement)("blockquote", {
34031        className: blockquoteClasses,
34032        style: blockquoteStyles
34033      }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
34034        value: value,
34035        multiline: true
34036      }), !external_wp_blockEditor_namespaceObject.RichText.isEmpty(citation) && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
34037        tagName: "cite",
34038        value: citation
34039      })));
34040    },
34041  
34042    migrate(_ref4) {
34043      let {
34044        className,
34045        figureStyle,
34046        mainColor,
34047        customMainColor,
34048        customTextColor,
34049        ...attributes
34050      } = _ref4;
34051      const isSolidColorStyle = (0,external_lodash_namespaceObject.includes)(className, SOLID_COLOR_CLASS);
34052      let style;
34053  
34054      if (customMainColor) {
34055        if (!isSolidColorStyle) {
34056          // Block supports: Set style.border.color if a deprecated block has a default style and a `customMainColor` attribute.
34057          style = {
34058            border: {
34059              color: customMainColor
34060            }
34061          };
34062        } else {
34063          // Block supports: Set style.color.background if a deprecated block has a solid style and a `customMainColor` attribute.
34064          style = {
34065            color: {
34066              background: customMainColor
34067            }
34068          };
34069        }
34070      } // Block supports: Set style.color.text if a deprecated block has a `customTextColor` attribute.
34071  
34072  
34073      if (customTextColor && style) {
34074        style.color = { ...style.color,
34075          text: customTextColor
34076        };
34077      } // If is the default style, and a main color is set,
34078      // migrate the main color value into a custom border color.
34079      // The custom border color value is retrieved by parsing the figure styles.
34080  
34081  
34082      if (!isSolidColorStyle && mainColor && figureStyle) {
34083        const borderColor = parseBorderColor(figureStyle);
34084  
34085        if (borderColor) {
34086          return { ...attributes,
34087            className,
34088            // Block supports: Set style.border.color if a deprecated block has `mainColor`, inline border CSS and is not a solid color style.
34089            style: {
34090              border: {
34091                color: borderColor
34092              }
34093            }
34094          };
34095        }
34096      }
34097  
34098      return {
34099        className,
34100        backgroundColor: isSolidColorStyle ? mainColor : undefined,
34101        borderColor: isSolidColorStyle ? undefined : mainColor,
34102        textAlign: isSolidColorStyle ? 'left' : undefined,
34103        style,
34104        ...attributes
34105      };
34106    }
34107  
34108  }, {
34109    attributes: pullquote_deprecated_blockAttributes,
34110  
34111    save(_ref5) {
34112      let {
34113        attributes
34114      } = _ref5;
34115      const {
34116        mainColor,
34117        customMainColor,
34118        textColor,
34119        customTextColor,
34120        value,
34121        citation,
34122        className
34123      } = attributes;
34124      const isSolidColorStyle = (0,external_lodash_namespaceObject.includes)(className, SOLID_COLOR_CLASS);
34125      let figureClass, figureStyles; // Is solid color style
34126  
34127      if (isSolidColorStyle) {
34128        figureClass = (0,external_wp_blockEditor_namespaceObject.getColorClassName)('background-color', mainColor);
34129  
34130        if (!figureClass) {
34131          figureStyles = {
34132            backgroundColor: customMainColor
34133          };
34134        } // Is normal style and a custom color is being used ( we can set a style directly with its value)
34135  
34136      } else if (customMainColor) {
34137        figureStyles = {
34138          borderColor: customMainColor
34139        }; // Is normal style and a named color is being used, we need to retrieve the color value to set the style,
34140        // as there is no expectation that themes create classes that set border colors.
34141      } else if (mainColor) {
34142        const colors = (0,external_lodash_namespaceObject.get)((0,external_wp_data_namespaceObject.select)(external_wp_blockEditor_namespaceObject.store).getSettings(), ['colors'], []);
34143        const colorObject = (0,external_wp_blockEditor_namespaceObject.getColorObjectByAttributeValues)(colors, mainColor);
34144        figureStyles = {
34145          borderColor: colorObject.color
34146        };
34147      }
34148  
34149      const blockquoteTextColorClass = (0,external_wp_blockEditor_namespaceObject.getColorClassName)('color', textColor);
34150      const blockquoteClasses = textColor || customTextColor ? classnames_default()('has-text-color', {
34151        [blockquoteTextColorClass]: blockquoteTextColorClass
34152      }) : undefined;
34153      const blockquoteStyle = blockquoteTextColorClass ? undefined : {
34154        color: customTextColor
34155      };
34156      return (0,external_wp_element_namespaceObject.createElement)("figure", {
34157        className: figureClass,
34158        style: figureStyles
34159      }, (0,external_wp_element_namespaceObject.createElement)("blockquote", {
34160        className: blockquoteClasses,
34161        style: blockquoteStyle
34162      }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
34163        value: value,
34164        multiline: true
34165      }), !external_wp_blockEditor_namespaceObject.RichText.isEmpty(citation) && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
34166        tagName: "cite",
34167        value: citation
34168      })));
34169    },
34170  
34171    migrate(_ref6) {
34172      let {
34173        className,
34174        mainColor,
34175        customMainColor,
34176        customTextColor,
34177        ...attributes
34178      } = _ref6;
34179      const isSolidColorStyle = (0,external_lodash_namespaceObject.includes)(className, SOLID_COLOR_CLASS);
34180      let style = {};
34181  
34182      if (customMainColor) {
34183        if (!isSolidColorStyle) {
34184          // Block supports: Set style.border.color if a deprecated block has a default style and a `customMainColor` attribute.
34185          style = {
34186            border: {
34187              color: customMainColor
34188            }
34189          };
34190        } else {
34191          // Block supports: Set style.color.background if a deprecated block has a solid style and a `customMainColor` attribute.
34192          style = {
34193            color: {
34194              background: customMainColor
34195            }
34196          };
34197        }
34198      } // Block supports: Set style.color.text if a deprecated block has a `customTextColor` attribute.
34199  
34200  
34201      if (customTextColor && style) {
34202        style.color = { ...style.color,
34203          text: customTextColor
34204        };
34205      }
34206  
34207      return {
34208        className,
34209        backgroundColor: isSolidColorStyle ? mainColor : undefined,
34210        borderColor: isSolidColorStyle ? undefined : mainColor,
34211        textAlign: isSolidColorStyle ? 'left' : undefined,
34212        style,
34213        ...attributes
34214      };
34215    }
34216  
34217  }, {
34218    attributes: { ...pullquote_deprecated_blockAttributes
34219    },
34220  
34221    save(_ref7) {
34222      let {
34223        attributes
34224      } = _ref7;
34225      const {
34226        value,
34227        citation
34228      } = attributes;
34229      return (0,external_wp_element_namespaceObject.createElement)("blockquote", null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
34230        value: value,
34231        multiline: true
34232      }), !external_wp_blockEditor_namespaceObject.RichText.isEmpty(citation) && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
34233        tagName: "cite",
34234        value: citation
34235      }));
34236    }
34237  
34238  }, {
34239    attributes: { ...pullquote_deprecated_blockAttributes,
34240      citation: {
34241        type: 'string',
34242        source: 'html',
34243        selector: 'footer'
34244      },
34245      align: {
34246        type: 'string',
34247        default: 'none'
34248      }
34249    },
34250  
34251    save(_ref8) {
34252      let {
34253        attributes
34254      } = _ref8;
34255      const {
34256        value,
34257        citation,
34258        align
34259      } = attributes;
34260      return (0,external_wp_element_namespaceObject.createElement)("blockquote", {
34261        className: `align$align}`
34262      }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
34263        value: value,
34264        multiline: true
34265      }), !external_wp_blockEditor_namespaceObject.RichText.isEmpty(citation) && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
34266        tagName: "footer",
34267        value: citation
34268      }));
34269    }
34270  
34271  }];
34272  /* harmony default export */ var pullquote_deprecated = (pullquote_deprecated_deprecated);
34273  
34274  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/pullquote/figure.js
34275  const Figure = 'figure';
34276  
34277  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/pullquote/blockquote.js
34278  const BlockQuote = 'blockquote';
34279  
34280  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/pullquote/edit.js
34281  
34282  
34283  /**
34284   * External dependencies
34285   */
34286  
34287  /**
34288   * WordPress dependencies
34289   */
34290  
34291  
34292  
34293  
34294  
34295  /**
34296   * Internal dependencies
34297   */
34298  
34299  
34300  
34301  const isWebPlatform = external_wp_element_namespaceObject.Platform.OS === 'web';
34302  
34303  function PullQuoteEdit(_ref) {
34304    let {
34305      attributes,
34306      setAttributes,
34307      isSelected,
34308      insertBlocksAfter
34309    } = _ref;
34310    const {
34311      textAlign,
34312      citation,
34313      value
34314    } = attributes;
34315    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
34316      className: classnames_default()({
34317        [`has-text-align-$textAlign}`]: textAlign
34318      })
34319    });
34320    const shouldShowCitation = !external_wp_blockEditor_namespaceObject.RichText.isEmpty(citation) || isSelected;
34321    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, {
34322      group: "block"
34323    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.AlignmentControl, {
34324      value: textAlign,
34325      onChange: nextAlign => {
34326        setAttributes({
34327          textAlign: nextAlign
34328        });
34329      }
34330    })), (0,external_wp_element_namespaceObject.createElement)(Figure, blockProps, (0,external_wp_element_namespaceObject.createElement)(BlockQuote, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText, {
34331      identifier: "value",
34332      multiline: true,
34333      value: value,
34334      onChange: nextValue => setAttributes({
34335        value: nextValue
34336      }),
34337      "aria-label": (0,external_wp_i18n_namespaceObject.__)('Pullquote text'),
34338      placeholder: // translators: placeholder text used for the quote
34339      (0,external_wp_i18n_namespaceObject.__)('Add quote'),
34340      textAlign: "center"
34341    }), shouldShowCitation && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText, {
34342      identifier: "citation",
34343      tagName: isWebPlatform ? 'cite' : undefined,
34344      style: {
34345        display: 'block'
34346      },
34347      value: citation,
34348      "aria-label": (0,external_wp_i18n_namespaceObject.__)('Pullquote citation text'),
34349      placeholder: // translators: placeholder text used for the citation
34350      (0,external_wp_i18n_namespaceObject.__)('Add citation'),
34351      onChange: nextCitation => setAttributes({
34352        citation: nextCitation
34353      }),
34354      className: "wp-block-pullquote__citation",
34355      __unstableMobileNoFocusOnMount: true,
34356      textAlign: "center",
34357      __unstableOnSplitAtEnd: () => insertBlocksAfter((0,external_wp_blocks_namespaceObject.createBlock)('core/paragraph'))
34358    }))));
34359  }
34360  
34361  /* harmony default export */ var pullquote_edit = (PullQuoteEdit);
34362  
34363  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/pullquote/save.js
34364  
34365  
34366  /**
34367   * External dependencies
34368   */
34369  
34370  /**
34371   * WordPress dependencies
34372   */
34373  
34374  
34375  function pullquote_save_save(_ref) {
34376    let {
34377      attributes
34378    } = _ref;
34379    const {
34380      textAlign,
34381      citation,
34382      value
34383    } = attributes;
34384    const shouldShowCitation = !external_wp_blockEditor_namespaceObject.RichText.isEmpty(citation);
34385    return (0,external_wp_element_namespaceObject.createElement)("figure", external_wp_blockEditor_namespaceObject.useBlockProps.save({
34386      className: classnames_default()({
34387        [`has-text-align-$textAlign}`]: textAlign
34388      })
34389    }), (0,external_wp_element_namespaceObject.createElement)("blockquote", null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
34390      value: value,
34391      multiline: true
34392    }), shouldShowCitation && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
34393      tagName: "cite",
34394      value: citation
34395    })));
34396  }
34397  
34398  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/pullquote/transforms.js
34399  /**
34400   * WordPress dependencies
34401   */
34402  
34403  
34404  const pullquote_transforms_transforms = {
34405    from: [{
34406      type: 'block',
34407      isMultiBlock: true,
34408      blocks: ['core/paragraph'],
34409      transform: attributes => {
34410        return (0,external_wp_blocks_namespaceObject.createBlock)('core/pullquote', {
34411          value: (0,external_wp_richText_namespaceObject.toHTMLString)({
34412            value: (0,external_wp_richText_namespaceObject.join)(attributes.map(_ref => {
34413              let {
34414                content
34415              } = _ref;
34416              return (0,external_wp_richText_namespaceObject.create)({
34417                html: content
34418              });
34419            }), '\u2028'),
34420            multilineTag: 'p'
34421          }),
34422          anchor: attributes.anchor
34423        });
34424      }
34425    }, {
34426      type: 'block',
34427      blocks: ['core/heading'],
34428      transform: _ref2 => {
34429        let {
34430          content,
34431          anchor
34432        } = _ref2;
34433        return (0,external_wp_blocks_namespaceObject.createBlock)('core/pullquote', {
34434          value: `<p>$content}</p>`,
34435          anchor
34436        });
34437      }
34438    }],
34439    to: [{
34440      type: 'block',
34441      blocks: ['core/paragraph'],
34442      transform: _ref3 => {
34443        let {
34444          value,
34445          citation
34446        } = _ref3;
34447        const paragraphs = [];
34448  
34449        if (value && value !== '<p></p>') {
34450          paragraphs.push(...(0,external_wp_richText_namespaceObject.split)((0,external_wp_richText_namespaceObject.create)({
34451            html: value,
34452            multilineTag: 'p'
34453          }), '\u2028').map(piece => (0,external_wp_blocks_namespaceObject.createBlock)('core/paragraph', {
34454            content: (0,external_wp_richText_namespaceObject.toHTMLString)({
34455              value: piece
34456            })
34457          })));
34458        }
34459  
34460        if (citation && citation !== '<p></p>') {
34461          paragraphs.push((0,external_wp_blocks_namespaceObject.createBlock)('core/paragraph', {
34462            content: citation
34463          }));
34464        }
34465  
34466        if (paragraphs.length === 0) {
34467          return (0,external_wp_blocks_namespaceObject.createBlock)('core/paragraph', {
34468            content: ''
34469          });
34470        }
34471  
34472        return paragraphs;
34473      }
34474    }, {
34475      type: 'block',
34476      blocks: ['core/heading'],
34477      transform: _ref4 => {
34478        let {
34479          value,
34480          citation,
34481          ...attrs
34482        } = _ref4;
34483  
34484        // If there is no pullquote content, use the citation as the
34485        // content of the resulting heading. A nonexistent citation
34486        // will result in an empty heading.
34487        if (value === '<p></p>') {
34488          return (0,external_wp_blocks_namespaceObject.createBlock)('core/heading', {
34489            content: citation
34490          });
34491        }
34492  
34493        const pieces = (0,external_wp_richText_namespaceObject.split)((0,external_wp_richText_namespaceObject.create)({
34494          html: value,
34495          multilineTag: 'p'
34496        }), '\u2028');
34497        const headingBlock = (0,external_wp_blocks_namespaceObject.createBlock)('core/heading', {
34498          content: (0,external_wp_richText_namespaceObject.toHTMLString)({
34499            value: pieces[0]
34500          })
34501        });
34502  
34503        if (!citation && pieces.length === 1) {
34504          return headingBlock;
34505        }
34506  
34507        const quotePieces = pieces.slice(1);
34508        const pullquoteBlock = (0,external_wp_blocks_namespaceObject.createBlock)('core/pullquote', { ...attrs,
34509          citation,
34510          value: (0,external_wp_richText_namespaceObject.toHTMLString)({
34511            value: quotePieces.length ? (0,external_wp_richText_namespaceObject.join)(pieces.slice(1), '\u2028') : (0,external_wp_richText_namespaceObject.create)(),
34512            multilineTag: 'p'
34513          })
34514        });
34515        return [headingBlock, pullquoteBlock];
34516      }
34517    }]
34518  };
34519  /* harmony default export */ var pullquote_transforms = (pullquote_transforms_transforms);
34520  
34521  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/pullquote/index.js
34522  /**
34523   * WordPress dependencies
34524   */
34525  
34526  
34527  /**
34528   * Internal dependencies
34529   */
34530  
34531  
34532  
34533  const pullquote_metadata = {
34534    $schema: "https://schemas.wp.org/trunk/block.json",
34535    apiVersion: 2,
34536    name: "core/pullquote",
34537    title: "Pullquote",
34538    category: "text",
34539    description: "Give special visual emphasis to a quote from your text.",
34540    textdomain: "default",
34541    attributes: {
34542      value: {
34543        type: "string",
34544        source: "html",
34545        selector: "blockquote",
34546        multiline: "p",
34547        __experimentalRole: "content"
34548      },
34549      citation: {
34550        type: "string",
34551        source: "html",
34552        selector: "cite",
34553        "default": "",
34554        __experimentalRole: "content"
34555      },
34556      textAlign: {
34557        type: "string"
34558      }
34559    },
34560    supports: {
34561      anchor: true,
34562      align: ["left", "right", "wide", "full"],
34563      color: {
34564        gradients: true,
34565        background: true,
34566        link: true,
34567        __experimentalDefaultControls: {
34568          background: true,
34569          text: true
34570        }
34571      },
34572      typography: {
34573        fontSize: true,
34574        lineHeight: true,
34575        __experimentalFontStyle: true,
34576        __experimentalFontWeight: true,
34577        __experimentalLetterSpacing: true,
34578        __experimentalTextTransform: true,
34579        __experimentalDefaultControls: {
34580          fontSize: true,
34581          fontAppearance: true
34582        }
34583      },
34584      __experimentalBorder: {
34585        color: true,
34586        radius: true,
34587        style: true,
34588        width: true,
34589        __experimentalDefaultControls: {
34590          color: true,
34591          radius: true,
34592          style: true,
34593          width: true
34594        }
34595      }
34596    },
34597    editorStyle: "wp-block-pullquote-editor",
34598    style: "wp-block-pullquote"
34599  };
34600  
34601  
34602  const {
34603    name: pullquote_name
34604  } = pullquote_metadata;
34605  
34606  const pullquote_settings = {
34607    icon: library_pullquote,
34608    example: {
34609      attributes: {
34610        value: '<p>' + // translators: Quote serving as example for the Pullquote block. Attributed to Matt Mullenweg.
34611        (0,external_wp_i18n_namespaceObject.__)('One of the hardest things to do in technology is disrupt yourself.') + '</p>',
34612        citation: (0,external_wp_i18n_namespaceObject.__)('Matt Mullenweg')
34613      }
34614    },
34615    transforms: pullquote_transforms,
34616    edit: pullquote_edit,
34617    save: pullquote_save_save,
34618    deprecated: pullquote_deprecated
34619  };
34620  
34621  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/loop.js
34622  
34623  
34624  /**
34625   * WordPress dependencies
34626   */
34627  
34628  const loop = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
34629    viewBox: "0 0 24 24",
34630    xmlns: "http://www.w3.org/2000/svg"
34631  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
34632    d: "M18.1823 11.6392C18.1823 13.0804 17.0139 14.2487 15.5727 14.2487C14.3579 14.2487 13.335 13.4179 13.0453 12.2922L13.0377 12.2625L13.0278 12.2335L12.3985 10.377L12.3942 10.3785C11.8571 8.64997 10.246 7.39405 8.33961 7.39405C5.99509 7.39405 4.09448 9.29465 4.09448 11.6392C4.09448 13.9837 5.99509 15.8843 8.33961 15.8843C8.88499 15.8843 9.40822 15.781 9.88943 15.5923L9.29212 14.0697C8.99812 14.185 8.67729 14.2487 8.33961 14.2487C6.89838 14.2487 5.73003 13.0804 5.73003 11.6392C5.73003 10.1979 6.89838 9.02959 8.33961 9.02959C9.55444 9.02959 10.5773 9.86046 10.867 10.9862L10.8772 10.9836L11.4695 12.7311C11.9515 14.546 13.6048 15.8843 15.5727 15.8843C17.9172 15.8843 19.8178 13.9837 19.8178 11.6392C19.8178 9.29465 17.9172 7.39404 15.5727 7.39404C15.0287 7.39404 14.5066 7.4968 14.0264 7.6847L14.6223 9.20781C14.9158 9.093 15.2358 9.02959 15.5727 9.02959C17.0139 9.02959 18.1823 10.1979 18.1823 11.6392Z"
34633  }));
34634  /* harmony default export */ var library_loop = (loop);
34635  
34636  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/settings.js
34637  
34638  
34639  /**
34640   * WordPress dependencies
34641   */
34642  
34643  const settings_settings = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
34644    xmlns: "http://www.w3.org/2000/svg",
34645    viewBox: "0 0 24 24"
34646  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
34647    d: "M14.5 13.8c-1.1 0-2.1.7-2.4 1.8H4V17h8.1c.3 1 1.3 1.8 2.4 1.8s2.1-.7 2.4-1.8H20v-1.5h-3.1c-.3-1-1.3-1.7-2.4-1.7zM11.9 7c-.3-1-1.3-1.8-2.4-1.8S7.4 6 7.1 7H4v1.5h3.1c.3 1 1.3 1.8 2.4 1.8s2.1-.7 2.4-1.8H20V7h-8.1z"
34648  }));
34649  /* harmony default export */ var library_settings = (settings_settings);
34650  
34651  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/query/edit/query-toolbar.js
34652  
34653  
34654  /**
34655   * WordPress dependencies
34656   */
34657  
34658  
34659  
34660  
34661  function QueryToolbar(_ref) {
34662    let {
34663      attributes: {
34664        query,
34665        displayLayout
34666      },
34667      setQuery,
34668      setDisplayLayout,
34669      openPatternSelectionModal
34670    } = _ref;
34671    const maxPageInputId = (0,external_wp_compose_namespaceObject.useInstanceId)(QueryToolbar, 'blocks-query-pagination-max-page-input');
34672    const displayLayoutControls = [{
34673      icon: library_list,
34674      title: (0,external_wp_i18n_namespaceObject.__)('List view'),
34675      onClick: () => setDisplayLayout({
34676        type: 'list'
34677      }),
34678      isActive: (displayLayout === null || displayLayout === void 0 ? void 0 : displayLayout.type) === 'list'
34679    }, {
34680      icon: library_grid,
34681      title: (0,external_wp_i18n_namespaceObject.__)('Grid view'),
34682      onClick: () => setDisplayLayout({
34683        type: 'flex',
34684        columns: (displayLayout === null || displayLayout === void 0 ? void 0 : displayLayout.columns) || 3
34685      }),
34686      isActive: (displayLayout === null || displayLayout === void 0 ? void 0 : displayLayout.type) === 'flex'
34687    }];
34688    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, !query.inherit && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarGroup, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Dropdown, {
34689      contentClassName: "block-library-query-toolbar__popover",
34690      renderToggle: _ref2 => {
34691        let {
34692          onToggle
34693        } = _ref2;
34694        return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, {
34695          icon: library_settings,
34696          label: (0,external_wp_i18n_namespaceObject.__)('Display settings'),
34697          onClick: onToggle
34698        });
34699      },
34700      renderContent: () => (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.BaseControl, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalNumberControl, {
34701        __unstableInputWidth: "60px",
34702        label: (0,external_wp_i18n_namespaceObject.__)('Items per Page'),
34703        labelPosition: "edge",
34704        min: 1,
34705        max: 100,
34706        onChange: value => {
34707          if (isNaN(value) || value < 1 || value > 100) {
34708            return;
34709          }
34710  
34711          setQuery({
34712            perPage: value
34713          });
34714        },
34715        step: "1",
34716        value: query.perPage,
34717        isDragEnabled: false
34718      })), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.BaseControl, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalNumberControl, {
34719        __unstableInputWidth: "60px",
34720        label: (0,external_wp_i18n_namespaceObject.__)('Offset'),
34721        labelPosition: "edge",
34722        min: 0,
34723        max: 100,
34724        onChange: value => {
34725          if (isNaN(value) || value < 0 || value > 100) {
34726            return;
34727          }
34728  
34729          setQuery({
34730            offset: value
34731          });
34732        },
34733        step: "1",
34734        value: query.offset,
34735        isDragEnabled: false
34736      })), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.BaseControl, {
34737        id: maxPageInputId,
34738        help: (0,external_wp_i18n_namespaceObject.__)('Limit the pages you want to show, even if the query has more results. To show all pages use 0 (zero).')
34739      }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalNumberControl, {
34740        id: maxPageInputId,
34741        __unstableInputWidth: "60px",
34742        label: (0,external_wp_i18n_namespaceObject.__)('Max page to show'),
34743        labelPosition: "edge",
34744        min: 0,
34745        onChange: value => {
34746          if (isNaN(value) || value < 0) {
34747            return;
34748          }
34749  
34750          setQuery({
34751            pages: value
34752          });
34753        },
34754        step: "1",
34755        value: query.pages,
34756        isDragEnabled: false
34757      })))
34758    })), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarGroup, {
34759      className: "wp-block-template-part__block-control-group"
34760    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, {
34761      onClick: openPatternSelectionModal
34762    }, (0,external_wp_i18n_namespaceObject.__)('Replace'))), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarGroup, {
34763      controls: displayLayoutControls
34764    }));
34765  }
34766  
34767  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/query/edit/inspector-controls/order-control.js
34768  
34769  
34770  /**
34771   * WordPress dependencies
34772   */
34773  
34774  
34775  const orderOptions = [{
34776    label: (0,external_wp_i18n_namespaceObject.__)('Newest to oldest'),
34777    value: 'date/desc'
34778  }, {
34779    label: (0,external_wp_i18n_namespaceObject.__)('Oldest to newest'),
34780    value: 'date/asc'
34781  }, {
34782    /* translators: label for ordering posts by title in ascending order */
34783    label: (0,external_wp_i18n_namespaceObject.__)('A → Z'),
34784    value: 'title/asc'
34785  }, {
34786    /* translators: label for ordering posts by title in descending order */
34787    label: (0,external_wp_i18n_namespaceObject.__)('Z → A'),
34788    value: 'title/desc'
34789  }];
34790  
34791  function OrderControl(_ref) {
34792    let {
34793      order,
34794      orderBy,
34795      onChange
34796    } = _ref;
34797    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SelectControl, {
34798      label: (0,external_wp_i18n_namespaceObject.__)('Order by'),
34799      value: `$orderBy}/$order}`,
34800      options: orderOptions,
34801      onChange: value => {
34802        const [newOrderBy, newOrder] = value.split('/');
34803        onChange({
34804          order: newOrder,
34805          orderBy: newOrderBy
34806        });
34807      }
34808    });
34809  }
34810  
34811  /* harmony default export */ var order_control = (OrderControl);
34812  
34813  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/query/utils.js
34814  /**
34815   * WordPress dependencies
34816   */
34817  
34818  
34819  
34820  /**
34821   * @typedef IHasNameAndId
34822   * @property {string|number} id   The entity's id.
34823   * @property {string}        name The entity's name.
34824   */
34825  
34826  /**
34827   * The object used in Query block that contains info and helper mappings
34828   * from an array of IHasNameAndId objects.
34829   *
34830   * @typedef {Object} QueryEntitiesInfo
34831   * @property {IHasNameAndId[]}               entities  The array of entities.
34832   * @property {Object<string, IHasNameAndId>} mapById   Object mapping with the id as key and the entity as value.
34833   * @property {Object<string, IHasNameAndId>} mapByName Object mapping with the name as key and the entity as value.
34834   * @property {string[]}                      names     Array with the entities' names.
34835   */
34836  
34837  /**
34838   * Returns a helper object with mapping from Objects that implement
34839   * the `IHasNameAndId` interface. The returned object is used for
34840   * integration with `FormTokenField` component.
34841   *
34842   * @param {IHasNameAndId[]} entities The entities to extract of helper object.
34843   * @return {QueryEntitiesInfo} The object with the entities information.
34844   */
34845  
34846  const getEntitiesInfo = entities => {
34847    const mapping = entities === null || entities === void 0 ? void 0 : entities.reduce((accumulator, entity) => {
34848      const {
34849        mapById,
34850        mapByName,
34851        names
34852      } = accumulator;
34853      mapById[entity.id] = entity;
34854      mapByName[entity.name] = entity;
34855      names.push(entity.name);
34856      return accumulator;
34857    }, {
34858      mapById: {},
34859      mapByName: {},
34860      names: []
34861    });
34862    return {
34863      entities,
34864      ...mapping
34865    };
34866  };
34867  /**
34868   * Returns a helper object that contains:
34869   * 1. An `options` object from the available post types, to be passed to a `SelectControl`.
34870   * 2. A helper map with available taxonomies per post type.
34871   *
34872   * @return {Object} The helper object related to post types.
34873   */
34874  
34875  const usePostTypes = () => {
34876    const postTypes = (0,external_wp_data_namespaceObject.useSelect)(select => {
34877      var _getPostTypes;
34878  
34879      const {
34880        getPostTypes
34881      } = select(external_wp_coreData_namespaceObject.store);
34882      const excludedPostTypes = ['attachment'];
34883      const filteredPostTypes = (_getPostTypes = getPostTypes({
34884        per_page: -1
34885      })) === null || _getPostTypes === void 0 ? void 0 : _getPostTypes.filter(_ref => {
34886        let {
34887          viewable,
34888          slug
34889        } = _ref;
34890        return viewable && !excludedPostTypes.includes(slug);
34891      });
34892      return filteredPostTypes;
34893    }, []);
34894    const postTypesTaxonomiesMap = (0,external_wp_element_namespaceObject.useMemo)(() => {
34895      if (!(postTypes !== null && postTypes !== void 0 && postTypes.length)) return;
34896      return postTypes.reduce((accumulator, type) => {
34897        accumulator[type.slug] = type.taxonomies;
34898        return accumulator;
34899      }, {});
34900    }, [postTypes]);
34901    const postTypesSelectOptions = (0,external_wp_element_namespaceObject.useMemo)(() => (postTypes || []).map(_ref2 => {
34902      let {
34903        labels,
34904        slug
34905      } = _ref2;
34906      return {
34907        label: labels.singular_name,
34908        value: slug
34909      };
34910    }), [postTypes]);
34911    return {
34912      postTypesTaxonomiesMap,
34913      postTypesSelectOptions
34914    };
34915  };
34916  /**
34917   * Hook that returns the taxonomies associated with a specific post type.
34918   *
34919   * @param {string} postType The post type from which to retrieve the associated taxonomies.
34920   * @return {Object[]} An array of the associated taxonomies.
34921   */
34922  
34923  const useTaxonomies = postType => {
34924    const taxonomies = (0,external_wp_data_namespaceObject.useSelect)(select => {
34925      const {
34926        getTaxonomies
34927      } = select(external_wp_coreData_namespaceObject.store);
34928      const filteredTaxonomies = getTaxonomies({
34929        type: postType,
34930        per_page: -1,
34931        context: 'view'
34932      });
34933      return filteredTaxonomies;
34934    }, [postType]);
34935    return taxonomies;
34936  };
34937  /**
34938   * Recurses over a list of blocks and returns the first found
34939   * Query Loop block's clientId.
34940   *
34941   * @param {WPBlock[]} blocks The list of blocks to look through.
34942   * @return {string=} The first found Query Loop's clientId.
34943   */
34944  
34945  const getFirstQueryClientIdFromBlocks = blocks => {
34946    const blocksQueue = [...blocks];
34947  
34948    while (blocksQueue.length > 0) {
34949      var _block$innerBlocks;
34950  
34951      const block = blocksQueue.shift();
34952  
34953      if (block.name === 'core/query') {
34954        return block.clientId;
34955      }
34956  
34957      (_block$innerBlocks = block.innerBlocks) === null || _block$innerBlocks === void 0 ? void 0 : _block$innerBlocks.forEach(innerBlock => {
34958        blocksQueue.push(innerBlock);
34959      });
34960    }
34961  };
34962  
34963  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/query/edit/inspector-controls/author-control.js
34964  
34965  
34966  /**
34967   * WordPress dependencies
34968   */
34969  
34970  
34971  
34972  
34973  /**
34974   * Internal dependencies
34975   */
34976  
34977  
34978  const author_control_AUTHORS_QUERY = {
34979    who: 'authors',
34980    per_page: -1,
34981    _fields: 'id,name',
34982    context: 'view'
34983  };
34984  
34985  function AuthorControl(_ref) {
34986    let {
34987      value,
34988      onChange
34989    } = _ref;
34990    const authorsList = (0,external_wp_data_namespaceObject.useSelect)(select => {
34991      const {
34992        getUsers
34993      } = select(external_wp_coreData_namespaceObject.store);
34994      return getUsers(author_control_AUTHORS_QUERY);
34995    }, []);
34996  
34997    if (!authorsList) {
34998      return null;
34999    }
35000  
35001    const authorsInfo = getEntitiesInfo(authorsList);
35002    /**
35003     * We need to normalize the value because the block operates on a
35004     * comma(`,`) separated string value and `FormTokenFiels` needs an
35005     * array.
35006     */
35007  
35008    const normalizedValue = !value ? [] : value.toString().split(','); // Returns only the existing authors ids. This prevents the component
35009    // from crashing in the editor, when non existing ids are provided.
35010  
35011    const sanitizedValue = normalizedValue.reduce((accumulator, authorId) => {
35012      const author = authorsInfo.mapById[authorId];
35013  
35014      if (author) {
35015        accumulator.push({
35016          id: authorId,
35017          value: author.name
35018        });
35019      }
35020  
35021      return accumulator;
35022    }, []);
35023  
35024    const getIdByValue = (entitiesMappedByName, authorValue) => {
35025      var _entitiesMappedByName;
35026  
35027      const id = (authorValue === null || authorValue === void 0 ? void 0 : authorValue.id) || ((_entitiesMappedByName = entitiesMappedByName[authorValue]) === null || _entitiesMappedByName === void 0 ? void 0 : _entitiesMappedByName.id);
35028      if (id) return id;
35029    };
35030  
35031    const onAuthorChange = newValue => {
35032      const ids = Array.from(newValue.reduce((accumulator, author) => {
35033        // Verify that new values point to existing entities.
35034        const id = getIdByValue(authorsInfo.mapByName, author);
35035        if (id) accumulator.add(id);
35036        return accumulator;
35037      }, new Set()));
35038      onChange({
35039        author: ids.join(',')
35040      });
35041    };
35042  
35043    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.FormTokenField, {
35044      label: (0,external_wp_i18n_namespaceObject.__)('Authors'),
35045      value: sanitizedValue,
35046      suggestions: authorsInfo.names,
35047      onChange: onAuthorChange
35048    });
35049  }
35050  
35051  /* harmony default export */ var author_control = (AuthorControl);
35052  
35053  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/query/constants.js
35054  const MAX_FETCHED_TERMS = 100;
35055  const DEFAULTS_POSTS_PER_PAGE = 3;
35056  /* harmony default export */ var constants = ({
35057    MAX_FETCHED_TERMS,
35058    DEFAULTS_POSTS_PER_PAGE
35059  });
35060  
35061  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/query/edit/inspector-controls/taxonomy-controls.js
35062  
35063  
35064  /**
35065   * WordPress dependencies
35066   */
35067  
35068  
35069  
35070  /**
35071   * Internal dependencies
35072   */
35073  
35074  
35075   // Helper function to get the term id based on user input in terms `FormTokenField`.
35076  
35077  const getTermIdByTermValue = (termsMappedByName, termValue) => {
35078    var _termsMappedByName$te;
35079  
35080    // First we check for exact match by `term.id` or case sensitive `term.name` match.
35081    const termId = (termValue === null || termValue === void 0 ? void 0 : termValue.id) || ((_termsMappedByName$te = termsMappedByName[termValue]) === null || _termsMappedByName$te === void 0 ? void 0 : _termsMappedByName$te.id);
35082    if (termId) return termId;
35083    /**
35084     * Here we make an extra check for entered terms in a non case sensitive way,
35085     * to match user expectations, due to `FormTokenField` behaviour that shows
35086     * suggestions which are case insensitive.
35087     *
35088     * Although WP tries to discourage users to add terms with the same name (case insensitive),
35089     * it's still possible if you manually change the name, as long as the terms have different slugs.
35090     * In this edge case we always apply the first match from the terms list.
35091     */
35092  
35093    const termValueLower = termValue.toLocaleLowerCase();
35094  
35095    for (const term in termsMappedByName) {
35096      if (term.toLocaleLowerCase() === termValueLower) {
35097        return termsMappedByName[term].id;
35098      }
35099    }
35100  };
35101  
35102  function TaxonomyControls(_ref) {
35103    let {
35104      onChange,
35105      query
35106    } = _ref;
35107    const taxonomies = useTaxonomies(query.postType);
35108    const taxonomiesInfo = (0,external_wp_data_namespaceObject.useSelect)(select => {
35109      const {
35110        getEntityRecords
35111      } = select(external_wp_coreData_namespaceObject.store);
35112      const termsQuery = {
35113        per_page: MAX_FETCHED_TERMS
35114      };
35115  
35116      const _taxonomiesInfo = taxonomies === null || taxonomies === void 0 ? void 0 : taxonomies.map(_ref2 => {
35117        let {
35118          slug,
35119          name
35120        } = _ref2;
35121  
35122        const _terms = getEntityRecords('taxonomy', slug, termsQuery);
35123  
35124        return {
35125          slug,
35126          name,
35127          terms: getEntitiesInfo(_terms)
35128        };
35129      });
35130  
35131      return _taxonomiesInfo;
35132    }, [taxonomies]);
35133  
35134    const onTermsChange = taxonomySlug => newTermValues => {
35135      const taxonomyInfo = taxonomiesInfo.find(_ref3 => {
35136        let {
35137          slug
35138        } = _ref3;
35139        return slug === taxonomySlug;
35140      });
35141      if (!taxonomyInfo) return;
35142      const termIds = Array.from(newTermValues.reduce((accumulator, termValue) => {
35143        const termId = getTermIdByTermValue(taxonomyInfo.terms.mapByName, termValue);
35144        if (termId) accumulator.add(termId);
35145        return accumulator;
35146      }, new Set()));
35147      const newTaxQuery = { ...query.taxQuery,
35148        [taxonomySlug]: termIds
35149      };
35150      onChange({
35151        taxQuery: newTaxQuery
35152      });
35153    }; // Returns only the existing term ids in proper format to be
35154    // used in `FormTokenField`. This prevents the component from
35155    // crashing in the editor, when non existing term ids were provided.
35156  
35157  
35158    const getExistingTaxQueryValue = taxonomySlug => {
35159      var _query$taxQuery;
35160  
35161      const taxonomyInfo = taxonomiesInfo.find(_ref4 => {
35162        let {
35163          slug
35164        } = _ref4;
35165        return slug === taxonomySlug;
35166      });
35167      if (!taxonomyInfo) return [];
35168      return (((_query$taxQuery = query.taxQuery) === null || _query$taxQuery === void 0 ? void 0 : _query$taxQuery[taxonomySlug]) || []).reduce((accumulator, termId) => {
35169        const term = taxonomyInfo.terms.mapById[termId];
35170  
35171        if (term) {
35172          accumulator.push({
35173            id: termId,
35174            value: term.name
35175          });
35176        }
35177  
35178        return accumulator;
35179      }, []);
35180    };
35181  
35182    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, !!(taxonomiesInfo !== null && taxonomiesInfo !== void 0 && taxonomiesInfo.length) && taxonomiesInfo.map(_ref5 => {
35183      var _terms$names;
35184  
35185      let {
35186        slug,
35187        name,
35188        terms
35189      } = _ref5;
35190  
35191      if (!(terms !== null && terms !== void 0 && (_terms$names = terms.names) !== null && _terms$names !== void 0 && _terms$names.length)) {
35192        return null;
35193      }
35194  
35195      return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.FormTokenField, {
35196        key: slug,
35197        label: name,
35198        value: getExistingTaxQueryValue(slug),
35199        suggestions: terms.names,
35200        onChange: onTermsChange(slug)
35201      });
35202    }));
35203  }
35204  
35205  /* harmony default export */ var taxonomy_controls = (TaxonomyControls);
35206  
35207  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/query/edit/inspector-controls/index.js
35208  
35209  
35210  /**
35211   * External dependencies
35212   */
35213  
35214  /**
35215   * WordPress dependencies
35216   */
35217  
35218  
35219  
35220  
35221  
35222  /**
35223   * Internal dependencies
35224   */
35225  
35226  
35227  
35228  
35229  
35230  const stickyOptions = [{
35231    label: (0,external_wp_i18n_namespaceObject.__)('Include'),
35232    value: ''
35233  }, {
35234    label: (0,external_wp_i18n_namespaceObject.__)('Exclude'),
35235    value: 'exclude'
35236  }, {
35237    label: (0,external_wp_i18n_namespaceObject.__)('Only'),
35238    value: 'only'
35239  }];
35240  function QueryInspectorControls(_ref) {
35241    let {
35242      attributes: {
35243        query,
35244        displayLayout
35245      },
35246      setQuery,
35247      setDisplayLayout
35248    } = _ref;
35249    const {
35250      order,
35251      orderBy,
35252      author: authorIds,
35253      postType,
35254      sticky,
35255      inherit,
35256      taxQuery
35257    } = query;
35258    const [showSticky, setShowSticky] = (0,external_wp_element_namespaceObject.useState)(postType === 'post');
35259    const {
35260      postTypesTaxonomiesMap,
35261      postTypesSelectOptions
35262    } = usePostTypes();
35263    (0,external_wp_element_namespaceObject.useEffect)(() => {
35264      setShowSticky(postType === 'post');
35265    }, [postType]);
35266  
35267    const onPostTypeChange = newValue => {
35268      const updateQuery = {
35269        postType: newValue
35270      }; // We need to dynamically update the `taxQuery` property,
35271      // by removing any not supported taxonomy from the query.
35272  
35273      const supportedTaxonomies = postTypesTaxonomiesMap[newValue];
35274      const updatedTaxQuery = Object.entries(taxQuery || {}).reduce((accumulator, _ref2) => {
35275        let [taxonomySlug, terms] = _ref2;
35276  
35277        if (supportedTaxonomies.includes(taxonomySlug)) {
35278          accumulator[taxonomySlug] = terms;
35279        }
35280  
35281        return accumulator;
35282      }, {});
35283      updateQuery.taxQuery = !!Object.keys(updatedTaxQuery).length ? updatedTaxQuery : undefined;
35284  
35285      if (newValue !== 'post') {
35286        updateQuery.sticky = '';
35287      }
35288  
35289      setQuery(updateQuery);
35290    };
35291  
35292    const [querySearch, setQuerySearch] = (0,external_wp_element_namespaceObject.useState)(query.search);
35293    const onChangeDebounced = (0,external_wp_element_namespaceObject.useCallback)((0,external_lodash_namespaceObject.debounce)(() => {
35294      if (query.search !== querySearch) {
35295        setQuery({
35296          search: querySearch
35297        });
35298      }
35299    }, 250), [querySearch, query.search]);
35300    (0,external_wp_element_namespaceObject.useEffect)(() => {
35301      onChangeDebounced();
35302      return onChangeDebounced.cancel;
35303    }, [querySearch, onChangeDebounced]);
35304    return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
35305      title: (0,external_wp_i18n_namespaceObject.__)('Settings')
35306    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
35307      label: (0,external_wp_i18n_namespaceObject.__)('Inherit query from template'),
35308      help: (0,external_wp_i18n_namespaceObject.__)('Toggle to use the global query context that is set with the current template, such as an archive or search. Disable to customize the settings independently.'),
35309      checked: !!inherit,
35310      onChange: value => setQuery({
35311        inherit: !!value
35312      })
35313    }), !inherit && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SelectControl, {
35314      options: postTypesSelectOptions,
35315      value: postType,
35316      label: (0,external_wp_i18n_namespaceObject.__)('Post type'),
35317      onChange: onPostTypeChange,
35318      help: (0,external_wp_i18n_namespaceObject.__)('WordPress contains different types of content and they are divided into collections called "Post types". By default there are a few different ones such as blog posts and pages, but plugins could add more.')
35319    }), (displayLayout === null || displayLayout === void 0 ? void 0 : displayLayout.type) === 'flex' && (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.RangeControl, {
35320      label: (0,external_wp_i18n_namespaceObject.__)('Columns'),
35321      value: displayLayout.columns,
35322      onChange: value => setDisplayLayout({
35323        columns: value
35324      }),
35325      min: 2,
35326      max: Math.max(6, displayLayout.columns)
35327    }), displayLayout.columns > 6 && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Notice, {
35328      status: "warning",
35329      isDismissible: false
35330    }, (0,external_wp_i18n_namespaceObject.__)('This column count exceeds the recommended amount and may cause visual breakage.'))), !inherit && (0,external_wp_element_namespaceObject.createElement)(order_control, {
35331      order,
35332      orderBy,
35333      onChange: setQuery
35334    }), showSticky && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SelectControl, {
35335      label: (0,external_wp_i18n_namespaceObject.__)('Sticky posts'),
35336      options: stickyOptions,
35337      value: sticky,
35338      onChange: value => setQuery({
35339        sticky: value
35340      }),
35341      help: (0,external_wp_i18n_namespaceObject.__)('Blog posts can be "stickied", a feature that places them at the top of the front page of posts, keeping it there until new sticky posts are published.')
35342    })), !inherit && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
35343      title: (0,external_wp_i18n_namespaceObject.__)('Filters')
35344    }, (0,external_wp_element_namespaceObject.createElement)(taxonomy_controls, {
35345      onChange: setQuery,
35346      query: query
35347    }), (0,external_wp_element_namespaceObject.createElement)(author_control, {
35348      value: authorIds,
35349      onChange: setQuery
35350    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TextControl, {
35351      label: (0,external_wp_i18n_namespaceObject.__)('Keyword'),
35352      value: querySearch,
35353      onChange: setQuerySearch
35354    })));
35355  }
35356  
35357  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/query/edit/query-placeholder.js
35358  
35359  
35360  /**
35361   * WordPress dependencies
35362   */
35363  
35364  
35365  
35366  
35367  function QueryPlaceholder(_ref) {
35368    let {
35369      clientId,
35370      name,
35371      setAttributes,
35372      icon,
35373      label
35374    } = _ref;
35375    const {
35376      defaultVariation,
35377      scopeVariations
35378    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
35379      const {
35380        getBlockVariations,
35381        getBlockType,
35382        getDefaultBlockVariation
35383      } = select(external_wp_blocks_namespaceObject.store);
35384      return {
35385        blockType: getBlockType(name),
35386        defaultVariation: getDefaultBlockVariation(name, 'block'),
35387        scopeVariations: getBlockVariations(name, 'block')
35388      };
35389    }, [name]);
35390    const {
35391      replaceInnerBlocks
35392    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_blockEditor_namespaceObject.store);
35393    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)();
35394    return (0,external_wp_element_namespaceObject.createElement)("div", blockProps, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.__experimentalBlockVariationPicker, {
35395      icon: icon,
35396      label: label,
35397      variations: scopeVariations,
35398      onSelect: function () {
35399        let nextVariation = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : defaultVariation;
35400  
35401        if (nextVariation.attributes) {
35402          setAttributes(nextVariation.attributes);
35403        }
35404  
35405        if (nextVariation.innerBlocks) {
35406          replaceInnerBlocks(clientId, (0,external_wp_blocks_namespaceObject.createBlocksFromInnerBlocksTemplate)(nextVariation.innerBlocks), false);
35407        }
35408      }
35409    }));
35410  }
35411  
35412  /* harmony default export */ var query_placeholder = (QueryPlaceholder);
35413  
35414  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/query/edit/index.js
35415  
35416  
35417  
35418  /**
35419   * WordPress dependencies
35420   */
35421  
35422  
35423  
35424  
35425  
35426  
35427  
35428  /**
35429   * Internal dependencies
35430   */
35431  
35432  
35433  
35434  
35435  
35436  
35437  const query_edit_TEMPLATE = [['core/post-template']];
35438  function QueryContent(_ref) {
35439    let {
35440      attributes,
35441      setAttributes,
35442      openPatternSelectionModal
35443    } = _ref;
35444    const {
35445      queryId,
35446      query,
35447      displayLayout,
35448      tagName: TagName = 'div',
35449      layout = {}
35450    } = attributes;
35451    const {
35452      __unstableMarkNextChangeAsNotPersistent
35453    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_blockEditor_namespaceObject.store);
35454    const instanceId = (0,external_wp_compose_namespaceObject.useInstanceId)(QueryContent);
35455    const {
35456      themeSupportsLayout
35457    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
35458      var _getSettings;
35459  
35460      const {
35461        getSettings
35462      } = select(external_wp_blockEditor_namespaceObject.store);
35463      return {
35464        themeSupportsLayout: (_getSettings = getSettings()) === null || _getSettings === void 0 ? void 0 : _getSettings.supportsLayout
35465      };
35466    }, []);
35467    const defaultLayout = (0,external_wp_blockEditor_namespaceObject.useSetting)('layout') || {};
35468    const usedLayout = !!layout && layout.inherit ? defaultLayout : layout;
35469    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)();
35470    const innerBlocksProps = (0,external_wp_blockEditor_namespaceObject.useInnerBlocksProps)(blockProps, {
35471      template: query_edit_TEMPLATE,
35472      __experimentalLayout: themeSupportsLayout ? usedLayout : undefined
35473    });
35474    const {
35475      postsPerPage
35476    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
35477      const {
35478        getSettings
35479      } = select(external_wp_blockEditor_namespaceObject.store);
35480      return {
35481        postsPerPage: +getSettings().postsPerPage || DEFAULTS_POSTS_PER_PAGE
35482      };
35483    }, []); // There are some effects running where some initialization logic is
35484    // happening and setting some values to some attributes (ex. queryId).
35485    // These updates can cause an `undo trap` where undoing will result in
35486    // resetting again, so we need to mark these changes as not persistent
35487    // with `__unstableMarkNextChangeAsNotPersistent`.
35488    // Changes in query property (which is an object) need to be in the same callback,
35489    // because updates are batched after the render and changes in different query properties
35490    // would cause to override previous wanted changes.
35491  
35492    (0,external_wp_element_namespaceObject.useEffect)(() => {
35493      const newQuery = {};
35494  
35495      if (!query.perPage && postsPerPage) {
35496        newQuery.perPage = postsPerPage;
35497      }
35498  
35499      if (!!Object.keys(newQuery).length) {
35500        __unstableMarkNextChangeAsNotPersistent();
35501  
35502        updateQuery(newQuery);
35503      }
35504    }, [query.perPage]); // We need this for multi-query block pagination.
35505    // Query parameters for each block are scoped to their ID.
35506  
35507    (0,external_wp_element_namespaceObject.useEffect)(() => {
35508      if (!Number.isFinite(queryId)) {
35509        __unstableMarkNextChangeAsNotPersistent();
35510  
35511        setAttributes({
35512          queryId: instanceId
35513        });
35514      }
35515    }, [queryId, instanceId]);
35516  
35517    const updateQuery = newQuery => setAttributes({
35518      query: { ...query,
35519        ...newQuery
35520      }
35521    });
35522  
35523    const updateDisplayLayout = newDisplayLayout => setAttributes({
35524      displayLayout: { ...displayLayout,
35525        ...newDisplayLayout
35526      }
35527    });
35528  
35529    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(QueryInspectorControls, {
35530      attributes: attributes,
35531      setQuery: updateQuery,
35532      setDisplayLayout: updateDisplayLayout
35533    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, null, (0,external_wp_element_namespaceObject.createElement)(QueryToolbar, {
35534      attributes: attributes,
35535      setQuery: updateQuery,
35536      setDisplayLayout: updateDisplayLayout,
35537      openPatternSelectionModal: openPatternSelectionModal
35538    })), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, {
35539      __experimentalGroup: "advanced"
35540    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SelectControl, {
35541      label: (0,external_wp_i18n_namespaceObject.__)('HTML element'),
35542      options: [{
35543        label: (0,external_wp_i18n_namespaceObject.__)('Default (<div>)'),
35544        value: 'div'
35545      }, {
35546        label: '<main>',
35547        value: 'main'
35548      }, {
35549        label: '<section>',
35550        value: 'section'
35551      }, {
35552        label: '<aside>',
35553        value: 'aside'
35554      }],
35555      value: TagName,
35556      onChange: value => setAttributes({
35557        tagName: value
35558      })
35559    })), (0,external_wp_element_namespaceObject.createElement)(TagName, innerBlocksProps));
35560  }
35561  
35562  function QueryPatternSetup(_ref2) {
35563    var _blockType$icon;
35564  
35565    let {
35566      attributes,
35567      clientId,
35568      name,
35569      openPatternSelectionModal,
35570      setAttributes
35571    } = _ref2;
35572    const [isStartingBlank, setIsStartingBlank] = (0,external_wp_element_namespaceObject.useState)(false);
35573    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)();
35574    const {
35575      blockType,
35576      allVariations,
35577      hasPatterns
35578    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
35579      const {
35580        getBlockVariations,
35581        getBlockType
35582      } = select(external_wp_blocks_namespaceObject.store);
35583      const {
35584        getBlockRootClientId,
35585        __experimentalGetPatternsByBlockTypes
35586      } = select(external_wp_blockEditor_namespaceObject.store);
35587      const rootClientId = getBlockRootClientId(clientId);
35588      return {
35589        blockType: getBlockType(name),
35590        allVariations: getBlockVariations(name),
35591        hasPatterns: !!__experimentalGetPatternsByBlockTypes(name, rootClientId).length
35592      };
35593    }, [name, clientId]);
35594    const matchingVariation = (0,external_wp_blockEditor_namespaceObject.__experimentalGetMatchingVariation)(attributes, allVariations);
35595    const icon = (matchingVariation === null || matchingVariation === void 0 ? void 0 : matchingVariation.icon) || (blockType === null || blockType === void 0 ? void 0 : (_blockType$icon = blockType.icon) === null || _blockType$icon === void 0 ? void 0 : _blockType$icon.src);
35596    const label = (matchingVariation === null || matchingVariation === void 0 ? void 0 : matchingVariation.title) || (blockType === null || blockType === void 0 ? void 0 : blockType.title);
35597  
35598    if (isStartingBlank) {
35599      return (0,external_wp_element_namespaceObject.createElement)(query_placeholder, {
35600        clientId: clientId,
35601        name: name,
35602        setAttributes: setAttributes,
35603        icon: icon,
35604        label: label
35605      });
35606    }
35607  
35608    return (0,external_wp_element_namespaceObject.createElement)("div", blockProps, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Placeholder, {
35609      icon: icon,
35610      label: label,
35611      instructions: (0,external_wp_i18n_namespaceObject.__)('Choose a pattern for the query loop or start blank.')
35612    }, !!hasPatterns && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
35613      variant: "primary",
35614      onClick: openPatternSelectionModal
35615    }, (0,external_wp_i18n_namespaceObject.__)('Choose')), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
35616      variant: "secondary",
35617      onClick: () => {
35618        setIsStartingBlank(true);
35619      }
35620    }, (0,external_wp_i18n_namespaceObject.__)('Start blank'))));
35621  }
35622  
35623  const QueryEdit = props => {
35624    const {
35625      clientId,
35626      name
35627    } = props;
35628    const [isPatternSelectionModalOpen, setIsPatternSelectionModalOpen] = (0,external_wp_element_namespaceObject.useState)(false);
35629    const {
35630      replaceBlock,
35631      selectBlock
35632    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_blockEditor_namespaceObject.store);
35633    const hasInnerBlocks = (0,external_wp_data_namespaceObject.useSelect)(select => !!select(external_wp_blockEditor_namespaceObject.store).getBlocks(clientId).length, [clientId]);
35634    const Component = hasInnerBlocks ? QueryContent : QueryPatternSetup;
35635  
35636    const onBlockPatternSelect = blocks => {
35637      const clonedBlocks = blocks.map(block => (0,external_wp_blocks_namespaceObject.cloneBlock)(block));
35638      const firstQueryClientId = getFirstQueryClientIdFromBlocks(clonedBlocks);
35639      replaceBlock(clientId, clonedBlocks);
35640  
35641      if (firstQueryClientId) {
35642        selectBlock(firstQueryClientId);
35643      }
35644    };
35645  
35646    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(Component, _extends({}, props, {
35647      openPatternSelectionModal: () => setIsPatternSelectionModalOpen(true)
35648    })), isPatternSelectionModalOpen && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Modal, {
35649      className: "block-editor-query-pattern__selection-modal",
35650      title: (0,external_wp_i18n_namespaceObject.__)('Choose a pattern'),
35651      closeLabel: (0,external_wp_i18n_namespaceObject.__)('Cancel'),
35652      onRequestClose: () => setIsPatternSelectionModalOpen(false)
35653    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.__experimentalBlockPatternSetup, {
35654      blockName: name,
35655      clientId: clientId,
35656      onBlockPatternSelect: onBlockPatternSelect
35657    })));
35658  };
35659  
35660  /* harmony default export */ var query_edit = (QueryEdit);
35661  
35662  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/query/save.js
35663  
35664  
35665  /**
35666   * WordPress dependencies
35667   */
35668  
35669  function QuerySave(_ref) {
35670    let {
35671      attributes: {
35672        tagName: Tag = 'div'
35673      }
35674    } = _ref;
35675    const blockProps = external_wp_blockEditor_namespaceObject.useBlockProps.save();
35676    const innerBlocksProps = external_wp_blockEditor_namespaceObject.useInnerBlocksProps.save(blockProps);
35677    return (0,external_wp_element_namespaceObject.createElement)(Tag, innerBlocksProps);
35678  }
35679  
35680  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/query/icons.js
35681  
35682  
35683  /**
35684   * WordPress dependencies
35685   */
35686  
35687  const titleDate = (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, {
35688    xmlns: "http://www.w3.org/2000/svg",
35689    viewBox: "0 0 48 48"
35690  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
35691    d: "M41 9H7v3h34V9zm-22 5H7v1h12v-1zM7 26h12v1H7v-1zm34-5H7v3h34v-3zM7 38h12v1H7v-1zm34-5H7v3h34v-3z"
35692  }));
35693  const titleExcerpt = (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, {
35694    xmlns: "http://www.w3.org/2000/svg",
35695    viewBox: "0 0 48 48"
35696  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
35697    d: "M41 9H7v3h34V9zm-4 5H7v1h30v-1zm4 3H7v1h34v-1zM7 20h30v1H7v-1zm0 12h30v1H7v-1zm34 3H7v1h34v-1zM7 38h30v1H7v-1zm34-11H7v3h34v-3z"
35698  }));
35699  const titleDateExcerpt = (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, {
35700    xmlns: "http://www.w3.org/2000/svg",
35701    viewBox: "0 0 48 48"
35702  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
35703    d: "M41 9H7v3h34V9zm-22 5H7v1h12v-1zm22 3H7v1h34v-1zM7 20h34v1H7v-1zm0 12h12v1H7v-1zm34 3H7v1h34v-1zM7 38h34v1H7v-1zm34-11H7v3h34v-3z"
35704  }));
35705  const imageDateTitle = (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, {
35706    xmlns: "http://www.w3.org/2000/svg",
35707    viewBox: "0 0 48 48"
35708  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
35709    d: "M7 9h34v6H7V9zm12 8H7v1h12v-1zm18 3H7v1h30v-1zm0 18H7v1h30v-1zM7 35h12v1H7v-1zm34-8H7v6h34v-6z"
35710  }));
35711  
35712  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/query/variations.js
35713  /**
35714   * WordPress dependencies
35715   */
35716  
35717  
35718  /**
35719   * Internal dependencies
35720   */
35721  
35722  
35723  const QUERY_DEFAULT_ATTRIBUTES = {
35724    query: {
35725      perPage: 3,
35726      pages: 0,
35727      offset: 0,
35728      postType: 'post',
35729      order: 'desc',
35730      orderBy: 'date',
35731      author: '',
35732      search: '',
35733      exclude: [],
35734      sticky: '',
35735      inherit: false
35736    }
35737  };
35738  const query_variations_variations = [{
35739    name: 'posts-list',
35740    title: (0,external_wp_i18n_namespaceObject.__)('Posts List'),
35741    description: (0,external_wp_i18n_namespaceObject.__)('Display a list of your most recent posts, excluding sticky posts.'),
35742    icon: post_list,
35743    attributes: {
35744      query: {
35745        perPage: 4,
35746        pages: 1,
35747        offset: 0,
35748        postType: 'post',
35749        order: 'desc',
35750        orderBy: 'date',
35751        author: '',
35752        search: '',
35753        sticky: 'exclude',
35754        inherit: false
35755      }
35756    },
35757    scope: ['inserter']
35758  }, {
35759    name: 'title-date',
35760    title: (0,external_wp_i18n_namespaceObject.__)('Title & Date'),
35761    icon: titleDate,
35762    attributes: { ...QUERY_DEFAULT_ATTRIBUTES
35763    },
35764    innerBlocks: [['core/post-template', {}, [['core/post-title'], ['core/post-date']]], ['core/query-pagination'], ['core/query-no-results']],
35765    scope: ['block']
35766  }, {
35767    name: 'title-excerpt',
35768    title: (0,external_wp_i18n_namespaceObject.__)('Title & Excerpt'),
35769    icon: titleExcerpt,
35770    attributes: { ...QUERY_DEFAULT_ATTRIBUTES
35771    },
35772    innerBlocks: [['core/post-template', {}, [['core/post-title'], ['core/post-excerpt']]], ['core/query-pagination'], ['core/query-no-results']],
35773    scope: ['block']
35774  }, {
35775    name: 'title-date-excerpt',
35776    title: (0,external_wp_i18n_namespaceObject.__)('Title, Date, & Excerpt'),
35777    icon: titleDateExcerpt,
35778    attributes: { ...QUERY_DEFAULT_ATTRIBUTES
35779    },
35780    innerBlocks: [['core/post-template', {}, [['core/post-title'], ['core/post-date'], ['core/post-excerpt']]], ['core/query-pagination'], ['core/query-no-results']],
35781    scope: ['block']
35782  }, {
35783    name: 'image-date-title',
35784    title: (0,external_wp_i18n_namespaceObject.__)('Image, Date, & Title'),
35785    icon: imageDateTitle,
35786    attributes: { ...QUERY_DEFAULT_ATTRIBUTES
35787    },
35788    innerBlocks: [['core/post-template', {}, [['core/post-featured-image'], ['core/post-date'], ['core/post-title']]], ['core/query-pagination'], ['core/query-no-results']],
35789    scope: ['block']
35790  }];
35791  /* harmony default export */ var query_variations = (query_variations_variations);
35792  
35793  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/query/deprecated.js
35794  
35795  
35796  /**
35797   * External dependencies
35798   */
35799  
35800  /**
35801   * WordPress dependencies
35802   */
35803  
35804  
35805  
35806  const migrateToTaxQuery = attributes => {
35807    var _query$categoryIds, _query$tagIds;
35808  
35809    const {
35810      query
35811    } = attributes;
35812    const newQuery = { ...(0,external_lodash_namespaceObject.omit)(query, ['categoryIds', 'tagIds'])
35813    };
35814  
35815    if ((_query$categoryIds = query.categoryIds) !== null && _query$categoryIds !== void 0 && _query$categoryIds.length || (_query$tagIds = query.tagIds) !== null && _query$tagIds !== void 0 && _query$tagIds.length) {
35816      var _query$categoryIds2, _query$tagIds2;
35817  
35818      newQuery.taxQuery = {
35819        category: !!((_query$categoryIds2 = query.categoryIds) !== null && _query$categoryIds2 !== void 0 && _query$categoryIds2.length) ? query.categoryIds : undefined,
35820        post_tag: !!((_query$tagIds2 = query.tagIds) !== null && _query$tagIds2 !== void 0 && _query$tagIds2.length) ? query.tagIds : undefined
35821      };
35822    }
35823  
35824    return { ...attributes,
35825      query: newQuery
35826    };
35827  };
35828  
35829  const query_deprecated_deprecated = [// Version with `categoryIds and tagIds`.
35830  {
35831    attributes: {
35832      queryId: {
35833        type: 'number'
35834      },
35835      query: {
35836        type: 'object',
35837        default: {
35838          perPage: null,
35839          pages: 0,
35840          offset: 0,
35841          postType: 'post',
35842          categoryIds: [],
35843          tagIds: [],
35844          order: 'desc',
35845          orderBy: 'date',
35846          author: '',
35847          search: '',
35848          exclude: [],
35849          sticky: '',
35850          inherit: true
35851        }
35852      },
35853      tagName: {
35854        type: 'string',
35855        default: 'div'
35856      },
35857      displayLayout: {
35858        type: 'object',
35859        default: {
35860          type: 'list'
35861        }
35862      }
35863    },
35864    supports: {
35865      align: ['wide', 'full'],
35866      html: false,
35867      color: {
35868        gradients: true,
35869        link: true
35870      },
35871      __experimentalLayout: true
35872    },
35873    isEligible: _ref => {
35874      let {
35875        query: {
35876          categoryIds,
35877          tagIds
35878        } = {}
35879      } = _ref;
35880      return categoryIds || tagIds;
35881    },
35882    migrate: migrateToTaxQuery,
35883  
35884    save(_ref2) {
35885      let {
35886        attributes: {
35887          tagName: Tag = 'div'
35888        }
35889      } = _ref2;
35890      const blockProps = external_wp_blockEditor_namespaceObject.useBlockProps.save();
35891      const innerBlocksProps = external_wp_blockEditor_namespaceObject.useInnerBlocksProps.save(blockProps);
35892      return (0,external_wp_element_namespaceObject.createElement)(Tag, innerBlocksProps);
35893    }
35894  
35895  }, // Version with NO wrapper `div` element.
35896  {
35897    attributes: {
35898      queryId: {
35899        type: 'number'
35900      },
35901      query: {
35902        type: 'object',
35903        default: {
35904          perPage: null,
35905          pages: 0,
35906          offset: 0,
35907          postType: 'post',
35908          categoryIds: [],
35909          tagIds: [],
35910          order: 'desc',
35911          orderBy: 'date',
35912          author: '',
35913          search: '',
35914          exclude: [],
35915          sticky: '',
35916          inherit: true
35917        }
35918      },
35919      layout: {
35920        type: 'object',
35921        default: {
35922          type: 'list'
35923        }
35924      }
35925    },
35926    supports: {
35927      html: false
35928    },
35929  
35930    migrate(attributes) {
35931      const withTaxQuery = migrateToTaxQuery(attributes);
35932      return { ...(0,external_lodash_namespaceObject.omit)(withTaxQuery, ['layout']),
35933        displayLayout: withTaxQuery.layout
35934      };
35935    },
35936  
35937    save() {
35938      return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InnerBlocks.Content, null);
35939    }
35940  
35941  }];
35942  /* harmony default export */ var query_deprecated = (query_deprecated_deprecated);
35943  
35944  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/query/hooks.js
35945  
35946  
35947  
35948  /**
35949   * WordPress dependencies
35950   */
35951  
35952  
35953  
35954  
35955  
35956  
35957  const CreateNewPostLink = _ref => {
35958    let {
35959      attributes: {
35960        query: {
35961          postType
35962        } = {}
35963      } = {}
35964    } = _ref;
35965    if (!postType) return null;
35966    const newPostUrl = (0,external_wp_url_namespaceObject.addQueryArgs)('post-new.php', {
35967      post_type: postType
35968    });
35969    return (0,external_wp_element_namespaceObject.createElement)("div", {
35970      className: "wp-block-query__create-new-link"
35971    }, (0,external_wp_element_namespaceObject.createInterpolateElement)((0,external_wp_i18n_namespaceObject.__)('<a>Create a new post</a> for this feed.'), // eslint-disable-next-line jsx-a11y/anchor-has-content
35972    {
35973      a: (0,external_wp_element_namespaceObject.createElement)("a", {
35974        href: newPostUrl
35975      })
35976    }));
35977  };
35978  /**
35979   * Override the default edit UI to include layout controls
35980   *
35981   * @param {Function} BlockEdit Original component
35982   * @return {Function}           Wrapped component
35983   */
35984  
35985  
35986  const queryTopInspectorControls = (0,external_wp_compose_namespaceObject.createHigherOrderComponent)(BlockEdit => props => {
35987    const {
35988      name,
35989      isSelected
35990    } = props;
35991  
35992    if (name !== 'core/query' || !isSelected) {
35993      return (0,external_wp_element_namespaceObject.createElement)(BlockEdit, _extends({
35994        key: "edit"
35995      }, props));
35996    }
35997  
35998    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, (0,external_wp_element_namespaceObject.createElement)(CreateNewPostLink, props)), (0,external_wp_element_namespaceObject.createElement)(BlockEdit, _extends({
35999      key: "edit"
36000    }, props)));
36001  }, 'withInspectorControls');
36002  /* harmony default export */ var query_hooks = (queryTopInspectorControls);
36003  
36004  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/query/index.js
36005  /**
36006   * WordPress dependencies
36007   */
36008  
36009  
36010  /**
36011   * Internal dependencies
36012   */
36013  
36014  const query_metadata = {
36015    $schema: "https://schemas.wp.org/trunk/block.json",
36016    apiVersion: 2,
36017    name: "core/query",
36018    title: "Query Loop",
36019    category: "theme",
36020    description: "An advanced block that allows displaying post types based on different query parameters and visual configurations.",
36021    textdomain: "default",
36022    attributes: {
36023      queryId: {
36024        type: "number"
36025      },
36026      query: {
36027        type: "object",
36028        "default": {
36029          perPage: null,
36030          pages: 0,
36031          offset: 0,
36032          postType: "post",
36033          order: "desc",
36034          orderBy: "date",
36035          author: "",
36036          search: "",
36037          exclude: [],
36038          sticky: "",
36039          inherit: true,
36040          taxQuery: null
36041        }
36042      },
36043      tagName: {
36044        type: "string",
36045        "default": "div"
36046      },
36047      displayLayout: {
36048        type: "object",
36049        "default": {
36050          type: "list"
36051        }
36052      }
36053    },
36054    providesContext: {
36055      queryId: "queryId",
36056      query: "query",
36057      displayLayout: "displayLayout"
36058    },
36059    supports: {
36060      align: ["wide", "full"],
36061      html: false,
36062      color: {
36063        gradients: true,
36064        link: true,
36065        __experimentalDefaultControls: {
36066          background: true,
36067          text: true
36068        }
36069      },
36070      __experimentalLayout: true
36071    },
36072    editorStyle: "wp-block-query-editor"
36073  };
36074  
36075  
36076  
36077  
36078  
36079  const {
36080    name: query_name
36081  } = query_metadata;
36082  
36083  const query_settings = {
36084    icon: library_loop,
36085    edit: query_edit,
36086    save: QuerySave,
36087    variations: query_variations,
36088    deprecated: query_deprecated
36089  }; // Importing this file includes side effects and is whitelisted
36090  // in block-library/package.json under `sideEffects`.
36091  
36092  (0,external_wp_hooks_namespaceObject.addFilter)('editor.BlockEdit', 'core/query', query_hooks);
36093  
36094  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/query-no-results/edit.js
36095  
36096  
36097  /**
36098   * WordPress dependencies
36099   */
36100  
36101  
36102  const query_no_results_edit_TEMPLATE = [['core/paragraph', {
36103    placeholder: (0,external_wp_i18n_namespaceObject.__)('Add text or blocks that will display when the query returns no results.')
36104  }]];
36105  function QueryNoResultsEdit() {
36106    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)();
36107    const innerBlocksProps = (0,external_wp_blockEditor_namespaceObject.useInnerBlocksProps)(blockProps, {
36108      template: query_no_results_edit_TEMPLATE
36109    });
36110    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)("div", innerBlocksProps));
36111  }
36112  
36113  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/query-no-results/save.js
36114  
36115  
36116  /**
36117   * WordPress dependencies
36118   */
36119  
36120  function QueryNoResultsSave() {
36121    return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InnerBlocks.Content, null);
36122  }
36123  
36124  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/query-no-results/index.js
36125  /**
36126   * WordPress dependencies
36127   */
36128  
36129  /**
36130   * Internal dependencies
36131   */
36132  
36133  const query_no_results_metadata = {
36134    $schema: "https://schemas.wp.org/trunk/block.json",
36135    apiVersion: 2,
36136    name: "core/query-no-results",
36137    title: "No results",
36138    category: "theme",
36139    description: "Contains the block elements used to render content when no query results are found.",
36140    parent: ["core/query"],
36141    textdomain: "default",
36142    usesContext: ["queryId", "query"],
36143    supports: {
36144      align: true,
36145      reusable: false,
36146      html: false,
36147      color: {
36148        gradients: true,
36149        link: true
36150      }
36151    }
36152  };
36153  
36154  
36155  const {
36156    name: query_no_results_name
36157  } = query_no_results_metadata;
36158  
36159  const query_no_results_settings = {
36160    icon: library_loop,
36161    edit: QueryNoResultsEdit,
36162    save: QueryNoResultsSave
36163  };
36164  
36165  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/query-pagination/query-pagination-arrow-controls.js
36166  
36167  
36168  /**
36169   * WordPress dependencies
36170   */
36171  
36172  
36173  function QueryPaginationArrowControls(_ref) {
36174    let {
36175      value,
36176      onChange
36177    } = _ref;
36178    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalToggleGroupControl, {
36179      label: (0,external_wp_i18n_namespaceObject.__)('Arrow'),
36180      value: value,
36181      onChange: onChange,
36182      help: (0,external_wp_i18n_namespaceObject.__)('A decorative arrow appended to the next and previous page link.'),
36183      isBlock: true
36184    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalToggleGroupControlOption, {
36185      value: "none",
36186      label: (0,external_wp_i18n_namespaceObject._x)('None', 'Arrow option for Query Pagination Next/Previous blocks')
36187    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalToggleGroupControlOption, {
36188      value: "arrow",
36189      label: (0,external_wp_i18n_namespaceObject._x)('Arrow', 'Arrow option for Query Pagination Next/Previous blocks')
36190    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalToggleGroupControlOption, {
36191      value: "chevron",
36192      label: (0,external_wp_i18n_namespaceObject._x)('Chevron', 'Arrow option for Query Pagination Next/Previous blocks')
36193    }));
36194  }
36195  
36196  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/query-pagination/edit.js
36197  
36198  
36199  /**
36200   * WordPress dependencies
36201   */
36202  
36203  
36204  
36205  
36206  
36207  /**
36208   * Internal dependencies
36209   */
36210  
36211  
36212  const query_pagination_edit_TEMPLATE = [['core/query-pagination-previous'], ['core/query-pagination-numbers'], ['core/query-pagination-next']];
36213  
36214  const edit_getDefaultBlockLayout = blockTypeOrName => {
36215    const layoutBlockSupportConfig = (0,external_wp_blocks_namespaceObject.getBlockSupport)(blockTypeOrName, '__experimentalLayout');
36216    return layoutBlockSupportConfig === null || layoutBlockSupportConfig === void 0 ? void 0 : layoutBlockSupportConfig.default;
36217  };
36218  
36219  function edit_QueryPaginationEdit(_ref) {
36220    let {
36221      attributes: {
36222        paginationArrow,
36223        layout
36224      },
36225      setAttributes,
36226      clientId,
36227      name
36228    } = _ref;
36229    const usedLayout = layout || edit_getDefaultBlockLayout(name);
36230    const hasNextPreviousBlocks = (0,external_wp_data_namespaceObject.useSelect)(select => {
36231      const {
36232        getBlocks
36233      } = select(external_wp_blockEditor_namespaceObject.store);
36234      const innerBlocks = getBlocks(clientId);
36235      /**
36236       * Show the `paginationArrow` control only if a
36237       * `QueryPaginationNext/Previous` block exists.
36238       */
36239  
36240      return innerBlocks === null || innerBlocks === void 0 ? void 0 : innerBlocks.find(innerBlock => {
36241        return ['core/query-pagination-next', 'core/query-pagination-previous'].includes(innerBlock.name);
36242      });
36243    }, []);
36244    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)();
36245    const innerBlocksProps = (0,external_wp_blockEditor_namespaceObject.useInnerBlocksProps)(blockProps, {
36246      template: query_pagination_edit_TEMPLATE,
36247      allowedBlocks: ['core/query-pagination-previous', 'core/query-pagination-numbers', 'core/query-pagination-next'],
36248      __experimentalLayout: usedLayout
36249    });
36250    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, hasNextPreviousBlocks && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
36251      title: (0,external_wp_i18n_namespaceObject.__)('Settings')
36252    }, (0,external_wp_element_namespaceObject.createElement)(QueryPaginationArrowControls, {
36253      value: paginationArrow,
36254      onChange: value => {
36255        setAttributes({
36256          paginationArrow: value
36257        });
36258      }
36259    }))), (0,external_wp_element_namespaceObject.createElement)("nav", innerBlocksProps));
36260  }
36261  
36262  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/query-pagination/save.js
36263  
36264  
36265  /**
36266   * WordPress dependencies
36267   */
36268  
36269  function query_pagination_save_save() {
36270    return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InnerBlocks.Content, null);
36271  }
36272  
36273  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/query-pagination/deprecated.js
36274  
36275  
36276  /**
36277   * WordPress dependencies
36278   */
36279  
36280  const query_pagination_deprecated_deprecated = [// Version with wrapper `div` element.
36281  {
36282    save() {
36283      return (0,external_wp_element_namespaceObject.createElement)("div", external_wp_blockEditor_namespaceObject.useBlockProps.save(), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InnerBlocks.Content, null));
36284    }
36285  
36286  }];
36287  /* harmony default export */ var query_pagination_deprecated = (query_pagination_deprecated_deprecated);
36288  
36289  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/query-pagination/index.js
36290  /**
36291   * WordPress dependencies
36292   */
36293  
36294  /**
36295   * Internal dependencies
36296   */
36297  
36298  const query_pagination_metadata = {
36299    $schema: "https://schemas.wp.org/trunk/block.json",
36300    apiVersion: 2,
36301    name: "core/query-pagination",
36302    title: "Pagination",
36303    category: "theme",
36304    parent: ["core/query"],
36305    description: "Displays a paginated navigation to next/previous set of posts, when applicable.",
36306    textdomain: "default",
36307    attributes: {
36308      paginationArrow: {
36309        type: "string",
36310        "default": "none"
36311      }
36312    },
36313    usesContext: ["queryId", "query"],
36314    providesContext: {
36315      paginationArrow: "paginationArrow"
36316    },
36317    supports: {
36318      align: true,
36319      reusable: false,
36320      html: false,
36321      color: {
36322        gradients: true,
36323        link: true,
36324        __experimentalDefaultControls: {
36325          background: true,
36326          text: true,
36327          link: true
36328        }
36329      },
36330      __experimentalLayout: {
36331        allowSwitching: false,
36332        allowInheriting: false,
36333        "default": {
36334          type: "flex"
36335        }
36336      }
36337    },
36338    editorStyle: "wp-block-query-pagination-editor",
36339    style: "wp-block-query-pagination"
36340  };
36341  
36342  
36343  
36344  const {
36345    name: query_pagination_name
36346  } = query_pagination_metadata;
36347  
36348  const query_pagination_settings = {
36349    icon: query_pagination,
36350    edit: edit_QueryPaginationEdit,
36351    save: query_pagination_save_save,
36352    deprecated: query_pagination_deprecated
36353  };
36354  
36355  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/query-pagination-next/edit.js
36356  
36357  
36358  
36359  /**
36360   * WordPress dependencies
36361   */
36362  
36363  
36364  const query_pagination_next_edit_arrowMap = {
36365    none: '',
36366    arrow: '→',
36367    chevron: '»'
36368  };
36369  function QueryPaginationNextEdit(_ref) {
36370    let {
36371      attributes: {
36372        label
36373      },
36374      setAttributes,
36375      context: {
36376        paginationArrow
36377      }
36378    } = _ref;
36379    const displayArrow = query_pagination_next_edit_arrowMap[paginationArrow];
36380    return (0,external_wp_element_namespaceObject.createElement)("a", _extends({
36381      href: "#pagination-next-pseudo-link",
36382      onClick: event => event.preventDefault()
36383    }, (0,external_wp_blockEditor_namespaceObject.useBlockProps)()), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.PlainText, {
36384      __experimentalVersion: 2,
36385      tagName: "span",
36386      "aria-label": (0,external_wp_i18n_namespaceObject.__)('Next page link'),
36387      placeholder: (0,external_wp_i18n_namespaceObject.__)('Next Page'),
36388      value: label,
36389      onChange: newLabel => setAttributes({
36390        label: newLabel
36391      })
36392    }), displayArrow && (0,external_wp_element_namespaceObject.createElement)("span", {
36393      className: `wp-block-query-pagination-next-arrow is-arrow-$paginationArrow}`
36394    }, displayArrow));
36395  }
36396  
36397  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/query-pagination-next/index.js
36398  /**
36399   * WordPress dependencies
36400   */
36401  
36402  /**
36403   * Internal dependencies
36404   */
36405  
36406  const query_pagination_next_metadata = {
36407    $schema: "https://schemas.wp.org/trunk/block.json",
36408    apiVersion: 2,
36409    name: "core/query-pagination-next",
36410    title: "Next Page",
36411    category: "theme",
36412    parent: ["core/query-pagination"],
36413    description: "Displays the next posts page link.",
36414    textdomain: "default",
36415    attributes: {
36416      label: {
36417        type: "string"
36418      }
36419    },
36420    usesContext: ["queryId", "query", "paginationArrow"],
36421    supports: {
36422      reusable: false,
36423      html: false,
36424      color: {
36425        gradients: true,
36426        text: false,
36427        __experimentalDefaultControls: {
36428          background: true
36429        }
36430      },
36431      typography: {
36432        fontSize: true,
36433        lineHeight: true,
36434        __experimentalFontStyle: true,
36435        __experimentalFontWeight: true,
36436        __experimentalLetterSpacing: true,
36437        __experimentalTextTransform: true,
36438        __experimentalDefaultControls: {
36439          fontSize: true
36440        }
36441      }
36442    }
36443  };
36444  
36445  const {
36446    name: query_pagination_next_name
36447  } = query_pagination_next_metadata;
36448  
36449  const query_pagination_next_settings = {
36450    icon: query_pagination_next,
36451    edit: QueryPaginationNextEdit
36452  };
36453  
36454  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/query-pagination-numbers/edit.js
36455  
36456  
36457  /**
36458   * WordPress dependencies
36459   */
36460  
36461  
36462  const createPaginationItem = function (content) {
36463    let Tag = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'a';
36464    let extraClass = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : '';
36465    return (0,external_wp_element_namespaceObject.createElement)(Tag, {
36466      className: `page-numbers $extraClass}`
36467    }, content);
36468  };
36469  
36470  const previewPaginationNumbers = () => (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, createPaginationItem(1), createPaginationItem(2), createPaginationItem(3, 'span', 'current'), createPaginationItem(4), createPaginationItem(5), createPaginationItem('...', 'span', 'dots'), createPaginationItem(8));
36471  
36472  function QueryPaginationNumbersEdit() {
36473    const paginationNumbers = previewPaginationNumbers();
36474    return (0,external_wp_element_namespaceObject.createElement)("div", (0,external_wp_blockEditor_namespaceObject.useBlockProps)(), paginationNumbers);
36475  }
36476  
36477  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/query-pagination-numbers/index.js
36478  /**
36479   * WordPress dependencies
36480   */
36481  
36482  /**
36483   * Internal dependencies
36484   */
36485  
36486  const query_pagination_numbers_metadata = {
36487    $schema: "https://schemas.wp.org/trunk/block.json",
36488    apiVersion: 2,
36489    name: "core/query-pagination-numbers",
36490    title: "Page Numbers",
36491    category: "theme",
36492    parent: ["core/query-pagination"],
36493    description: "Displays a list of page numbers for pagination",
36494    textdomain: "default",
36495    usesContext: ["queryId", "query"],
36496    supports: {
36497      reusable: false,
36498      html: false,
36499      color: {
36500        gradients: true,
36501        text: false,
36502        __experimentalDefaultControls: {
36503          background: true
36504        }
36505      },
36506      typography: {
36507        fontSize: true,
36508        lineHeight: true,
36509        __experimentalFontStyle: true,
36510        __experimentalFontWeight: true,
36511        __experimentalLetterSpacing: true,
36512        __experimentalTextTransform: true,
36513        __experimentalDefaultControls: {
36514          fontSize: true
36515        }
36516      }
36517    },
36518    editorStyle: "query-pagination-numbers-editor"
36519  };
36520  
36521  const {
36522    name: query_pagination_numbers_name
36523  } = query_pagination_numbers_metadata;
36524  
36525  const query_pagination_numbers_settings = {
36526    icon: query_pagination_numbers,
36527    edit: QueryPaginationNumbersEdit
36528  };
36529  
36530  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/query-pagination-previous/edit.js
36531  
36532  
36533  
36534  /**
36535   * WordPress dependencies
36536   */
36537  
36538  
36539  const query_pagination_previous_edit_arrowMap = {
36540    none: '',
36541    arrow: '←',
36542    chevron: '«'
36543  };
36544  function QueryPaginationPreviousEdit(_ref) {
36545    let {
36546      attributes: {
36547        label
36548      },
36549      setAttributes,
36550      context: {
36551        paginationArrow
36552      }
36553    } = _ref;
36554    const displayArrow = query_pagination_previous_edit_arrowMap[paginationArrow];
36555    return (0,external_wp_element_namespaceObject.createElement)("a", _extends({
36556      href: "#pagination-previous-pseudo-link",
36557      onClick: event => event.preventDefault()
36558    }, (0,external_wp_blockEditor_namespaceObject.useBlockProps)()), displayArrow && (0,external_wp_element_namespaceObject.createElement)("span", {
36559      className: `wp-block-query-pagination-previous-arrow is-arrow-$paginationArrow}`
36560    }, displayArrow), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.PlainText, {
36561      __experimentalVersion: 2,
36562      tagName: "span",
36563      "aria-label": (0,external_wp_i18n_namespaceObject.__)('Previous page link'),
36564      placeholder: (0,external_wp_i18n_namespaceObject.__)('Previous Page'),
36565      value: label,
36566      onChange: newLabel => setAttributes({
36567        label: newLabel
36568      })
36569    }));
36570  }
36571  
36572  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/query-pagination-previous/index.js
36573  /**
36574   * WordPress dependencies
36575   */
36576  
36577  /**
36578   * Internal dependencies
36579   */
36580  
36581  const query_pagination_previous_metadata = {
36582    $schema: "https://schemas.wp.org/trunk/block.json",
36583    apiVersion: 2,
36584    name: "core/query-pagination-previous",
36585    title: "Previous Page",
36586    category: "theme",
36587    parent: ["core/query-pagination"],
36588    description: "Displays the previous posts page link.",
36589    textdomain: "default",
36590    attributes: {
36591      label: {
36592        type: "string"
36593      }
36594    },
36595    usesContext: ["queryId", "query", "paginationArrow"],
36596    supports: {
36597      reusable: false,
36598      html: false,
36599      color: {
36600        gradients: true,
36601        text: false,
36602        __experimentalDefaultControls: {
36603          background: true
36604        }
36605      },
36606      typography: {
36607        fontSize: true,
36608        lineHeight: true,
36609        __experimentalFontStyle: true,
36610        __experimentalFontWeight: true,
36611        __experimentalLetterSpacing: true,
36612        __experimentalTextTransform: true,
36613        __experimentalDefaultControls: {
36614          fontSize: true
36615        }
36616      }
36617    }
36618  };
36619  
36620  const {
36621    name: query_pagination_previous_name
36622  } = query_pagination_previous_metadata;
36623  
36624  const query_pagination_previous_settings = {
36625    icon: query_pagination_previous,
36626    edit: QueryPaginationPreviousEdit
36627  };
36628  
36629  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/query-title/edit.js
36630  
36631  
36632  /**
36633   * External dependencies
36634   */
36635  
36636  /**
36637   * WordPress dependencies
36638   */
36639  
36640  
36641  
36642  /**
36643   * Internal dependencies
36644   */
36645  
36646  
36647  const SUPPORTED_TYPES = ['archive'];
36648  function QueryTitleEdit(_ref) {
36649    let {
36650      attributes: {
36651        type,
36652        level,
36653        textAlign
36654      },
36655      setAttributes
36656    } = _ref;
36657    const TagName = `h$level}`;
36658    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
36659      className: classnames_default()({
36660        [`has-text-align-$textAlign}`]: textAlign,
36661        'wp-block-query-title__placeholder': type === 'archive'
36662      })
36663    }); // The plan is to augment this block with more
36664    // block variations like `Search Title`.
36665  
36666    if (!SUPPORTED_TYPES.includes(type)) {
36667      return (0,external_wp_element_namespaceObject.createElement)("div", blockProps, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.Warning, null, (0,external_wp_i18n_namespaceObject.__)('Provided type is not supported.')));
36668    }
36669  
36670    let titleElement;
36671  
36672    if (type === 'archive') {
36673      titleElement = (0,external_wp_element_namespaceObject.createElement)(TagName, blockProps, (0,external_wp_i18n_namespaceObject.__)('Archive title'));
36674    }
36675  
36676    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, {
36677      group: "block"
36678    }, (0,external_wp_element_namespaceObject.createElement)(HeadingLevelDropdown, {
36679      selectedLevel: level,
36680      onChange: newLevel => setAttributes({
36681        level: newLevel
36682      })
36683    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.AlignmentControl, {
36684      value: textAlign,
36685      onChange: nextAlign => {
36686        setAttributes({
36687          textAlign: nextAlign
36688        });
36689      }
36690    })), titleElement);
36691  }
36692  
36693  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/archive-title.js
36694  
36695  
36696  /**
36697   * WordPress dependencies
36698   */
36699  
36700  const archiveTitle = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
36701    viewBox: "0 0 24 24",
36702    xmlns: "http://www.w3.org/2000/svg"
36703  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
36704    d: "M6.08 10.103h2.914L9.657 12h1.417L8.23 4H6.846L4 12h1.417l.663-1.897Zm1.463-4.137.994 2.857h-2l1.006-2.857ZM20 16H4v-1.5h16V16Zm-7 4H4v-1.5h9V20Z"
36705  }));
36706  /* harmony default export */ var archive_title = (archiveTitle);
36707  
36708  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/query-title/variations.js
36709  /**
36710   * WordPress dependencies
36711   */
36712  
36713  
36714  const query_title_variations_variations = [{
36715    isDefault: true,
36716    name: 'archive-title',
36717    title: (0,external_wp_i18n_namespaceObject.__)('Archive Title'),
36718    description: (0,external_wp_i18n_namespaceObject.__)('Display the archive title based on the queried object.'),
36719    icon: archive_title,
36720    attributes: {
36721      type: 'archive'
36722    },
36723    scope: ['inserter']
36724  }];
36725  /**
36726   * Add `isActive` function to all `query-title` variations, if not defined.
36727   * `isActive` function is used to find a variation match from a created
36728   *  Block by providing its attributes.
36729   */
36730  
36731  query_title_variations_variations.forEach(variation => {
36732    if (variation.isActive) return;
36733  
36734    variation.isActive = (blockAttributes, variationAttributes) => blockAttributes.type === variationAttributes.type;
36735  });
36736  /* harmony default export */ var query_title_variations = (query_title_variations_variations);
36737  
36738  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/query-title/deprecated.js
36739  /**
36740   * Internal dependencies
36741   */
36742  
36743  const query_title_deprecated_v1 = {
36744    attributes: {
36745      type: {
36746        type: 'string'
36747      },
36748      textAlign: {
36749        type: 'string'
36750      },
36751      level: {
36752        type: 'number',
36753        default: 1
36754      }
36755    },
36756    supports: {
36757      align: ['wide', 'full'],
36758      html: false,
36759      color: {
36760        gradients: true
36761      },
36762      spacing: {
36763        margin: true
36764      },
36765      typography: {
36766        fontSize: true,
36767        lineHeight: true,
36768        __experimentalFontFamily: true
36769      }
36770    },
36771  
36772    save() {
36773      return null;
36774    },
36775  
36776    migrate: migrate_font_family,
36777  
36778    isEligible(_ref) {
36779      var _style$typography;
36780  
36781      let {
36782        style
36783      } = _ref;
36784      return style === null || style === void 0 ? void 0 : (_style$typography = style.typography) === null || _style$typography === void 0 ? void 0 : _style$typography.fontFamily;
36785    }
36786  
36787  };
36788  /**
36789   * New deprecations need to be placed first
36790   * for them to have higher priority.
36791   *
36792   * Old deprecations may need to be updated as well.
36793   *
36794   * See block-deprecation.md
36795   */
36796  
36797  /* harmony default export */ var query_title_deprecated = ([query_title_deprecated_v1]);
36798  
36799  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/query-title.js
36800  
36801  
36802  /**
36803   * WordPress dependencies
36804   */
36805  
36806  const queryTitle = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
36807    viewBox: "0 0 24 24",
36808    xmlns: "http://www.w3.org/2000/svg"
36809  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
36810    d: "M4 20h9v-1.5H4V20zm0-5.5V16h16v-1.5H4zm1.3-2.9c.6.3 1.3.5 2 .5.8 0 1.4-.2 2-.5.1 0 .1-.1.2-.2l.8.7.9-1-.8-.7.3-.3a5.09 5.09 0 0 0 0-4.4c-.2-.6-.7-1-1.3-1.4-.6-.3-1.3-.5-2-.5-.8 0-1.4.2-2 .5-.7.4-1.1.8-1.5 1.5-.3.6-.5 1.3-.5 2.2 0 .8.2 1.6.5 2.2.4.6.8 1.1 1.4 1.4zm-.1-5c.2-.4.5-.7.8-1s.8-.4 1.3-.4 1 .1 1.3.4.6.6.8 1c.3.4.4.8.4 1.4 0 .5-.1 1-.3 1.4v.1l-1-.9-.9 1 .9.9c-.3.2-.7.3-1.2.3s-1-.1-1.3-.4c-.4-.2-.6-.6-.8-1C5 9 4.9 8.5 4.9 8c0-.6.1-1 .3-1.4z"
36811  }));
36812  /* harmony default export */ var query_title = (queryTitle);
36813  
36814  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/query-title/index.js
36815  /**
36816   * Internal dependencies
36817   */
36818  const query_title_metadata = {
36819    $schema: "https://schemas.wp.org/trunk/block.json",
36820    apiVersion: 2,
36821    name: "core/query-title",
36822    title: "Query Title",
36823    category: "theme",
36824    description: "Display the query title.",
36825    textdomain: "default",
36826    attributes: {
36827      type: {
36828        type: "string"
36829      },
36830      textAlign: {
36831        type: "string"
36832      },
36833      level: {
36834        type: "number",
36835        "default": 1
36836      }
36837    },
36838    supports: {
36839      align: ["wide", "full"],
36840      html: false,
36841      color: {
36842        gradients: true,
36843        __experimentalDefaultControls: {
36844          background: true,
36845          text: true
36846        }
36847      },
36848      spacing: {
36849        margin: true
36850      },
36851      typography: {
36852        fontSize: true,
36853        lineHeight: true,
36854        __experimentalFontFamily: true,
36855        __experimentalFontStyle: true,
36856        __experimentalFontWeight: true,
36857        __experimentalLetterSpacing: true,
36858        __experimentalTextTransform: true,
36859        __experimentalDefaultControls: {
36860          fontSize: true,
36861          fontAppearance: true,
36862          textTransform: true
36863        }
36864      }
36865    },
36866    editorStyle: "wp-block-query-title-editor"
36867  };
36868  
36869  
36870  
36871  /**
36872   * WordPress dependencies
36873   */
36874  
36875  
36876  const {
36877    name: query_title_name
36878  } = query_title_metadata;
36879  
36880  const query_title_settings = {
36881    icon: query_title,
36882    edit: QueryTitleEdit,
36883    variations: query_title_variations,
36884    deprecated: query_title_deprecated
36885  };
36886  
36887  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/quote.js
36888  
36889  
36890  /**
36891   * WordPress dependencies
36892   */
36893  
36894  const quote = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
36895    viewBox: "0 0 24 24",
36896    xmlns: "http://www.w3.org/2000/svg"
36897  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
36898    d: "M13 6v6h5.2v4c0 .8-.2 1.4-.5 1.7-.6.6-1.6.6-2.5.5h-.3v1.5h.5c1 0 2.3-.1 3.3-1 .6-.6 1-1.6 1-2.8V6H13zm-9 6h5.2v4c0 .8-.2 1.4-.5 1.7-.6.6-1.6.6-2.5.5h-.3v1.5h.5c1 0 2.3-.1 3.3-1 .6-.6 1-1.6 1-2.8V6H4v6z"
36899  }));
36900  /* harmony default export */ var library_quote = (quote);
36901  
36902  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/quote/deprecated.js
36903  
36904  
36905  /**
36906   * External dependencies
36907   */
36908  
36909  /**
36910   * WordPress dependencies
36911   */
36912  
36913  
36914  const quote_deprecated_blockAttributes = {
36915    value: {
36916      type: 'string',
36917      source: 'html',
36918      selector: 'blockquote',
36919      multiline: 'p',
36920      default: ''
36921    },
36922    citation: {
36923      type: 'string',
36924      source: 'html',
36925      selector: 'cite',
36926      default: ''
36927    },
36928    align: {
36929      type: 'string'
36930    }
36931  };
36932  const quote_deprecated_deprecated = [{
36933    attributes: quote_deprecated_blockAttributes,
36934  
36935    save(_ref) {
36936      let {
36937        attributes
36938      } = _ref;
36939      const {
36940        align,
36941        value,
36942        citation
36943      } = attributes;
36944      return (0,external_wp_element_namespaceObject.createElement)("blockquote", {
36945        style: {
36946          textAlign: align ? align : null
36947        }
36948      }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
36949        multiline: true,
36950        value: value
36951      }), !external_wp_blockEditor_namespaceObject.RichText.isEmpty(citation) && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
36952        tagName: "cite",
36953        value: citation
36954      }));
36955    }
36956  
36957  }, {
36958    attributes: { ...quote_deprecated_blockAttributes,
36959      style: {
36960        type: 'number',
36961        default: 1
36962      }
36963    },
36964  
36965    migrate(attributes) {
36966      if (attributes.style === 2) {
36967        return { ...(0,external_lodash_namespaceObject.omit)(attributes, ['style']),
36968          className: attributes.className ? attributes.className + ' is-style-large' : 'is-style-large'
36969        };
36970      }
36971  
36972      return attributes;
36973    },
36974  
36975    save(_ref2) {
36976      let {
36977        attributes
36978      } = _ref2;
36979      const {
36980        align,
36981        value,
36982        citation,
36983        style
36984      } = attributes;
36985      return (0,external_wp_element_namespaceObject.createElement)("blockquote", {
36986        className: style === 2 ? 'is-large' : '',
36987        style: {
36988          textAlign: align ? align : null
36989        }
36990      }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
36991        multiline: true,
36992        value: value
36993      }), !external_wp_blockEditor_namespaceObject.RichText.isEmpty(citation) && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
36994        tagName: "cite",
36995        value: citation
36996      }));
36997    }
36998  
36999  }, {
37000    attributes: { ...quote_deprecated_blockAttributes,
37001      citation: {
37002        type: 'string',
37003        source: 'html',
37004        selector: 'footer',
37005        default: ''
37006      },
37007      style: {
37008        type: 'number',
37009        default: 1
37010      }
37011    },
37012  
37013    migrate(attributes) {
37014      if (!isNaN(parseInt(attributes.style))) {
37015        return { ...(0,external_lodash_namespaceObject.omit)(attributes, ['style'])
37016        };
37017      }
37018  
37019      return attributes;
37020    },
37021  
37022    save(_ref3) {
37023      let {
37024        attributes
37025      } = _ref3;
37026      const {
37027        align,
37028        value,
37029        citation,
37030        style
37031      } = attributes;
37032      return (0,external_wp_element_namespaceObject.createElement)("blockquote", {
37033        className: `blocks-quote-style-$style}`,
37034        style: {
37035          textAlign: align ? align : null
37036        }
37037      }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
37038        multiline: true,
37039        value: value
37040      }), !external_wp_blockEditor_namespaceObject.RichText.isEmpty(citation) && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
37041        tagName: "footer",
37042        value: citation
37043      }));
37044    }
37045  
37046  }];
37047  /* harmony default export */ var quote_deprecated = (quote_deprecated_deprecated);
37048  
37049  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/quote/edit.js
37050  
37051  
37052  /**
37053   * External dependencies
37054   */
37055  
37056  /**
37057   * WordPress dependencies
37058   */
37059  
37060  
37061  
37062  
37063  
37064  
37065  const edit_isWebPlatform = external_wp_element_namespaceObject.Platform.OS === 'web';
37066  function QuoteEdit(_ref) {
37067    let {
37068      attributes,
37069      setAttributes,
37070      isSelected,
37071      mergeBlocks,
37072      onReplace,
37073      className,
37074      insertBlocksAfter,
37075      style
37076    } = _ref;
37077    const {
37078      align,
37079      value,
37080      citation
37081    } = attributes;
37082    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
37083      className: classnames_default()(className, {
37084        [`has-text-align-$align}`]: align
37085      }),
37086      style
37087    });
37088    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, {
37089      group: "block"
37090    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.AlignmentControl, {
37091      value: align,
37092      onChange: nextAlign => {
37093        setAttributes({
37094          align: nextAlign
37095        });
37096      }
37097    })), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.BlockQuotation, blockProps, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText, {
37098      identifier: "value",
37099      multiline: true,
37100      value: value,
37101      onChange: nextValue => setAttributes({
37102        value: nextValue
37103      }),
37104      onMerge: mergeBlocks,
37105      onRemove: forward => {
37106        const hasEmptyCitation = !citation || citation.length === 0;
37107  
37108        if (!forward && hasEmptyCitation) {
37109          onReplace([]);
37110        }
37111      },
37112      "aria-label": (0,external_wp_i18n_namespaceObject.__)('Quote text'),
37113      placeholder: // translators: placeholder text used for the quote
37114      (0,external_wp_i18n_namespaceObject.__)('Add quote'),
37115      onReplace: onReplace,
37116      onSplit: piece => (0,external_wp_blocks_namespaceObject.createBlock)('core/quote', { ...attributes,
37117        value: piece
37118      }),
37119      __unstableOnSplitMiddle: () => (0,external_wp_blocks_namespaceObject.createBlock)('core/paragraph'),
37120      textAlign: align
37121    }), (!external_wp_blockEditor_namespaceObject.RichText.isEmpty(citation) || isSelected) && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText, {
37122      identifier: "citation",
37123      tagName: edit_isWebPlatform ? 'cite' : undefined,
37124      style: {
37125        display: 'block'
37126      },
37127      value: citation,
37128      onChange: nextCitation => setAttributes({
37129        citation: nextCitation
37130      }),
37131      __unstableMobileNoFocusOnMount: true,
37132      "aria-label": (0,external_wp_i18n_namespaceObject.__)('Quote citation text'),
37133      placeholder: // translators: placeholder text used for the citation
37134      (0,external_wp_i18n_namespaceObject.__)('Add citation'),
37135      className: "wp-block-quote__citation",
37136      textAlign: align,
37137      __unstableOnSplitAtEnd: () => insertBlocksAfter((0,external_wp_blocks_namespaceObject.createBlock)('core/paragraph'))
37138    })));
37139  }
37140  
37141  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/quote/save.js
37142  
37143  
37144  /**
37145   * External dependencies
37146   */
37147  
37148  /**
37149   * WordPress dependencies
37150   */
37151  
37152  
37153  function quote_save_save(_ref) {
37154    let {
37155      attributes
37156    } = _ref;
37157    const {
37158      align,
37159      value,
37160      citation
37161    } = attributes;
37162    const className = classnames_default()({
37163      [`has-text-align-$align}`]: align
37164    });
37165    return (0,external_wp_element_namespaceObject.createElement)("blockquote", external_wp_blockEditor_namespaceObject.useBlockProps.save({
37166      className
37167    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
37168      multiline: true,
37169      value: value
37170    }), !external_wp_blockEditor_namespaceObject.RichText.isEmpty(citation) && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
37171      tagName: "cite",
37172      value: citation
37173    }));
37174  }
37175  
37176  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/quote/transforms.js
37177  /**
37178   * WordPress dependencies
37179   */
37180  
37181  
37182  const quote_transforms_transforms = {
37183    from: [{
37184      type: 'block',
37185      isMultiBlock: true,
37186      blocks: ['core/paragraph'],
37187      transform: attributes => {
37188        return (0,external_wp_blocks_namespaceObject.createBlock)('core/quote', {
37189          value: (0,external_wp_richText_namespaceObject.toHTMLString)({
37190            value: (0,external_wp_richText_namespaceObject.join)(attributes.map(_ref => {
37191              let {
37192                content
37193              } = _ref;
37194              return (0,external_wp_richText_namespaceObject.create)({
37195                html: content
37196              });
37197            }), '\u2028'),
37198            multilineTag: 'p'
37199          }),
37200          anchor: attributes.anchor
37201        });
37202      }
37203    }, {
37204      type: 'block',
37205      blocks: ['core/heading'],
37206      transform: _ref2 => {
37207        let {
37208          content,
37209          anchor
37210        } = _ref2;
37211        return (0,external_wp_blocks_namespaceObject.createBlock)('core/quote', {
37212          value: `<p>$content}</p>`,
37213          anchor
37214        });
37215      }
37216    }, {
37217      type: 'block',
37218      blocks: ['core/pullquote'],
37219      transform: _ref3 => {
37220        let {
37221          value,
37222          citation,
37223          anchor
37224        } = _ref3;
37225        return (0,external_wp_blocks_namespaceObject.createBlock)('core/quote', {
37226          value,
37227          citation,
37228          anchor
37229        });
37230      }
37231    }, {
37232      type: 'prefix',
37233      prefix: '>',
37234      transform: content => {
37235        return (0,external_wp_blocks_namespaceObject.createBlock)('core/quote', {
37236          value: `<p>$content}</p>`
37237        });
37238      }
37239    }, {
37240      type: 'raw',
37241      isMatch: node => {
37242        const isParagraphOrSingleCite = (() => {
37243          let hasCitation = false;
37244          return child => {
37245            // Child is a paragraph.
37246            if (child.nodeName === 'P') {
37247              return true;
37248            } // Child is a cite and no other cite child exists before it.
37249  
37250  
37251            if (!hasCitation && child.nodeName === 'CITE') {
37252              hasCitation = true;
37253              return true;
37254            }
37255          };
37256        })();
37257  
37258        return node.nodeName === 'BLOCKQUOTE' && // The quote block can only handle multiline paragraph
37259        // content with an optional cite child.
37260        Array.from(node.childNodes).every(isParagraphOrSingleCite);
37261      },
37262      schema: _ref4 => {
37263        let {
37264          phrasingContentSchema
37265        } = _ref4;
37266        return {
37267          blockquote: {
37268            children: {
37269              p: {
37270                children: phrasingContentSchema
37271              },
37272              cite: {
37273                children: phrasingContentSchema
37274              }
37275            }
37276          }
37277        };
37278      }
37279    }],
37280    to: [{
37281      type: 'block',
37282      blocks: ['core/paragraph'],
37283      transform: _ref5 => {
37284        let {
37285          value,
37286          citation
37287        } = _ref5;
37288        const paragraphs = [];
37289  
37290        if (value && value !== '<p></p>') {
37291          paragraphs.push(...(0,external_wp_richText_namespaceObject.split)((0,external_wp_richText_namespaceObject.create)({
37292            html: value,
37293            multilineTag: 'p'
37294          }), '\u2028').map(piece => (0,external_wp_blocks_namespaceObject.createBlock)('core/paragraph', {
37295            content: (0,external_wp_richText_namespaceObject.toHTMLString)({
37296              value: piece
37297            })
37298          })));
37299        }
37300  
37301        if (citation && citation !== '<p></p>') {
37302          paragraphs.push((0,external_wp_blocks_namespaceObject.createBlock)('core/paragraph', {
37303            content: citation
37304          }));
37305        }
37306  
37307        if (paragraphs.length === 0) {
37308          return (0,external_wp_blocks_namespaceObject.createBlock)('core/paragraph', {
37309            content: ''
37310          });
37311        }
37312  
37313        return paragraphs;
37314      }
37315    }, {
37316      type: 'block',
37317      blocks: ['core/heading'],
37318      transform: _ref6 => {
37319        let {
37320          value,
37321          citation,
37322          ...attrs
37323        } = _ref6;
37324  
37325        // If there is no quote content, use the citation as the
37326        // content of the resulting heading. A nonexistent citation
37327        // will result in an empty heading.
37328        if (value === '<p></p>') {
37329          return (0,external_wp_blocks_namespaceObject.createBlock)('core/heading', {
37330            content: citation
37331          });
37332        }
37333  
37334        const pieces = (0,external_wp_richText_namespaceObject.split)((0,external_wp_richText_namespaceObject.create)({
37335          html: value,
37336          multilineTag: 'p'
37337        }), '\u2028');
37338        const headingBlock = (0,external_wp_blocks_namespaceObject.createBlock)('core/heading', {
37339          content: (0,external_wp_richText_namespaceObject.toHTMLString)({
37340            value: pieces[0]
37341          })
37342        });
37343  
37344        if (!citation && pieces.length === 1) {
37345          return headingBlock;
37346        }
37347  
37348        const quotePieces = pieces.slice(1);
37349        const quoteBlock = (0,external_wp_blocks_namespaceObject.createBlock)('core/quote', { ...attrs,
37350          citation,
37351          value: (0,external_wp_richText_namespaceObject.toHTMLString)({
37352            value: quotePieces.length ? (0,external_wp_richText_namespaceObject.join)(pieces.slice(1), '\u2028') : (0,external_wp_richText_namespaceObject.create)(),
37353            multilineTag: 'p'
37354          })
37355        });
37356        return [headingBlock, quoteBlock];
37357      }
37358    }, {
37359      type: 'block',
37360      blocks: ['core/pullquote'],
37361      transform: _ref7 => {
37362        let {
37363          value,
37364          citation,
37365          anchor
37366        } = _ref7;
37367        return (0,external_wp_blocks_namespaceObject.createBlock)('core/pullquote', {
37368          value,
37369          citation,
37370          anchor
37371        });
37372      }
37373    }]
37374  };
37375  /* harmony default export */ var quote_transforms = (quote_transforms_transforms);
37376  
37377  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/quote/index.js
37378  /**
37379   * WordPress dependencies
37380   */
37381  
37382  
37383  /**
37384   * Internal dependencies
37385   */
37386  
37387  
37388  
37389  const quote_metadata = {
37390    $schema: "https://schemas.wp.org/trunk/block.json",
37391    apiVersion: 2,
37392    name: "core/quote",
37393    title: "Quote",
37394    category: "text",
37395    description: "Give quoted text visual emphasis. \"In quoting others, we cite ourselves.\" \u2014 Julio Cort\xE1zar",
37396    keywords: ["blockquote", "cite"],
37397    textdomain: "default",
37398    attributes: {
37399      value: {
37400        type: "string",
37401        source: "html",
37402        selector: "blockquote",
37403        multiline: "p",
37404        "default": "",
37405        __experimentalRole: "content"
37406      },
37407      citation: {
37408        type: "string",
37409        source: "html",
37410        selector: "cite",
37411        "default": "",
37412        __experimentalRole: "content"
37413      },
37414      align: {
37415        type: "string"
37416      }
37417    },
37418    supports: {
37419      anchor: true,
37420      __experimentalSlashInserter: true,
37421      typography: {
37422        fontSize: true,
37423        lineHeight: true,
37424        __experimentalFontStyle: true,
37425        __experimentalFontWeight: true,
37426        __experimentalLetterSpacing: true,
37427        __experimentalTextTransform: true,
37428        __experimentalDefaultControls: {
37429          fontSize: true,
37430          fontAppearance: true
37431        }
37432      },
37433      color: {
37434        gradients: true,
37435        link: true,
37436        __experimentalDefaultControls: {
37437          background: true,
37438          text: true
37439        }
37440      }
37441    },
37442    styles: [{
37443      name: "default",
37444      label: "Default",
37445      isDefault: true
37446    }, {
37447      name: "plain",
37448      label: "Plain"
37449    }],
37450    editorStyle: "wp-block-quote-editor",
37451    style: "wp-block-quote"
37452  };
37453  
37454  
37455  
37456  const {
37457    name: quote_name
37458  } = quote_metadata;
37459  
37460  const quote_settingsV1 = {
37461    icon: library_quote,
37462    example: {
37463      attributes: {
37464        value: '<p>' + (0,external_wp_i18n_namespaceObject.__)('In quoting others, we cite ourselves.') + '</p>',
37465        citation: 'Julio Cortázar'
37466      }
37467    },
37468    transforms: quote_transforms,
37469    edit: QuoteEdit,
37470    save: quote_save_save,
37471  
37472    merge(attributes, _ref) {
37473      let {
37474        value,
37475        citation
37476      } = _ref;
37477  
37478      // Quote citations cannot be merged. Pick the second one unless it's
37479      // empty.
37480      if (!citation) {
37481        citation = attributes.citation;
37482      }
37483  
37484      if (!value || value === '<p></p>') {
37485        return { ...attributes,
37486          citation
37487        };
37488      }
37489  
37490      return { ...attributes,
37491        value: attributes.value + value,
37492        citation
37493      };
37494    },
37495  
37496    deprecated: quote_deprecated
37497  };
37498  let quote_settings = quote_settingsV1;
37499  
37500  if (false) { var quote_window; }
37501  
37502  
37503  
37504  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/symbol.js
37505  
37506  
37507  /**
37508   * WordPress dependencies
37509   */
37510  
37511  const symbol = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
37512    xmlns: "http://www.w3.org/2000/svg",
37513    viewBox: "0 0 24 24"
37514  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
37515    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-1 1.4l-5.6 5.6c-.1.1-.3.1-.4 0l-5.6-5.6c-.1-.1-.1-.3 0-.4l5.6-5.6s.1-.1.2-.1.1 0 .2.1l5.6 5.6c.1.1.1.3 0 .4zm-16.6-.4L10 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"
37516  }));
37517  /* harmony default export */ var library_symbol = (symbol);
37518  
37519  ;// CONCATENATED MODULE: external ["wp","reusableBlocks"]
37520  var external_wp_reusableBlocks_namespaceObject = window["wp"]["reusableBlocks"];
37521  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/ungroup.js
37522  
37523  
37524  /**
37525   * WordPress dependencies
37526   */
37527  
37528  const ungroup = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
37529    xmlns: "http://www.w3.org/2000/svg",
37530    viewBox: "0 0 24 24"
37531  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
37532    d: "M18 4h-7c-1.1 0-2 .9-2 2v7c0 1.1.9 2 2 2h7c1.1 0 2-.9 2-2V6c0-1.1-.9-2-2-2zm.5 9c0 .3-.2.5-.5.5h-7c-.3 0-.5-.2-.5-.5V6c0-.3.2-.5.5-.5h7c.3 0 .5.2.5.5v7zm-5 5c0 .3-.2.5-.5.5H6c-.3 0-.5-.2-.5-.5v-7c0-.3.2-.5.5-.5h1V9H6c-1.1 0-2 .9-2 2v7c0 1.1.9 2 2 2h7c1.1 0 2-.9 2-2v-1h-1.5v1z"
37533  }));
37534  /* harmony default export */ var library_ungroup = (ungroup);
37535  
37536  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/block/edit.js
37537  
37538  
37539  /**
37540   * WordPress dependencies
37541   */
37542  
37543  
37544  
37545  
37546  
37547  
37548  
37549  function ReusableBlockEdit(_ref) {
37550    let {
37551      attributes: {
37552        ref
37553      },
37554      clientId
37555    } = _ref;
37556    const [hasAlreadyRendered, RecursionProvider] = (0,external_wp_blockEditor_namespaceObject.__experimentalUseNoRecursiveRenders)(ref);
37557    const {
37558      record,
37559      hasResolved
37560    } = (0,external_wp_coreData_namespaceObject.__experimentalUseEntityRecord)('postType', 'wp_block', ref);
37561    const isMissing = hasResolved && !record;
37562    const canRemove = (0,external_wp_data_namespaceObject.useSelect)(select => select(external_wp_blockEditor_namespaceObject.store).canRemoveBlock(clientId), [clientId]);
37563    const {
37564      __experimentalConvertBlockToStatic: convertBlockToStatic
37565    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_reusableBlocks_namespaceObject.store);
37566    const [blocks, onInput, onChange] = (0,external_wp_coreData_namespaceObject.useEntityBlockEditor)('postType', 'wp_block', {
37567      id: ref
37568    });
37569    const [title, setTitle] = (0,external_wp_coreData_namespaceObject.useEntityProp)('postType', 'wp_block', 'title', ref);
37570    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)();
37571    const innerBlocksProps = (0,external_wp_blockEditor_namespaceObject.useInnerBlocksProps)({}, {
37572      value: blocks,
37573      onInput,
37574      onChange,
37575      renderAppender: blocks !== null && blocks !== void 0 && blocks.length ? undefined : external_wp_blockEditor_namespaceObject.InnerBlocks.ButtonBlockAppender
37576    });
37577  
37578    if (hasAlreadyRendered) {
37579      return (0,external_wp_element_namespaceObject.createElement)("div", blockProps, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.Warning, null, (0,external_wp_i18n_namespaceObject.__)('Block cannot be rendered inside itself.')));
37580    }
37581  
37582    if (isMissing) {
37583      return (0,external_wp_element_namespaceObject.createElement)("div", blockProps, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.Warning, null, (0,external_wp_i18n_namespaceObject.__)('Block has been deleted or is unavailable.')));
37584    }
37585  
37586    if (!hasResolved) {
37587      return (0,external_wp_element_namespaceObject.createElement)("div", blockProps, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Placeholder, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Spinner, null)));
37588    }
37589  
37590    return (0,external_wp_element_namespaceObject.createElement)(RecursionProvider, null, (0,external_wp_element_namespaceObject.createElement)("div", blockProps, canRemove && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarGroup, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, {
37591      onClick: () => convertBlockToStatic(clientId),
37592      label: (0,external_wp_i18n_namespaceObject.__)('Convert to regular blocks'),
37593      icon: library_ungroup,
37594      showTooltip: true
37595    }))), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TextControl, {
37596      label: (0,external_wp_i18n_namespaceObject.__)('Name'),
37597      value: title,
37598      onChange: setTitle
37599    }))), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.__experimentalBlockContentOverlay, {
37600      clientId: clientId,
37601      wrapperProps: innerBlocksProps,
37602      className: "block-library-block__reusable-block-container"
37603    })));
37604  }
37605  
37606  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/block/index.js
37607  /**
37608   * WordPress dependencies
37609   */
37610  
37611  /**
37612   * Internal dependencies
37613   */
37614  
37615  const block_metadata = {
37616    $schema: "https://schemas.wp.org/trunk/block.json",
37617    apiVersion: 2,
37618    name: "core/block",
37619    title: "Reusable block",
37620    category: "reusable",
37621    description: "Create and save content to reuse across your site. Update the block, and the changes apply everywhere it\u2019s used.",
37622    textdomain: "default",
37623    attributes: {
37624      ref: {
37625        type: "number"
37626      }
37627    },
37628    supports: {
37629      customClassName: false,
37630      html: false,
37631      inserter: false
37632    },
37633    editorStyle: "wp-block-editor"
37634  };
37635  
37636  const {
37637    name: block_name
37638  } = block_metadata;
37639  
37640  const block_settings = {
37641    edit: ReusableBlockEdit,
37642    icon: library_symbol
37643  };
37644  
37645  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/read-more/edit.js
37646  
37647  
37648  
37649  /**
37650   * WordPress dependencies
37651   */
37652  
37653  
37654  
37655  
37656  function ReadMore(_ref) {
37657    let {
37658      attributes: {
37659        content,
37660        linkTarget
37661      },
37662      setAttributes,
37663      insertBlocksAfter
37664    } = _ref;
37665    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)();
37666    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
37667      title: (0,external_wp_i18n_namespaceObject.__)('Link settings')
37668    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
37669      label: (0,external_wp_i18n_namespaceObject.__)('Open in new tab'),
37670      onChange: value => setAttributes({
37671        linkTarget: value ? '_blank' : '_self'
37672      }),
37673      checked: linkTarget === '_blank'
37674    }))), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText, _extends({
37675      tagName: "a",
37676      "aria-label": (0,external_wp_i18n_namespaceObject.__)('"Read more" link text'),
37677      placeholder: (0,external_wp_i18n_namespaceObject.__)('Read more'),
37678      value: content,
37679      onChange: newValue => setAttributes({
37680        content: newValue
37681      }),
37682      __unstableOnSplitAtEnd: () => insertBlocksAfter((0,external_wp_blocks_namespaceObject.createBlock)((0,external_wp_blocks_namespaceObject.getDefaultBlockName)())),
37683      withoutInteractiveFormatting: true
37684    }, blockProps)));
37685  }
37686  
37687  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/read-more/index.js
37688  /**
37689   * WordPress dependencies
37690   */
37691  
37692  /**
37693   * Internal dependencies
37694   */
37695  
37696  const read_more_metadata = {
37697    $schema: "https://schemas.wp.org/trunk/block.json",
37698    apiVersion: 2,
37699    name: "core/read-more",
37700    title: "Read More",
37701    category: "theme",
37702    description: "Displays the link of a post, page, or any other content-type.",
37703    textdomain: "default",
37704    attributes: {
37705      content: {
37706        type: "string"
37707      },
37708      linkTarget: {
37709        type: "string",
37710        "default": "_self"
37711      }
37712    },
37713    usesContext: ["postId"],
37714    supports: {
37715      html: false,
37716      color: {
37717        gradients: true,
37718        text: true
37719      },
37720      typography: {
37721        fontSize: true,
37722        lineHeight: true,
37723        __experimentalFontFamily: true,
37724        __experimentalFontWeight: true,
37725        __experimentalFontStyle: true,
37726        __experimentalTextTransform: true,
37727        __experimentalLetterSpacing: true,
37728        __experimentalTextDecoration: true,
37729        __experimentalDefaultControls: {
37730          fontSize: true,
37731          textDecoration: true
37732        }
37733      },
37734      spacing: {
37735        margin: ["top", "bottom"],
37736        padding: true,
37737        __experimentalDefaultControls: {
37738          padding: true
37739        }
37740      },
37741      __experimentalBorder: {
37742        color: true,
37743        radius: true,
37744        width: true,
37745        __experimentalDefaultControls: {
37746          width: true
37747        }
37748      }
37749    },
37750    style: "wp-block-read-more"
37751  };
37752  
37753  const {
37754    name: read_more_name
37755  } = read_more_metadata;
37756  
37757  const read_more_settings = {
37758    icon: library_link,
37759    edit: ReadMore
37760  };
37761  
37762  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/rss.js
37763  
37764  
37765  /**
37766   * WordPress dependencies
37767   */
37768  
37769  const rss = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
37770    xmlns: "http://www.w3.org/2000/svg",
37771    viewBox: "0 0 24 24"
37772  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
37773    d: "M5 10.2h-.8v1.5H5c1.9 0 3.8.8 5.1 2.1 1.4 1.4 2.1 3.2 2.1 5.1v.8h1.5V19c0-2.3-.9-4.5-2.6-6.2-1.6-1.6-3.8-2.6-6.1-2.6zm10.4-1.6C12.6 5.8 8.9 4.2 5 4.2h-.8v1.5H5c3.5 0 6.9 1.4 9.4 3.9s3.9 5.8 3.9 9.4v.8h1.5V19c0-3.9-1.6-7.6-4.4-10.4zM4 20h3v-3H4v3z"
37774  }));
37775  /* harmony default export */ var library_rss = (rss);
37776  
37777  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/rss/edit.js
37778  
37779  
37780  /**
37781   * WordPress dependencies
37782   */
37783  
37784  
37785  
37786  
37787  
37788  
37789  
37790  const DEFAULT_MIN_ITEMS = 1;
37791  const DEFAULT_MAX_ITEMS = 20;
37792  function RSSEdit(_ref) {
37793    let {
37794      attributes,
37795      setAttributes
37796    } = _ref;
37797    const [isEditing, setIsEditing] = (0,external_wp_element_namespaceObject.useState)(!attributes.feedURL);
37798    const {
37799      blockLayout,
37800      columns,
37801      displayAuthor,
37802      displayDate,
37803      displayExcerpt,
37804      excerptLength,
37805      feedURL,
37806      itemsToShow
37807    } = attributes;
37808  
37809    function toggleAttribute(propName) {
37810      return () => {
37811        const value = attributes[propName];
37812        setAttributes({
37813          [propName]: !value
37814        });
37815      };
37816    }
37817  
37818    function onSubmitURL(event) {
37819      event.preventDefault();
37820  
37821      if (feedURL) {
37822        setAttributes({
37823          feedURL: (0,external_wp_url_namespaceObject.prependHTTP)(feedURL)
37824        });
37825        setIsEditing(false);
37826      }
37827    }
37828  
37829    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)();
37830  
37831    if (isEditing) {
37832      return (0,external_wp_element_namespaceObject.createElement)("div", blockProps, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Placeholder, {
37833        icon: library_rss,
37834        label: "RSS"
37835      }, (0,external_wp_element_namespaceObject.createElement)("form", {
37836        onSubmit: onSubmitURL,
37837        className: "wp-block-rss__placeholder-form"
37838      }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TextControl, {
37839        placeholder: (0,external_wp_i18n_namespaceObject.__)('Enter URL here…'),
37840        value: feedURL,
37841        onChange: value => setAttributes({
37842          feedURL: value
37843        }),
37844        className: "wp-block-rss__placeholder-input"
37845      }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
37846        variant: "primary",
37847        type: "submit"
37848      }, (0,external_wp_i18n_namespaceObject.__)('Use URL')))));
37849    }
37850  
37851    const toolbarControls = [{
37852      icon: library_edit,
37853      title: (0,external_wp_i18n_namespaceObject.__)('Edit RSS URL'),
37854      onClick: () => setIsEditing(true)
37855    }, {
37856      icon: library_list,
37857      title: (0,external_wp_i18n_namespaceObject.__)('List view'),
37858      onClick: () => setAttributes({
37859        blockLayout: 'list'
37860      }),
37861      isActive: blockLayout === 'list'
37862    }, {
37863      icon: library_grid,
37864      title: (0,external_wp_i18n_namespaceObject.__)('Grid view'),
37865      onClick: () => setAttributes({
37866        blockLayout: 'grid'
37867      }),
37868      isActive: blockLayout === 'grid'
37869    }];
37870    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarGroup, {
37871      controls: toolbarControls
37872    })), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
37873      title: (0,external_wp_i18n_namespaceObject.__)('RSS settings')
37874    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.RangeControl, {
37875      label: (0,external_wp_i18n_namespaceObject.__)('Number of items'),
37876      value: itemsToShow,
37877      onChange: value => setAttributes({
37878        itemsToShow: value
37879      }),
37880      min: DEFAULT_MIN_ITEMS,
37881      max: DEFAULT_MAX_ITEMS,
37882      required: true
37883    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
37884      label: (0,external_wp_i18n_namespaceObject.__)('Display author'),
37885      checked: displayAuthor,
37886      onChange: toggleAttribute('displayAuthor')
37887    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
37888      label: (0,external_wp_i18n_namespaceObject.__)('Display date'),
37889      checked: displayDate,
37890      onChange: toggleAttribute('displayDate')
37891    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
37892      label: (0,external_wp_i18n_namespaceObject.__)('Display excerpt'),
37893      checked: displayExcerpt,
37894      onChange: toggleAttribute('displayExcerpt')
37895    }), displayExcerpt && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.RangeControl, {
37896      label: (0,external_wp_i18n_namespaceObject.__)('Max number of words in excerpt'),
37897      value: excerptLength,
37898      onChange: value => setAttributes({
37899        excerptLength: value
37900      }),
37901      min: 10,
37902      max: 100,
37903      required: true
37904    }), blockLayout === 'grid' && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.RangeControl, {
37905      label: (0,external_wp_i18n_namespaceObject.__)('Columns'),
37906      value: columns,
37907      onChange: value => setAttributes({
37908        columns: value
37909      }),
37910      min: 2,
37911      max: 6,
37912      required: true
37913    }))), (0,external_wp_element_namespaceObject.createElement)("div", blockProps, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Disabled, null, (0,external_wp_element_namespaceObject.createElement)((external_wp_serverSideRender_default()), {
37914      block: "core/rss",
37915      attributes: attributes
37916    }))));
37917  }
37918  
37919  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/rss/index.js
37920  /**
37921   * WordPress dependencies
37922   */
37923  
37924  /**
37925   * Internal dependencies
37926   */
37927  
37928  const rss_metadata = {
37929    $schema: "https://schemas.wp.org/trunk/block.json",
37930    apiVersion: 2,
37931    name: "core/rss",
37932    title: "RSS",
37933    category: "widgets",
37934    description: "Display entries from any RSS or Atom feed.",
37935    keywords: ["atom", "feed"],
37936    textdomain: "default",
37937    attributes: {
37938      columns: {
37939        type: "number",
37940        "default": 2
37941      },
37942      blockLayout: {
37943        type: "string",
37944        "default": "list"
37945      },
37946      feedURL: {
37947        type: "string",
37948        "default": ""
37949      },
37950      itemsToShow: {
37951        type: "number",
37952        "default": 5
37953      },
37954      displayExcerpt: {
37955        type: "boolean",
37956        "default": false
37957      },
37958      displayAuthor: {
37959        type: "boolean",
37960        "default": false
37961      },
37962      displayDate: {
37963        type: "boolean",
37964        "default": false
37965      },
37966      excerptLength: {
37967        type: "number",
37968        "default": 55
37969      }
37970    },
37971    supports: {
37972      align: true,
37973      html: false
37974    },
37975    editorStyle: "wp-block-rss-editor",
37976    style: "wp-block-rss"
37977  };
37978  
37979  const {
37980    name: rss_name
37981  } = rss_metadata;
37982  
37983  const rss_settings = {
37984    icon: library_rss,
37985    example: {
37986      attributes: {
37987        feedURL: 'https://wordpress.org'
37988      }
37989    },
37990    edit: RSSEdit
37991  };
37992  
37993  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/search.js
37994  
37995  
37996  /**
37997   * WordPress dependencies
37998   */
37999  
38000  const search = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
38001    xmlns: "http://www.w3.org/2000/svg",
38002    viewBox: "0 0 24 24"
38003  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
38004    d: "M13.5 6C10.5 6 8 8.5 8 11.5c0 1.1.3 2.1.9 3l-3.4 3 1 1.1 3.4-2.9c1 .9 2.2 1.4 3.6 1.4 3 0 5.5-2.5 5.5-5.5C19 8.5 16.5 6 13.5 6zm0 9.5c-2.2 0-4-1.8-4-4s1.8-4 4-4 4 1.8 4 4-1.8 4-4 4z"
38005  }));
38006  /* harmony default export */ var library_search = (search);
38007  
38008  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/search/icons.js
38009  
38010  
38011  /**
38012   * WordPress dependencies
38013   */
38014  
38015  const buttonOnly = (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, {
38016    xmlns: "http://www.w3.org/2000/svg",
38017    viewBox: "0 0 24 24"
38018  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Rect, {
38019    x: "7",
38020    y: "10",
38021    width: "10",
38022    height: "4",
38023    rx: "1",
38024    fill: "currentColor"
38025  }));
38026  const buttonOutside = (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, {
38027    xmlns: "http://www.w3.org/2000/svg",
38028    viewBox: "0 0 24 24"
38029  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Rect, {
38030    x: "4.75",
38031    y: "15.25",
38032    width: "6.5",
38033    height: "9.5",
38034    transform: "rotate(-90 4.75 15.25)",
38035    stroke: "currentColor",
38036    strokeWidth: "1.5",
38037    fill: "none"
38038  }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Rect, {
38039    x: "16",
38040    y: "10",
38041    width: "4",
38042    height: "4",
38043    rx: "1",
38044    fill: "currentColor"
38045  }));
38046  const buttonInside = (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, {
38047    xmlns: "http://www.w3.org/2000/svg",
38048    viewBox: "0 0 24 24"
38049  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Rect, {
38050    x: "4.75",
38051    y: "15.25",
38052    width: "6.5",
38053    height: "14.5",
38054    transform: "rotate(-90 4.75 15.25)",
38055    stroke: "currentColor",
38056    strokeWidth: "1.5",
38057    fill: "none"
38058  }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Rect, {
38059    x: "14",
38060    y: "10",
38061    width: "4",
38062    height: "4",
38063    rx: "1",
38064    fill: "currentColor"
38065  }));
38066  const noButton = (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, {
38067    xmlns: "http://www.w3.org/2000/svg",
38068    viewBox: "0 0 24 24"
38069  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Rect, {
38070    x: "4.75",
38071    y: "15.25",
38072    width: "6.5",
38073    height: "14.5",
38074    transform: "rotate(-90 4.75 15.25)",
38075    stroke: "currentColor",
38076    fill: "none",
38077    strokeWidth: "1.5"
38078  }));
38079  const buttonWithIcon = (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, {
38080    xmlns: "http://www.w3.org/2000/svg",
38081    viewBox: "0 0 24 24"
38082  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Rect, {
38083    x: "4.75",
38084    y: "7.75",
38085    width: "14.5",
38086    height: "8.5",
38087    rx: "1.25",
38088    stroke: "currentColor",
38089    fill: "none",
38090    strokeWidth: "1.5"
38091  }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Rect, {
38092    x: "8",
38093    y: "11",
38094    width: "8",
38095    height: "2",
38096    fill: "currentColor"
38097  }));
38098  const toggleLabel = (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, {
38099    xmlns: "http://www.w3.org/2000/svg",
38100    viewBox: "0 0 24 24"
38101  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Rect, {
38102    x: "4.75",
38103    y: "17.25",
38104    width: "5.5",
38105    height: "14.5",
38106    transform: "rotate(-90 4.75 17.25)",
38107    stroke: "currentColor",
38108    fill: "none",
38109    strokeWidth: "1.5"
38110  }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Rect, {
38111    x: "4",
38112    y: "7",
38113    width: "10",
38114    height: "2",
38115    fill: "currentColor"
38116  }));
38117  
38118  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/search/utils.js
38119  /**
38120   * Constants
38121   */
38122  const PC_WIDTH_DEFAULT = 50;
38123  const PX_WIDTH_DEFAULT = 350;
38124  const MIN_WIDTH = 220;
38125  const MIN_WIDTH_UNIT = 'px';
38126  /**
38127   * Returns a boolean whether passed unit is percentage
38128   *
38129   * @param {string} unit Block width unit.
38130   *
38131   * @return {boolean}     Whether unit is '%'.
38132   */
38133  
38134  function utils_isPercentageUnit(unit) {
38135    return unit === '%';
38136  }
38137  
38138  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/search/edit.js
38139  
38140  
38141  /**
38142   * External dependencies
38143   */
38144  
38145  /**
38146   * WordPress dependencies
38147   */
38148  
38149  
38150  
38151  
38152  
38153  
38154  
38155  
38156  
38157  /**
38158   * Internal dependencies
38159   */
38160  
38161  
38162   // Used to calculate border radius adjustment to avoid "fat" corners when
38163  // button is placed inside wrapper.
38164  
38165  const DEFAULT_INNER_PADDING = '4px';
38166  function SearchEdit(_ref) {
38167    var _style$border, _style$border2, _style$border3;
38168  
38169    let {
38170      className,
38171      attributes,
38172      setAttributes,
38173      toggleSelection,
38174      isSelected,
38175      clientId
38176    } = _ref;
38177    const {
38178      label,
38179      showLabel,
38180      placeholder,
38181      width,
38182      widthUnit,
38183      align,
38184      buttonText,
38185      buttonPosition,
38186      buttonUseIcon,
38187      style
38188    } = attributes;
38189    const insertedInNavigationBlock = (0,external_wp_data_namespaceObject.useSelect)(select => {
38190      var _getBlockParentsByBlo;
38191  
38192      const {
38193        getBlockParentsByBlockName,
38194        wasBlockJustInserted
38195      } = select(external_wp_blockEditor_namespaceObject.store);
38196      return !!((_getBlockParentsByBlo = getBlockParentsByBlockName(clientId, 'core/navigation')) !== null && _getBlockParentsByBlo !== void 0 && _getBlockParentsByBlo.length) && wasBlockJustInserted(clientId);
38197    }, [clientId]);
38198    const {
38199      __unstableMarkNextChangeAsNotPersistent
38200    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_blockEditor_namespaceObject.store);
38201    (0,external_wp_element_namespaceObject.useEffect)(() => {
38202      if (!insertedInNavigationBlock) return; // This side-effect should not create an undo level.
38203  
38204      __unstableMarkNextChangeAsNotPersistent();
38205  
38206      setAttributes({
38207        showLabel: false,
38208        buttonUseIcon: true,
38209        buttonPosition: 'button-inside'
38210      });
38211    }, [insertedInNavigationBlock]);
38212    const borderRadius = style === null || style === void 0 ? void 0 : (_style$border = style.border) === null || _style$border === void 0 ? void 0 : _style$border.radius;
38213    const borderColor = style === null || style === void 0 ? void 0 : (_style$border2 = style.border) === null || _style$border2 === void 0 ? void 0 : _style$border2.color;
38214    const borderWidth = style === null || style === void 0 ? void 0 : (_style$border3 = style.border) === null || _style$border3 === void 0 ? void 0 : _style$border3.width;
38215    const borderProps = (0,external_wp_blockEditor_namespaceObject.__experimentalUseBorderProps)(attributes); // Check for old deprecated numerical border radius. Done as a separate
38216    // check so that a borderRadius style won't overwrite the longhand
38217    // per-corner styles.
38218  
38219    if (typeof borderRadius === 'number') {
38220      borderProps.style.borderRadius = `$borderRadius}px`;
38221    }
38222  
38223    const colorProps = (0,external_wp_blockEditor_namespaceObject.__experimentalUseColorProps)(attributes);
38224    const unitControlInstanceId = (0,external_wp_compose_namespaceObject.useInstanceId)(external_wp_components_namespaceObject.__experimentalUnitControl);
38225    const unitControlInputId = `wp-block-search__width-$unitControlInstanceId}`;
38226    const isButtonPositionInside = 'button-inside' === buttonPosition;
38227    const isButtonPositionOutside = 'button-outside' === buttonPosition;
38228    const hasNoButton = 'no-button' === buttonPosition;
38229    const hasOnlyButton = 'button-only' === buttonPosition;
38230    const units = (0,external_wp_components_namespaceObject.__experimentalUseCustomUnits)({
38231      availableUnits: ['%', 'px'],
38232      defaultValues: {
38233        '%': PC_WIDTH_DEFAULT,
38234        px: PX_WIDTH_DEFAULT
38235      }
38236    });
38237  
38238    const getBlockClassNames = () => {
38239      return classnames_default()(className, isButtonPositionInside ? 'wp-block-search__button-inside' : undefined, isButtonPositionOutside ? 'wp-block-search__button-outside' : undefined, hasNoButton ? 'wp-block-search__no-button' : undefined, hasOnlyButton ? 'wp-block-search__button-only' : undefined, !buttonUseIcon && !hasNoButton ? 'wp-block-search__text-button' : undefined, buttonUseIcon && !hasNoButton ? 'wp-block-search__icon-button' : undefined);
38240    };
38241  
38242    const buttonPositionControls = [{
38243      role: 'menuitemradio',
38244      title: (0,external_wp_i18n_namespaceObject.__)('Button outside'),
38245      isActive: buttonPosition === 'button-outside',
38246      icon: buttonOutside,
38247      onClick: () => {
38248        setAttributes({
38249          buttonPosition: 'button-outside'
38250        });
38251      }
38252    }, {
38253      role: 'menuitemradio',
38254      title: (0,external_wp_i18n_namespaceObject.__)('Button inside'),
38255      isActive: buttonPosition === 'button-inside',
38256      icon: buttonInside,
38257      onClick: () => {
38258        setAttributes({
38259          buttonPosition: 'button-inside'
38260        });
38261      }
38262    }, {
38263      role: 'menuitemradio',
38264      title: (0,external_wp_i18n_namespaceObject.__)('No button'),
38265      isActive: buttonPosition === 'no-button',
38266      icon: noButton,
38267      onClick: () => {
38268        setAttributes({
38269          buttonPosition: 'no-button'
38270        });
38271      }
38272    }];
38273  
38274    const getButtonPositionIcon = () => {
38275      switch (buttonPosition) {
38276        case 'button-inside':
38277          return buttonInside;
38278  
38279        case 'button-outside':
38280          return buttonOutside;
38281  
38282        case 'no-button':
38283          return noButton;
38284  
38285        case 'button-only':
38286          return buttonOnly;
38287      }
38288    };
38289  
38290    const getResizableSides = () => {
38291      if (hasOnlyButton) {
38292        return {};
38293      }
38294  
38295      return {
38296        right: align !== 'right',
38297        left: align === 'right'
38298      };
38299    };
38300  
38301    const renderTextField = () => {
38302      // If the input is inside the wrapper, the wrapper gets the border color styles/classes, not the input control.
38303      const textFieldClasses = classnames_default()('wp-block-search__input', isButtonPositionInside ? undefined : borderProps.className);
38304      const textFieldStyles = isButtonPositionInside ? {
38305        borderRadius
38306      } : borderProps.style;
38307      return (0,external_wp_element_namespaceObject.createElement)("input", {
38308        className: textFieldClasses,
38309        style: textFieldStyles,
38310        "aria-label": (0,external_wp_i18n_namespaceObject.__)('Optional placeholder text') // We hide the placeholder field's placeholder when there is a value. This
38311        // stops screen readers from reading the placeholder field's placeholder
38312        // which is confusing.
38313        ,
38314        placeholder: placeholder ? undefined : (0,external_wp_i18n_namespaceObject.__)('Optional placeholder…'),
38315        value: placeholder,
38316        onChange: event => setAttributes({
38317          placeholder: event.target.value
38318        })
38319      });
38320    };
38321  
38322    const renderButton = () => {
38323      // If the button is inside the wrapper, the wrapper gets the border color styles/classes, not the button.
38324      const buttonClasses = classnames_default()('wp-block-search__button', colorProps.className, isButtonPositionInside ? undefined : borderProps.className, buttonUseIcon ? 'has-icon' : undefined);
38325      const buttonStyles = { ...colorProps.style,
38326        ...(isButtonPositionInside ? {
38327          borderRadius
38328        } : borderProps.style)
38329      };
38330      return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, buttonUseIcon && (0,external_wp_element_namespaceObject.createElement)("button", {
38331        type: "button",
38332        className: buttonClasses,
38333        style: buttonStyles,
38334        "aria-label": buttonText ? (0,external_wp_dom_namespaceObject.__unstableStripHTML)(buttonText) : (0,external_wp_i18n_namespaceObject.__)('Search')
38335      }, (0,external_wp_element_namespaceObject.createElement)(icon, {
38336        icon: library_search
38337      })), !buttonUseIcon && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText, {
38338        className: buttonClasses,
38339        style: buttonStyles,
38340        "aria-label": (0,external_wp_i18n_namespaceObject.__)('Button text'),
38341        placeholder: (0,external_wp_i18n_namespaceObject.__)('Add button text…'),
38342        withoutInteractiveFormatting: true,
38343        value: buttonText,
38344        onChange: html => setAttributes({
38345          buttonText: html
38346        })
38347      }));
38348    };
38349  
38350    const controls = (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarGroup, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, {
38351      title: (0,external_wp_i18n_namespaceObject.__)('Toggle search label'),
38352      icon: toggleLabel,
38353      onClick: () => {
38354        setAttributes({
38355          showLabel: !showLabel
38356        });
38357      },
38358      className: showLabel ? 'is-pressed' : undefined
38359    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarDropdownMenu, {
38360      icon: getButtonPositionIcon(),
38361      label: (0,external_wp_i18n_namespaceObject.__)('Change button position'),
38362      controls: buttonPositionControls
38363    }), !hasNoButton && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, {
38364      title: (0,external_wp_i18n_namespaceObject.__)('Use button with icon'),
38365      icon: buttonWithIcon,
38366      onClick: () => {
38367        setAttributes({
38368          buttonUseIcon: !buttonUseIcon
38369        });
38370      },
38371      className: buttonUseIcon ? 'is-pressed' : undefined
38372    }))), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
38373      title: (0,external_wp_i18n_namespaceObject.__)('Display Settings')
38374    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.BaseControl, {
38375      label: (0,external_wp_i18n_namespaceObject.__)('Width'),
38376      id: unitControlInputId
38377    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalUnitControl, {
38378      id: unitControlInputId,
38379      min: `$MIN_WIDTH}$MIN_WIDTH_UNIT}`,
38380      onChange: newWidth => {
38381        const filteredWidth = widthUnit === '%' && parseInt(newWidth, 10) > 100 ? 100 : newWidth;
38382        setAttributes({
38383          width: parseInt(filteredWidth, 10)
38384        });
38385      },
38386      onUnitChange: newUnit => {
38387        setAttributes({
38388          width: '%' === newUnit ? PC_WIDTH_DEFAULT : PX_WIDTH_DEFAULT,
38389          widthUnit: newUnit
38390        });
38391      },
38392      style: {
38393        maxWidth: 80
38394      },
38395      value: `$width}$widthUnit}`,
38396      units: units
38397    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ButtonGroup, {
38398      className: "wp-block-search__components-button-group",
38399      "aria-label": (0,external_wp_i18n_namespaceObject.__)('Percentage Width')
38400    }, [25, 50, 75, 100].map(widthValue => {
38401      return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
38402        key: widthValue,
38403        isSmall: true,
38404        variant: `$widthValue}%` === `$width}$widthUnit}` ? 0 : undefined,
38405        onClick: () => setAttributes({
38406          width: widthValue,
38407          widthUnit: '%'
38408        })
38409      }, widthValue, "%");
38410    }))))));
38411  
38412    const padBorderRadius = radius => radius ? `calc($radius} + $DEFAULT_INNER_PADDING})` : undefined;
38413  
38414    const getWrapperStyles = () => {
38415      const styles = {
38416        borderColor,
38417        borderWidth: isButtonPositionInside ? borderWidth : undefined
38418      };
38419      const isNonZeroBorderRadius = borderRadius !== undefined && parseInt(borderRadius, 10) !== 0;
38420  
38421      if (isButtonPositionInside && isNonZeroBorderRadius) {
38422        // We have button inside wrapper and a border radius value to apply.
38423        // Add default padding so we don't get "fat" corners.
38424        //
38425        // CSS calc() is used here to support non-pixel units. The inline
38426        // style using calc() will only apply if both values have units.
38427        if (typeof borderRadius === 'object') {
38428          // Individual corner border radii present.
38429          const {
38430            topLeft,
38431            topRight,
38432            bottomLeft,
38433            bottomRight
38434          } = borderRadius;
38435          return {
38436            borderTopLeftRadius: padBorderRadius(topLeft),
38437            borderTopRightRadius: padBorderRadius(topRight),
38438            borderBottomLeftRadius: padBorderRadius(bottomLeft),
38439            borderBottomRightRadius: padBorderRadius(bottomRight),
38440            ...styles
38441          };
38442        } // The inline style using calc() will only apply if both values
38443        // supplied to calc() have units. Deprecated block's may have
38444        // unitless integer.
38445  
38446  
38447        const radius = Number.isInteger(borderRadius) ? `$borderRadius}px` : borderRadius;
38448        styles.borderRadius = `calc($radius} + $DEFAULT_INNER_PADDING})`;
38449      }
38450  
38451      return styles;
38452    };
38453  
38454    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
38455      className: getBlockClassNames()
38456    });
38457    return (0,external_wp_element_namespaceObject.createElement)("div", blockProps, controls, showLabel && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText, {
38458      className: "wp-block-search__label",
38459      "aria-label": (0,external_wp_i18n_namespaceObject.__)('Label text'),
38460      placeholder: (0,external_wp_i18n_namespaceObject.__)('Add label…'),
38461      withoutInteractiveFormatting: true,
38462      value: label,
38463      onChange: html => setAttributes({
38464        label: html
38465      })
38466    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ResizableBox, {
38467      size: {
38468        width: `$width}$widthUnit}`
38469      },
38470      className: classnames_default()('wp-block-search__inside-wrapper', isButtonPositionInside ? borderProps.className : undefined),
38471      style: getWrapperStyles(),
38472      minWidth: MIN_WIDTH,
38473      enable: getResizableSides(),
38474      onResizeStart: (event, direction, elt) => {
38475        setAttributes({
38476          width: parseInt(elt.offsetWidth, 10),
38477          widthUnit: 'px'
38478        });
38479        toggleSelection(false);
38480      },
38481      onResizeStop: (event, direction, elt, delta) => {
38482        setAttributes({
38483          width: parseInt(width + delta.width, 10)
38484        });
38485        toggleSelection(true);
38486      },
38487      showHandle: isSelected
38488    }, (isButtonPositionInside || isButtonPositionOutside) && (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, renderTextField(), renderButton()), hasOnlyButton && renderButton(), hasNoButton && renderTextField()));
38489  }
38490  
38491  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/search/variations.js
38492  /**
38493   * WordPress dependencies
38494   */
38495  
38496  const search_variations_variations = [{
38497    name: 'default',
38498    isDefault: true,
38499    attributes: {
38500      buttonText: (0,external_wp_i18n_namespaceObject.__)('Search'),
38501      label: (0,external_wp_i18n_namespaceObject.__)('Search')
38502    }
38503  }];
38504  /* harmony default export */ var search_variations = (search_variations_variations);
38505  
38506  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/search/index.js
38507  /**
38508   * WordPress dependencies
38509   */
38510  
38511  /**
38512   * Internal dependencies
38513   */
38514  
38515  const search_metadata = {
38516    $schema: "https://schemas.wp.org/trunk/block.json",
38517    apiVersion: 2,
38518    name: "core/search",
38519    title: "Search",
38520    category: "widgets",
38521    description: "Help visitors find your content.",
38522    keywords: ["find"],
38523    textdomain: "default",
38524    attributes: {
38525      label: {
38526        type: "string",
38527        __experimentalRole: "content"
38528      },
38529      showLabel: {
38530        type: "boolean",
38531        "default": true
38532      },
38533      placeholder: {
38534        type: "string",
38535        "default": "",
38536        __experimentalRole: "content"
38537      },
38538      width: {
38539        type: "number"
38540      },
38541      widthUnit: {
38542        type: "string"
38543      },
38544      buttonText: {
38545        type: "string",
38546        __experimentalRole: "content"
38547      },
38548      buttonPosition: {
38549        type: "string",
38550        "default": "button-outside"
38551      },
38552      buttonUseIcon: {
38553        type: "boolean",
38554        "default": false
38555      }
38556    },
38557    supports: {
38558      align: ["left", "center", "right"],
38559      color: {
38560        gradients: true,
38561        __experimentalSkipSerialization: true,
38562        __experimentalDefaultControls: {
38563          background: true,
38564          text: true
38565        }
38566      },
38567      __experimentalBorder: {
38568        color: true,
38569        radius: true,
38570        width: true,
38571        __experimentalSkipSerialization: true,
38572        __experimentalDefaultControls: {
38573          color: true,
38574          radius: true,
38575          width: true
38576        }
38577      },
38578      html: false
38579    },
38580    editorStyle: "wp-block-search-editor",
38581    style: "wp-block-search"
38582  };
38583  
38584  
38585  const {
38586    name: search_name
38587  } = search_metadata;
38588  
38589  const search_settings = {
38590    icon: library_search,
38591    example: {},
38592    variations: search_variations,
38593    edit: SearchEdit
38594  };
38595  
38596  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/separator.js
38597  
38598  
38599  /**
38600   * WordPress dependencies
38601   */
38602  
38603  const separator = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
38604    viewBox: "0 0 24 24",
38605    xmlns: "http://www.w3.org/2000/svg"
38606  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
38607    d: "M20.2 7v4H3.8V7H2.2v9h1.6v-3.5h16.4V16h1.6V7z"
38608  }));
38609  /* harmony default export */ var library_separator = (separator);
38610  
38611  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/separator/use-deprecated-opacity.js
38612  /**
38613   * WordPress dependencies
38614   */
38615  
38616  
38617  function useDeprecatedOpacity(opacity, currentColor, setAttributes) {
38618    const [deprecatedOpacityWithNoColor, setDeprecatedOpacityWithNoColor] = (0,external_wp_element_namespaceObject.useState)(false);
38619    const previousColor = (0,external_wp_compose_namespaceObject.usePrevious)(currentColor); // A separator with no color set will always have previousColor set to undefined,
38620    // and we need to differentiate these from those with color set that will return
38621    // previousColor as undefined on the first render.
38622  
38623    (0,external_wp_element_namespaceObject.useEffect)(() => {
38624      if (opacity === 'css' && !currentColor && !previousColor) {
38625        setDeprecatedOpacityWithNoColor(true);
38626      }
38627    }, [currentColor, previousColor, opacity]); // For deprecated blocks, that have a default 0.4 css opacity set, we
38628    // need to remove this if the current color is changed, or a color is added.
38629    // In these instances the opacity attribute is set back to the default of
38630    // alpha-channel which allows a new custom opacity to be set via the color picker.
38631  
38632    (0,external_wp_element_namespaceObject.useEffect)(() => {
38633      if (opacity === 'css' && (deprecatedOpacityWithNoColor && currentColor || previousColor && currentColor !== previousColor)) {
38634        setAttributes({
38635          opacity: 'alpha-channel'
38636        });
38637        setDeprecatedOpacityWithNoColor(false);
38638      }
38639    }, [deprecatedOpacityWithNoColor, currentColor, previousColor]);
38640  }
38641  
38642  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/separator/edit.js
38643  
38644  
38645  /**
38646   * External dependencies
38647   */
38648  
38649  /**
38650   * WordPress dependencies
38651   */
38652  
38653  
38654  
38655  /**
38656   * Internal dependencies
38657   */
38658  
38659  
38660  function SeparatorEdit(_ref) {
38661    var _colorProps$style, _style$color;
38662  
38663    let {
38664      attributes,
38665      setAttributes
38666    } = _ref;
38667    const {
38668      backgroundColor,
38669      opacity,
38670      style
38671    } = attributes;
38672    const colorProps = (0,external_wp_blockEditor_namespaceObject.__experimentalUseColorProps)(attributes);
38673    const currentColor = colorProps === null || colorProps === void 0 ? void 0 : (_colorProps$style = colorProps.style) === null || _colorProps$style === void 0 ? void 0 : _colorProps$style.backgroundColor;
38674    const hasCustomColor = !!(style !== null && style !== void 0 && (_style$color = style.color) !== null && _style$color !== void 0 && _style$color.background);
38675    useDeprecatedOpacity(opacity, currentColor, setAttributes); // The dots styles uses text for the dots, to change those dots color is
38676    // using color, not backgroundColor.
38677  
38678    const colorClass = (0,external_wp_blockEditor_namespaceObject.getColorClassName)('color', backgroundColor);
38679    const className = classnames_default()({
38680      'has-text-color': backgroundColor || currentColor,
38681      [colorClass]: colorClass,
38682      'has-css-opacity': opacity === 'css',
38683      'has-alpha-channel-opacity': opacity === 'alpha-channel'
38684    }, colorProps.classname);
38685    const styles = {
38686      color: currentColor,
38687      backgroundColor: currentColor
38688    };
38689    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.HorizontalRule, (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
38690      className,
38691      style: hasCustomColor ? styles : undefined
38692    })));
38693  }
38694  
38695  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/separator/save.js
38696  
38697  
38698  /**
38699   * External dependencies
38700   */
38701  
38702  /**
38703   * WordPress dependencies
38704   */
38705  
38706  
38707  function separatorSave(_ref) {
38708    var _style$color, _colorProps$style;
38709  
38710    let {
38711      attributes
38712    } = _ref;
38713    const {
38714      backgroundColor,
38715      style,
38716      opacity
38717    } = attributes;
38718    const customColor = style === null || style === void 0 ? void 0 : (_style$color = style.color) === null || _style$color === void 0 ? void 0 : _style$color.background;
38719    const colorProps = (0,external_wp_blockEditor_namespaceObject.__experimentalGetColorClassesAndStyles)(attributes); // The hr support changing color using border-color, since border-color
38720    // is not yet supported in the color palette, we use background-color.
38721    // The dots styles uses text for the dots, to change those dots color is
38722    // using color, not backgroundColor.
38723  
38724    const colorClass = (0,external_wp_blockEditor_namespaceObject.getColorClassName)('color', backgroundColor);
38725    const className = classnames_default()({
38726      'has-text-color': backgroundColor || customColor,
38727      [colorClass]: colorClass,
38728      'has-css-opacity': opacity === 'css',
38729      'has-alpha-channel-opacity': opacity === 'alpha-channel'
38730    }, colorProps.className);
38731    const styles = {
38732      backgroundColor: colorProps === null || colorProps === void 0 ? void 0 : (_colorProps$style = colorProps.style) === null || _colorProps$style === void 0 ? void 0 : _colorProps$style.backgroundColor,
38733      color: colorClass ? undefined : customColor
38734    };
38735    return (0,external_wp_element_namespaceObject.createElement)("hr", external_wp_blockEditor_namespaceObject.useBlockProps.save({
38736      className,
38737      style: styles
38738    }));
38739  }
38740  
38741  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/separator/transforms.js
38742  /**
38743   * WordPress dependencies
38744   */
38745  
38746  const separator_transforms_transforms = {
38747    from: [{
38748      type: 'enter',
38749      regExp: /^-{3,}$/,
38750      transform: () => (0,external_wp_blocks_namespaceObject.createBlock)('core/separator')
38751    }, {
38752      type: 'raw',
38753      selector: 'hr',
38754      schema: {
38755        hr: {}
38756      }
38757    }]
38758  };
38759  /* harmony default export */ var separator_transforms = (separator_transforms_transforms);
38760  
38761  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/separator/deprecated.js
38762  
38763  
38764  /**
38765   * External dependencies
38766   */
38767  
38768  
38769  /**
38770   * WordPress dependencies
38771   */
38772  
38773  
38774  const separator_deprecated_v1 = {
38775    attributes: {
38776      color: {
38777        type: 'string'
38778      },
38779      customColor: {
38780        type: 'string'
38781      }
38782    },
38783  
38784    save(_ref) {
38785      let {
38786        attributes
38787      } = _ref;
38788      const {
38789        color,
38790        customColor
38791      } = attributes; // the hr support changing color using border-color, since border-color
38792      // is not yet supported in the color palette, we use background-color
38793  
38794      const backgroundClass = (0,external_wp_blockEditor_namespaceObject.getColorClassName)('background-color', color); // the dots styles uses text for the dots, to change those dots color is
38795      // using color, not backgroundColor
38796  
38797      const colorClass = (0,external_wp_blockEditor_namespaceObject.getColorClassName)('color', color);
38798      const className = classnames_default()({
38799        'has-text-color has-background': color || customColor,
38800        [backgroundClass]: backgroundClass,
38801        [colorClass]: colorClass
38802      });
38803      const style = {
38804        backgroundColor: backgroundClass ? undefined : customColor,
38805        color: colorClass ? undefined : customColor
38806      };
38807      return (0,external_wp_element_namespaceObject.createElement)("hr", external_wp_blockEditor_namespaceObject.useBlockProps.save({
38808        className,
38809        style
38810      }));
38811    },
38812  
38813    migrate(attributes) {
38814      const {
38815        color,
38816        customColor
38817      } = attributes;
38818      return { ...(0,external_lodash_namespaceObject.omit)(attributes, ['color', 'customColor']),
38819        backgroundColor: color ? color : undefined,
38820        opacity: 'css',
38821        style: customColor ? {
38822          color: {
38823            background: customColor
38824          }
38825        } : undefined
38826      };
38827    }
38828  
38829  };
38830  /* harmony default export */ var separator_deprecated = ([separator_deprecated_v1]);
38831  
38832  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/separator/index.js
38833  /**
38834   * WordPress dependencies
38835   */
38836  
38837  /**
38838   * Internal dependencies
38839   */
38840  
38841  
38842  const separator_metadata = {
38843    $schema: "https://schemas.wp.org/trunk/block.json",
38844    apiVersion: 2,
38845    name: "core/separator",
38846    title: "Separator",
38847    category: "design",
38848    description: "Create a break between ideas or sections with a horizontal separator.",
38849    keywords: ["horizontal-line", "hr", "divider"],
38850    textdomain: "default",
38851    attributes: {
38852      opacity: {
38853        type: "string",
38854        "default": "alpha-channel"
38855      }
38856    },
38857    supports: {
38858      anchor: true,
38859      align: ["center", "wide", "full"],
38860      color: {
38861        __experimentalSkipSerialization: true,
38862        gradients: true,
38863        background: true,
38864        text: false,
38865        __experimentalDefaultControls: {
38866          background: true
38867        }
38868      }
38869    },
38870    styles: [{
38871      name: "default",
38872      label: "Default",
38873      isDefault: true
38874    }, {
38875      name: "wide",
38876      label: "Wide Line"
38877    }, {
38878      name: "dots",
38879      label: "Dots"
38880    }],
38881    editorStyle: "wp-block-separator-editor",
38882    style: "wp-block-separator"
38883  };
38884  
38885  
38886  
38887  const {
38888    name: separator_name
38889  } = separator_metadata;
38890  
38891  const separator_settings = {
38892    icon: library_separator,
38893    example: {
38894      attributes: {
38895        customColor: '#065174',
38896        className: 'is-style-wide'
38897      }
38898    },
38899    transforms: separator_transforms,
38900    edit: SeparatorEdit,
38901    save: separatorSave,
38902    deprecated: separator_deprecated
38903  };
38904  
38905  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/shortcode.js
38906  
38907  
38908  /**
38909   * WordPress dependencies
38910   */
38911  
38912  const shortcode = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
38913    viewBox: "0 0 24 24",
38914    xmlns: "http://www.w3.org/2000/svg"
38915  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
38916    d: "M16 4.2v1.5h2.5v12.5H16v1.5h4V4.2h-4zM4.2 19.8h4v-1.5H5.8V5.8h2.5V4.2h-4l-.1 15.6zm5.1-3.1l1.4.6 4-10-1.4-.6-4 10z"
38917  }));
38918  /* harmony default export */ var library_shortcode = (shortcode);
38919  
38920  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/shortcode/edit.js
38921  
38922  
38923  /**
38924   * WordPress dependencies
38925   */
38926  
38927  
38928  
38929  
38930  function ShortcodeEdit(_ref) {
38931    let {
38932      attributes,
38933      setAttributes
38934    } = _ref;
38935    const instanceId = (0,external_wp_compose_namespaceObject.useInstanceId)(ShortcodeEdit);
38936    const inputId = `blocks-shortcode-input-$instanceId}`;
38937    return (0,external_wp_element_namespaceObject.createElement)("div", (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
38938      className: 'components-placeholder'
38939    }), (0,external_wp_element_namespaceObject.createElement)("label", {
38940      htmlFor: inputId,
38941      className: "components-placeholder__label"
38942    }, (0,external_wp_element_namespaceObject.createElement)(icon, {
38943      icon: library_shortcode
38944    }), (0,external_wp_i18n_namespaceObject.__)('Shortcode')), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.PlainText, {
38945      className: "blocks-shortcode__textarea",
38946      id: inputId,
38947      value: attributes.text,
38948      "aria-label": (0,external_wp_i18n_namespaceObject.__)('Shortcode text'),
38949      placeholder: (0,external_wp_i18n_namespaceObject.__)('Write shortcode here…'),
38950      onChange: text => setAttributes({
38951        text
38952      })
38953    }));
38954  }
38955  
38956  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/shortcode/save.js
38957  
38958  
38959  /**
38960   * WordPress dependencies
38961   */
38962  
38963  function shortcode_save_save(_ref) {
38964    let {
38965      attributes
38966    } = _ref;
38967    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.RawHTML, null, attributes.text);
38968  }
38969  
38970  ;// CONCATENATED MODULE: external ["wp","autop"]
38971  var external_wp_autop_namespaceObject = window["wp"]["autop"];
38972  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/shortcode/transforms.js
38973  /**
38974   * WordPress dependencies
38975   */
38976  
38977  const shortcode_transforms_transforms = {
38978    from: [{
38979      type: 'shortcode',
38980      // Per "Shortcode names should be all lowercase and use all
38981      // letters, but numbers and underscores should work fine too.
38982      // Be wary of using hyphens (dashes), you'll be better off not
38983      // using them." in https://codex.wordpress.org/Shortcode_API
38984      // Require that the first character be a letter. This notably
38985      // prevents footnote markings ([1]) from being caught as
38986      // shortcodes.
38987      tag: '[a-z][a-z0-9_-]*',
38988      attributes: {
38989        text: {
38990          type: 'string',
38991          shortcode: (attrs, _ref) => {
38992            let {
38993              content
38994            } = _ref;
38995            return (0,external_wp_autop_namespaceObject.removep)((0,external_wp_autop_namespaceObject.autop)(content));
38996          }
38997        }
38998      },
38999      priority: 20
39000    }]
39001  };
39002  /* harmony default export */ var shortcode_transforms = (shortcode_transforms_transforms);
39003  
39004  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/shortcode/index.js
39005  /**
39006   * WordPress dependencies
39007   */
39008  
39009  /**
39010   * Internal dependencies
39011   */
39012  
39013  
39014  
39015  
39016  const shortcode_metadata = {
39017    $schema: "https://schemas.wp.org/trunk/block.json",
39018    apiVersion: 2,
39019    name: "core/shortcode",
39020    title: "Shortcode",
39021    category: "widgets",
39022    description: "Insert additional custom elements with a WordPress shortcode.",
39023    textdomain: "default",
39024    attributes: {
39025      text: {
39026        type: "string",
39027        source: "html"
39028      }
39029    },
39030    supports: {
39031      className: false,
39032      customClassName: false,
39033      html: false
39034    },
39035    editorStyle: "wp-block-shortcode-editor"
39036  };
39037  const {
39038    name: shortcode_name
39039  } = shortcode_metadata;
39040  
39041  const shortcode_settings = {
39042    icon: library_shortcode,
39043    transforms: shortcode_transforms,
39044    edit: ShortcodeEdit,
39045    save: shortcode_save_save
39046  };
39047  
39048  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/site-logo.js
39049  
39050  
39051  /**
39052   * WordPress dependencies
39053   */
39054  
39055  const siteLogo = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
39056    xmlns: "http://www.w3.org/2000/svg",
39057    viewBox: "0 0 24 24"
39058  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
39059    d: "M12 3c-5 0-9 4-9 9s4 9 9 9 9-4 9-9-4-9-9-9zm0 1.5c4.1 0 7.5 3.4 7.5 7.5v.1c-1.4-.8-3.3-1.7-3.4-1.8-.2-.1-.5-.1-.8.1l-2.9 2.1L9 11.3c-.2-.1-.4 0-.6.1l-3.7 2.2c-.1-.5-.2-1-.2-1.5 0-4.2 3.4-7.6 7.5-7.6zm0 15c-3.1 0-5.7-1.9-6.9-4.5l3.7-2.2 3.5 1.2c.2.1.5 0 .7-.1l2.9-2.1c.8.4 2.5 1.2 3.5 1.9-.9 3.3-3.9 5.8-7.4 5.8z"
39060  }));
39061  /* harmony default export */ var site_logo = (siteLogo);
39062  
39063  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/site-logo/edit.js
39064  
39065  
39066  /**
39067   * External dependencies
39068   */
39069  
39070  
39071  /**
39072   * WordPress dependencies
39073   */
39074  
39075  
39076  
39077  
39078  
39079  
39080  
39081  
39082  
39083  
39084  
39085  
39086  /**
39087   * Internal dependencies
39088   */
39089  
39090  
39091  /**
39092   * Module constants
39093   */
39094  
39095  
39096  const site_logo_edit_ALLOWED_MEDIA_TYPES = ['image'];
39097  const ACCEPT_MEDIA_STRING = 'image/*';
39098  
39099  const SiteLogo = _ref => {
39100    let {
39101      alt,
39102      attributes: {
39103        align,
39104        width,
39105        height,
39106        isLink,
39107        linkTarget,
39108        shouldSyncIcon
39109      },
39110      containerRef,
39111      isSelected,
39112      setAttributes,
39113      setLogo,
39114      logoUrl,
39115      siteUrl,
39116      logoId,
39117      iconId,
39118      setIcon,
39119      canUserEdit
39120    } = _ref;
39121    const clientWidth = useClientWidth(containerRef, [align]);
39122    const isLargeViewport = (0,external_wp_compose_namespaceObject.useViewportMatch)('medium');
39123    const isWideAligned = (0,external_lodash_namespaceObject.includes)(['wide', 'full'], align);
39124    const isResizable = !isWideAligned && isLargeViewport;
39125    const [{
39126      naturalWidth,
39127      naturalHeight
39128    }, setNaturalSize] = (0,external_wp_element_namespaceObject.useState)({});
39129    const [isEditingImage, setIsEditingImage] = (0,external_wp_element_namespaceObject.useState)(false);
39130    const {
39131      toggleSelection
39132    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_blockEditor_namespaceObject.store);
39133    const classes = classnames_default()('custom-logo-link', {
39134      'is-transient': (0,external_wp_blob_namespaceObject.isBlobURL)(logoUrl)
39135    });
39136    const {
39137      imageEditing,
39138      maxWidth,
39139      title
39140    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
39141      const {
39142        getSettings
39143      } = select(external_wp_blockEditor_namespaceObject.store);
39144      const siteEntities = select(external_wp_coreData_namespaceObject.store).getEditedEntityRecord('root', 'site');
39145      return {
39146        title: siteEntities.title,
39147        ...(0,external_lodash_namespaceObject.pick)(getSettings(), ['imageEditing', 'maxWidth'])
39148      };
39149    }, []);
39150    (0,external_wp_element_namespaceObject.useEffect)(() => {
39151      // Turn the `Use as site icon` toggle off if it is on but the logo and icon have
39152      // fallen out of sync. This can happen if the toggle is saved in the `on` position,
39153      // but changes are later made to the site icon in the Customizer.
39154      if (shouldSyncIcon && logoId !== iconId) {
39155        setAttributes({
39156          shouldSyncIcon: false
39157        });
39158      }
39159    }, []);
39160    (0,external_wp_element_namespaceObject.useEffect)(() => {
39161      if (!isSelected) {
39162        setIsEditingImage(false);
39163      }
39164    }, [isSelected]);
39165  
39166    function onResizeStart() {
39167      toggleSelection(false);
39168    }
39169  
39170    function onResizeStop() {
39171      toggleSelection(true);
39172    }
39173  
39174    const img = (0,external_wp_element_namespaceObject.createElement)("img", {
39175      className: "custom-logo",
39176      src: logoUrl,
39177      alt: alt,
39178      onLoad: event => {
39179        setNaturalSize((0,external_lodash_namespaceObject.pick)(event.target, ['naturalWidth', 'naturalHeight']));
39180      }
39181    });
39182    let imgWrapper = img; // Disable reason: Image itself is not meant to be interactive, but
39183    // should direct focus to block.
39184  
39185    if (isLink) {
39186      imgWrapper =
39187      /* eslint-disable jsx-a11y/no-noninteractive-element-interactions, jsx-a11y/click-events-have-key-events */
39188      (0,external_wp_element_namespaceObject.createElement)("a", {
39189        href: siteUrl,
39190        className: classes,
39191        rel: "home",
39192        title: title,
39193        onClick: event => event.preventDefault()
39194      }, img)
39195      /* eslint-enable jsx-a11y/no-noninteractive-element-interactions, jsx-a11y/click-events-have-key-events */
39196      ;
39197    }
39198  
39199    let imageWidthWithinContainer;
39200  
39201    if (clientWidth && naturalWidth && naturalHeight) {
39202      const exceedMaxWidth = naturalWidth > clientWidth;
39203      imageWidthWithinContainer = exceedMaxWidth ? clientWidth : naturalWidth;
39204    }
39205  
39206    if (!isResizable || !imageWidthWithinContainer) {
39207      return (0,external_wp_element_namespaceObject.createElement)("div", {
39208        style: {
39209          width,
39210          height
39211        }
39212      }, imgWrapper);
39213    } // Set the default width to a responsible size.
39214    // Note that this width is also set in the attached frontend CSS file.
39215  
39216  
39217    const defaultWidth = 120;
39218    const currentWidth = width || defaultWidth;
39219    const ratio = naturalWidth / naturalHeight;
39220    const currentHeight = currentWidth / ratio;
39221    const minWidth = naturalWidth < naturalHeight ? MIN_SIZE : Math.ceil(MIN_SIZE * ratio);
39222    const minHeight = naturalHeight < naturalWidth ? MIN_SIZE : Math.ceil(MIN_SIZE / ratio); // With the current implementation of ResizableBox, an image needs an
39223    // explicit pixel value for the max-width. In absence of being able to
39224    // set the content-width, this max-width is currently dictated by the
39225    // vanilla editor style. The following variable adds a buffer to this
39226    // vanilla style, so 3rd party themes have some wiggleroom. This does,
39227    // in most cases, allow you to scale the image beyond the width of the
39228    // main column, though not infinitely.
39229    // @todo It would be good to revisit this once a content-width variable
39230    // becomes available.
39231  
39232    const maxWidthBuffer = maxWidth * 2.5;
39233    let showRightHandle = false;
39234    let showLeftHandle = false;
39235    /* eslint-disable no-lonely-if */
39236    // See https://github.com/WordPress/gutenberg/issues/7584.
39237  
39238    if (align === 'center') {
39239      // When the image is centered, show both handles.
39240      showRightHandle = true;
39241      showLeftHandle = true;
39242    } else if ((0,external_wp_i18n_namespaceObject.isRTL)()) {
39243      // In RTL mode the image is on the right by default.
39244      // Show the right handle and hide the left handle only when it is
39245      // aligned left. Otherwise always show the left handle.
39246      if (align === 'left') {
39247        showRightHandle = true;
39248      } else {
39249        showLeftHandle = true;
39250      }
39251    } else {
39252      // Show the left handle and hide the right handle only when the
39253      // image is aligned right. Otherwise always show the right handle.
39254      if (align === 'right') {
39255        showLeftHandle = true;
39256      } else {
39257        showRightHandle = true;
39258      }
39259    }
39260    /* eslint-enable no-lonely-if */
39261  
39262  
39263    const canEditImage = logoId && naturalWidth && naturalHeight && imageEditing;
39264    const imgEdit = canEditImage && isEditingImage ? (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.__experimentalImageEditingProvider, {
39265      id: logoId,
39266      url: logoUrl,
39267      naturalWidth: naturalWidth,
39268      naturalHeight: naturalHeight,
39269      clientWidth: clientWidth,
39270      onSaveImage: imageAttributes => {
39271        setLogo(imageAttributes.id);
39272      },
39273      isEditing: isEditingImage,
39274      onFinishEditing: () => setIsEditingImage(false)
39275    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.__experimentalImageEditor, {
39276      url: logoUrl,
39277      width: currentWidth,
39278      height: currentHeight,
39279      clientWidth: clientWidth,
39280      naturalHeight: naturalHeight,
39281      naturalWidth: naturalWidth
39282    })) : (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ResizableBox, {
39283      size: {
39284        width: currentWidth,
39285        height: currentHeight
39286      },
39287      showHandle: isSelected,
39288      minWidth: minWidth,
39289      maxWidth: maxWidthBuffer,
39290      minHeight: minHeight,
39291      maxHeight: maxWidthBuffer / ratio,
39292      lockAspectRatio: true,
39293      enable: {
39294        top: false,
39295        right: showRightHandle,
39296        bottom: true,
39297        left: showLeftHandle
39298      },
39299      onResizeStart: onResizeStart,
39300      onResizeStop: (event, direction, elt, delta) => {
39301        onResizeStop();
39302        setAttributes({
39303          width: parseInt(currentWidth + delta.width, 10),
39304          height: parseInt(currentHeight + delta.height, 10)
39305        });
39306      }
39307    }, imgWrapper);
39308    const syncSiteIconHelpText = (0,external_wp_element_namespaceObject.createInterpolateElement)((0,external_wp_i18n_namespaceObject.__)('Site Icons are what you see in browser tabs, bookmark bars, and within the WordPress mobile apps. To use a custom icon that is different from your site logo, use the <a>Site Icon settings</a>.'), {
39309      a: // eslint-disable-next-line jsx-a11y/anchor-has-content
39310      (0,external_wp_element_namespaceObject.createElement)("a", {
39311        href: siteUrl + '/wp-admin/customize.php?autofocus[section]=title_tagline',
39312        target: "_blank",
39313        rel: "noopener noreferrer"
39314      })
39315    });
39316    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
39317      title: (0,external_wp_i18n_namespaceObject.__)('Settings')
39318    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.RangeControl, {
39319      label: (0,external_wp_i18n_namespaceObject.__)('Image width'),
39320      onChange: newWidth => setAttributes({
39321        width: newWidth
39322      }),
39323      min: minWidth,
39324      max: maxWidthBuffer,
39325      initialPosition: Math.min(defaultWidth, maxWidthBuffer),
39326      value: width || '',
39327      disabled: !isResizable
39328    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
39329      label: (0,external_wp_i18n_namespaceObject.__)('Link image to home'),
39330      onChange: () => setAttributes({
39331        isLink: !isLink
39332      }),
39333      checked: isLink
39334    }), isLink && (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
39335      label: (0,external_wp_i18n_namespaceObject.__)('Open in new tab'),
39336      onChange: value => setAttributes({
39337        linkTarget: value ? '_blank' : '_self'
39338      }),
39339      checked: linkTarget === '_blank'
39340    })), canUserEdit && (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
39341      label: (0,external_wp_i18n_namespaceObject.__)('Use as site icon'),
39342      onChange: value => {
39343        setAttributes({
39344          shouldSyncIcon: value
39345        });
39346        setIcon(value ? logoId : undefined);
39347      },
39348      checked: !!shouldSyncIcon,
39349      help: syncSiteIconHelpText
39350    })))), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, {
39351      group: "block"
39352    }, canEditImage && !isEditingImage && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, {
39353      onClick: () => setIsEditingImage(true),
39354      icon: library_crop,
39355      label: (0,external_wp_i18n_namespaceObject.__)('Crop')
39356    })), imgEdit);
39357  };
39358  
39359  function LogoEdit(_ref2) {
39360    let {
39361      attributes,
39362      className,
39363      setAttributes,
39364      isSelected
39365    } = _ref2;
39366    const {
39367      width,
39368      shouldSyncIcon
39369    } = attributes;
39370    const [logoUrl, setLogoUrl] = (0,external_wp_element_namespaceObject.useState)();
39371    const ref = (0,external_wp_element_namespaceObject.useRef)();
39372    const {
39373      siteLogoId,
39374      canUserEdit,
39375      url,
39376      siteIconId,
39377      mediaItemData,
39378      isRequestingMediaItem
39379    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
39380      const {
39381        canUser,
39382        getEntityRecord,
39383        getEditedEntityRecord
39384      } = select(external_wp_coreData_namespaceObject.store);
39385      const siteSettings = getEditedEntityRecord('root', 'site');
39386      const siteData = getEntityRecord('root', '__unstableBase');
39387  
39388      const _siteLogo = siteSettings === null || siteSettings === void 0 ? void 0 : siteSettings.site_logo;
39389  
39390      const _readOnlyLogo = siteData === null || siteData === void 0 ? void 0 : siteData.site_logo;
39391  
39392      const _canUserEdit = canUser('update', 'settings');
39393  
39394      const _siteLogoId = _canUserEdit ? _siteLogo : _readOnlyLogo;
39395  
39396      const _siteIconId = siteSettings === null || siteSettings === void 0 ? void 0 : siteSettings.site_icon;
39397  
39398      const mediaItem = _siteLogoId && select(external_wp_coreData_namespaceObject.store).getMedia(_siteLogoId, {
39399        context: 'view'
39400      });
39401  
39402      const _isRequestingMediaItem = _siteLogoId && !select(external_wp_coreData_namespaceObject.store).hasFinishedResolution('getMedia', [_siteLogoId, {
39403        context: 'view'
39404      }]);
39405  
39406      return {
39407        siteLogoId: _siteLogoId,
39408        canUserEdit: _canUserEdit,
39409        url: siteData === null || siteData === void 0 ? void 0 : siteData.url,
39410        mediaItemData: mediaItem,
39411        isRequestingMediaItem: _isRequestingMediaItem,
39412        siteIconId: _siteIconId
39413      };
39414    }, []);
39415    const {
39416      editEntityRecord
39417    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_coreData_namespaceObject.store);
39418  
39419    const setLogo = function (newValue) {
39420      let shouldForceSync = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
39421  
39422      // `shouldForceSync` is used to force syncing when the attribute
39423      // may not have updated yet.
39424      if (shouldSyncIcon || shouldForceSync) {
39425        setIcon(newValue);
39426      }
39427  
39428      editEntityRecord('root', 'site', undefined, {
39429        site_logo: newValue
39430      });
39431    };
39432  
39433    const setIcon = newValue => // The new value needs to be `null` to reset the Site Icon.
39434    editEntityRecord('root', 'site', undefined, {
39435      site_icon: newValue !== null && newValue !== void 0 ? newValue : null
39436    });
39437  
39438    let alt = null;
39439  
39440    if (mediaItemData) {
39441      alt = mediaItemData.alt_text;
39442  
39443      if (logoUrl !== mediaItemData.source_url) {
39444        setLogoUrl(mediaItemData.source_url);
39445      }
39446    }
39447  
39448    const onInitialSelectLogo = media => {
39449      // Initialize the syncSiteIcon toggle. If we currently have no Site logo and no
39450      // site icon, automatically sync the logo to the icon.
39451      if (shouldSyncIcon === undefined) {
39452        const shouldForceSync = !siteIconId;
39453        setAttributes({
39454          shouldSyncIcon: shouldForceSync
39455        }); // Because we cannot rely on the `shouldSyncIcon` attribute to have updated by
39456        // the time `setLogo` is called, pass an argument to force the syncing.
39457  
39458        onSelectLogo(media, shouldForceSync);
39459        return;
39460      }
39461  
39462      onSelectLogo(media);
39463    };
39464  
39465    const onSelectLogo = function (media) {
39466      let shouldForceSync = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
39467  
39468      if (!media) {
39469        return;
39470      }
39471  
39472      if (!media.id && media.url) {
39473        // This is a temporary blob image.
39474        setLogo(undefined);
39475        setLogoUrl(media.url);
39476        return;
39477      }
39478  
39479      setLogo(media.id, shouldForceSync);
39480    };
39481  
39482    const onRemoveLogo = () => {
39483      setLogo(null);
39484      setLogoUrl(undefined);
39485      setAttributes({
39486        width: undefined
39487      });
39488    };
39489  
39490    const {
39491      createErrorNotice
39492    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_notices_namespaceObject.store);
39493  
39494    const onUploadError = message => {
39495      createErrorNotice(message[2], {
39496        type: 'snackbar'
39497      });
39498    };
39499  
39500    const controls = canUserEdit && logoUrl && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, {
39501      group: "other"
39502    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.MediaReplaceFlow, {
39503      mediaURL: logoUrl,
39504      allowedTypes: site_logo_edit_ALLOWED_MEDIA_TYPES,
39505      accept: ACCEPT_MEDIA_STRING,
39506      onSelect: onSelectLogo,
39507      onError: onUploadError
39508    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, {
39509      onClick: onRemoveLogo
39510    }, (0,external_wp_i18n_namespaceObject.__)('Reset'))));
39511    let logoImage;
39512    const isLoading = siteLogoId === undefined || isRequestingMediaItem;
39513  
39514    if (isLoading) {
39515      logoImage = (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Spinner, null);
39516    }
39517  
39518    if (!!logoUrl) {
39519      logoImage = (0,external_wp_element_namespaceObject.createElement)(SiteLogo, {
39520        alt: alt,
39521        attributes: attributes,
39522        className: className,
39523        containerRef: ref,
39524        isSelected: isSelected,
39525        setAttributes: setAttributes,
39526        logoUrl: logoUrl,
39527        setLogo: setLogo,
39528        logoId: (mediaItemData === null || mediaItemData === void 0 ? void 0 : mediaItemData.id) || siteLogoId,
39529        siteUrl: url,
39530        setIcon: setIcon,
39531        iconId: siteIconId,
39532        canUserEdit: canUserEdit
39533      });
39534    }
39535  
39536    const placeholder = content => {
39537      const placeholderClassName = classnames_default()('block-editor-media-placeholder', className);
39538      return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Placeholder, {
39539        className: placeholderClassName,
39540        preview: logoImage
39541      }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
39542        className: "components-placeholder__illustration",
39543        fill: "none",
39544        xmlns: "http://www.w3.org/2000/svg",
39545        viewBox: "0 0 60 60"
39546      }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
39547        vectorEffect: "non-scaling-stroke",
39548        d: "m61 32.622-13.555-9.137-15.888 9.859a5 5 0 0 1-5.386-.073l-9.095-5.989L1 37.5"
39549      })), content);
39550    };
39551  
39552    const classes = classnames_default()(className, {
39553      'is-default-size': !width
39554    });
39555    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
39556      ref,
39557      className: classes
39558    });
39559  
39560    const label = (0,external_wp_i18n_namespaceObject.__)('Add a site logo');
39561  
39562    return (0,external_wp_element_namespaceObject.createElement)("div", blockProps, controls, !!logoUrl && logoImage, !logoUrl && !canUserEdit && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Placeholder, {
39563      className: "site-logo_placeholder"
39564    }, isLoading && (0,external_wp_element_namespaceObject.createElement)("span", {
39565      className: "components-placeholder__preview"
39566    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Spinner, null))), !logoUrl && canUserEdit && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.MediaPlaceholder, {
39567      onSelect: onInitialSelectLogo,
39568      accept: ACCEPT_MEDIA_STRING,
39569      allowedTypes: site_logo_edit_ALLOWED_MEDIA_TYPES,
39570      onError: onUploadError,
39571      placeholder: placeholder,
39572      mediaLibraryButton: _ref3 => {
39573        let {
39574          open
39575        } = _ref3;
39576        return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
39577          icon: library_upload,
39578          variant: "primary",
39579          label: label,
39580          showTooltip: true,
39581          tooltipPosition: "top center",
39582          onClick: () => {
39583            open();
39584          }
39585        });
39586      }
39587    }));
39588  }
39589  
39590  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/site-logo/transforms.js
39591  /**
39592   * WordPress dependencies
39593   */
39594  
39595  const site_logo_transforms_transforms = {
39596    to: [{
39597      type: 'block',
39598      blocks: ['core/site-title'],
39599      transform: _ref => {
39600        let {
39601          isLink,
39602          linkTarget
39603        } = _ref;
39604        return (0,external_wp_blocks_namespaceObject.createBlock)('core/site-title', {
39605          isLink,
39606          linkTarget
39607        });
39608      }
39609    }]
39610  };
39611  /* harmony default export */ var site_logo_transforms = (site_logo_transforms_transforms);
39612  
39613  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/site-logo/index.js
39614  /**
39615   * WordPress dependencies
39616   */
39617  
39618  /**
39619   * Internal dependencies
39620   */
39621  
39622  const site_logo_metadata = {
39623    $schema: "https://schemas.wp.org/trunk/block.json",
39624    apiVersion: 2,
39625    name: "core/site-logo",
39626    title: "Site Logo",
39627    category: "theme",
39628    description: "Display a graphic to represent this site. Update the block, and the changes apply everywhere it\u2019s used. This is different than the site icon, which is the smaller image visible in your dashboard, browser tabs, etc used to help others recognize this site.",
39629    textdomain: "default",
39630    attributes: {
39631      width: {
39632        type: "number"
39633      },
39634      isLink: {
39635        type: "boolean",
39636        "default": true
39637      },
39638      linkTarget: {
39639        type: "string",
39640        "default": "_self"
39641      },
39642      shouldSyncIcon: {
39643        type: "boolean"
39644      }
39645    },
39646    example: {
39647      viewportWidth: 500,
39648      attributes: {
39649        width: 350,
39650        className: "block-editor-block-types-list__site-logo-example"
39651      }
39652    },
39653    supports: {
39654      html: false,
39655      align: true,
39656      alignWide: false,
39657      color: {
39658        __experimentalDuotone: "img, .components-placeholder__illustration, .components-placeholder::before",
39659        text: false,
39660        background: false
39661      }
39662    },
39663    styles: [{
39664      name: "default",
39665      label: "Default",
39666      isDefault: true
39667    }, {
39668      name: "rounded",
39669      label: "Rounded"
39670    }],
39671    editorStyle: "wp-block-site-logo-editor",
39672    style: "wp-block-site-logo"
39673  };
39674  
39675  
39676  const {
39677    name: site_logo_name
39678  } = site_logo_metadata;
39679  
39680  const site_logo_settings = {
39681    icon: site_logo,
39682    edit: LogoEdit,
39683    transforms: site_logo_transforms
39684  };
39685  
39686  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/site-tagline/edit.js
39687  
39688  
39689  
39690  /**
39691   * External dependencies
39692   */
39693  
39694  /**
39695   * WordPress dependencies
39696   */
39697  
39698  
39699  
39700  
39701  
39702  
39703  function SiteTaglineEdit(_ref) {
39704    let {
39705      attributes,
39706      setAttributes,
39707      insertBlocksAfter
39708    } = _ref;
39709    const {
39710      textAlign
39711    } = attributes;
39712    const [siteTagline, setSiteTagline] = (0,external_wp_coreData_namespaceObject.useEntityProp)('root', 'site', 'description');
39713    const {
39714      canUserEdit,
39715      readOnlySiteTagLine
39716    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
39717      const {
39718        canUser,
39719        getEntityRecord
39720      } = select(external_wp_coreData_namespaceObject.store);
39721      const siteData = getEntityRecord('root', '__unstableBase');
39722      return {
39723        canUserEdit: canUser('update', 'settings'),
39724        readOnlySiteTagLine: siteData === null || siteData === void 0 ? void 0 : siteData.description
39725      };
39726    }, []);
39727    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
39728      className: classnames_default()({
39729        [`has-text-align-$textAlign}`]: textAlign,
39730        'wp-block-site-tagline__placeholder': !canUserEdit && !readOnlySiteTagLine
39731      })
39732    });
39733    const siteTaglineContent = canUserEdit ? (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText, _extends({
39734      allowedFormats: [],
39735      onChange: setSiteTagline,
39736      "aria-label": (0,external_wp_i18n_namespaceObject.__)('Site tagline text'),
39737      placeholder: (0,external_wp_i18n_namespaceObject.__)('Write site tagline…'),
39738      tagName: "p",
39739      value: siteTagline,
39740      disableLineBreaks: true,
39741      __unstableOnSplitAtEnd: () => insertBlocksAfter((0,external_wp_blocks_namespaceObject.createBlock)((0,external_wp_blocks_namespaceObject.getDefaultBlockName)()))
39742    }, blockProps)) : (0,external_wp_element_namespaceObject.createElement)("p", blockProps, readOnlySiteTagLine || (0,external_wp_i18n_namespaceObject.__)('Site Tagline placeholder'));
39743    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, {
39744      group: "block"
39745    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.AlignmentControl, {
39746      onChange: newAlign => setAttributes({
39747        textAlign: newAlign
39748      }),
39749      value: textAlign
39750    })), siteTaglineContent);
39751  }
39752  
39753  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/site-tagline/icon.js
39754  
39755  
39756  /**
39757   * WordPress dependencies
39758   */
39759  
39760  /* harmony default export */ var site_tagline_icon = ((0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, {
39761    xmlns: "http://www.w3.org/2000/svg",
39762    width: "24",
39763    height: "24"
39764  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
39765    fill: "none",
39766    d: "M0 0h24v24H0z"
39767  }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
39768    d: "M4 9h16v2H4V9zm0 4h10v2H4v-2z"
39769  })));
39770  
39771  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/site-tagline/deprecated.js
39772  /**
39773   * Internal dependencies
39774   */
39775  
39776  const site_tagline_deprecated_v1 = {
39777    attributes: {
39778      textAlign: {
39779        type: 'string'
39780      }
39781    },
39782    supports: {
39783      align: ['wide', 'full'],
39784      html: false,
39785      color: {
39786        gradients: true
39787      },
39788      spacing: {
39789        margin: true,
39790        padding: true
39791      },
39792      typography: {
39793        fontSize: true,
39794        lineHeight: true,
39795        __experimentalFontFamily: true,
39796        __experimentalTextTransform: true,
39797        __experimentalFontStyle: true,
39798        __experimentalFontWeight: true,
39799        __experimentalLetterSpacing: true
39800      }
39801    },
39802  
39803    save() {
39804      return null;
39805    },
39806  
39807    migrate: migrate_font_family,
39808  
39809    isEligible(_ref) {
39810      var _style$typography;
39811  
39812      let {
39813        style
39814      } = _ref;
39815      return style === null || style === void 0 ? void 0 : (_style$typography = style.typography) === null || _style$typography === void 0 ? void 0 : _style$typography.fontFamily;
39816    }
39817  
39818  };
39819  /**
39820   * New deprecations need to be placed first
39821   * for them to have higher priority.
39822   *
39823   * Old deprecations may need to be updated as well.
39824   *
39825   * See block-deprecation.md
39826   */
39827  
39828  /* harmony default export */ var site_tagline_deprecated = ([site_tagline_deprecated_v1]);
39829  
39830  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/site-tagline/index.js
39831  /**
39832   * Internal dependencies
39833   */
39834  const site_tagline_metadata = {
39835    $schema: "https://schemas.wp.org/trunk/block.json",
39836    apiVersion: 2,
39837    name: "core/site-tagline",
39838    title: "Site Tagline",
39839    category: "theme",
39840    description: "Describe in a few words what the site is about. The tagline can be used in search results or when sharing on social networks even if it's not displayed in the theme design.",
39841    keywords: ["description"],
39842    textdomain: "default",
39843    attributes: {
39844      textAlign: {
39845        type: "string"
39846      }
39847    },
39848    supports: {
39849      align: ["wide", "full"],
39850      html: false,
39851      color: {
39852        gradients: true,
39853        __experimentalDefaultControls: {
39854          background: true,
39855          text: true
39856        }
39857      },
39858      spacing: {
39859        margin: true,
39860        padding: true
39861      },
39862      typography: {
39863        fontSize: true,
39864        lineHeight: true,
39865        __experimentalFontFamily: true,
39866        __experimentalTextTransform: true,
39867        __experimentalFontStyle: true,
39868        __experimentalFontWeight: true,
39869        __experimentalLetterSpacing: true,
39870        __experimentalDefaultControls: {
39871          fontSize: true
39872        }
39873      }
39874    },
39875    editorStyle: "wp-block-site-tagline-editor"
39876  };
39877  
39878  
39879  
39880  const {
39881    name: site_tagline_name
39882  } = site_tagline_metadata;
39883  
39884  const site_tagline_settings = {
39885    icon: site_tagline_icon,
39886    edit: SiteTaglineEdit,
39887    deprecated: site_tagline_deprecated
39888  };
39889  
39890  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/map-marker.js
39891  
39892  
39893  /**
39894   * WordPress dependencies
39895   */
39896  
39897  const mapMarker = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
39898    xmlns: "https://www.w3.org/2000/svg",
39899    viewBox: "0 0 24 24"
39900  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
39901    d: "M12 9c-.8 0-1.5.7-1.5 1.5S11.2 12 12 12s1.5-.7 1.5-1.5S12.8 9 12 9zm0-5c-3.6 0-6.5 2.8-6.5 6.2 0 .8.3 1.8.9 3.1.5 1.1 1.2 2.3 2 3.6.7 1 3 3.8 3.2 3.9l.4.5.4-.5c.2-.2 2.6-2.9 3.2-3.9.8-1.2 1.5-2.5 2-3.6.6-1.3.9-2.3.9-3.1C18.5 6.8 15.6 4 12 4zm4.3 8.7c-.5 1-1.1 2.2-1.9 3.4-.5.7-1.7 2.2-2.4 3-.7-.8-1.9-2.3-2.4-3-.8-1.2-1.4-2.3-1.9-3.3-.6-1.4-.7-2.2-.7-2.5 0-2.6 2.2-4.7 5-4.7s5 2.1 5 4.7c0 .2-.1 1-.7 2.4z"
39902  }));
39903  /* harmony default export */ var map_marker = (mapMarker);
39904  
39905  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/site-title/edit/level-icon.js
39906  
39907  
39908  /**
39909   * WordPress dependencies
39910   */
39911  
39912  
39913  function LevelIcon(_ref) {
39914    let {
39915      level,
39916      isPressed = false
39917    } = _ref;
39918    if (level === 0) return library_paragraph;
39919    const levelToPath = {
39920      1: 'M9 5h2v10H9v-4H5v4H3V5h2v4h4V5zm6.6 0c-.6.9-1.5 1.7-2.6 2v1h2v7h2V5h-1.4z',
39921      2: 'M7 5h2v10H7v-4H3v4H1V5h2v4h4V5zm8 8c.5-.4.6-.6 1.1-1.1.4-.4.8-.8 1.2-1.3.3-.4.6-.8.9-1.3.2-.4.3-.8.3-1.3 0-.4-.1-.9-.3-1.3-.2-.4-.4-.7-.8-1-.3-.3-.7-.5-1.2-.6-.5-.2-1-.2-1.5-.2-.4 0-.7 0-1.1.1-.3.1-.7.2-1 .3-.3.1-.6.3-.9.5-.3.2-.6.4-.8.7l1.2 1.2c.3-.3.6-.5 1-.7.4-.2.7-.3 1.2-.3s.9.1 1.3.4c.3.3.5.7.5 1.1 0 .4-.1.8-.4 1.1-.3.5-.6.9-1 1.2-.4.4-1 .9-1.6 1.4-.6.5-1.4 1.1-2.2 1.6V15h8v-2H15z',
39922      3: 'M12.1 12.2c.4.3.8.5 1.2.7.4.2.9.3 1.4.3.5 0 1-.1 1.4-.3.3-.1.5-.5.5-.8 0-.2 0-.4-.1-.6-.1-.2-.3-.3-.5-.4-.3-.1-.7-.2-1-.3-.5-.1-1-.1-1.5-.1V9.1c.7.1 1.5-.1 2.2-.4.4-.2.6-.5.6-.9 0-.3-.1-.6-.4-.8-.3-.2-.7-.3-1.1-.3-.4 0-.8.1-1.1.3-.4.2-.7.4-1.1.6l-1.2-1.4c.5-.4 1.1-.7 1.6-.9.5-.2 1.2-.3 1.8-.3.5 0 1 .1 1.6.2.4.1.8.3 1.2.5.3.2.6.5.8.8.2.3.3.7.3 1.1 0 .5-.2.9-.5 1.3-.4.4-.9.7-1.5.9v.1c.6.1 1.2.4 1.6.8.4.4.7.9.7 1.5 0 .4-.1.8-.3 1.2-.2.4-.5.7-.9.9-.4.3-.9.4-1.3.5-.5.1-1 .2-1.6.2-.8 0-1.6-.1-2.3-.4-.6-.2-1.1-.6-1.6-1l1.1-1.4zM7 9H3V5H1v10h2v-4h4v4h2V5H7v4z',
39923      4: 'M9 15H7v-4H3v4H1V5h2v4h4V5h2v10zm10-2h-1v2h-2v-2h-5v-2l4-6h3v6h1v2zm-3-2V7l-2.8 4H16z',
39924      5: 'M12.1 12.2c.4.3.7.5 1.1.7.4.2.9.3 1.3.3.5 0 1-.1 1.4-.4.4-.3.6-.7.6-1.1 0-.4-.2-.9-.6-1.1-.4-.3-.9-.4-1.4-.4H14c-.1 0-.3 0-.4.1l-.4.1-.5.2-1-.6.3-5h6.4v1.9h-4.3L14 8.8c.2-.1.5-.1.7-.2.2 0 .5-.1.7-.1.5 0 .9.1 1.4.2.4.1.8.3 1.1.6.3.2.6.6.8.9.2.4.3.9.3 1.4 0 .5-.1 1-.3 1.4-.2.4-.5.8-.9 1.1-.4.3-.8.5-1.3.7-.5.2-1 .3-1.5.3-.8 0-1.6-.1-2.3-.4-.6-.2-1.1-.6-1.6-1-.1-.1 1-1.5 1-1.5zM9 15H7v-4H3v4H1V5h2v4h4V5h2v10z',
39925      6: 'M9 15H7v-4H3v4H1V5h2v4h4V5h2v10zm8.6-7.5c-.2-.2-.5-.4-.8-.5-.6-.2-1.3-.2-1.9 0-.3.1-.6.3-.8.5l-.6.9c-.2.5-.2.9-.2 1.4.4-.3.8-.6 1.2-.8.4-.2.8-.3 1.3-.3.4 0 .8 0 1.2.2.4.1.7.3 1 .6.3.3.5.6.7.9.2.4.3.8.3 1.3s-.1.9-.3 1.4c-.2.4-.5.7-.8 1-.4.3-.8.5-1.2.6-1 .3-2 .3-3 0-.5-.2-1-.5-1.4-.9-.4-.4-.8-.9-1-1.5-.2-.6-.3-1.3-.3-2.1s.1-1.6.4-2.3c.2-.6.6-1.2 1-1.6.4-.4.9-.7 1.4-.9.6-.3 1.1-.4 1.7-.4.7 0 1.4.1 2 .3.5.2 1 .5 1.4.8 0 .1-1.3 1.4-1.3 1.4zm-2.4 5.8c.2 0 .4 0 .6-.1.2 0 .4-.1.5-.2.1-.1.3-.3.4-.5.1-.2.1-.5.1-.7 0-.4-.1-.8-.4-1.1-.3-.2-.7-.3-1.1-.3-.3 0-.7.1-1 .2-.4.2-.7.4-1 .7 0 .3.1.7.3 1 .1.2.3.4.4.6.2.1.3.3.5.3.2.1.5.2.7.1z'
39926    };
39927    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, {
39928      width: "20",
39929      height: "20",
39930      viewBox: "0 0 20 20",
39931      xmlns: "http://www.w3.org/2000/svg",
39932      isPressed: isPressed
39933    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
39934      d: levelToPath[level]
39935    }));
39936  }
39937  
39938  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/site-title/edit/level-toolbar.js
39939  
39940  
39941  /**
39942   * WordPress dependencies
39943   */
39944  
39945  
39946  /**
39947   * Internal dependencies
39948   */
39949  
39950  
39951  function LevelControl(_ref) {
39952    let {
39953      level,
39954      onChange
39955    } = _ref;
39956    const allControls = [1, 2, 3, 4, 5, 6, 0].map(currentLevel => {
39957      const isActive = currentLevel === level;
39958      return {
39959        icon: (0,external_wp_element_namespaceObject.createElement)(LevelIcon, {
39960          level: currentLevel,
39961          isPressed: isActive
39962        }),
39963        title: currentLevel === 0 ? (0,external_wp_i18n_namespaceObject.__)('Paragraph') : // translators: %s: heading level e.g: "1", "2", "3"
39964        (0,external_wp_i18n_namespaceObject.sprintf)((0,external_wp_i18n_namespaceObject.__)('Heading %d'), currentLevel),
39965        isActive,
39966        onClick: () => onChange(currentLevel)
39967      };
39968    });
39969    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarDropdownMenu, {
39970      label: (0,external_wp_i18n_namespaceObject.__)('Change heading level'),
39971      icon: (0,external_wp_element_namespaceObject.createElement)(LevelIcon, {
39972        level: level
39973      }),
39974      controls: allControls
39975    });
39976  }
39977  
39978  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/site-title/edit/index.js
39979  
39980  
39981  /**
39982   * External dependencies
39983   */
39984  
39985  /**
39986   * WordPress dependencies
39987   */
39988  
39989  
39990  
39991  
39992  
39993  
39994  
39995  
39996  /**
39997   * Internal dependencies
39998   */
39999  
40000  
40001  function SiteTitleEdit(_ref) {
40002    let {
40003      attributes,
40004      setAttributes,
40005      insertBlocksAfter
40006    } = _ref;
40007    const {
40008      level,
40009      textAlign,
40010      isLink,
40011      linkTarget
40012    } = attributes;
40013    const [title, setTitle] = (0,external_wp_coreData_namespaceObject.useEntityProp)('root', 'site', 'title');
40014    const {
40015      canUserEdit,
40016      readOnlyTitle
40017    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
40018      const {
40019        canUser,
40020        getEntityRecord
40021      } = select(external_wp_coreData_namespaceObject.store);
40022      const siteData = getEntityRecord('root', '__unstableBase');
40023      return {
40024        canUserEdit: canUser('update', 'settings'),
40025        readOnlyTitle: (0,external_wp_htmlEntities_namespaceObject.decodeEntities)(siteData === null || siteData === void 0 ? void 0 : siteData.name)
40026      };
40027    }, []);
40028    const TagName = level === 0 ? 'p' : `h$level}`;
40029    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
40030      className: classnames_default()({
40031        [`has-text-align-$textAlign}`]: textAlign,
40032        'wp-block-site-title__placeholder': !canUserEdit && !readOnlyTitle
40033      })
40034    });
40035    const siteTitleContent = canUserEdit ? (0,external_wp_element_namespaceObject.createElement)(TagName, blockProps, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText, {
40036      tagName: isLink ? 'a' : 'span',
40037      href: isLink ? '#site-title-pseudo-link' : undefined,
40038      "aria-label": (0,external_wp_i18n_namespaceObject.__)('Site title text'),
40039      placeholder: (0,external_wp_i18n_namespaceObject.__)('Write site title…'),
40040      value: title,
40041      onChange: setTitle,
40042      allowedFormats: [],
40043      disableLineBreaks: true,
40044      __unstableOnSplitAtEnd: () => insertBlocksAfter((0,external_wp_blocks_namespaceObject.createBlock)((0,external_wp_blocks_namespaceObject.getDefaultBlockName)()))
40045    })) : (0,external_wp_element_namespaceObject.createElement)(TagName, blockProps, isLink ? (0,external_wp_element_namespaceObject.createElement)("a", {
40046      href: "#site-title-pseudo-link",
40047      onClick: event => event.preventDefault()
40048    }, readOnlyTitle || (0,external_wp_i18n_namespaceObject.__)('Site Title placeholder')) : (0,external_wp_element_namespaceObject.createElement)("span", null, title || readOnlyTitle));
40049    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, {
40050      group: "block"
40051    }, (0,external_wp_element_namespaceObject.createElement)(LevelControl, {
40052      level: level,
40053      onChange: newLevel => setAttributes({
40054        level: newLevel
40055      })
40056    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.AlignmentControl, {
40057      value: textAlign,
40058      onChange: nextAlign => {
40059        setAttributes({
40060          textAlign: nextAlign
40061        });
40062      }
40063    })), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
40064      title: (0,external_wp_i18n_namespaceObject.__)('Link settings')
40065    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
40066      label: (0,external_wp_i18n_namespaceObject.__)('Make title link to home'),
40067      onChange: () => setAttributes({
40068        isLink: !isLink
40069      }),
40070      checked: isLink
40071    }), isLink && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
40072      label: (0,external_wp_i18n_namespaceObject.__)('Open in new tab'),
40073      onChange: value => setAttributes({
40074        linkTarget: value ? '_blank' : '_self'
40075      }),
40076      checked: linkTarget === '_blank'
40077    }))), siteTitleContent);
40078  }
40079  
40080  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/site-title/deprecated.js
40081  /**
40082   * Internal dependencies
40083   */
40084  
40085  const site_title_deprecated_v1 = {
40086    attributes: {
40087      level: {
40088        type: 'number',
40089        default: 1
40090      },
40091      textAlign: {
40092        type: 'string'
40093      },
40094      isLink: {
40095        type: 'boolean',
40096        default: true
40097      },
40098      linkTarget: {
40099        type: 'string',
40100        default: '_self'
40101      }
40102    },
40103    supports: {
40104      align: ['wide', 'full'],
40105      html: false,
40106      color: {
40107        gradients: true,
40108        link: true
40109      },
40110      spacing: {
40111        padding: true,
40112        margin: true
40113      },
40114      typography: {
40115        fontSize: true,
40116        lineHeight: true,
40117        __experimentalFontFamily: true,
40118        __experimentalTextTransform: true,
40119        __experimentalFontStyle: true,
40120        __experimentalFontWeight: true,
40121        __experimentalLetterSpacing: true
40122      }
40123    },
40124  
40125    save() {
40126      return null;
40127    },
40128  
40129    migrate: migrate_font_family,
40130  
40131    isEligible(_ref) {
40132      var _style$typography;
40133  
40134      let {
40135        style
40136      } = _ref;
40137      return style === null || style === void 0 ? void 0 : (_style$typography = style.typography) === null || _style$typography === void 0 ? void 0 : _style$typography.fontFamily;
40138    }
40139  
40140  };
40141  /**
40142   * New deprecations need to be placed first
40143   * for them to have higher priority.
40144   *
40145   * Old deprecations may need to be updated as well.
40146   *
40147   * See block-deprecation.md
40148   */
40149  
40150  /* harmony default export */ var site_title_deprecated = ([site_title_deprecated_v1]);
40151  
40152  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/site-title/transforms.js
40153  /**
40154   * WordPress dependencies
40155   */
40156  
40157  const site_title_transforms_transforms = {
40158    to: [{
40159      type: 'block',
40160      blocks: ['core/site-logo'],
40161      transform: _ref => {
40162        let {
40163          isLink,
40164          linkTarget
40165        } = _ref;
40166        return (0,external_wp_blocks_namespaceObject.createBlock)('core/site-logo', {
40167          isLink,
40168          linkTarget
40169        });
40170      }
40171    }]
40172  };
40173  /* harmony default export */ var site_title_transforms = (site_title_transforms_transforms);
40174  
40175  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/site-title/index.js
40176  /**
40177   * WordPress dependencies
40178   */
40179  
40180  /**
40181   * Internal dependencies
40182   */
40183  
40184  const site_title_metadata = {
40185    $schema: "https://schemas.wp.org/trunk/block.json",
40186    apiVersion: 2,
40187    name: "core/site-title",
40188    title: "Site Title",
40189    category: "theme",
40190    description: "Displays the name of this site. Update the block, and the changes apply everywhere it\u2019s used. This will also appear in the browser title bar and in search results.",
40191    textdomain: "default",
40192    attributes: {
40193      level: {
40194        type: "number",
40195        "default": 1
40196      },
40197      textAlign: {
40198        type: "string"
40199      },
40200      isLink: {
40201        type: "boolean",
40202        "default": true
40203      },
40204      linkTarget: {
40205        type: "string",
40206        "default": "_self"
40207      }
40208    },
40209    example: {
40210      viewportWidth: 500
40211    },
40212    supports: {
40213      align: ["wide", "full"],
40214      html: false,
40215      color: {
40216        gradients: true,
40217        link: true,
40218        __experimentalDefaultControls: {
40219          background: true,
40220          text: true,
40221          link: true
40222        }
40223      },
40224      spacing: {
40225        padding: true,
40226        margin: true
40227      },
40228      typography: {
40229        fontSize: true,
40230        lineHeight: true,
40231        __experimentalFontFamily: true,
40232        __experimentalTextTransform: true,
40233        __experimentalFontStyle: true,
40234        __experimentalFontWeight: true,
40235        __experimentalLetterSpacing: true,
40236        __experimentalDefaultControls: {
40237          fontSize: true,
40238          lineHeight: true,
40239          fontAppearance: true,
40240          letterSpacing: true,
40241          textTransform: true
40242        }
40243      }
40244    },
40245    editorStyle: "wp-block-site-title-editor"
40246  };
40247  
40248  
40249  
40250  const {
40251    name: site_title_name
40252  } = site_title_metadata;
40253  
40254  const site_title_settings = {
40255    icon: map_marker,
40256    edit: SiteTitleEdit,
40257    transforms: site_title_transforms,
40258    deprecated: site_title_deprecated
40259  };
40260  
40261  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/share.js
40262  
40263  
40264  /**
40265   * WordPress dependencies
40266   */
40267  
40268  const share = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
40269    viewBox: "0 0 24 24",
40270    xmlns: "http://www.w3.org/2000/svg"
40271  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
40272    d: "M9 11.8l6.1-4.5c.1.4.4.7.9.7h2c.6 0 1-.4 1-1V5c0-.6-.4-1-1-1h-2c-.6 0-1 .4-1 1v.4l-6.4 4.8c-.2-.1-.4-.2-.6-.2H6c-.6 0-1 .4-1 1v2c0 .6.4 1 1 1h2c.2 0 .4-.1.6-.2l6.4 4.8v.4c0 .6.4 1 1 1h2c.6 0 1-.4 1-1v-2c0-.6-.4-1-1-1h-2c-.5 0-.8.3-.9.7L9 12.2v-.4z"
40273  }));
40274  /* harmony default export */ var library_share = (share);
40275  
40276  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/keyboard-return.js
40277  
40278  
40279  /**
40280   * WordPress dependencies
40281   */
40282  
40283  const keyboardReturn = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
40284    xmlns: "http://www.w3.org/2000/svg",
40285    viewBox: "-2 -2 24 24"
40286  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
40287    d: "M6.734 16.106l2.176-2.38-1.093-1.028-3.846 4.158 3.846 4.157 1.093-1.027-2.176-2.38h2.811c1.125 0 2.25.03 3.374 0 1.428-.001 3.362-.25 4.963-1.277 1.66-1.065 2.868-2.906 2.868-5.859 0-2.479-1.327-4.896-3.65-5.93-1.82-.813-3.044-.8-4.806-.788l-.567.002v1.5c.184 0 .368 0 .553-.002 1.82-.007 2.704-.014 4.21.657 1.854.827 2.76 2.657 2.76 4.561 0 2.472-.973 3.824-2.178 4.596-1.258.807-2.864 1.04-4.163 1.04h-.02c-1.115.03-2.229 0-3.344 0H6.734z"
40288  }));
40289  /* harmony default export */ var keyboard_return = (keyboardReturn);
40290  
40291  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-link/icons/wordpress.js
40292  
40293  
40294  /**
40295   * WordPress dependencies
40296   */
40297  
40298  const WordPressIcon = () => (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
40299    width: "24",
40300    height: "24",
40301    viewBox: "0 0 24 24",
40302    version: "1.1",
40303    xmlns: "http://www.w3.org/2000/svg"
40304  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
40305    d: "M12.158,12.786L9.46,20.625c0.806,0.237,1.657,0.366,2.54,0.366c1.047,0,2.051-0.181,2.986-0.51 c-0.024-0.038-0.046-0.079-0.065-0.124L12.158,12.786z M3.009,12c0,3.559,2.068,6.634,5.067,8.092L3.788,8.341 C3.289,9.459,3.009,10.696,3.009,12z M18.069,11.546c0-1.112-0.399-1.881-0.741-2.48c-0.456-0.741-0.883-1.368-0.883-2.109 c0-0.826,0.627-1.596,1.51-1.596c0.04,0,0.078,0.005,0.116,0.007C16.472,3.904,14.34,3.009,12,3.009 c-3.141,0-5.904,1.612-7.512,4.052c0.211,0.007,0.41,0.011,0.579,0.011c0.94,0,2.396-0.114,2.396-0.114 C7.947,6.93,8.004,7.642,7.52,7.699c0,0-0.487,0.057-1.029,0.085l3.274,9.739l1.968-5.901l-1.401-3.838 C9.848,7.756,9.389,7.699,9.389,7.699C8.904,7.67,8.961,6.93,9.446,6.958c0,0,1.484,0.114,2.368,0.114 c0.94,0,2.397-0.114,2.397-0.114c0.485-0.028,0.542,0.684,0.057,0.741c0,0-0.488,0.057-1.029,0.085l3.249,9.665l0.897-2.996 C17.841,13.284,18.069,12.316,18.069,11.546z M19.889,7.686c0.039,0.286,0.06,0.593,0.06,0.924c0,0.912-0.171,1.938-0.684,3.22 l-2.746,7.94c2.673-1.558,4.47-4.454,4.47-7.771C20.991,10.436,20.591,8.967,19.889,7.686z M12,22C6.486,22,2,17.514,2,12 C2,6.486,6.486,2,12,2c5.514,0,10,4.486,10,10C22,17.514,17.514,22,12,22z"
40306  }));
40307  
40308  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-link/icons/fivehundredpx.js
40309  
40310  
40311  /**
40312   * WordPress dependencies
40313   */
40314  
40315  const FivehundredpxIcon = () => (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
40316    width: "24",
40317    height: "24",
40318    viewBox: "0 0 24 24",
40319    version: "1.1"
40320  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
40321    d: "M6.94026,15.1412c.00437.01213.108.29862.168.44064a6.55008,6.55008,0,1,0,6.03191-9.09557,6.68654,6.68654,0,0,0-2.58357.51467A8.53914,8.53914,0,0,0,8.21268,8.61344L8.209,8.61725V3.22948l9.0504-.00008c.32934-.0036.32934-.46353.32934-.61466s0-.61091-.33035-.61467L7.47248,2a.43.43,0,0,0-.43131.42692v7.58355c0,.24466.30476.42131.58793.4819.553.11812.68074-.05864.81617-.2457l.018-.02481A10.52673,10.52673,0,0,1,9.32258,9.258a5.35268,5.35268,0,1,1,7.58985,7.54976,5.417,5.417,0,0,1-3.80867,1.56365,5.17483,5.17483,0,0,1-2.69822-.74478l.00342-4.61111a2.79372,2.79372,0,0,1,.71372-1.78792,2.61611,2.61611,0,0,1,1.98282-.89477,2.75683,2.75683,0,0,1,1.95525.79477,2.66867,2.66867,0,0,1,.79656,1.909,2.724,2.724,0,0,1-2.75849,2.748,4.94651,4.94651,0,0,1-.86254-.13719c-.31234-.093-.44519.34058-.48892.48349-.16811.54966.08453.65862.13687.67489a3.75751,3.75751,0,0,0,1.25234.18375,3.94634,3.94634,0,1,0-2.82444-6.742,3.67478,3.67478,0,0,0-1.13028,2.584l-.00041.02323c-.0035.11667-.00579,2.881-.00644,3.78811l-.00407-.00451a6.18521,6.18521,0,0,1-1.0851-1.86092c-.10544-.27856-.34358-.22925-.66857-.12917-.14192.04372-.57386.17677-.47833.489Zm4.65165-1.08338a.51346.51346,0,0,0,.19513.31818l.02276.022a.52945.52945,0,0,0,.3517.18416.24242.24242,0,0,0,.16577-.0611c.05473-.05082.67382-.67812.73287-.738l.69041.68819a.28978.28978,0,0,0,.21437.11032.53239.53239,0,0,0,.35708-.19486c.29792-.30419.14885-.46821.07676-.54751l-.69954-.69975.72952-.73469c.16-.17311.01874-.35708-.12218-.498-.20461-.20461-.402-.25742-.52855-.14083l-.7254.72665-.73354-.73375a.20128.20128,0,0,0-.14179-.05695.54135.54135,0,0,0-.34379.19648c-.22561.22555-.274.38149-.15656.5059l.73374.7315-.72942.73072A.26589.26589,0,0,0,11.59191,14.05782Zm1.59866-9.915A8.86081,8.86081,0,0,0,9.854,4.776a.26169.26169,0,0,0-.16938.22759.92978.92978,0,0,0,.08619.42094c.05682.14524.20779.531.50006.41955a8.40969,8.40969,0,0,1,2.91968-.55484,7.87875,7.87875,0,0,1,3.086.62286,8.61817,8.61817,0,0,1,2.30562,1.49315.2781.2781,0,0,0,.18318.07586c.15529,0,.30425-.15253.43167-.29551.21268-.23861.35873-.4369.1492-.63538a8.50425,8.50425,0,0,0-2.62312-1.694A9.0177,9.0177,0,0,0,13.19058,4.14283ZM19.50945,18.6236h0a.93171.93171,0,0,0-.36642-.25406.26589.26589,0,0,0-.27613.06613l-.06943.06929A7.90606,7.90606,0,0,1,7.60639,18.505a7.57284,7.57284,0,0,1-1.696-2.51537,8.58715,8.58715,0,0,1-.5147-1.77754l-.00871-.04864c-.04939-.25873-.28755-.27684-.62981-.22448-.14234.02178-.5755.088-.53426.39969l.001.00712a9.08807,9.08807,0,0,0,15.406,4.99094c.00193-.00192.04753-.04718.0725-.07436C19.79425,19.16234,19.87422,18.98728,19.50945,18.6236Z"
40322  }));
40323  
40324  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-link/icons/amazon.js
40325  
40326  
40327  /**
40328   * WordPress dependencies
40329   */
40330  
40331  const AmazonIcon = () => (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
40332    width: "24",
40333    height: "24",
40334    viewBox: "0 0 24 24",
40335    version: "1.1"
40336  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
40337    d: "M13.582,8.182C11.934,8.367,9.78,8.49,8.238,9.166c-1.781,0.769-3.03,2.337-3.03,4.644 c0,2.953,1.86,4.429,4.253,4.429c2.02,0,3.125-0.477,4.685-2.065c0.516,0.747,0.685,1.109,1.629,1.894 c0.212,0.114,0.483,0.103,0.672-0.066l0.006,0.006c0.567-0.505,1.599-1.401,2.18-1.888c0.231-0.188,0.19-0.496,0.009-0.754 c-0.52-0.718-1.072-1.303-1.072-2.634V8.305c0-1.876,0.133-3.599-1.249-4.891C15.23,2.369,13.422,2,12.04,2 C9.336,2,6.318,3.01,5.686,6.351C5.618,6.706,5.877,6.893,6.109,6.945l2.754,0.298C9.121,7.23,9.308,6.977,9.357,6.72 c0.236-1.151,1.2-1.706,2.284-1.706c0.584,0,1.249,0.215,1.595,0.738c0.398,0.584,0.346,1.384,0.346,2.061V8.182z M13.049,14.088 c-0.451,0.8-1.169,1.291-1.967,1.291c-1.09,0-1.728-0.83-1.728-2.061c0-2.42,2.171-2.86,4.227-2.86v0.615 C13.582,12.181,13.608,13.104,13.049,14.088z M20.683,19.339C18.329,21.076,14.917,22,11.979,22c-4.118,0-7.826-1.522-10.632-4.057 c-0.22-0.199-0.024-0.471,0.241-0.317c3.027,1.762,6.771,2.823,10.639,2.823c2.608,0,5.476-0.541,8.115-1.66 C20.739,18.62,21.072,19.051,20.683,19.339z M21.336,21.043c-0.194,0.163-0.379,0.076-0.293-0.139 c0.284-0.71,0.92-2.298,0.619-2.684c-0.301-0.386-1.99-0.183-2.749-0.092c-0.23,0.027-0.266-0.173-0.059-0.319 c1.348-0.946,3.555-0.673,3.811-0.356C22.925,17.773,22.599,19.986,21.336,21.043z"
40338  }));
40339  
40340  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-link/icons/bandcamp.js
40341  
40342  
40343  /**
40344   * WordPress dependencies
40345   */
40346  
40347  const BandcampIcon = () => (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
40348    width: "24",
40349    height: "24",
40350    viewBox: "0 0 24 24",
40351    version: "1.1"
40352  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
40353    d: "M15.27 17.289 3 17.289 8.73 6.711 21 6.711 15.27 17.289"
40354  }));
40355  
40356  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-link/icons/behance.js
40357  
40358  
40359  /**
40360   * WordPress dependencies
40361   */
40362  
40363  const BehanceIcon = () => (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
40364    width: "24",
40365    height: "24",
40366    viewBox: "0 0 24 24",
40367    version: "1.1"
40368  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
40369    d: "M7.799,5.698c0.589,0,1.12,0.051,1.606,0.156c0.482,0.102,0.894,0.273,1.241,0.507c0.344,0.235,0.612,0.546,0.804,0.938 c0.188,0.387,0.281,0.871,0.281,1.443c0,0.619-0.141,1.137-0.421,1.551c-0.284,0.413-0.7,0.751-1.255,1.014 c0.756,0.218,1.317,0.601,1.689,1.146c0.374,0.549,0.557,1.205,0.557,1.975c0,0.623-0.12,1.161-0.359,1.612 c-0.241,0.457-0.569,0.828-0.973,1.114c-0.408,0.288-0.876,0.5-1.399,0.637C9.052,17.931,8.514,18,7.963,18H2V5.698H7.799 M7.449,10.668c0.481,0,0.878-0.114,1.192-0.345c0.311-0.228,0.463-0.603,0.463-1.119c0-0.286-0.051-0.523-0.152-0.707 C8.848,8.315,8.711,8.171,8.536,8.07C8.362,7.966,8.166,7.894,7.94,7.854c-0.224-0.044-0.457-0.06-0.697-0.06H4.709v2.874H7.449z M7.6,15.905c0.267,0,0.521-0.024,0.759-0.077c0.243-0.053,0.457-0.137,0.637-0.261c0.182-0.12,0.332-0.283,0.441-0.491 C9.547,14.87,9.6,14.602,9.6,14.278c0-0.633-0.18-1.084-0.533-1.357c-0.356-0.27-0.83-0.404-1.413-0.404H4.709v3.388L7.6,15.905z M16.162,15.864c0.367,0.358,0.897,0.538,1.583,0.538c0.493,0,0.92-0.125,1.277-0.374c0.354-0.248,0.571-0.514,0.654-0.79h2.155 c-0.347,1.072-0.872,1.838-1.589,2.299C19.534,18,18.67,18.23,17.662,18.23c-0.701,0-1.332-0.113-1.899-0.337 c-0.567-0.227-1.041-0.544-1.439-0.958c-0.389-0.415-0.689-0.907-0.904-1.484c-0.213-0.574-0.32-1.21-0.32-1.899 c0-0.666,0.11-1.288,0.329-1.863c0.222-0.577,0.529-1.075,0.933-1.492c0.406-0.42,0.885-0.751,1.444-0.994 c0.558-0.241,1.175-0.363,1.857-0.363c0.754,0,1.414,0.145,1.98,0.44c0.563,0.291,1.026,0.686,1.389,1.181 c0.363,0.493,0.622,1.057,0.783,1.69c0.16,0.632,0.217,1.292,0.171,1.983h-6.428C15.557,14.84,15.795,15.506,16.162,15.864 M18.973,11.184c-0.291-0.321-0.783-0.496-1.384-0.496c-0.39,0-0.714,0.066-0.973,0.2c-0.254,0.132-0.461,0.297-0.621,0.491 c-0.157,0.197-0.265,0.405-0.328,0.628c-0.063,0.217-0.101,0.413-0.111,0.587h3.98C19.478,11.969,19.265,11.509,18.973,11.184z M15.057,7.738h4.985V6.524h-4.985L15.057,7.738z"
40370  }));
40371  
40372  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-link/icons/chain.js
40373  
40374  
40375  /**
40376   * WordPress dependencies
40377   */
40378  
40379  const ChainIcon = () => (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
40380    width: "24",
40381    height: "24",
40382    viewBox: "0 0 24 24",
40383    version: "1.1"
40384  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
40385    d: "M19.647,16.706a1.134,1.134,0,0,0-.343-.833l-2.549-2.549a1.134,1.134,0,0,0-.833-.343,1.168,1.168,0,0,0-.883.392l.233.226q.2.189.264.264a2.922,2.922,0,0,1,.184.233.986.986,0,0,1,.159.312,1.242,1.242,0,0,1,.043.337,1.172,1.172,0,0,1-1.176,1.176,1.237,1.237,0,0,1-.337-.043,1,1,0,0,1-.312-.159,2.76,2.76,0,0,1-.233-.184q-.073-.068-.264-.264l-.226-.233a1.19,1.19,0,0,0-.4.895,1.134,1.134,0,0,0,.343.833L15.837,19.3a1.13,1.13,0,0,0,.833.331,1.18,1.18,0,0,0,.833-.318l1.8-1.789a1.12,1.12,0,0,0,.343-.821Zm-8.615-8.64a1.134,1.134,0,0,0-.343-.833L8.163,4.7a1.134,1.134,0,0,0-.833-.343,1.184,1.184,0,0,0-.833.331L4.7,6.473a1.12,1.12,0,0,0-.343.821,1.134,1.134,0,0,0,.343.833l2.549,2.549a1.13,1.13,0,0,0,.833.331,1.184,1.184,0,0,0,.883-.38L8.728,10.4q-.2-.189-.264-.264A2.922,2.922,0,0,1,8.28,9.9a.986.986,0,0,1-.159-.312,1.242,1.242,0,0,1-.043-.337A1.172,1.172,0,0,1,9.254,8.079a1.237,1.237,0,0,1,.337.043,1,1,0,0,1,.312.159,2.761,2.761,0,0,1,.233.184q.073.068.264.264l.226.233a1.19,1.19,0,0,0,.4-.895ZM22,16.706a3.343,3.343,0,0,1-1.042,2.488l-1.8,1.789a3.536,3.536,0,0,1-4.988-.025l-2.525-2.537a3.384,3.384,0,0,1-1.017-2.488,3.448,3.448,0,0,1,1.078-2.561l-1.078-1.078a3.434,3.434,0,0,1-2.549,1.078,3.4,3.4,0,0,1-2.5-1.029L3.029,9.794A3.4,3.4,0,0,1,2,7.294,3.343,3.343,0,0,1,3.042,4.806l1.8-1.789A3.384,3.384,0,0,1,7.331,2a3.357,3.357,0,0,1,2.5,1.042l2.525,2.537a3.384,3.384,0,0,1,1.017,2.488,3.448,3.448,0,0,1-1.078,2.561l1.078,1.078a3.551,3.551,0,0,1,5.049-.049l2.549,2.549A3.4,3.4,0,0,1,22,16.706Z"
40386  }));
40387  
40388  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-link/icons/codepen.js
40389  
40390  
40391  /**
40392   * WordPress dependencies
40393   */
40394  
40395  const CodepenIcon = () => (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
40396    width: "24",
40397    height: "24",
40398    viewBox: "0 0 24 24",
40399    version: "1.1"
40400  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
40401    d: "M22.016,8.84c-0.002-0.013-0.005-0.025-0.007-0.037c-0.005-0.025-0.008-0.048-0.015-0.072 c-0.003-0.015-0.01-0.028-0.013-0.042c-0.008-0.02-0.015-0.04-0.023-0.062c-0.007-0.015-0.013-0.028-0.02-0.042 c-0.008-0.02-0.018-0.037-0.03-0.057c-0.007-0.013-0.017-0.027-0.025-0.038c-0.012-0.018-0.023-0.035-0.035-0.052 c-0.01-0.013-0.02-0.025-0.03-0.037c-0.015-0.017-0.028-0.032-0.043-0.045c-0.01-0.012-0.022-0.023-0.035-0.035 c-0.015-0.015-0.032-0.028-0.048-0.04c-0.012-0.01-0.025-0.02-0.037-0.03c-0.005-0.003-0.01-0.008-0.015-0.012l-9.161-6.096 c-0.289-0.192-0.666-0.192-0.955,0L2.359,8.237C2.354,8.24,2.349,8.245,2.344,8.249L2.306,8.277 c-0.017,0.013-0.033,0.027-0.048,0.04C2.246,8.331,2.234,8.342,2.222,8.352c-0.015,0.015-0.028,0.03-0.042,0.047 c-0.012,0.013-0.022,0.023-0.03,0.037C2.139,8.453,2.125,8.471,2.115,8.488C2.107,8.501,2.099,8.514,2.09,8.526 C2.079,8.548,2.069,8.565,2.06,8.585C2.054,8.6,2.047,8.613,2.04,8.626C2.032,8.648,2.025,8.67,2.019,8.69 c-0.005,0.013-0.01,0.027-0.013,0.042C1.999,8.755,1.995,8.778,1.99,8.803C1.989,8.817,1.985,8.828,1.984,8.84 C1.978,8.879,1.975,8.915,1.975,8.954v6.093c0,0.037,0.003,0.075,0.008,0.112c0.002,0.012,0.005,0.025,0.007,0.038 c0.005,0.023,0.008,0.047,0.015,0.072c0.003,0.015,0.008,0.028,0.013,0.04c0.007,0.022,0.013,0.042,0.022,0.063 c0.007,0.015,0.013,0.028,0.02,0.04c0.008,0.02,0.018,0.038,0.03,0.058c0.007,0.013,0.015,0.027,0.025,0.038 c0.012,0.018,0.023,0.035,0.035,0.052c0.01,0.013,0.02,0.025,0.03,0.037c0.013,0.015,0.028,0.032,0.042,0.045 c0.012,0.012,0.023,0.023,0.035,0.035c0.015,0.013,0.032,0.028,0.048,0.04l0.038,0.03c0.005,0.003,0.01,0.007,0.013,0.01 l9.163,6.095C11.668,21.953,11.833,22,12,22c0.167,0,0.332-0.047,0.478-0.144l9.163-6.095l0.015-0.01 c0.013-0.01,0.027-0.02,0.037-0.03c0.018-0.013,0.035-0.028,0.048-0.04c0.013-0.012,0.025-0.023,0.035-0.035 c0.017-0.015,0.03-0.032,0.043-0.045c0.01-0.013,0.02-0.025,0.03-0.037c0.013-0.018,0.025-0.035,0.035-0.052 c0.008-0.013,0.018-0.027,0.025-0.038c0.012-0.02,0.022-0.038,0.03-0.058c0.007-0.013,0.013-0.027,0.02-0.04 c0.008-0.022,0.015-0.042,0.023-0.063c0.003-0.013,0.01-0.027,0.013-0.04c0.007-0.025,0.01-0.048,0.015-0.072 c0.002-0.013,0.005-0.027,0.007-0.037c0.003-0.042,0.007-0.079,0.007-0.117V8.954C22.025,8.915,22.022,8.879,22.016,8.84z M12.862,4.464l6.751,4.49l-3.016,2.013l-3.735-2.492V4.464z M11.138,4.464v4.009l-3.735,2.494L4.389,8.954L11.138,4.464z M3.699,10.562L5.853,12l-2.155,1.438V10.562z M11.138,19.536l-6.749-4.491l3.015-2.011l3.735,2.492V19.536z M12,14.035L8.953,12 L12,9.966L15.047,12L12,14.035z M12.862,19.536v-4.009l3.735-2.492l3.016,2.011L12.862,19.536z M20.303,13.438L18.147,12 l2.156-1.438L20.303,13.438z"
40402  }));
40403  
40404  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-link/icons/deviantart.js
40405  
40406  
40407  /**
40408   * WordPress dependencies
40409   */
40410  
40411  const DeviantArtIcon = () => (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
40412    width: "24",
40413    height: "24",
40414    viewBox: "0 0 24 24",
40415    version: "1.1"
40416  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
40417    d: "M 18.19 5.636 18.19 2 18.188 2 14.553 2 14.19 2.366 12.474 5.636 11.935 6 5.81 6 5.81 10.994 9.177 10.994 9.477 11.357 5.81 18.363 5.81 22 5.811 22 9.447 22 9.81 21.634 11.526 18.364 12.065 18 18.19 18 18.19 13.006 14.823 13.006 14.523 12.641 18.19 5.636z"
40418  }));
40419  
40420  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-link/icons/dribbble.js
40421  
40422  
40423  /**
40424   * WordPress dependencies
40425   */
40426  
40427  const DribbbleIcon = () => (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
40428    width: "24",
40429    height: "24",
40430    viewBox: "0 0 24 24",
40431    version: "1.1"
40432  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
40433    d: "M12,22C6.486,22,2,17.514,2,12S6.486,2,12,2c5.514,0,10,4.486,10,10S17.514,22,12,22z M20.434,13.369 c-0.292-0.092-2.644-0.794-5.32-0.365c1.117,3.07,1.572,5.57,1.659,6.09C18.689,17.798,20.053,15.745,20.434,13.369z M15.336,19.876c-0.127-0.749-0.623-3.361-1.822-6.477c-0.019,0.006-0.038,0.013-0.056,0.019c-4.818,1.679-6.547,5.02-6.701,5.334 c1.448,1.129,3.268,1.803,5.243,1.803C13.183,20.555,14.311,20.313,15.336,19.876z M5.654,17.724 c0.193-0.331,2.538-4.213,6.943-5.637c0.111-0.036,0.224-0.07,0.337-0.102c-0.214-0.485-0.448-0.971-0.692-1.45 c-4.266,1.277-8.405,1.223-8.778,1.216c-0.003,0.087-0.004,0.174-0.004,0.261C3.458,14.207,4.29,16.21,5.654,17.724z M3.639,10.264 c0.382,0.005,3.901,0.02,7.897-1.041c-1.415-2.516-2.942-4.631-3.167-4.94C5.979,5.41,4.193,7.613,3.639,10.264z M9.998,3.709 c0.236,0.316,1.787,2.429,3.187,5c3.037-1.138,4.323-2.867,4.477-3.085C16.154,4.286,14.17,3.471,12,3.471 C11.311,3.471,10.641,3.554,9.998,3.709z M18.612,6.612C18.432,6.855,17,8.69,13.842,9.979c0.199,0.407,0.389,0.821,0.567,1.237 c0.063,0.148,0.124,0.295,0.184,0.441c2.842-0.357,5.666,0.215,5.948,0.275C20.522,9.916,19.801,8.065,18.612,6.612z"
40434  }));
40435  
40436  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-link/icons/dropbox.js
40437  
40438  
40439  /**
40440   * WordPress dependencies
40441   */
40442  
40443  const DropboxIcon = () => (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
40444    width: "24",
40445    height: "24",
40446    viewBox: "0 0 24 24",
40447    version: "1.1"
40448  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
40449    d: "M12,6.134L6.069,9.797L2,6.54l5.883-3.843L12,6.134z M2,13.054l5.883,3.843L12,13.459L6.069,9.797L2,13.054z M12,13.459 l4.116,3.439L22,13.054l-4.069-3.257L12,13.459z M22,6.54l-5.884-3.843L12,6.134l5.931,3.663L22,6.54z M12.011,14.2l-4.129,3.426 l-1.767-1.153v1.291l5.896,3.539l5.897-3.539v-1.291l-1.769,1.153L12.011,14.2z"
40450  }));
40451  
40452  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-link/icons/etsy.js
40453  
40454  
40455  /**
40456   * WordPress dependencies
40457   */
40458  
40459  const EtsyIcon = () => (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
40460    width: "24",
40461    height: "24",
40462    viewBox: "0 0 24 24",
40463    version: "1.1"
40464  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
40465    d: "M9.16033,4.038c0-.27174.02717-.43478.48913-.43478h6.22283c1.087,0,1.68478.92391,2.11957,2.663l.35326,1.38587h1.05978C19.59511,3.712,19.75815,2,19.75815,2s-2.663.29891-4.23913.29891h-7.962L3.29076,2.163v1.1413L4.731,3.57609c1.00543.19022,1.25.40761,1.33152,1.33152,0,0,.08152,2.71739.08152,7.20109s-.08152,7.17391-.08152,7.17391c0,.81522-.32609,1.11413-1.33152,1.30435l-1.44022.27174V22l4.2663-.13587h7.11957c1.60326,0,5.32609.13587,5.32609.13587.08152-.97826.625-5.40761.70652-5.89674H19.7038L18.644,18.52174c-.84239,1.90217-2.06522,2.038-3.42391,2.038H11.1712c-1.3587,0-2.01087-.54348-2.01087-1.712V12.65217s3.0163,0,3.99457.08152c.76087.05435,1.22283.27174,1.46739,1.33152l.32609,1.413h1.16848l-.08152-3.55978.163-3.587H15.02989l-.38043,1.57609c-.24457,1.03261-.40761,1.22283-1.46739,1.33152-1.38587.13587-4.02174.1087-4.02174.1087Z"
40466  }));
40467  
40468  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-link/icons/facebook.js
40469  
40470  
40471  /**
40472   * WordPress dependencies
40473   */
40474  
40475  const FacebookIcon = () => (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
40476    width: "24",
40477    height: "24",
40478    viewBox: "0 0 24 24",
40479    version: "1.1"
40480  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
40481    d: "M12 2C6.5 2 2 6.5 2 12c0 5 3.7 9.1 8.4 9.9v-7H7.9V12h2.5V9.8c0-2.5 1.5-3.9 3.8-3.9 1.1 0 2.2.2 2.2.2v2.5h-1.3c-1.2 0-1.6.8-1.6 1.6V12h2.8l-.4 2.9h-2.3v7C18.3 21.1 22 17 22 12c0-5.5-4.5-10-10-10z"
40482  }));
40483  
40484  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-link/icons/feed.js
40485  
40486  
40487  /**
40488   * WordPress dependencies
40489   */
40490  
40491  const FeedIcon = () => (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
40492    width: "24",
40493    height: "24",
40494    viewBox: "0 0 24 24",
40495    version: "1.1"
40496  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
40497    d: "M2,8.667V12c5.515,0,10,4.485,10,10h3.333C15.333,14.637,9.363,8.667,2,8.667z M2,2v3.333 c9.19,0,16.667,7.477,16.667,16.667H22C22,10.955,13.045,2,2,2z M4.5,17C3.118,17,2,18.12,2,19.5S3.118,22,4.5,22S7,20.88,7,19.5 S5.882,17,4.5,17z"
40498  }));
40499  
40500  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-link/icons/flickr.js
40501  
40502  
40503  /**
40504   * WordPress dependencies
40505   */
40506  
40507  const FlickrIcon = () => (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
40508    width: "24",
40509    height: "24",
40510    viewBox: "0 0 24 24",
40511    version: "1.1"
40512  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
40513    d: "M6.5,7c-2.75,0-5,2.25-5,5s2.25,5,5,5s5-2.25,5-5S9.25,7,6.5,7z M17.5,7c-2.75,0-5,2.25-5,5s2.25,5,5,5s5-2.25,5-5 S20.25,7,17.5,7z"
40514  }));
40515  
40516  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-link/icons/foursquare.js
40517  
40518  
40519  /**
40520   * WordPress dependencies
40521   */
40522  
40523  const FoursquareIcon = () => (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
40524    width: "24",
40525    height: "24",
40526    viewBox: "0 0 24 24",
40527    version: "1.1"
40528  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
40529    d: "M17.573,2c0,0-9.197,0-10.668,0S5,3.107,5,3.805s0,16.948,0,16.948c0,0.785,0.422,1.077,0.66,1.172 c0.238,0.097,0.892,0.177,1.285-0.275c0,0,5.035-5.843,5.122-5.93c0.132-0.132,0.132-0.132,0.262-0.132h3.26 c1.368,0,1.588-0.977,1.732-1.552c0.078-0.318,0.692-3.428,1.225-6.122l0.675-3.368C19.56,2.893,19.14,2,17.573,2z M16.495,7.22 c-0.053,0.252-0.372,0.518-0.665,0.518c-0.293,0-4.157,0-4.157,0c-0.467,0-0.802,0.318-0.802,0.787v0.508 c0,0.467,0.337,0.798,0.805,0.798c0,0,3.197,0,3.528,0s0.655,0.362,0.583,0.715c-0.072,0.353-0.407,2.102-0.448,2.295 c-0.04,0.193-0.262,0.523-0.655,0.523c-0.33,0-2.88,0-2.88,0c-0.523,0-0.683,0.068-1.033,0.503 c-0.35,0.437-3.505,4.223-3.505,4.223c-0.032,0.035-0.063,0.027-0.063-0.015V4.852c0-0.298,0.26-0.648,0.648-0.648 c0,0,8.228,0,8.562,0c0.315,0,0.61,0.297,0.528,0.683L16.495,7.22z"
40530  }));
40531  
40532  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-link/icons/goodreads.js
40533  
40534  
40535  /**
40536   * WordPress dependencies
40537   */
40538  
40539  const GoodreadsIcon = () => (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
40540    width: "24",
40541    height: "24",
40542    viewBox: "0 0 24 24",
40543    version: "1.1"
40544  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
40545    d: "M17.3,17.5c-0.2,0.8-0.5,1.4-1,1.9c-0.4,0.5-1,0.9-1.7,1.2C13.9,20.9,13.1,21,12,21c-0.6,0-1.3-0.1-1.9-0.2 c-0.6-0.1-1.1-0.4-1.6-0.7c-0.5-0.3-0.9-0.7-1.2-1.2c-0.3-0.5-0.5-1.1-0.5-1.7h1.5c0.1,0.5,0.2,0.9,0.5,1.2 c0.2,0.3,0.5,0.6,0.9,0.8c0.3,0.2,0.7,0.3,1.1,0.4c0.4,0.1,0.8,0.1,1.2,0.1c1.4,0,2.5-0.4,3.1-1.2c0.6-0.8,1-2,1-3.5v-1.7h0 c-0.4,0.8-0.9,1.4-1.6,1.9c-0.7,0.5-1.5,0.7-2.4,0.7c-1,0-1.9-0.2-2.6-0.5C8.7,15,8.1,14.5,7.7,14c-0.5-0.6-0.8-1.3-1-2.1 c-0.2-0.8-0.3-1.6-0.3-2.5c0-0.9,0.1-1.7,0.4-2.5c0.3-0.8,0.6-1.5,1.1-2c0.5-0.6,1.1-1,1.8-1.4C10.3,3.2,11.1,3,12,3 c0.5,0,0.9,0.1,1.3,0.2c0.4,0.1,0.8,0.3,1.1,0.5c0.3,0.2,0.6,0.5,0.9,0.8c0.3,0.3,0.5,0.6,0.6,1h0V3.4h1.5V15 C17.6,15.9,17.5,16.7,17.3,17.5z M13.8,14.1c0.5-0.3,0.9-0.7,1.3-1.1c0.3-0.5,0.6-1,0.8-1.6c0.2-0.6,0.3-1.2,0.3-1.9 c0-0.6-0.1-1.2-0.2-1.9c-0.1-0.6-0.4-1.2-0.7-1.7c-0.3-0.5-0.7-0.9-1.3-1.2c-0.5-0.3-1.1-0.5-1.9-0.5s-1.4,0.2-1.9,0.5 c-0.5,0.3-1,0.7-1.3,1.2C8.5,6.4,8.3,7,8.1,7.6C8,8.2,7.9,8.9,7.9,9.5c0,0.6,0.1,1.3,0.2,1.9C8.3,12,8.6,12.5,8.9,13 c0.3,0.5,0.8,0.8,1.3,1.1c0.5,0.3,1.1,0.4,1.9,0.4C12.7,14.5,13.3,14.4,13.8,14.1z"
40546  }));
40547  
40548  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-link/icons/google.js
40549  
40550  
40551  /**
40552   * WordPress dependencies
40553   */
40554  
40555  const GoogleIcon = () => (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
40556    width: "24",
40557    height: "24",
40558    viewBox: "0 0 24 24",
40559    version: "1.1"
40560  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
40561    d: "M12.02,10.18v3.72v0.01h5.51c-0.26,1.57-1.67,4.22-5.5,4.22c-3.31,0-6.01-2.75-6.01-6.12s2.7-6.12,6.01-6.12 c1.87,0,3.13,0.8,3.85,1.48l2.84-2.76C16.99,2.99,14.73,2,12.03,2c-5.52,0-10,4.48-10,10s4.48,10,10,10c5.77,0,9.6-4.06,9.6-9.77 c0-0.83-0.11-1.42-0.25-2.05H12.02z"
40562  }));
40563  
40564  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-link/icons/github.js
40565  
40566  
40567  /**
40568   * WordPress dependencies
40569   */
40570  
40571  const GitHubIcon = () => (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
40572    width: "24",
40573    height: "24",
40574    viewBox: "0 0 24 24",
40575    version: "1.1"
40576  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
40577    d: "M12,2C6.477,2,2,6.477,2,12c0,4.419,2.865,8.166,6.839,9.489c0.5,0.09,0.682-0.218,0.682-0.484 c0-0.236-0.009-0.866-0.014-1.699c-2.782,0.602-3.369-1.34-3.369-1.34c-0.455-1.157-1.11-1.465-1.11-1.465 c-0.909-0.62,0.069-0.608,0.069-0.608c1.004,0.071,1.532,1.03,1.532,1.03c0.891,1.529,2.341,1.089,2.91,0.833 c0.091-0.647,0.349-1.086,0.635-1.337c-2.22-0.251-4.555-1.111-4.555-4.943c0-1.091,0.39-1.984,1.03-2.682 C6.546,8.54,6.202,7.524,6.746,6.148c0,0,0.84-0.269,2.75,1.025C10.295,6.95,11.15,6.84,12,6.836 c0.85,0.004,1.705,0.114,2.504,0.336c1.909-1.294,2.748-1.025,2.748-1.025c0.546,1.376,0.202,2.394,0.1,2.646 c0.64,0.699,1.026,1.591,1.026,2.682c0,3.841-2.337,4.687-4.565,4.935c0.359,0.307,0.679,0.917,0.679,1.852 c0,1.335-0.012,2.415-0.012,2.741c0,0.269,0.18,0.579,0.688,0.481C19.138,20.161,22,16.416,22,12C22,6.477,17.523,2,12,2z"
40578  }));
40579  
40580  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-link/icons/instagram.js
40581  
40582  
40583  /**
40584   * WordPress dependencies
40585   */
40586  
40587  const InstagramIcon = () => (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
40588    width: "24",
40589    height: "24",
40590    viewBox: "0 0 24 24",
40591    version: "1.1"
40592  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
40593    d: "M12,4.622c2.403,0,2.688,0.009,3.637,0.052c0.877,0.04,1.354,0.187,1.671,0.31c0.42,0.163,0.72,0.358,1.035,0.673 c0.315,0.315,0.51,0.615,0.673,1.035c0.123,0.317,0.27,0.794,0.31,1.671c0.043,0.949,0.052,1.234,0.052,3.637 s-0.009,2.688-0.052,3.637c-0.04,0.877-0.187,1.354-0.31,1.671c-0.163,0.42-0.358,0.72-0.673,1.035 c-0.315,0.315-0.615,0.51-1.035,0.673c-0.317,0.123-0.794,0.27-1.671,0.31c-0.949,0.043-1.233,0.052-3.637,0.052 s-2.688-0.009-3.637-0.052c-0.877-0.04-1.354-0.187-1.671-0.31c-0.42-0.163-0.72-0.358-1.035-0.673 c-0.315-0.315-0.51-0.615-0.673-1.035c-0.123-0.317-0.27-0.794-0.31-1.671C4.631,14.688,4.622,14.403,4.622,12 s0.009-2.688,0.052-3.637c0.04-0.877,0.187-1.354,0.31-1.671c0.163-0.42,0.358-0.72,0.673-1.035 c0.315-0.315,0.615-0.51,1.035-0.673c0.317-0.123,0.794-0.27,1.671-0.31C9.312,4.631,9.597,4.622,12,4.622 M12,3 C9.556,3,9.249,3.01,8.289,3.054C7.331,3.098,6.677,3.25,6.105,3.472C5.513,3.702,5.011,4.01,4.511,4.511 c-0.5,0.5-0.808,1.002-1.038,1.594C3.25,6.677,3.098,7.331,3.054,8.289C3.01,9.249,3,9.556,3,12c0,2.444,0.01,2.751,0.054,3.711 c0.044,0.958,0.196,1.612,0.418,2.185c0.23,0.592,0.538,1.094,1.038,1.594c0.5,0.5,1.002,0.808,1.594,1.038 c0.572,0.222,1.227,0.375,2.185,0.418C9.249,20.99,9.556,21,12,21s2.751-0.01,3.711-0.054c0.958-0.044,1.612-0.196,2.185-0.418 c0.592-0.23,1.094-0.538,1.594-1.038c0.5-0.5,0.808-1.002,1.038-1.594c0.222-0.572,0.375-1.227,0.418-2.185 C20.99,14.751,21,14.444,21,12s-0.01-2.751-0.054-3.711c-0.044-0.958-0.196-1.612-0.418-2.185c-0.23-0.592-0.538-1.094-1.038-1.594 c-0.5-0.5-1.002-0.808-1.594-1.038c-0.572-0.222-1.227-0.375-2.185-0.418C14.751,3.01,14.444,3,12,3L12,3z M12,7.378 c-2.552,0-4.622,2.069-4.622,4.622S9.448,16.622,12,16.622s4.622-2.069,4.622-4.622S14.552,7.378,12,7.378z M12,15 c-1.657,0-3-1.343-3-3s1.343-3,3-3s3,1.343,3,3S13.657,15,12,15z M16.804,6.116c-0.596,0-1.08,0.484-1.08,1.08 s0.484,1.08,1.08,1.08c0.596,0,1.08-0.484,1.08-1.08S17.401,6.116,16.804,6.116z"
40594  }));
40595  
40596  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-link/icons/lastfm.js
40597  
40598  
40599  /**
40600   * WordPress dependencies
40601   */
40602  
40603  const LastfmIcon = () => (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
40604    width: "24",
40605    height: "24",
40606    viewBox: "0 0 24 24",
40607    version: "1.1"
40608  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
40609    d: "M 12.0002 1.5 C 6.2006 1.5 1.5 6.2011 1.5 11.9998 C 1.5 17.799 6.2006 22.5 12.0002 22.5 C 17.799 22.5 22.5 17.799 22.5 11.9998 C 22.5 6.2011 17.799 1.5 12.0002 1.5 Z M 16.1974 16.2204 C 14.8164 16.2152 13.9346 15.587 13.3345 14.1859 L 13.1816 13.8451 L 11.8541 10.8101 C 11.4271 9.7688 10.3526 9.0712 9.1801 9.0712 C 7.5695 9.0712 6.2593 10.3851 6.2593 12.001 C 6.2593 13.6165 7.5695 14.9303 9.1801 14.9303 C 10.272 14.9303 11.2651 14.3275 11.772 13.3567 C 11.7893 13.3235 11.8239 13.302 11.863 13.3038 C 11.9007 13.3054 11.9353 13.3288 11.9504 13.3632 L 12.4865 14.6046 C 12.5016 14.639 12.4956 14.6778 12.4723 14.7069 C 11.6605 15.6995 10.4602 16.2683 9.1801 16.2683 C 6.8331 16.2683 4.9234 14.3536 4.9234 12.001 C 4.9234 9.6468 6.833 7.732 9.1801 7.732 C 10.9572 7.732 12.3909 8.6907 13.1138 10.3636 C 13.1206 10.3802 13.8412 12.0708 14.4744 13.5191 C 14.8486 14.374 15.1462 14.896 16.1288 14.9292 C 17.0663 14.9613 17.7538 14.4122 17.7538 13.6485 C 17.7538 12.9691 17.3321 12.8004 16.3803 12.4822 C 14.7365 11.9398 13.845 11.3861 13.845 10.0182 C 13.845 8.6809 14.7667 7.8162 16.192 7.8162 C 17.1288 7.8162 17.8155 8.2287 18.2921 9.0768 C 18.305 9.1006 18.3079 9.1281 18.3004 9.1542 C 18.2929 9.1803 18.2748 9.2021 18.2507 9.2138 L 17.3614 9.669 C 17.3178 9.692 17.2643 9.6781 17.2356 9.6385 C 16.9329 9.2135 16.5956 9.0251 16.1423 9.0251 C 15.5512 9.0251 15.122 9.429 15.122 9.9865 C 15.122 10.6738 15.6529 10.8414 16.5339 11.1192 C 16.6491 11.1558 16.7696 11.194 16.8939 11.2343 C 18.2763 11.6865 19.0768 12.2311 19.0768 13.6836 C 19.0769 15.1297 17.8389 16.2204 16.1974 16.2204 Z"
40610  }));
40611  
40612  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-link/icons/linkedin.js
40613  
40614  
40615  /**
40616   * WordPress dependencies
40617   */
40618  
40619  const LinkedInIcon = () => (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
40620    width: "24",
40621    height: "24",
40622    viewBox: "0 0 24 24",
40623    version: "1.1"
40624  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
40625    d: "M19.7,3H4.3C3.582,3,3,3.582,3,4.3v15.4C3,20.418,3.582,21,4.3,21h15.4c0.718,0,1.3-0.582,1.3-1.3V4.3 C21,3.582,20.418,3,19.7,3z M8.339,18.338H5.667v-8.59h2.672V18.338z M7.004,8.574c-0.857,0-1.549-0.694-1.549-1.548 c0-0.855,0.691-1.548,1.549-1.548c0.854,0,1.547,0.694,1.547,1.548C8.551,7.881,7.858,8.574,7.004,8.574z M18.339,18.338h-2.669 v-4.177c0-0.996-0.017-2.278-1.387-2.278c-1.389,0-1.601,1.086-1.601,2.206v4.249h-2.667v-8.59h2.559v1.174h0.037 c0.356-0.675,1.227-1.387,2.526-1.387c2.703,0,3.203,1.779,3.203,4.092V18.338z"
40626  }));
40627  
40628  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-link/icons/mail.js
40629  
40630  
40631  /**
40632   * WordPress dependencies
40633   */
40634  
40635  const MailIcon = () => (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
40636    width: "24",
40637    height: "24",
40638    viewBox: "0 0 24 24",
40639    version: "1.1"
40640  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
40641    d: "M20,4H4C2.895,4,2,4.895,2,6v12c0,1.105,0.895,2,2,2h16c1.105,0,2-0.895,2-2V6C22,4.895,21.105,4,20,4z M20,8.236l-8,4.882 L4,8.236V6h16V8.236z"
40642  }));
40643  
40644  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-link/icons/mastodon.js
40645  
40646  
40647  /**
40648   * WordPress dependencies
40649   */
40650  
40651  const MastodonIcon = () => (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
40652    width: "24",
40653    height: "24",
40654    viewBox: "0 0 24 24",
40655    version: "1.1"
40656  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
40657    d: "M23.193 7.879c0-5.206-3.411-6.732-3.411-6.732C18.062.357 15.108.025 12.041 0h-.076c-3.068.025-6.02.357-7.74 1.147 0 0-3.411 1.526-3.411 6.732 0 1.192-.023 2.618.015 4.129.124 5.092.934 10.109 5.641 11.355 2.17.574 4.034.695 5.535.612 2.722-.15 4.25-.972 4.25-.972l-.09-1.975s-1.945.613-4.129.539c-2.165-.074-4.449-.233-4.799-2.891a5.499 5.499 0 0 1-.048-.745s2.125.52 4.817.643c1.646.075 3.19-.097 4.758-.283 3.007-.359 5.625-2.212 5.954-3.905.517-2.665.475-6.507.475-6.507zm-4.024 6.709h-2.497V8.469c0-1.29-.543-1.944-1.628-1.944-1.2 0-1.802.776-1.802 2.312v3.349h-2.483v-3.35c0-1.536-.602-2.312-1.802-2.312-1.085 0-1.628.655-1.628 1.944v6.119H4.832V8.284c0-1.289.328-2.313.987-3.07.68-.758 1.569-1.146 2.674-1.146 1.278 0 2.246.491 2.886 1.474L12 6.585l.622-1.043c.64-.983 1.608-1.474 2.886-1.474 1.104 0 1.994.388 2.674 1.146.658.757.986 1.781.986 3.07v6.304z"
40658  }));
40659  
40660  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-link/icons/meetup.js
40661  
40662  
40663  /**
40664   * WordPress dependencies
40665   */
40666  
40667  const MeetupIcon = () => (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
40668    width: "24",
40669    height: "24",
40670    viewBox: "0 0 24 24",
40671    version: "1.1"
40672  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
40673    d: "M19.24775,14.722a3.57032,3.57032,0,0,1-2.94457,3.52073,3.61886,3.61886,0,0,1-.64652.05634c-.07314-.0008-.10187.02846-.12507.09547A2.38881,2.38881,0,0,1,13.49453,20.094a2.33092,2.33092,0,0,1-1.827-.50716.13635.13635,0,0,0-.19878-.00408,3.191,3.191,0,0,1-2.104.60248,3.26309,3.26309,0,0,1-3.00324-2.71993,2.19076,2.19076,0,0,1-.03512-.30865c-.00156-.08579-.03413-.1189-.11608-.13493a2.86421,2.86421,0,0,1-1.23189-.56111,2.945,2.945,0,0,1-1.166-2.05749,2.97484,2.97484,0,0,1,.87524-2.50774.112.112,0,0,0,.02091-.16107,2.7213,2.7213,0,0,1-.36648-1.48A2.81256,2.81256,0,0,1,6.57673,7.58838a.35764.35764,0,0,0,.28869-.22819,4.2208,4.2208,0,0,1,6.02892-1.90111.25161.25161,0,0,0,.22023.0243,3.65608,3.65608,0,0,1,3.76031.90678A3.57244,3.57244,0,0,1,17.95918,8.626a2.97339,2.97339,0,0,1,.01829.57356.10637.10637,0,0,0,.0853.12792,1.97669,1.97669,0,0,1,1.27939,1.33733,2.00266,2.00266,0,0,1-.57112,2.12652c-.05284.05166-.04168.08328-.01173.13489A3.51189,3.51189,0,0,1,19.24775,14.722Zm-6.35959-.27836a1.6984,1.6984,0,0,0,1.14556,1.61113,3.82039,3.82039,0,0,0,1.036.17935,1.46888,1.46888,0,0,0,.73509-.12255.44082.44082,0,0,0,.26057-.44274.45312.45312,0,0,0-.29211-.43375.97191.97191,0,0,0-.20678-.063c-.21326-.03806-.42754-.0701-.63973-.11215a.54787.54787,0,0,1-.50172-.60926,2.75864,2.75864,0,0,1,.1773-.901c.1763-.535.414-1.045.64183-1.55913A12.686,12.686,0,0,0,15.85,10.47863a1.58461,1.58461,0,0,0,.04861-.87208,1.04531,1.04531,0,0,0-.85432-.83981,1.60658,1.60658,0,0,0-1.23654.16594.27593.27593,0,0,1-.36286-.03413c-.085-.0747-.16594-.15379-.24918-.23055a.98682.98682,0,0,0-1.33577-.04933,6.1468,6.1468,0,0,1-.4989.41615.47762.47762,0,0,1-.51535.03566c-.17448-.09307-.35512-.175-.53531-.25665a1.74949,1.74949,0,0,0-.56476-.2016,1.69943,1.69943,0,0,0-1.61654.91787,8.05815,8.05815,0,0,0-.32952.80126c-.45471,1.2557-.82507,2.53825-1.20838,3.81639a1.24151,1.24151,0,0,0,.51532,1.44389,1.42659,1.42659,0,0,0,1.22008.17166,1.09728,1.09728,0,0,0,.66994-.69764c.44145-1.04111.839-2.09989,1.25981-3.14926.11581-.28876.22792-.57874.35078-.86438a.44548.44548,0,0,1,.69189-.19539.50521.50521,0,0,1,.15044.43836,1.75625,1.75625,0,0,1-.14731.50453c-.27379.69219-.55265,1.38236-.82766,2.074a2.0836,2.0836,0,0,0-.14038.42876.50719.50719,0,0,0,.27082.57722.87236.87236,0,0,0,.66145.02739.99137.99137,0,0,0,.53406-.532q.61571-1.20914,1.228-2.42031.28423-.55863.57585-1.1133a.87189.87189,0,0,1,.29055-.35253.34987.34987,0,0,1,.37634-.01265.30291.30291,0,0,1,.12434.31459.56716.56716,0,0,1-.04655.1915c-.05318.12739-.10286.25669-.16183.38156-.34118.71775-.68754,1.43273-1.02568,2.152A2.00213,2.00213,0,0,0,12.88816,14.44366Zm4.78568,5.28972a.88573.88573,0,0,0-1.77139.00465.8857.8857,0,0,0,1.77139-.00465Zm-14.83838-7.296a.84329.84329,0,1,0,.00827-1.68655.8433.8433,0,0,0-.00827,1.68655Zm10.366-9.43673a.83506.83506,0,1,0-.0091,1.67.83505.83505,0,0,0,.0091-1.67Zm6.85014,5.22a.71651.71651,0,0,0-1.433.0093.71656.71656,0,0,0,1.433-.0093ZM5.37528,6.17908A.63823.63823,0,1,0,6.015,5.54483.62292.62292,0,0,0,5.37528,6.17908Zm6.68214,14.80843a.54949.54949,0,1,0-.55052.541A.54556.54556,0,0,0,12.05742,20.98752Zm8.53235-8.49689a.54777.54777,0,0,0-.54027.54023.53327.53327,0,0,0,.532.52293.51548.51548,0,0,0,.53272-.5237A.53187.53187,0,0,0,20.58977,12.49063ZM7.82846,2.4715a.44927.44927,0,1,0,.44484.44766A.43821.43821,0,0,0,7.82846,2.4715Zm13.775,7.60492a.41186.41186,0,0,0-.40065.39623.40178.40178,0,0,0,.40168.40168A.38994.38994,0,0,0,22,10.48172.39946.39946,0,0,0,21.60349,10.07642ZM5.79193,17.96207a.40469.40469,0,0,0-.397-.39646.399.399,0,0,0-.396.405.39234.39234,0,0,0,.39939.389A.39857.39857,0,0,0,5.79193,17.96207Z"
40674  }));
40675  
40676  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-link/icons/medium.js
40677  
40678  
40679  /**
40680   * WordPress dependencies
40681   */
40682  
40683  const MediumIcon = () => (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
40684    width: "24",
40685    height: "24",
40686    viewBox: "0 0 24 24",
40687    version: "1.1"
40688  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
40689    d: "M20.962,7.257l-5.457,8.867l-3.923-6.375l3.126-5.08c0.112-0.182,0.319-0.286,0.527-0.286c0.05,0,0.1,0.008,0.149,0.02 c0.039,0.01,0.078,0.023,0.114,0.041l5.43,2.715l0.006,0.003c0.004,0.002,0.007,0.006,0.011,0.008 C20.971,7.191,20.98,7.227,20.962,7.257z M9.86,8.592v5.783l5.14,2.57L9.86,8.592z M15.772,17.331l4.231,2.115 C20.554,19.721,21,19.529,21,19.016V8.835L15.772,17.331z M8.968,7.178L3.665,4.527C3.569,4.479,3.478,4.456,3.395,4.456 C3.163,4.456,3,4.636,3,4.938v11.45c0,0.306,0.224,0.669,0.498,0.806l4.671,2.335c0.12,0.06,0.234,0.088,0.337,0.088 c0.29,0,0.494-0.225,0.494-0.602V7.231C9,7.208,8.988,7.188,8.968,7.178z"
40690  }));
40691  
40692  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-link/icons/patreon.js
40693  
40694  
40695  /**
40696   * WordPress dependencies
40697   */
40698  
40699  const PatreonIcon = () => (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
40700    width: "24",
40701    height: "24",
40702    viewBox: "0 0 569 546",
40703    version: "1.1"
40704  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Circle, {
40705    cx: "363",
40706    cy: "205",
40707    r: "205"
40708  }), (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Rect, {
40709    width: "100",
40710    height: "546",
40711    x: "0",
40712    y: "0"
40713  }));
40714  
40715  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-link/icons/pinterest.js
40716  
40717  
40718  /**
40719   * WordPress dependencies
40720   */
40721  
40722  const PinterestIcon = () => (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
40723    width: "24",
40724    height: "24",
40725    viewBox: "0 0 24 24",
40726    version: "1.1"
40727  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
40728    d: "M12.289,2C6.617,2,3.606,5.648,3.606,9.622c0,1.846,1.025,4.146,2.666,4.878c0.25,0.111,0.381,0.063,0.439-0.169 c0.044-0.175,0.267-1.029,0.365-1.428c0.032-0.128,0.017-0.237-0.091-0.362C6.445,11.911,6.01,10.75,6.01,9.668 c0-2.777,2.194-5.464,5.933-5.464c3.23,0,5.49,2.108,5.49,5.122c0,3.407-1.794,5.768-4.13,5.768c-1.291,0-2.257-1.021-1.948-2.277 c0.372-1.495,1.089-3.112,1.089-4.191c0-0.967-0.542-1.775-1.663-1.775c-1.319,0-2.379,1.309-2.379,3.059 c0,1.115,0.394,1.869,0.394,1.869s-1.302,5.279-1.54,6.261c-0.405,1.666,0.053,4.368,0.094,4.604 c0.021,0.126,0.167,0.169,0.25,0.063c0.129-0.165,1.699-2.419,2.142-4.051c0.158-0.59,0.817-2.995,0.817-2.995 c0.43,0.784,1.681,1.446,3.013,1.446c3.963,0,6.822-3.494,6.822-7.833C20.394,5.112,16.849,2,12.289,2"
40729  }));
40730  
40731  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-link/icons/pocket.js
40732  
40733  
40734  /**
40735   * WordPress dependencies
40736   */
40737  
40738  const PocketIcon = () => (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
40739    width: "24",
40740    height: "24",
40741    viewBox: "0 0 24 24",
40742    version: "1.1"
40743  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
40744    d: "M21.927,4.194C21.667,3.48,20.982,3,20.222,3h-0.01h-1.721H3.839C3.092,3,2.411,3.47,2.145,4.17 C2.066,4.378,2.026,4.594,2.026,4.814v6.035l0.069,1.2c0.29,2.73,1.707,5.115,3.899,6.778c0.039,0.03,0.079,0.059,0.119,0.089 l0.025,0.018c1.175,0.859,2.491,1.441,3.91,1.727c0.655,0.132,1.325,0.2,1.991,0.2c0.615,0,1.232-0.057,1.839-0.17 c0.073-0.014,0.145-0.028,0.219-0.044c0.02-0.004,0.042-0.012,0.064-0.023c1.359-0.297,2.621-0.864,3.753-1.691l0.025-0.018 c0.04-0.029,0.08-0.058,0.119-0.089c2.192-1.664,3.609-4.049,3.898-6.778l0.069-1.2V4.814C22.026,4.605,22,4.398,21.927,4.194z M17.692,10.481l-4.704,4.512c-0.266,0.254-0.608,0.382-0.949,0.382c-0.342,0-0.684-0.128-0.949-0.382l-4.705-4.512 C5.838,9.957,5.82,9.089,6.344,8.542c0.524-0.547,1.392-0.565,1.939-0.04l3.756,3.601l3.755-3.601 c0.547-0.524,1.415-0.506,1.939,0.04C18.256,9.089,18.238,9.956,17.692,10.481z"
40745  }));
40746  
40747  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-link/icons/reddit.js
40748  
40749  
40750  /**
40751   * WordPress dependencies
40752   */
40753  
40754  const RedditIcon = () => (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
40755    width: "24",
40756    height: "24",
40757    viewBox: "0 0 24 24",
40758    version: "1.1"
40759  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
40760    d: "M22,11.816c0-1.256-1.021-2.277-2.277-2.277c-0.593,0-1.122,0.24-1.526,0.614c-1.481-0.965-3.455-1.594-5.647-1.69 l1.171-3.702l3.18,0.748c0.008,1.028,0.846,1.862,1.876,1.862c1.035,0,1.877-0.842,1.877-1.878c0-1.035-0.842-1.877-1.877-1.877 c-0.769,0-1.431,0.466-1.72,1.13l-3.508-0.826c-0.203-0.047-0.399,0.067-0.46,0.261l-1.35,4.268 c-2.316,0.038-4.411,0.67-5.97,1.671C5.368,9.765,4.853,9.539,4.277,9.539C3.021,9.539,2,10.56,2,11.816 c0,0.814,0.433,1.523,1.078,1.925c-0.037,0.221-0.061,0.444-0.061,0.672c0,3.292,4.011,5.97,8.941,5.97s8.941-2.678,8.941-5.97 c0-0.214-0.02-0.424-0.053-0.632C21.533,13.39,22,12.661,22,11.816z M18.776,4.394c0.606,0,1.1,0.493,1.1,1.1s-0.493,1.1-1.1,1.1 s-1.1-0.494-1.1-1.1S18.169,4.394,18.776,4.394z M2.777,11.816c0-0.827,0.672-1.5,1.499-1.5c0.313,0,0.598,0.103,0.838,0.269 c-0.851,0.676-1.477,1.479-1.812,2.36C2.983,12.672,2.777,12.27,2.777,11.816z M11.959,19.606c-4.501,0-8.164-2.329-8.164-5.193 S7.457,9.22,11.959,9.22s8.164,2.329,8.164,5.193S16.46,19.606,11.959,19.606z M20.636,13.001c-0.326-0.89-0.948-1.701-1.797-2.384 c0.248-0.186,0.55-0.301,0.883-0.301c0.827,0,1.5,0.673,1.5,1.5C21.223,12.299,20.992,12.727,20.636,13.001z M8.996,14.704 c-0.76,0-1.397-0.616-1.397-1.376c0-0.76,0.637-1.397,1.397-1.397c0.76,0,1.376,0.637,1.376,1.397 C10.372,14.088,9.756,14.704,8.996,14.704z M16.401,13.328c0,0.76-0.616,1.376-1.376,1.376c-0.76,0-1.399-0.616-1.399-1.376 c0-0.76,0.639-1.397,1.399-1.397C15.785,11.931,16.401,12.568,16.401,13.328z M15.229,16.708c0.152,0.152,0.152,0.398,0,0.55 c-0.674,0.674-1.727,1.002-3.219,1.002c-0.004,0-0.007-0.002-0.011-0.002c-0.004,0-0.007,0.002-0.011,0.002 c-1.492,0-2.544-0.328-3.218-1.002c-0.152-0.152-0.152-0.398,0-0.55c0.152-0.152,0.399-0.151,0.55,0 c0.521,0.521,1.394,0.775,2.669,0.775c0.004,0,0.007,0.002,0.011,0.002c0.004,0,0.007-0.002,0.011-0.002 c1.275,0,2.148-0.253,2.669-0.775C14.831,16.556,15.078,16.556,15.229,16.708z"
40761  }));
40762  
40763  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-link/icons/skype.js
40764  
40765  
40766  /**
40767   * WordPress dependencies
40768   */
40769  
40770  const SkypeIcon = () => (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
40771    width: "24",
40772    height: "24",
40773    viewBox: "0 0 24 24",
40774    version: "1.1"
40775  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
40776    d: "M10.113,2.699c0.033-0.006,0.067-0.013,0.1-0.02c0.033,0.017,0.066,0.033,0.098,0.051L10.113,2.699z M2.72,10.223 c-0.006,0.034-0.011,0.069-0.017,0.103c0.018,0.032,0.033,0.064,0.051,0.095L2.72,10.223z M21.275,13.771 c0.007-0.035,0.011-0.071,0.018-0.106c-0.018-0.031-0.033-0.064-0.052-0.095L21.275,13.771z M13.563,21.199 c0.032,0.019,0.065,0.035,0.096,0.053c0.036-0.006,0.071-0.011,0.105-0.017L13.563,21.199z M22,16.386 c0,1.494-0.581,2.898-1.637,3.953c-1.056,1.057-2.459,1.637-3.953,1.637c-0.967,0-1.914-0.251-2.75-0.725 c0.036-0.006,0.071-0.011,0.105-0.017l-0.202-0.035c0.032,0.019,0.065,0.035,0.096,0.053c-0.543,0.096-1.099,0.147-1.654,0.147 c-1.275,0-2.512-0.25-3.676-0.743c-1.125-0.474-2.135-1.156-3.002-2.023c-0.867-0.867-1.548-1.877-2.023-3.002 c-0.493-1.164-0.743-2.401-0.743-3.676c0-0.546,0.049-1.093,0.142-1.628c0.018,0.032,0.033,0.064,0.051,0.095L2.72,10.223 c-0.006,0.034-0.011,0.069-0.017,0.103C2.244,9.5,2,8.566,2,7.615c0-1.493,0.582-2.898,1.637-3.953 c1.056-1.056,2.46-1.638,3.953-1.638c0.915,0,1.818,0.228,2.622,0.655c-0.033,0.007-0.067,0.013-0.1,0.02l0.199,0.031 c-0.032-0.018-0.066-0.034-0.098-0.051c0.002,0,0.003-0.001,0.004-0.001c0.586-0.112,1.187-0.169,1.788-0.169 c1.275,0,2.512,0.249,3.676,0.742c1.124,0.476,2.135,1.156,3.002,2.024c0.868,0.867,1.548,1.877,2.024,3.002 c0.493,1.164,0.743,2.401,0.743,3.676c0,0.575-0.054,1.15-0.157,1.712c-0.018-0.031-0.033-0.064-0.052-0.095l0.034,0.201 c0.007-0.035,0.011-0.071,0.018-0.106C21.754,14.494,22,15.432,22,16.386z M16.817,14.138c0-1.331-0.613-2.743-3.033-3.282 l-2.209-0.49c-0.84-0.192-1.807-0.444-1.807-1.237c0-0.794,0.679-1.348,1.903-1.348c2.468,0,2.243,1.696,3.468,1.696 c0.645,0,1.209-0.379,1.209-1.031c0-1.521-2.435-2.663-4.5-2.663c-2.242,0-4.63,0.952-4.63,3.488c0,1.221,0.436,2.521,2.839,3.123 l2.984,0.745c0.903,0.223,1.129,0.731,1.129,1.189c0,0.762-0.758,1.507-2.129,1.507c-2.679,0-2.307-2.062-3.743-2.062 c-0.645,0-1.113,0.444-1.113,1.078c0,1.236,1.501,2.886,4.856,2.886C15.236,17.737,16.817,16.199,16.817,14.138z"
40777  }));
40778  
40779  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-link/icons/snapchat.js
40780  
40781  
40782  /**
40783   * WordPress dependencies
40784   */
40785  
40786  const SnapchatIcon = () => (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
40787    width: "24",
40788    height: "24",
40789    viewBox: "0 0 24 24",
40790    version: "1.1"
40791  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
40792    d: "M12.065,2a5.526,5.526,0,0,1,3.132.892A5.854,5.854,0,0,1,17.326,5.4a5.821,5.821,0,0,1,.351,2.33q0,.612-.117,2.487a.809.809,0,0,0,.365.091,1.93,1.93,0,0,0,.664-.176,1.93,1.93,0,0,1,.664-.176,1.3,1.3,0,0,1,.729.234.7.7,0,0,1,.351.6.839.839,0,0,1-.41.7,2.732,2.732,0,0,1-.9.41,3.192,3.192,0,0,0-.9.378.728.728,0,0,0-.41.618,1.575,1.575,0,0,0,.156.56,6.9,6.9,0,0,0,1.334,1.953,5.6,5.6,0,0,0,1.881,1.315,5.875,5.875,0,0,0,1.042.3.42.42,0,0,1,.365.456q0,.911-2.852,1.341a1.379,1.379,0,0,0-.143.507,1.8,1.8,0,0,1-.182.605.451.451,0,0,1-.429.241,5.878,5.878,0,0,1-.807-.085,5.917,5.917,0,0,0-.833-.085,4.217,4.217,0,0,0-.807.065,2.42,2.42,0,0,0-.82.293,6.682,6.682,0,0,0-.755.5q-.351.267-.755.527a3.886,3.886,0,0,1-.989.436A4.471,4.471,0,0,1,11.831,22a4.307,4.307,0,0,1-1.256-.176,3.784,3.784,0,0,1-.976-.436q-.4-.26-.749-.527a6.682,6.682,0,0,0-.755-.5,2.422,2.422,0,0,0-.807-.293,4.432,4.432,0,0,0-.82-.065,5.089,5.089,0,0,0-.853.1,5,5,0,0,1-.762.1.474.474,0,0,1-.456-.241,1.819,1.819,0,0,1-.182-.618,1.411,1.411,0,0,0-.143-.521q-2.852-.429-2.852-1.341a.42.42,0,0,1,.365-.456,5.793,5.793,0,0,0,1.042-.3,5.524,5.524,0,0,0,1.881-1.315,6.789,6.789,0,0,0,1.334-1.953A1.575,1.575,0,0,0,6,12.9a.728.728,0,0,0-.41-.618,3.323,3.323,0,0,0-.9-.384,2.912,2.912,0,0,1-.9-.41.814.814,0,0,1-.41-.684.71.71,0,0,1,.338-.593,1.208,1.208,0,0,1,.716-.241,1.976,1.976,0,0,1,.625.169,2.008,2.008,0,0,0,.69.169.919.919,0,0,0,.416-.091q-.117-1.849-.117-2.474A5.861,5.861,0,0,1,6.385,5.4,5.516,5.516,0,0,1,8.625,2.819,7.075,7.075,0,0,1,12.062,2Z"
40793  }));
40794  
40795  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-link/icons/soundcloud.js
40796  
40797  
40798  /**
40799   * WordPress dependencies
40800   */
40801  
40802  const SoundCloudIcon = () => (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
40803    width: "24",
40804    height: "24",
40805    viewBox: "0 0 24 24",
40806    version: "1.1"
40807  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
40808    d: "M8.9,16.1L9,14L8.9,9.5c0-0.1,0-0.1-0.1-0.1c0,0-0.1-0.1-0.1-0.1c-0.1,0-0.1,0-0.1,0.1c0,0-0.1,0.1-0.1,0.1L8.3,14l0.1,2.1 c0,0.1,0,0.1,0.1,0.1c0,0,0.1,0.1,0.1,0.1C8.8,16.3,8.9,16.3,8.9,16.1z M11.4,15.9l0.1-1.8L11.4,9c0-0.1,0-0.2-0.1-0.2 c0,0-0.1,0-0.1,0s-0.1,0-0.1,0c-0.1,0-0.1,0.1-0.1,0.2l0,0.1l-0.1,5c0,0,0,0.7,0.1,2v0c0,0.1,0,0.1,0.1,0.1c0.1,0.1,0.1,0.1,0.2,0.1 c0.1,0,0.1,0,0.2-0.1c0.1,0,0.1-0.1,0.1-0.2L11.4,15.9z M2.4,12.9L2.5,14l-0.2,1.1c0,0.1,0,0.1-0.1,0.1c0,0-0.1,0-0.1-0.1L2.1,14 l0.1-1.1C2.2,12.9,2.3,12.9,2.4,12.9C2.3,12.9,2.4,12.9,2.4,12.9z M3.1,12.2L3.3,14l-0.2,1.8c0,0.1,0,0.1-0.1,0.1 c-0.1,0-0.1,0-0.1-0.1L2.8,14L3,12.2C3,12.2,3,12.2,3.1,12.2C3.1,12.2,3.1,12.2,3.1,12.2z M3.9,11.9L4.1,14l-0.2,2.1 c0,0.1,0,0.1-0.1,0.1c-0.1,0-0.1,0-0.1-0.1L3.5,14l0.2-2.1c0-0.1,0-0.1,0.1-0.1C3.9,11.8,3.9,11.8,3.9,11.9z M4.7,11.9L4.9,14 l-0.2,2.1c0,0.1-0.1,0.1-0.1,0.1c-0.1,0-0.1,0-0.1-0.1L4.3,14l0.2-2.2c0-0.1,0-0.1,0.1-0.1C4.7,11.7,4.7,11.8,4.7,11.9z M5.6,12 l0.2,2l-0.2,2.1c0,0.1-0.1,0.1-0.1,0.1c0,0-0.1,0-0.1,0c0,0,0-0.1,0-0.1L5.1,14l0.2-2c0,0,0-0.1,0-0.1s0.1,0,0.1,0 C5.5,11.9,5.5,11.9,5.6,12L5.6,12z M6.4,10.7L6.6,14l-0.2,2.1c0,0,0,0.1,0,0.1c0,0-0.1,0-0.1,0c-0.1,0-0.1-0.1-0.2-0.2L5.9,14 l0.2-3.3c0-0.1,0.1-0.2,0.2-0.2c0,0,0.1,0,0.1,0C6.4,10.7,6.4,10.7,6.4,10.7z M7.2,10l0.2,4.1l-0.2,2.1c0,0,0,0.1,0,0.1 c0,0-0.1,0-0.1,0c-0.1,0-0.2-0.1-0.2-0.2l-0.1-2.1L6.8,10c0-0.1,0.1-0.2,0.2-0.2c0,0,0.1,0,0.1,0S7.2,9.9,7.2,10z M8,9.6L8.2,14 L8,16.1c0,0.1-0.1,0.2-0.2,0.2c-0.1,0-0.2-0.1-0.2-0.2L7.5,14l0.1-4.4c0-0.1,0-0.1,0.1-0.1c0,0,0.1-0.1,0.1-0.1c0.1,0,0.1,0,0.1,0.1 C8,9.6,8,9.6,8,9.6z M11.4,16.1L11.4,16.1L11.4,16.1z M9.7,9.6L9.8,14l-0.1,2.1c0,0.1,0,0.1-0.1,0.2s-0.1,0.1-0.2,0.1 c-0.1,0-0.1,0-0.1-0.1s-0.1-0.1-0.1-0.2L9.2,14l0.1-4.4c0-0.1,0-0.1,0.1-0.2s0.1-0.1,0.2-0.1c0.1,0,0.1,0,0.2,0.1S9.7,9.5,9.7,9.6 L9.7,9.6z M10.6,9.8l0.1,4.3l-0.1,2c0,0.1,0,0.1-0.1,0.2c0,0-0.1,0.1-0.2,0.1c-0.1,0-0.1,0-0.2-0.1c0,0-0.1-0.1-0.1-0.2L10,14 l0.1-4.3c0-0.1,0-0.1,0.1-0.2c0,0,0.1-0.1,0.2-0.1c0.1,0,0.1,0,0.2,0.1S10.6,9.7,10.6,9.8z M12.4,14l-0.1,2c0,0.1,0,0.1-0.1,0.2 c-0.1,0.1-0.1,0.1-0.2,0.1c-0.1,0-0.1,0-0.2-0.1c-0.1-0.1-0.1-0.1-0.1-0.2l-0.1-1l-0.1-1l0.1-5.5v0c0-0.1,0-0.2,0.1-0.2 c0.1,0,0.1-0.1,0.2-0.1c0,0,0.1,0,0.1,0c0.1,0,0.1,0.1,0.1,0.2L12.4,14z M22.1,13.9c0,0.7-0.2,1.3-0.7,1.7c-0.5,0.5-1.1,0.7-1.7,0.7 h-6.8c-0.1,0-0.1,0-0.2-0.1c-0.1-0.1-0.1-0.1-0.1-0.2V8.2c0-0.1,0.1-0.2,0.2-0.3c0.5-0.2,1-0.3,1.6-0.3c1.1,0,2.1,0.4,2.9,1.1 c0.8,0.8,1.3,1.7,1.4,2.8c0.3-0.1,0.6-0.2,1-0.2c0.7,0,1.3,0.2,1.7,0.7C21.8,12.6,22.1,13.2,22.1,13.9L22.1,13.9z"
40809  }));
40810  
40811  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-link/icons/spotify.js
40812  
40813  
40814  /**
40815   * WordPress dependencies
40816   */
40817  
40818  const SpotifyIcon = () => (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
40819    width: "24",
40820    height: "24",
40821    viewBox: "0 0 24 24",
40822    version: "1.1"
40823  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
40824    d: "M12,2C6.477,2,2,6.477,2,12c0,5.523,4.477,10,10,10c5.523,0,10-4.477,10-10C22,6.477,17.523,2,12,2 M16.586,16.424 c-0.18,0.295-0.563,0.387-0.857,0.207c-2.348-1.435-5.304-1.76-8.785-0.964c-0.335,0.077-0.67-0.133-0.746-0.469 c-0.077-0.335,0.132-0.67,0.469-0.746c3.809-0.871,7.077-0.496,9.713,1.115C16.673,15.746,16.766,16.13,16.586,16.424 M17.81,13.7 c-0.226,0.367-0.706,0.482-1.072,0.257c-2.687-1.652-6.785-2.131-9.965-1.166C6.36,12.917,5.925,12.684,5.8,12.273 C5.675,11.86,5.908,11.425,6.32,11.3c3.632-1.102,8.147-0.568,11.234,1.328C17.92,12.854,18.035,13.335,17.81,13.7 M17.915,10.865 c-3.223-1.914-8.54-2.09-11.618-1.156C5.804,9.859,5.281,9.58,5.131,9.086C4.982,8.591,5.26,8.069,5.755,7.919 c3.532-1.072,9.404-0.865,13.115,1.338c0.445,0.264,0.59,0.838,0.327,1.282C18.933,10.983,18.359,11.129,17.915,10.865"
40825  }));
40826  
40827  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-link/icons/telegram.js
40828  
40829  
40830  /**
40831   * WordPress dependencies
40832   */
40833  
40834  const TelegramIcon = () => (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
40835    width: "24",
40836    height: "24",
40837    viewBox: "0 0 128 128",
40838    version: "1.1"
40839  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
40840    d: "M28.9700376,63.3244248 C47.6273373,55.1957357 60.0684594,49.8368063 66.2934036,47.2476366 C84.0668845,39.855031 87.7600616,38.5708563 90.1672227,38.528 C90.6966555,38.5191258 91.8804274,38.6503351 92.6472251,39.2725385 C93.294694,39.7979149 93.4728387,40.5076237 93.5580865,41.0057381 C93.6433345,41.5038525 93.7494885,42.63857 93.6651041,43.5252052 C92.7019529,53.6451182 88.5344133,78.2034783 86.4142057,89.5379542 C85.5170662,94.3339958 83.750571,95.9420841 82.0403991,96.0994568 C78.3237996,96.4414641 75.5015827,93.6432685 71.9018743,91.2836143 C66.2690414,87.5912212 63.0868492,85.2926952 57.6192095,81.6896017 C51.3004058,77.5256038 55.3966232,75.2369981 58.9976911,71.4967761 C59.9401076,70.5179421 76.3155302,55.6232293 76.6324771,54.2720454 C76.6721165,54.1030573 76.7089039,53.4731496 76.3346867,53.1405352 C75.9604695,52.8079208 75.4081573,52.921662 75.0095933,53.0121213 C74.444641,53.1403447 65.4461175,59.0880351 48.0140228,70.8551922 C45.4598218,72.6091037 43.1463059,73.4636682 41.0734751,73.4188859 C38.7883453,73.3695169 34.3926725,72.1268388 31.1249416,71.0646282 C27.1169366,69.7617838 23.931454,69.0729605 24.208838,66.8603276 C24.3533167,65.7078514 25.9403832,64.5292172 28.9700376,63.3244248 Z"
40841  }));
40842  
40843  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-link/icons/tiktok.js
40844  
40845  
40846  /**
40847   * WordPress dependencies
40848   */
40849  
40850  const TiktokIcon = () => (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
40851    width: "24",
40852    height: "24",
40853    viewBox: "0 0 32 32",
40854    version: "1.1"
40855  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
40856    d: "M16.708 0.027c1.745-0.027 3.48-0.011 5.213-0.027 0.105 2.041 0.839 4.12 2.333 5.563 1.491 1.479 3.6 2.156 5.652 2.385v5.369c-1.923-0.063-3.855-0.463-5.6-1.291-0.76-0.344-1.468-0.787-2.161-1.24-0.009 3.896 0.016 7.787-0.025 11.667-0.104 1.864-0.719 3.719-1.803 5.255-1.744 2.557-4.771 4.224-7.88 4.276-1.907 0.109-3.812-0.411-5.437-1.369-2.693-1.588-4.588-4.495-4.864-7.615-0.032-0.667-0.043-1.333-0.016-1.984 0.24-2.537 1.495-4.964 3.443-6.615 2.208-1.923 5.301-2.839 8.197-2.297 0.027 1.975-0.052 3.948-0.052 5.923-1.323-0.428-2.869-0.308-4.025 0.495-0.844 0.547-1.485 1.385-1.819 2.333-0.276 0.676-0.197 1.427-0.181 2.145 0.317 2.188 2.421 4.027 4.667 3.828 1.489-0.016 2.916-0.88 3.692-2.145 0.251-0.443 0.532-0.896 0.547-1.417 0.131-2.385 0.079-4.76 0.095-7.145 0.011-5.375-0.016-10.735 0.025-16.093z"
40857  }));
40858  
40859  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-link/icons/tumblr.js
40860  
40861  
40862  /**
40863   * WordPress dependencies
40864   */
40865  
40866  const TumblrIcon = () => (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
40867    width: "24",
40868    height: "24",
40869    viewBox: "0 0 24 24",
40870    version: "1.1"
40871  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
40872    d: "M17.04 21.28h-3.28c-2.84 0-4.94-1.37-4.94-5.02v-5.67H6.08V7.5c2.93-.73 4.11-3.3 4.3-5.48h3.01v4.93h3.47v3.65H13.4v4.93c0 1.47.73 2.01 1.92 2.01h1.73v3.75z"
40873  }));
40874  
40875  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-link/icons/twitch.js
40876  
40877  
40878  /**
40879   * WordPress dependencies
40880   */
40881  
40882  const TwitchIcon = () => (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
40883    width: "24",
40884    height: "24",
40885    viewBox: "0 0 24 24",
40886    version: "1.1"
40887  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
40888    d: "M16.499,8.089h-1.636v4.91h1.636V8.089z M12,8.089h-1.637v4.91H12V8.089z M4.228,3.178L3,6.451v13.092h4.499V22h2.456 l2.454-2.456h3.681L21,14.636V3.178H4.228z M19.364,13.816l-2.864,2.865H12l-2.453,2.453V16.68H5.863V4.814h13.501V13.816z"
40889  }));
40890  
40891  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-link/icons/twitter.js
40892  
40893  
40894  /**
40895   * WordPress dependencies
40896   */
40897  
40898  const TwitterIcon = () => (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
40899    width: "24",
40900    height: "24",
40901    viewBox: "0 0 24 24",
40902    version: "1.1"
40903  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
40904    d: "M22.23,5.924c-0.736,0.326-1.527,0.547-2.357,0.646c0.847-0.508,1.498-1.312,1.804-2.27 c-0.793,0.47-1.671,0.812-2.606,0.996C18.324,4.498,17.257,4,16.077,4c-2.266,0-4.103,1.837-4.103,4.103 c0,0.322,0.036,0.635,0.106,0.935C8.67,8.867,5.647,7.234,3.623,4.751C3.27,5.357,3.067,6.062,3.067,6.814 c0,1.424,0.724,2.679,1.825,3.415c-0.673-0.021-1.305-0.206-1.859-0.513c0,0.017,0,0.034,0,0.052c0,1.988,1.414,3.647,3.292,4.023 c-0.344,0.094-0.707,0.144-1.081,0.144c-0.264,0-0.521-0.026-0.772-0.074c0.522,1.63,2.038,2.816,3.833,2.85 c-1.404,1.1-3.174,1.756-5.096,1.756c-0.331,0-0.658-0.019-0.979-0.057c1.816,1.164,3.973,1.843,6.29,1.843 c7.547,0,11.675-6.252,11.675-11.675c0-0.178-0.004-0.355-0.012-0.531C20.985,7.47,21.68,6.747,22.23,5.924z"
40905  }));
40906  
40907  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-link/icons/vimeo.js
40908  
40909  
40910  /**
40911   * WordPress dependencies
40912   */
40913  
40914  const VimeoIcon = () => (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
40915    width: "24",
40916    height: "24",
40917    viewBox: "0 0 24 24",
40918    version: "1.1"
40919  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
40920    d: "M22.396,7.164c-0.093,2.026-1.507,4.799-4.245,8.32C15.322,19.161,12.928,21,10.97,21c-1.214,0-2.24-1.119-3.079-3.359 c-0.56-2.053-1.119-4.106-1.68-6.159C5.588,9.243,4.921,8.122,4.206,8.122c-0.156,0-0.701,0.328-1.634,0.98L1.594,7.841 c1.027-0.902,2.04-1.805,3.037-2.708C6.001,3.95,7.03,3.327,7.715,3.264c1.619-0.156,2.616,0.951,2.99,3.321 c0.404,2.557,0.685,4.147,0.841,4.769c0.467,2.121,0.981,3.181,1.542,3.181c0.435,0,1.09-0.688,1.963-2.065 c0.871-1.376,1.338-2.422,1.401-3.142c0.125-1.187-0.343-1.782-1.401-1.782c-0.498,0-1.012,0.115-1.541,0.341 c1.023-3.35,2.977-4.977,5.862-4.884C21.511,3.066,22.52,4.453,22.396,7.164z"
40921  }));
40922  
40923  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-link/icons/vk.js
40924  
40925  
40926  /**
40927   * WordPress dependencies
40928   */
40929  
40930  const VkIcon = () => (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
40931    width: "24",
40932    height: "24",
40933    viewBox: "0 0 24 24",
40934    version: "1.1"
40935  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
40936    d: "M22,7.1c0.2,0.4-0.4,1.5-1.6,3.1c-0.2,0.2-0.4,0.5-0.7,0.9c-0.5,0.7-0.9,1.1-0.9,1.4c-0.1,0.3-0.1,0.6,0.1,0.8 c0.1,0.1,0.4,0.4,0.8,0.9h0l0,0c1,0.9,1.6,1.7,2,2.3c0,0,0,0.1,0.1,0.1c0,0.1,0,0.1,0.1,0.3c0,0.1,0,0.2,0,0.4 c0,0.1-0.1,0.2-0.3,0.3c-0.1,0.1-0.4,0.1-0.6,0.1l-2.7,0c-0.2,0-0.4,0-0.6-0.1c-0.2-0.1-0.4-0.1-0.5-0.2l-0.2-0.1 c-0.2-0.1-0.5-0.4-0.7-0.7s-0.5-0.6-0.7-0.8c-0.2-0.2-0.4-0.4-0.6-0.6C14.8,15,14.6,15,14.4,15c0,0,0,0-0.1,0c0,0-0.1,0.1-0.2,0.2 c-0.1,0.1-0.2,0.2-0.2,0.3c-0.1,0.1-0.1,0.3-0.2,0.5c-0.1,0.2-0.1,0.5-0.1,0.8c0,0.1,0,0.2,0,0.3c0,0.1-0.1,0.2-0.1,0.2l0,0.1 c-0.1,0.1-0.3,0.2-0.6,0.2h-1.2c-0.5,0-1,0-1.5-0.2c-0.5-0.1-1-0.3-1.4-0.6s-0.7-0.5-1.1-0.7s-0.6-0.4-0.7-0.6l-0.3-0.3 c-0.1-0.1-0.2-0.2-0.3-0.3s-0.4-0.5-0.7-0.9s-0.7-1-1.1-1.6c-0.4-0.6-0.8-1.3-1.3-2.2C2.9,9.4,2.5,8.5,2.1,7.5C2,7.4,2,7.3,2,7.2 c0-0.1,0-0.1,0-0.2l0-0.1c0.1-0.1,0.3-0.2,0.6-0.2l2.9,0c0.1,0,0.2,0,0.2,0.1S5.9,6.9,5.9,7L6,7c0.1,0.1,0.2,0.2,0.3,0.3 C6.4,7.7,6.5,8,6.7,8.4C6.9,8.8,7,9,7.1,9.2l0.2,0.3c0.2,0.4,0.4,0.8,0.6,1.1c0.2,0.3,0.4,0.5,0.5,0.7s0.3,0.3,0.4,0.4 c0.1,0.1,0.3,0.1,0.4,0.1c0.1,0,0.2,0,0.3-0.1c0,0,0,0,0.1-0.1c0,0,0.1-0.1,0.1-0.2c0.1-0.1,0.1-0.3,0.1-0.5c0-0.2,0.1-0.5,0.1-0.8 c0-0.4,0-0.8,0-1.3c0-0.3,0-0.5-0.1-0.8c0-0.2-0.1-0.4-0.1-0.5L9.6,7.6C9.4,7.3,9.1,7.2,8.7,7.1C8.6,7.1,8.6,7,8.7,6.9 C8.9,6.7,9,6.6,9.1,6.5c0.4-0.2,1.2-0.3,2.5-0.3c0.6,0,1,0.1,1.4,0.1c0.1,0,0.3,0.1,0.3,0.1c0.1,0.1,0.2,0.1,0.2,0.3 c0,0.1,0.1,0.2,0.1,0.3s0,0.3,0,0.5c0,0.2,0,0.4,0,0.6c0,0.2,0,0.4,0,0.7c0,0.3,0,0.6,0,0.9c0,0.1,0,0.2,0,0.4c0,0.2,0,0.4,0,0.5 c0,0.1,0,0.3,0,0.4s0.1,0.3,0.1,0.4c0.1,0.1,0.1,0.2,0.2,0.3c0.1,0,0.1,0,0.2,0c0.1,0,0.2,0,0.3-0.1c0.1-0.1,0.2-0.2,0.4-0.4 s0.3-0.4,0.5-0.7c0.2-0.3,0.5-0.7,0.7-1.1c0.4-0.7,0.8-1.5,1.1-2.3c0-0.1,0.1-0.1,0.1-0.2c0-0.1,0.1-0.1,0.1-0.1l0,0l0.1,0 c0,0,0,0,0.1,0s0.2,0,0.2,0l3,0c0.3,0,0.5,0,0.7,0S21.9,7,21.9,7L22,7.1z"
40937  }));
40938  
40939  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-link/icons/yelp.js
40940  
40941  
40942  /**
40943   * WordPress dependencies
40944   */
40945  
40946  const YelpIcon = () => (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
40947    width: "24",
40948    height: "24",
40949    viewBox: "0 0 24 24",
40950    version: "1.1"
40951  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
40952    d: "M12.271,16.718v1.417q-.011,3.257-.067,3.4a.707.707,0,0,1-.569.446,4.637,4.637,0,0,1-2.024-.424A4.609,4.609,0,0,1,7.8,20.565a.844.844,0,0,1-.19-.4.692.692,0,0,1,.044-.29,3.181,3.181,0,0,1,.379-.524q.335-.412,2.019-2.409.011,0,.669-.781a.757.757,0,0,1,.44-.274.965.965,0,0,1,.552.039.945.945,0,0,1,.418.324.732.732,0,0,1,.139.468Zm-1.662-2.8a.783.783,0,0,1-.58.781l-1.339.435q-3.067.981-3.257.981a.711.711,0,0,1-.6-.4,2.636,2.636,0,0,1-.19-.836,9.134,9.134,0,0,1,.011-1.857,3.559,3.559,0,0,1,.335-1.389.659.659,0,0,1,.625-.357,22.629,22.629,0,0,1,2.253.859q.781.324,1.283.524l.937.379a.771.771,0,0,1,.4.34A.982.982,0,0,1,10.609,13.917Zm9.213,3.313a4.467,4.467,0,0,1-1.021,1.8,4.559,4.559,0,0,1-1.512,1.417.671.671,0,0,1-.7-.078q-.156-.112-2.052-3.2l-.524-.859a.761.761,0,0,1-.128-.513.957.957,0,0,1,.217-.513.774.774,0,0,1,.926-.29q.011.011,1.327.446,2.264.736,2.7.887a2.082,2.082,0,0,1,.524.229.673.673,0,0,1,.245.68Zm-7.5-7.049q.056,1.137-.6,1.361-.647.19-1.272-.792L6.237,4.08a.7.7,0,0,1,.212-.691,5.788,5.788,0,0,1,2.314-1,5.928,5.928,0,0,1,2.5-.352.681.681,0,0,1,.547.5q.034.2.245,3.407T12.327,10.181Zm7.384,1.2a.679.679,0,0,1-.29.658q-.167.112-3.67.959-.747.167-1.015.257l.011-.022a.769.769,0,0,1-.513-.044.914.914,0,0,1-.413-.357.786.786,0,0,1,0-.971q.011-.011.836-1.137,1.394-1.908,1.673-2.275a2.423,2.423,0,0,1,.379-.435A.7.7,0,0,1,17.435,8a4.482,4.482,0,0,1,1.372,1.489,4.81,4.81,0,0,1,.9,1.868v.034Z"
40953  }));
40954  
40955  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-link/icons/youtube.js
40956  
40957  
40958  /**
40959   * WordPress dependencies
40960   */
40961  
40962  const YouTubeIcon = () => (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
40963    width: "24",
40964    height: "24",
40965    viewBox: "0 0 24 24",
40966    version: "1.1"
40967  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
40968    d: "M21.8,8.001c0,0-0.195-1.378-0.795-1.985c-0.76-0.797-1.613-0.801-2.004-0.847c-2.799-0.202-6.997-0.202-6.997-0.202 h-0.009c0,0-4.198,0-6.997,0.202C4.608,5.216,3.756,5.22,2.995,6.016C2.395,6.623,2.2,8.001,2.2,8.001S2,9.62,2,11.238v1.517 c0,1.618,0.2,3.237,0.2,3.237s0.195,1.378,0.795,1.985c0.761,0.797,1.76,0.771,2.205,0.855c1.6,0.153,6.8,0.201,6.8,0.201 s4.203-0.006,7.001-0.209c0.391-0.047,1.243-0.051,2.004-0.847c0.6-0.607,0.795-1.985,0.795-1.985s0.2-1.618,0.2-3.237v-1.517 C22,9.62,21.8,8.001,21.8,8.001z M9.935,14.594l-0.001-5.62l5.404,2.82L9.935,14.594z"
40969  }));
40970  
40971  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-link/variations.js
40972  /**
40973   * Internal dependencies
40974   */
40975  
40976  const social_link_variations_variations = [{
40977    isDefault: true,
40978    name: 'wordpress',
40979    attributes: {
40980      service: 'wordpress'
40981    },
40982    title: 'WordPress',
40983    icon: WordPressIcon
40984  }, {
40985    name: 'fivehundredpx',
40986    attributes: {
40987      service: 'fivehundredpx'
40988    },
40989    title: '500px',
40990    icon: FivehundredpxIcon
40991  }, {
40992    name: 'amazon',
40993    attributes: {
40994      service: 'amazon'
40995    },
40996    title: 'Amazon',
40997    icon: AmazonIcon
40998  }, {
40999    name: 'bandcamp',
41000    attributes: {
41001      service: 'bandcamp'
41002    },
41003    title: 'Bandcamp',
41004    icon: BandcampIcon
41005  }, {
41006    name: 'behance',
41007    attributes: {
41008      service: 'behance'
41009    },
41010    title: 'Behance',
41011    icon: BehanceIcon
41012  }, {
41013    name: 'chain',
41014    attributes: {
41015      service: 'chain'
41016    },
41017    title: 'Link',
41018    icon: ChainIcon
41019  }, {
41020    name: 'codepen',
41021    attributes: {
41022      service: 'codepen'
41023    },
41024    title: 'CodePen',
41025    icon: CodepenIcon
41026  }, {
41027    name: 'deviantart',
41028    attributes: {
41029      service: 'deviantart'
41030    },
41031    title: 'DeviantArt',
41032    icon: DeviantArtIcon
41033  }, {
41034    name: 'dribbble',
41035    attributes: {
41036      service: 'dribbble'
41037    },
41038    title: 'Dribbble',
41039    icon: DribbbleIcon
41040  }, {
41041    name: 'dropbox',
41042    attributes: {
41043      service: 'dropbox'
41044    },
41045    title: 'Dropbox',
41046    icon: DropboxIcon
41047  }, {
41048    name: 'etsy',
41049    attributes: {
41050      service: 'etsy'
41051    },
41052    title: 'Etsy',
41053    icon: EtsyIcon
41054  }, {
41055    name: 'facebook',
41056    attributes: {
41057      service: 'facebook'
41058    },
41059    title: 'Facebook',
41060    icon: FacebookIcon
41061  }, {
41062    name: 'feed',
41063    attributes: {
41064      service: 'feed'
41065    },
41066    title: 'RSS Feed',
41067    icon: FeedIcon
41068  }, {
41069    name: 'flickr',
41070    attributes: {
41071      service: 'flickr'
41072    },
41073    title: 'Flickr',
41074    icon: FlickrIcon
41075  }, {
41076    name: 'foursquare',
41077    attributes: {
41078      service: 'foursquare'
41079    },
41080    title: 'Foursquare',
41081    icon: FoursquareIcon
41082  }, {
41083    name: 'goodreads',
41084    attributes: {
41085      service: 'goodreads'
41086    },
41087    title: 'Goodreads',
41088    icon: GoodreadsIcon
41089  }, {
41090    name: 'google',
41091    attributes: {
41092      service: 'google'
41093    },
41094    title: 'Google',
41095    icon: GoogleIcon
41096  }, {
41097    name: 'github',
41098    attributes: {
41099      service: 'github'
41100    },
41101    title: 'GitHub',
41102    icon: GitHubIcon
41103  }, {
41104    name: 'instagram',
41105    attributes: {
41106      service: 'instagram'
41107    },
41108    title: 'Instagram',
41109    icon: InstagramIcon
41110  }, {
41111    name: 'lastfm',
41112    attributes: {
41113      service: 'lastfm'
41114    },
41115    title: 'Last.fm',
41116    icon: LastfmIcon
41117  }, {
41118    name: 'linkedin',
41119    attributes: {
41120      service: 'linkedin'
41121    },
41122    title: 'LinkedIn',
41123    icon: LinkedInIcon
41124  }, {
41125    name: 'mail',
41126    attributes: {
41127      service: 'mail'
41128    },
41129    title: 'Mail',
41130    keywords: ['email', 'e-mail'],
41131    icon: MailIcon
41132  }, {
41133    name: 'mastodon',
41134    attributes: {
41135      service: 'mastodon'
41136    },
41137    title: 'Mastodon',
41138    icon: MastodonIcon
41139  }, {
41140    name: 'meetup',
41141    attributes: {
41142      service: 'meetup'
41143    },
41144    title: 'Meetup',
41145    icon: MeetupIcon
41146  }, {
41147    name: 'medium',
41148    attributes: {
41149      service: 'medium'
41150    },
41151    title: 'Medium',
41152    icon: MediumIcon
41153  }, {
41154    name: 'patreon',
41155    attributes: {
41156      service: 'patreon'
41157    },
41158    title: 'Patreon',
41159    icon: PatreonIcon
41160  }, {
41161    name: 'pinterest',
41162    attributes: {
41163      service: 'pinterest'
41164    },
41165    title: 'Pinterest',
41166    icon: PinterestIcon
41167  }, {
41168    name: 'pocket',
41169    attributes: {
41170      service: 'pocket'
41171    },
41172    title: 'Pocket',
41173    icon: PocketIcon
41174  }, {
41175    name: 'reddit',
41176    attributes: {
41177      service: 'reddit'
41178    },
41179    title: 'Reddit',
41180    icon: RedditIcon
41181  }, {
41182    name: 'skype',
41183    attributes: {
41184      service: 'skype'
41185    },
41186    title: 'Skype',
41187    icon: SkypeIcon
41188  }, {
41189    name: 'snapchat',
41190    attributes: {
41191      service: 'snapchat'
41192    },
41193    title: 'Snapchat',
41194    icon: SnapchatIcon
41195  }, {
41196    name: 'soundcloud',
41197    attributes: {
41198      service: 'soundcloud'
41199    },
41200    title: 'SoundCloud',
41201    icon: SoundCloudIcon
41202  }, {
41203    name: 'spotify',
41204    attributes: {
41205      service: 'spotify'
41206    },
41207    title: 'Spotify',
41208    icon: SpotifyIcon
41209  }, {
41210    name: 'telegram',
41211    attributes: {
41212      service: 'telegram'
41213    },
41214    title: 'Telegram',
41215    icon: TelegramIcon
41216  }, {
41217    name: 'tiktok',
41218    attributes: {
41219      service: 'tiktok'
41220    },
41221    title: 'TikTok',
41222    icon: TiktokIcon
41223  }, {
41224    name: 'tumblr',
41225    attributes: {
41226      service: 'tumblr'
41227    },
41228    title: 'Tumblr',
41229    icon: TumblrIcon
41230  }, {
41231    name: 'twitch',
41232    attributes: {
41233      service: 'twitch'
41234    },
41235    title: 'Twitch',
41236    icon: TwitchIcon
41237  }, {
41238    name: 'twitter',
41239    attributes: {
41240      service: 'twitter'
41241    },
41242    title: 'Twitter',
41243    icon: TwitterIcon
41244  }, {
41245    name: 'vimeo',
41246    attributes: {
41247      service: 'vimeo'
41248    },
41249    title: 'Vimeo',
41250    icon: VimeoIcon
41251  }, {
41252    name: 'vk',
41253    attributes: {
41254      service: 'vk'
41255    },
41256    title: 'VK',
41257    icon: VkIcon
41258  }, {
41259    name: 'yelp',
41260    attributes: {
41261      service: 'yelp'
41262    },
41263    title: 'Yelp',
41264    icon: YelpIcon
41265  }, {
41266    name: 'youtube',
41267    attributes: {
41268      service: 'youtube'
41269    },
41270    title: 'YouTube',
41271    icon: YouTubeIcon
41272  }];
41273  /**
41274   * Add `isActive` function to all `social link` variations, if not defined.
41275   * `isActive` function is used to find a variation match from a created
41276   *  Block by providing its attributes.
41277   */
41278  
41279  social_link_variations_variations.forEach(variation => {
41280    if (variation.isActive) return;
41281  
41282    variation.isActive = (blockAttributes, variationAttributes) => blockAttributes.service === variationAttributes.service;
41283  });
41284  /* harmony default export */ var social_link_variations = (social_link_variations_variations);
41285  
41286  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-link/social-list.js
41287  /**
41288   * External dependencies
41289   */
41290  
41291  /**
41292   * WordPress dependencies
41293   */
41294  
41295  
41296  /**
41297   * Internal dependencies
41298   */
41299  
41300  
41301  
41302  /**
41303   * Retrieves the social service's icon component.
41304   *
41305   * @param {string} name key for a social service (lowercase slug)
41306   *
41307   * @return {WPComponent} Icon component for social service.
41308   */
41309  
41310  const getIconBySite = name => {
41311    const variation = (0,external_lodash_namespaceObject.find)(social_link_variations, {
41312      name
41313    });
41314    return variation ? variation.icon : ChainIcon;
41315  };
41316  /**
41317   * Retrieves the display name for the social service.
41318   *
41319   * @param {string} name key for a social service (lowercase slug)
41320   *
41321   * @return {string} Display name for social service
41322   */
41323  
41324  const getNameBySite = name => {
41325    const variation = (0,external_lodash_namespaceObject.find)(social_link_variations, {
41326      name
41327    });
41328    return variation ? variation.title : (0,external_wp_i18n_namespaceObject.__)('Social Icon');
41329  };
41330  
41331  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-link/edit.js
41332  
41333  
41334  /**
41335   * External dependencies
41336   */
41337  
41338  /**
41339   * WordPress dependencies
41340   */
41341  
41342  
41343  
41344  
41345  
41346  
41347  /**
41348   * Internal dependencies
41349   */
41350  
41351  
41352  
41353  const SocialLinkURLPopover = _ref => {
41354    let {
41355      url,
41356      setAttributes,
41357      setPopover,
41358      anchorRef
41359    } = _ref;
41360    return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.URLPopover, {
41361      anchorRef: anchorRef === null || anchorRef === void 0 ? void 0 : anchorRef.current,
41362      onClose: () => setPopover(false)
41363    }, (0,external_wp_element_namespaceObject.createElement)("form", {
41364      className: "block-editor-url-popover__link-editor",
41365      onSubmit: event => {
41366        event.preventDefault();
41367        setPopover(false);
41368      }
41369    }, (0,external_wp_element_namespaceObject.createElement)("div", {
41370      className: "block-editor-url-input"
41371    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.URLInput, {
41372      value: url,
41373      onChange: nextURL => setAttributes({
41374        url: nextURL
41375      }),
41376      placeholder: (0,external_wp_i18n_namespaceObject.__)('Enter address'),
41377      disableSuggestions: true
41378    })), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
41379      icon: keyboard_return,
41380      label: (0,external_wp_i18n_namespaceObject.__)('Apply'),
41381      type: "submit"
41382    })));
41383  };
41384  
41385  const SocialLinkEdit = _ref2 => {
41386    let {
41387      attributes,
41388      context,
41389      isSelected,
41390      setAttributes
41391    } = _ref2;
41392    const {
41393      url,
41394      service,
41395      label
41396    } = attributes;
41397    const {
41398      showLabels,
41399      iconColorValue,
41400      iconBackgroundColorValue
41401    } = context;
41402    const [showURLPopover, setPopover] = (0,external_wp_element_namespaceObject.useState)(false);
41403    const classes = classnames_default()('wp-social-link', 'wp-social-link-' + service, {
41404      'wp-social-link__is-incomplete': !url
41405    });
41406    const ref = (0,external_wp_element_namespaceObject.useRef)();
41407    const IconComponent = getIconBySite(service);
41408    const socialLinkName = getNameBySite(service);
41409    const socialLinkLabel = label !== null && label !== void 0 ? label : socialLinkName;
41410    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
41411      className: classes,
41412      style: {
41413        color: iconColorValue,
41414        backgroundColor: iconBackgroundColorValue
41415      }
41416    });
41417    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
41418      title: (0,external_wp_i18n_namespaceObject.sprintf)(
41419      /* translators: %s: name of the social service. */
41420      (0,external_wp_i18n_namespaceObject.__)('%s label'), socialLinkName),
41421      initialOpen: false
41422    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelRow, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TextControl, {
41423      label: (0,external_wp_i18n_namespaceObject.__)('Link label'),
41424      help: (0,external_wp_i18n_namespaceObject.__)('Briefly describe the link to help screen reader users.'),
41425      value: label,
41426      onChange: value => setAttributes({
41427        label: value
41428      })
41429    })))), (0,external_wp_element_namespaceObject.createElement)("li", blockProps, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
41430      className: "wp-block-social-link-anchor",
41431      ref: ref,
41432      onClick: () => setPopover(true)
41433    }, (0,external_wp_element_namespaceObject.createElement)(IconComponent, null), (0,external_wp_element_namespaceObject.createElement)("span", {
41434      className: classnames_default()('wp-block-social-link-label', {
41435        'screen-reader-text': !showLabels
41436      })
41437    }, socialLinkLabel), isSelected && showURLPopover && (0,external_wp_element_namespaceObject.createElement)(SocialLinkURLPopover, {
41438      url: url,
41439      setAttributes: setAttributes,
41440      setPopover: setPopover,
41441      anchorRef: ref
41442    }))));
41443  };
41444  
41445  /* harmony default export */ var social_link_edit = (SocialLinkEdit);
41446  
41447  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-link/index.js
41448  /**
41449   * WordPress dependencies
41450   */
41451  
41452  /**
41453   * Internal dependencies
41454   */
41455  
41456  
41457  const social_link_metadata = {
41458    $schema: "https://schemas.wp.org/trunk/block.json",
41459    apiVersion: 2,
41460    name: "core/social-link",
41461    title: "Social Icon",
41462    category: "widgets",
41463    parent: ["core/social-links"],
41464    description: "Display an icon linking to a social media profile or site.",
41465    textdomain: "default",
41466    attributes: {
41467      url: {
41468        type: "string"
41469      },
41470      service: {
41471        type: "string"
41472      },
41473      label: {
41474        type: "string"
41475      }
41476    },
41477    usesContext: ["openInNewTab", "showLabels", "iconColorValue", "iconBackgroundColorValue"],
41478    supports: {
41479      reusable: false,
41480      html: false
41481    },
41482    editorStyle: "wp-block-social-link-editor"
41483  };
41484  
41485  const {
41486    name: social_link_name
41487  } = social_link_metadata;
41488  
41489  const social_link_settings = {
41490    icon: library_share,
41491    edit: social_link_edit,
41492    variations: social_link_variations
41493  };
41494  
41495  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-links/deprecated.js
41496  
41497  
41498  /**
41499   * External dependencies
41500   */
41501  
41502  /**
41503   * WordPress dependencies
41504   */
41505  
41506  
41507  /**
41508   * The specific handling by `className` below is needed because `itemsJustification`
41509   * was introduced in https://github.com/WordPress/gutenberg/pull/28980/files and wasn't
41510   * declared in block.json.
41511   *
41512   * @param {Object} attributes Block's attributes.
41513   */
41514  
41515  const social_links_deprecated_migrateWithLayout = attributes => {
41516    var _className$match, _className$match$;
41517  
41518    if (!!attributes.layout) {
41519      return attributes;
41520    }
41521  
41522    const {
41523      className
41524    } = attributes; // Matches classes with `items-justified-` prefix.
41525  
41526    const prefix = `items-justified-`;
41527    const justifiedItemsRegex = new RegExp(`\\b$prefix}[^ ]*[ ]?\\b`, 'g');
41528    const newAttributes = { ...attributes,
41529      className: className === null || className === void 0 ? void 0 : className.replace(justifiedItemsRegex, '').trim()
41530    };
41531    /**
41532     * Add `layout` prop only if `justifyContent` is defined, for backwards
41533     * compatibility. In other cases the block's default layout will be used.
41534     * Also noting that due to the missing attribute, it's possible for a block
41535     * to have more than one of `justified` classes.
41536     */
41537  
41538    const justifyContent = className === null || className === void 0 ? void 0 : (_className$match = className.match(justifiedItemsRegex)) === null || _className$match === void 0 ? void 0 : (_className$match$ = _className$match[0]) === null || _className$match$ === void 0 ? void 0 : _className$match$.trim();
41539  
41540    if (justifyContent) {
41541      Object.assign(newAttributes, {
41542        layout: {
41543          type: 'flex',
41544          justifyContent: justifyContent.slice(prefix.length)
41545        }
41546      });
41547    }
41548  
41549    return newAttributes;
41550  }; // Social Links block deprecations.
41551  
41552  
41553  const social_links_deprecated_deprecated = [// V1. Remove CSS variable use for colors.
41554  {
41555    attributes: {
41556      iconColor: {
41557        type: 'string'
41558      },
41559      customIconColor: {
41560        type: 'string'
41561      },
41562      iconColorValue: {
41563        type: 'string'
41564      },
41565      iconBackgroundColor: {
41566        type: 'string'
41567      },
41568      customIconBackgroundColor: {
41569        type: 'string'
41570      },
41571      iconBackgroundColorValue: {
41572        type: 'string'
41573      },
41574      openInNewTab: {
41575        type: 'boolean',
41576        default: false
41577      },
41578      size: {
41579        type: 'string'
41580      }
41581    },
41582    providesContext: {
41583      openInNewTab: 'openInNewTab'
41584    },
41585    supports: {
41586      align: ['left', 'center', 'right'],
41587      anchor: true
41588    },
41589    migrate: social_links_deprecated_migrateWithLayout,
41590    save: props => {
41591      const {
41592        attributes: {
41593          iconBackgroundColorValue,
41594          iconColorValue,
41595          itemsJustification,
41596          size
41597        }
41598      } = props;
41599      const className = classnames_default()(size, {
41600        'has-icon-color': iconColorValue,
41601        'has-icon-background-color': iconBackgroundColorValue,
41602        [`items-justified-$itemsJustification}`]: itemsJustification
41603      });
41604      const style = {
41605        '--wp--social-links--icon-color': iconColorValue,
41606        '--wp--social-links--icon-background-color': iconBackgroundColorValue
41607      };
41608      return (0,external_wp_element_namespaceObject.createElement)("ul", external_wp_blockEditor_namespaceObject.useBlockProps.save({
41609        className,
41610        style
41611      }), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InnerBlocks.Content, null));
41612    }
41613  }];
41614  /* harmony default export */ var social_links_deprecated = (social_links_deprecated_deprecated);
41615  
41616  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/check.js
41617  
41618  
41619  /**
41620   * WordPress dependencies
41621   */
41622  
41623  const check = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
41624    xmlns: "http://www.w3.org/2000/svg",
41625    viewBox: "0 0 24 24"
41626  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
41627    d: "M16.7 7.1l-6.3 8.5-3.3-2.5-.9 1.2 4.5 3.4L17.9 8z"
41628  }));
41629  /* harmony default export */ var library_check = (check);
41630  
41631  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-links/edit.js
41632  
41633  
41634  /**
41635   * External dependencies
41636   */
41637  
41638  /**
41639   * WordPress dependencies
41640   */
41641  
41642  
41643  
41644  
41645  
41646  
41647  
41648  const social_links_edit_ALLOWED_BLOCKS = ['core/social-link'];
41649  const sizeOptions = [{
41650    name: (0,external_wp_i18n_namespaceObject.__)('Small'),
41651    value: 'has-small-icon-size'
41652  }, {
41653    name: (0,external_wp_i18n_namespaceObject.__)('Normal'),
41654    value: 'has-normal-icon-size'
41655  }, {
41656    name: (0,external_wp_i18n_namespaceObject.__)('Large'),
41657    value: 'has-large-icon-size'
41658  }, {
41659    name: (0,external_wp_i18n_namespaceObject.__)('Huge'),
41660    value: 'has-huge-icon-size'
41661  }];
41662  
41663  const social_links_edit_getDefaultBlockLayout = blockTypeOrName => {
41664    const layoutBlockSupportConfig = (0,external_wp_blocks_namespaceObject.getBlockSupport)(blockTypeOrName, '__experimentalLayout');
41665    return layoutBlockSupportConfig === null || layoutBlockSupportConfig === void 0 ? void 0 : layoutBlockSupportConfig.default;
41666  };
41667  
41668  function SocialLinksEdit(props) {
41669    var _attributes$className;
41670  
41671    const {
41672      name,
41673      attributes,
41674      iconBackgroundColor,
41675      iconColor,
41676      isSelected,
41677      setAttributes,
41678      setIconBackgroundColor,
41679      setIconColor
41680    } = props;
41681    const {
41682      iconBackgroundColorValue,
41683      customIconBackgroundColor,
41684      iconColorValue,
41685      openInNewTab,
41686      showLabels,
41687      size,
41688      layout
41689    } = attributes;
41690    const usedLayout = layout || social_links_edit_getDefaultBlockLayout(name);
41691    const logosOnly = (_attributes$className = attributes.className) === null || _attributes$className === void 0 ? void 0 : _attributes$className.includes('is-style-logos-only'); // Remove icon background color when logos only style is selected or
41692    // restore it when any other style is selected.
41693  
41694    const backgroundBackup = (0,external_wp_element_namespaceObject.useRef)({});
41695    (0,external_wp_element_namespaceObject.useEffect)(() => {
41696      if (logosOnly) {
41697        backgroundBackup.current = {
41698          iconBackgroundColor,
41699          iconBackgroundColorValue,
41700          customIconBackgroundColor
41701        };
41702        setAttributes({
41703          iconBackgroundColor: undefined,
41704          customIconBackgroundColor: undefined,
41705          iconBackgroundColorValue: undefined
41706        });
41707      } else {
41708        setAttributes({ ...backgroundBackup.current
41709        });
41710      }
41711    }, [logosOnly]);
41712    const SocialPlaceholder = (0,external_wp_element_namespaceObject.createElement)("li", {
41713      className: "wp-block-social-links__social-placeholder"
41714    }, (0,external_wp_element_namespaceObject.createElement)("div", {
41715      className: "wp-block-social-links__social-placeholder-icons"
41716    }, (0,external_wp_element_namespaceObject.createElement)("div", {
41717      className: "wp-social-link wp-social-link-twitter"
41718    }), (0,external_wp_element_namespaceObject.createElement)("div", {
41719      className: "wp-social-link wp-social-link-facebook"
41720    }), (0,external_wp_element_namespaceObject.createElement)("div", {
41721      className: "wp-social-link wp-social-link-instagram"
41722    })));
41723    const SelectedSocialPlaceholder = (0,external_wp_element_namespaceObject.createElement)("li", {
41724      className: "wp-block-social-links__social-prompt"
41725    }, (0,external_wp_i18n_namespaceObject.__)('Click plus to add')); // Fallback color values are used maintain selections in case switching
41726    // themes and named colors in palette do not match.
41727  
41728    const className = classnames_default()(size, {
41729      'has-icon-color': iconColor.color || iconColorValue,
41730      'has-icon-background-color': iconBackgroundColor.color || iconBackgroundColorValue
41731    });
41732    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
41733      className
41734    });
41735    const innerBlocksProps = (0,external_wp_blockEditor_namespaceObject.useInnerBlocksProps)(blockProps, {
41736      allowedBlocks: social_links_edit_ALLOWED_BLOCKS,
41737      placeholder: isSelected ? SelectedSocialPlaceholder : SocialPlaceholder,
41738      templateLock: false,
41739      __experimentalAppenderTagName: 'li',
41740      __experimentalLayout: usedLayout
41741    });
41742    const POPOVER_PROPS = {
41743      position: 'bottom right'
41744    };
41745    const colorSettings = [{
41746      // Use custom attribute as fallback to prevent loss of named color selection when
41747      // switching themes to a new theme that does not have a matching named color.
41748      value: iconColor.color || iconColorValue,
41749      onChange: colorValue => {
41750        setIconColor(colorValue);
41751        setAttributes({
41752          iconColorValue: colorValue
41753        });
41754      },
41755      label: (0,external_wp_i18n_namespaceObject.__)('Icon color')
41756    }];
41757  
41758    if (!logosOnly) {
41759      colorSettings.push({
41760        // Use custom attribute as fallback to prevent loss of named color selection when
41761        // switching themes to a new theme that does not have a matching named color.
41762        value: iconBackgroundColor.color || iconBackgroundColorValue,
41763        onChange: colorValue => {
41764          setIconBackgroundColor(colorValue);
41765          setAttributes({
41766            iconBackgroundColorValue: colorValue
41767          });
41768        },
41769        label: (0,external_wp_i18n_namespaceObject.__)('Icon background')
41770      });
41771    }
41772  
41773    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, {
41774      group: "other"
41775    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarDropdownMenu, {
41776      label: (0,external_wp_i18n_namespaceObject.__)('Size'),
41777      text: (0,external_wp_i18n_namespaceObject.__)('Size'),
41778      icon: null,
41779      popoverProps: POPOVER_PROPS
41780    }, _ref => {
41781      let {
41782        onClose
41783      } = _ref;
41784      return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuGroup, null, sizeOptions.map(entry => {
41785        return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, {
41786          icon: (size === entry.value || !size && entry.value === 'has-normal-icon-size') && library_check,
41787          isSelected: size === entry.value,
41788          key: entry.value,
41789          onClick: () => {
41790            setAttributes({
41791              size: entry.value
41792            });
41793          },
41794          onClose: onClose,
41795          role: "menuitemradio"
41796        }, entry.name);
41797      }));
41798    })), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
41799      title: (0,external_wp_i18n_namespaceObject.__)('Link settings')
41800    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
41801      label: (0,external_wp_i18n_namespaceObject.__)('Open links in new tab'),
41802      checked: openInNewTab,
41803      onChange: () => setAttributes({
41804        openInNewTab: !openInNewTab
41805      })
41806    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
41807      label: (0,external_wp_i18n_namespaceObject.__)('Show labels'),
41808      checked: showLabels,
41809      onChange: () => setAttributes({
41810        showLabels: !showLabels
41811      })
41812    })), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.PanelColorSettings, {
41813      __experimentalHasMultipleOrigins: true,
41814      __experimentalIsRenderedInSidebar: true,
41815      title: (0,external_wp_i18n_namespaceObject.__)('Color'),
41816      colorSettings: colorSettings
41817    }), !logosOnly && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.ContrastChecker, {
41818      textColor: iconColorValue,
41819      backgroundColor: iconBackgroundColorValue,
41820      isLargeText: false
41821    })), (0,external_wp_element_namespaceObject.createElement)("ul", innerBlocksProps));
41822  }
41823  const iconColorAttributes = {
41824    iconColor: 'icon-color',
41825    iconBackgroundColor: 'icon-background-color'
41826  };
41827  /* harmony default export */ var social_links_edit = ((0,external_wp_blockEditor_namespaceObject.withColors)(iconColorAttributes)(SocialLinksEdit));
41828  
41829  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-links/save.js
41830  
41831  
41832  /**
41833   * External dependencies
41834   */
41835  
41836  /**
41837   * WordPress dependencies
41838   */
41839  
41840  
41841  function social_links_save_save(props) {
41842    const {
41843      attributes: {
41844        iconBackgroundColorValue,
41845        iconColorValue,
41846        showLabels,
41847        size
41848      }
41849    } = props;
41850    const className = classnames_default()(size, {
41851      'has-visible-labels': showLabels,
41852      'has-icon-color': iconColorValue,
41853      'has-icon-background-color': iconBackgroundColorValue
41854    });
41855    const blockProps = external_wp_blockEditor_namespaceObject.useBlockProps.save({
41856      className
41857    });
41858    const innerBlocksProps = external_wp_blockEditor_namespaceObject.useInnerBlocksProps.save(blockProps);
41859    return (0,external_wp_element_namespaceObject.createElement)("ul", innerBlocksProps);
41860  }
41861  
41862  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/social-links/index.js
41863  /**
41864   * WordPress dependencies
41865   */
41866  
41867  /**
41868   * Internal dependencies
41869   */
41870  
41871  
41872  
41873  const social_links_metadata = {
41874    $schema: "https://schemas.wp.org/trunk/block.json",
41875    apiVersion: 2,
41876    name: "core/social-links",
41877    title: "Social Icons",
41878    category: "widgets",
41879    description: "Display icons linking to your social media profiles or sites.",
41880    keywords: ["links"],
41881    textdomain: "default",
41882    attributes: {
41883      iconColor: {
41884        type: "string"
41885      },
41886      customIconColor: {
41887        type: "string"
41888      },
41889      iconColorValue: {
41890        type: "string"
41891      },
41892      iconBackgroundColor: {
41893        type: "string"
41894      },
41895      customIconBackgroundColor: {
41896        type: "string"
41897      },
41898      iconBackgroundColorValue: {
41899        type: "string"
41900      },
41901      openInNewTab: {
41902        type: "boolean",
41903        "default": false
41904      },
41905      showLabels: {
41906        type: "boolean",
41907        "default": false
41908      },
41909      size: {
41910        type: "string"
41911      }
41912    },
41913    providesContext: {
41914      openInNewTab: "openInNewTab",
41915      showLabels: "showLabels",
41916      iconColorValue: "iconColorValue",
41917      iconBackgroundColorValue: "iconBackgroundColorValue"
41918    },
41919    supports: {
41920      align: ["left", "center", "right"],
41921      anchor: true,
41922      __experimentalExposeControlsToChildren: true,
41923      __experimentalLayout: {
41924        allowSwitching: false,
41925        allowInheriting: false,
41926        allowVerticalAlignment: false,
41927        "default": {
41928          type: "flex"
41929        }
41930      },
41931      spacing: {
41932        blockGap: ["horizontal", "vertical"],
41933        margin: ["top", "bottom"],
41934        units: ["px", "em", "rem", "vh", "vw"],
41935        __experimentalDefaultControls: {
41936          blockGap: true
41937        }
41938      }
41939    },
41940    styles: [{
41941      name: "default",
41942      label: "Default",
41943      isDefault: true
41944    }, {
41945      name: "logos-only",
41946      label: "Logos Only"
41947    }, {
41948      name: "pill-shape",
41949      label: "Pill Shape"
41950    }],
41951    editorStyle: "wp-block-social-links-editor",
41952    style: "wp-block-social-links"
41953  };
41954  
41955  const {
41956    name: social_links_name
41957  } = social_links_metadata;
41958  
41959  const social_links_settings = {
41960    example: {
41961      innerBlocks: [{
41962        name: 'core/social-link',
41963        attributes: {
41964          service: 'wordpress',
41965          url: 'https://wordpress.org'
41966        }
41967      }, {
41968        name: 'core/social-link',
41969        attributes: {
41970          service: 'facebook',
41971          url: 'https://www.facebook.com/WordPress/'
41972        }
41973      }, {
41974        name: 'core/social-link',
41975        attributes: {
41976          service: 'twitter',
41977          url: 'https://twitter.com/WordPress'
41978        }
41979      }]
41980    },
41981    icon: library_share,
41982    edit: social_links_edit,
41983    save: social_links_save_save,
41984    deprecated: social_links_deprecated
41985  };
41986  
41987  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/resize-corner-n-e.js
41988  
41989  
41990  /**
41991   * WordPress dependencies
41992   */
41993  
41994  const resizeCornerNE = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
41995    viewBox: "0 0 24 24",
41996    xmlns: "http://www.w3.org/2000/svg"
41997  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
41998    d: "M12.5 4.2v1.6h4.7L5.8 17.2V12H4.2v7.8H12v-1.6H6.8L18.2 6.8v4.7h1.6V4.2z"
41999  }));
42000  /* harmony default export */ var resize_corner_n_e = (resizeCornerNE);
42001  
42002  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/spacer/deprecated.js
42003  
42004  
42005  /**
42006   * WordPress dependencies
42007   */
42008  
42009  const spacer_deprecated_deprecated = [{
42010    attributes: {
42011      height: {
42012        type: 'number',
42013        default: 100
42014      },
42015      width: {
42016        type: 'number'
42017      }
42018    },
42019  
42020    migrate(attributes) {
42021      const {
42022        height,
42023        width
42024      } = attributes;
42025      return { ...attributes,
42026        width: width !== undefined ? `$width}px` : undefined,
42027        height: height !== undefined ? `$height}px` : undefined
42028      };
42029    },
42030  
42031    save(_ref) {
42032      let {
42033        attributes
42034      } = _ref;
42035      return (0,external_wp_element_namespaceObject.createElement)("div", external_wp_blockEditor_namespaceObject.useBlockProps.save({
42036        style: {
42037          height: attributes.height,
42038          width: attributes.width
42039        },
42040        'aria-hidden': true
42041      }));
42042    }
42043  
42044  }];
42045  /* harmony default export */ var spacer_deprecated = (spacer_deprecated_deprecated);
42046  
42047  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/spacer/controls.js
42048  
42049  
42050  /**
42051   * WordPress dependencies
42052   */
42053  
42054  
42055  
42056  
42057  /**
42058   * Internal dependencies
42059   */
42060  
42061  
42062  
42063  function DimensionInput(_ref) {
42064    var _ref2;
42065  
42066    let {
42067      label,
42068      onChange,
42069      isResizing,
42070      value = ''
42071    } = _ref;
42072    const inputId = (0,external_wp_compose_namespaceObject.useInstanceId)(external_wp_components_namespaceObject.__experimentalUnitControl, 'block-spacer-height-input'); // In most contexts the spacer size cannot meaningfully be set to a
42073    // percentage, since this is relative to the parent container. This
42074    // unit is disabled from the UI.
42075  
42076    const availableUnitSettings = (_ref2 = (0,external_wp_blockEditor_namespaceObject.useSetting)('spacing.units') || undefined) === null || _ref2 === void 0 ? void 0 : _ref2.filter(availableUnit => availableUnit !== '%');
42077    const units = (0,external_wp_components_namespaceObject.__experimentalUseCustomUnits)({
42078      availableUnits: availableUnitSettings || ['px', 'em', 'rem', 'vw', 'vh'],
42079      defaultValues: {
42080        px: 100,
42081        em: 10,
42082        rem: 10,
42083        vw: 10,
42084        vh: 25
42085      }
42086    });
42087  
42088    const handleOnChange = unprocessedValue => {
42089      onChange(unprocessedValue);
42090    }; // Force the unit to update to `px` when the Spacer is being resized.
42091  
42092  
42093    const [parsedQuantity, parsedUnit] = (0,external_wp_components_namespaceObject.__experimentalParseQuantityAndUnitFromRawValue)(value);
42094    const computedValue = [parsedQuantity, isResizing ? 'px' : parsedUnit].join('');
42095    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.BaseControl, {
42096      label: label,
42097      id: inputId
42098    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalUnitControl, {
42099      id: inputId,
42100      isResetValueOnUnitChange: true,
42101      min: MIN_SPACER_SIZE,
42102      onChange: handleOnChange,
42103      style: {
42104        maxWidth: 80
42105      },
42106      value: computedValue,
42107      units: units
42108    }));
42109  }
42110  
42111  function SpacerControls(_ref3) {
42112    let {
42113      setAttributes,
42114      orientation,
42115      height,
42116      width,
42117      isResizing
42118    } = _ref3;
42119    return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
42120      title: (0,external_wp_i18n_namespaceObject.__)('Spacer settings')
42121    }, orientation === 'horizontal' && (0,external_wp_element_namespaceObject.createElement)(DimensionInput, {
42122      label: (0,external_wp_i18n_namespaceObject.__)('Width'),
42123      value: width,
42124      onChange: nextWidth => setAttributes({
42125        width: nextWidth
42126      }),
42127      isResizing: isResizing
42128    }), orientation !== 'horizontal' && (0,external_wp_element_namespaceObject.createElement)(DimensionInput, {
42129      label: (0,external_wp_i18n_namespaceObject.__)('Height'),
42130      value: height,
42131      onChange: nextHeight => setAttributes({
42132        height: nextHeight
42133      }),
42134      isResizing: isResizing
42135    })));
42136  }
42137  
42138  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/spacer/edit.js
42139  
42140  
42141  
42142  /**
42143   * External dependencies
42144   */
42145  
42146  /**
42147   * WordPress dependencies
42148   */
42149  
42150  
42151  
42152  
42153  
42154  /**
42155   * Internal dependencies
42156   */
42157  
42158  
42159  const MIN_SPACER_SIZE = 0;
42160  
42161  const ResizableSpacer = _ref => {
42162    let {
42163      orientation,
42164      onResizeStart,
42165      onResize,
42166      onResizeStop,
42167      isSelected,
42168      isResizing,
42169      setIsResizing,
42170      ...props
42171    } = _ref;
42172  
42173    const getCurrentSize = elt => {
42174      return orientation === 'horizontal' ? elt.clientWidth : elt.clientHeight;
42175    };
42176  
42177    const getNextVal = elt => {
42178      return `$getCurrentSize(elt)}px`;
42179    };
42180  
42181    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ResizableBox, _extends({
42182      className: classnames_default()('block-library-spacer__resize-container', {
42183        'resize-horizontal': orientation === 'horizontal',
42184        'is-resizing': isResizing,
42185        'is-selected': isSelected
42186      }),
42187      onResizeStart: (_event, _direction, elt) => {
42188        const nextVal = getNextVal(elt);
42189        onResizeStart(nextVal);
42190        onResize(nextVal);
42191      },
42192      onResize: (_event, _direction, elt) => {
42193        onResize(getNextVal(elt));
42194  
42195        if (!isResizing) {
42196          setIsResizing(true);
42197        }
42198      },
42199      onResizeStop: (_event, _direction, elt) => {
42200        const nextVal = getCurrentSize(elt);
42201        onResizeStop(`$nextVal}px`);
42202        setIsResizing(false);
42203      },
42204      __experimentalShowTooltip: true,
42205      __experimentalTooltipProps: {
42206        axis: orientation === 'horizontal' ? 'x' : 'y',
42207        position: 'corner',
42208        isVisible: isResizing
42209      },
42210      showHandle: isSelected
42211    }, props));
42212  };
42213  
42214  const SpacerEdit = _ref2 => {
42215    let {
42216      attributes,
42217      isSelected,
42218      setAttributes,
42219      toggleSelection,
42220      context
42221    } = _ref2;
42222    const {
42223      orientation
42224    } = context;
42225    const {
42226      height,
42227      width
42228    } = attributes;
42229    const [isResizing, setIsResizing] = (0,external_wp_element_namespaceObject.useState)(false);
42230    const [temporaryHeight, setTemporaryHeight] = (0,external_wp_element_namespaceObject.useState)(null);
42231    const [temporaryWidth, setTemporaryWidth] = (0,external_wp_element_namespaceObject.useState)(null);
42232  
42233    const onResizeStart = () => toggleSelection(false);
42234  
42235    const onResizeStop = () => toggleSelection(true);
42236  
42237    const handleOnVerticalResizeStop = newHeight => {
42238      onResizeStop();
42239      setAttributes({
42240        height: newHeight
42241      });
42242      setTemporaryHeight(null);
42243    };
42244  
42245    const handleOnHorizontalResizeStop = newWidth => {
42246      onResizeStop();
42247      setAttributes({
42248        width: newWidth
42249      });
42250      setTemporaryWidth(null);
42251    };
42252  
42253    const style = {
42254      height: orientation === 'horizontal' ? 24 : temporaryHeight || height || undefined,
42255      width: orientation === 'horizontal' ? temporaryWidth || width || undefined : undefined
42256    };
42257  
42258    const resizableBoxWithOrientation = blockOrientation => {
42259      if (blockOrientation === 'horizontal') {
42260        return (0,external_wp_element_namespaceObject.createElement)(ResizableSpacer, {
42261          minWidth: MIN_SPACER_SIZE,
42262          enable: {
42263            top: false,
42264            right: true,
42265            bottom: false,
42266            left: false,
42267            topRight: false,
42268            bottomRight: false,
42269            bottomLeft: false,
42270            topLeft: false
42271          },
42272          orientation: blockOrientation,
42273          onResizeStart: onResizeStart,
42274          onResize: setTemporaryWidth,
42275          onResizeStop: handleOnHorizontalResizeStop,
42276          isSelected: isSelected,
42277          isResizing: isResizing,
42278          setIsResizing: setIsResizing
42279        });
42280      }
42281  
42282      return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(ResizableSpacer, {
42283        minHeight: MIN_SPACER_SIZE,
42284        enable: {
42285          top: false,
42286          right: false,
42287          bottom: true,
42288          left: false,
42289          topRight: false,
42290          bottomRight: false,
42291          bottomLeft: false,
42292          topLeft: false
42293        },
42294        orientation: blockOrientation,
42295        onResizeStart: onResizeStart,
42296        onResize: setTemporaryHeight,
42297        onResizeStop: handleOnVerticalResizeStop,
42298        isSelected: isSelected,
42299        isResizing: isResizing,
42300        setIsResizing: setIsResizing
42301      }));
42302    };
42303  
42304    (0,external_wp_element_namespaceObject.useEffect)(() => {
42305      if (orientation === 'horizontal' && !width) {
42306        setAttributes({
42307          height: '0px',
42308          width: '72px'
42309        });
42310      }
42311    }, []);
42312    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.View, (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
42313      style
42314    }), resizableBoxWithOrientation(orientation)), (0,external_wp_element_namespaceObject.createElement)(SpacerControls, {
42315      setAttributes: setAttributes,
42316      height: temporaryHeight || height,
42317      width: temporaryWidth || width,
42318      orientation: orientation,
42319      isResizing: isResizing
42320    }));
42321  };
42322  
42323  /* harmony default export */ var spacer_edit = (SpacerEdit);
42324  
42325  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/spacer/save.js
42326  
42327  
42328  /**
42329   * WordPress dependencies
42330   */
42331  
42332  function spacer_save_save(_ref) {
42333    let {
42334      attributes: {
42335        height,
42336        width
42337      }
42338    } = _ref;
42339    return (0,external_wp_element_namespaceObject.createElement)("div", external_wp_blockEditor_namespaceObject.useBlockProps.save({
42340      style: {
42341        height,
42342        width
42343      },
42344      'aria-hidden': true
42345    }));
42346  }
42347  
42348  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/spacer/index.js
42349  /**
42350   * WordPress dependencies
42351   */
42352  
42353  /**
42354   * Internal dependencies
42355   */
42356  
42357  
42358  
42359  const spacer_metadata = {
42360    $schema: "https://schemas.wp.org/trunk/block.json",
42361    apiVersion: 2,
42362    name: "core/spacer",
42363    title: "Spacer",
42364    category: "design",
42365    description: "Add white space between blocks and customize its height.",
42366    textdomain: "default",
42367    attributes: {
42368      height: {
42369        type: "string",
42370        "default": "100px"
42371      },
42372      width: {
42373        type: "string"
42374      }
42375    },
42376    usesContext: ["orientation"],
42377    supports: {
42378      anchor: true
42379    },
42380    editorStyle: "wp-block-spacer-editor",
42381    style: "wp-block-spacer"
42382  };
42383  
42384  const {
42385    name: spacer_name
42386  } = spacer_metadata;
42387  
42388  const spacer_settings = {
42389    icon: resize_corner_n_e,
42390    edit: spacer_edit,
42391    save: spacer_save_save,
42392    deprecated: spacer_deprecated
42393  };
42394  
42395  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/block-table.js
42396  
42397  
42398  /**
42399   * WordPress dependencies
42400   */
42401  
42402  const blockTable = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
42403    viewBox: "0 0 24 24",
42404    xmlns: "http://www.w3.org/2000/svg"
42405  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
42406    d: "M19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zM5 4.5h14c.3 0 .5.2.5.5v3.5h-15V5c0-.3.2-.5.5-.5zm8 5.5h6.5v3.5H13V10zm-1.5 3.5h-7V10h7v3.5zm-7 5.5v-4h7v4.5H5c-.3 0-.5-.2-.5-.5zm14.5.5h-6V15h6.5v4c0 .3-.2.5-.5.5z"
42407  }));
42408  /* harmony default export */ var block_table = (blockTable);
42409  
42410  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/table/deprecated.js
42411  
42412  
42413  /**
42414   * External dependencies
42415   */
42416  
42417  /**
42418   * WordPress dependencies
42419   */
42420  
42421  
42422  const deprecated_supports = {
42423    align: true
42424  }; // As the previous arbitrary colors won't match theme color palettes, the hex
42425  // value will be mapped to the style.color.background attribute as if it was
42426  // a custom color selection.
42427  
42428  const oldColors = {
42429    'subtle-light-gray': '#f3f4f5',
42430    'subtle-pale-green': '#e9fbe5',
42431    'subtle-pale-blue': '#e7f5fe',
42432    'subtle-pale-pink': '#fcf0ef'
42433  };
42434  const table_deprecated_deprecated = [// Deprecation migrating table block to use colors block support feature.
42435  {
42436    attributes: {
42437      hasFixedLayout: {
42438        type: 'boolean',
42439        default: false
42440      },
42441      backgroundColor: {
42442        type: 'string'
42443      },
42444      caption: {
42445        type: 'string',
42446        source: 'html',
42447        selector: 'figcaption',
42448        default: ''
42449      },
42450      head: {
42451        type: 'array',
42452        default: [],
42453        source: 'query',
42454        selector: 'thead tr',
42455        query: {
42456          cells: {
42457            type: 'array',
42458            default: [],
42459            source: 'query',
42460            selector: 'td,th',
42461            query: {
42462              content: {
42463                type: 'string',
42464                source: 'html'
42465              },
42466              tag: {
42467                type: 'string',
42468                default: 'td',
42469                source: 'tag'
42470              },
42471              scope: {
42472                type: 'string',
42473                source: 'attribute',
42474                attribute: 'scope'
42475              },
42476              align: {
42477                type: 'string',
42478                source: 'attribute',
42479                attribute: 'data-align'
42480              }
42481            }
42482          }
42483        }
42484      },
42485      body: {
42486        type: 'array',
42487        default: [],
42488        source: 'query',
42489        selector: 'tbody tr',
42490        query: {
42491          cells: {
42492            type: 'array',
42493            default: [],
42494            source: 'query',
42495            selector: 'td,th',
42496            query: {
42497              content: {
42498                type: 'string',
42499                source: 'html'
42500              },
42501              tag: {
42502                type: 'string',
42503                default: 'td',
42504                source: 'tag'
42505              },
42506              scope: {
42507                type: 'string',
42508                source: 'attribute',
42509                attribute: 'scope'
42510              },
42511              align: {
42512                type: 'string',
42513                source: 'attribute',
42514                attribute: 'data-align'
42515              }
42516            }
42517          }
42518        }
42519      },
42520      foot: {
42521        type: 'array',
42522        default: [],
42523        source: 'query',
42524        selector: 'tfoot tr',
42525        query: {
42526          cells: {
42527            type: 'array',
42528            default: [],
42529            source: 'query',
42530            selector: 'td,th',
42531            query: {
42532              content: {
42533                type: 'string',
42534                source: 'html'
42535              },
42536              tag: {
42537                type: 'string',
42538                default: 'td',
42539                source: 'tag'
42540              },
42541              scope: {
42542                type: 'string',
42543                source: 'attribute',
42544                attribute: 'scope'
42545              },
42546              align: {
42547                type: 'string',
42548                source: 'attribute',
42549                attribute: 'data-align'
42550              }
42551            }
42552          }
42553        }
42554      }
42555    },
42556    supports: {
42557      anchor: true,
42558      align: true,
42559      __experimentalSelector: '.wp-block-table > table'
42560    },
42561    save: _ref => {
42562      let {
42563        attributes
42564      } = _ref;
42565      const {
42566        hasFixedLayout,
42567        head,
42568        body,
42569        foot,
42570        backgroundColor,
42571        caption
42572      } = attributes;
42573      const isEmpty = !head.length && !body.length && !foot.length;
42574  
42575      if (isEmpty) {
42576        return null;
42577      }
42578  
42579      const backgroundClass = (0,external_wp_blockEditor_namespaceObject.getColorClassName)('background-color', backgroundColor);
42580      const classes = classnames_default()(backgroundClass, {
42581        'has-fixed-layout': hasFixedLayout,
42582        'has-background': !!backgroundClass
42583      });
42584      const hasCaption = !external_wp_blockEditor_namespaceObject.RichText.isEmpty(caption);
42585  
42586      const Section = _ref2 => {
42587        let {
42588          type,
42589          rows
42590        } = _ref2;
42591  
42592        if (!rows.length) {
42593          return null;
42594        }
42595  
42596        const Tag = `t$type}`;
42597        return (0,external_wp_element_namespaceObject.createElement)(Tag, null, rows.map((_ref3, rowIndex) => {
42598          let {
42599            cells
42600          } = _ref3;
42601          return (0,external_wp_element_namespaceObject.createElement)("tr", {
42602            key: rowIndex
42603          }, cells.map((_ref4, cellIndex) => {
42604            let {
42605              content,
42606              tag,
42607              scope,
42608              align
42609            } = _ref4;
42610            const cellClasses = classnames_default()({
42611              [`has-text-align-$align}`]: align
42612            });
42613            return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
42614              className: cellClasses ? cellClasses : undefined,
42615              "data-align": align,
42616              tagName: tag,
42617              value: content,
42618              key: cellIndex,
42619              scope: tag === 'th' ? scope : undefined
42620            });
42621          }));
42622        }));
42623      };
42624  
42625      return (0,external_wp_element_namespaceObject.createElement)("figure", external_wp_blockEditor_namespaceObject.useBlockProps.save(), (0,external_wp_element_namespaceObject.createElement)("table", {
42626        className: classes === '' ? undefined : classes
42627      }, (0,external_wp_element_namespaceObject.createElement)(Section, {
42628        type: "head",
42629        rows: head
42630      }), (0,external_wp_element_namespaceObject.createElement)(Section, {
42631        type: "body",
42632        rows: body
42633      }), (0,external_wp_element_namespaceObject.createElement)(Section, {
42634        type: "foot",
42635        rows: foot
42636      })), hasCaption && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
42637        tagName: "figcaption",
42638        value: caption
42639      }));
42640    },
42641    isEligible: attributes => {
42642      return attributes.backgroundColor && attributes.backgroundColor in oldColors && !attributes.style;
42643    },
42644    // This version is the first to introduce the style attribute to the
42645    // table block. As a result, we'll explicitly override that.
42646    migrate: attributes => {
42647      return { ...attributes,
42648        backgroundColor: undefined,
42649        style: {
42650          color: {
42651            background: oldColors[attributes.backgroundColor]
42652          }
42653        }
42654      };
42655    }
42656  }, {
42657    attributes: {
42658      hasFixedLayout: {
42659        type: 'boolean',
42660        default: false
42661      },
42662      backgroundColor: {
42663        type: 'string'
42664      },
42665      head: {
42666        type: 'array',
42667        default: [],
42668        source: 'query',
42669        selector: 'thead tr',
42670        query: {
42671          cells: {
42672            type: 'array',
42673            default: [],
42674            source: 'query',
42675            selector: 'td,th',
42676            query: {
42677              content: {
42678                type: 'string',
42679                source: 'html'
42680              },
42681              tag: {
42682                type: 'string',
42683                default: 'td',
42684                source: 'tag'
42685              },
42686              scope: {
42687                type: 'string',
42688                source: 'attribute',
42689                attribute: 'scope'
42690              }
42691            }
42692          }
42693        }
42694      },
42695      body: {
42696        type: 'array',
42697        default: [],
42698        source: 'query',
42699        selector: 'tbody tr',
42700        query: {
42701          cells: {
42702            type: 'array',
42703            default: [],
42704            source: 'query',
42705            selector: 'td,th',
42706            query: {
42707              content: {
42708                type: 'string',
42709                source: 'html'
42710              },
42711              tag: {
42712                type: 'string',
42713                default: 'td',
42714                source: 'tag'
42715              },
42716              scope: {
42717                type: 'string',
42718                source: 'attribute',
42719                attribute: 'scope'
42720              }
42721            }
42722          }
42723        }
42724      },
42725      foot: {
42726        type: 'array',
42727        default: [],
42728        source: 'query',
42729        selector: 'tfoot tr',
42730        query: {
42731          cells: {
42732            type: 'array',
42733            default: [],
42734            source: 'query',
42735            selector: 'td,th',
42736            query: {
42737              content: {
42738                type: 'string',
42739                source: 'html'
42740              },
42741              tag: {
42742                type: 'string',
42743                default: 'td',
42744                source: 'tag'
42745              },
42746              scope: {
42747                type: 'string',
42748                source: 'attribute',
42749                attribute: 'scope'
42750              }
42751            }
42752          }
42753        }
42754      }
42755    },
42756    supports: deprecated_supports,
42757  
42758    save(_ref5) {
42759      let {
42760        attributes
42761      } = _ref5;
42762      const {
42763        hasFixedLayout,
42764        head,
42765        body,
42766        foot,
42767        backgroundColor
42768      } = attributes;
42769      const isEmpty = !head.length && !body.length && !foot.length;
42770  
42771      if (isEmpty) {
42772        return null;
42773      }
42774  
42775      const backgroundClass = (0,external_wp_blockEditor_namespaceObject.getColorClassName)('background-color', backgroundColor);
42776      const classes = classnames_default()(backgroundClass, {
42777        'has-fixed-layout': hasFixedLayout,
42778        'has-background': !!backgroundClass
42779      });
42780  
42781      const Section = _ref6 => {
42782        let {
42783          type,
42784          rows
42785        } = _ref6;
42786  
42787        if (!rows.length) {
42788          return null;
42789        }
42790  
42791        const Tag = `t$type}`;
42792        return (0,external_wp_element_namespaceObject.createElement)(Tag, null, rows.map((_ref7, rowIndex) => {
42793          let {
42794            cells
42795          } = _ref7;
42796          return (0,external_wp_element_namespaceObject.createElement)("tr", {
42797            key: rowIndex
42798          }, cells.map((_ref8, cellIndex) => {
42799            let {
42800              content,
42801              tag,
42802              scope
42803            } = _ref8;
42804            return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
42805              tagName: tag,
42806              value: content,
42807              key: cellIndex,
42808              scope: tag === 'th' ? scope : undefined
42809            });
42810          }));
42811        }));
42812      };
42813  
42814      return (0,external_wp_element_namespaceObject.createElement)("table", {
42815        className: classes
42816      }, (0,external_wp_element_namespaceObject.createElement)(Section, {
42817        type: "head",
42818        rows: head
42819      }), (0,external_wp_element_namespaceObject.createElement)(Section, {
42820        type: "body",
42821        rows: body
42822      }), (0,external_wp_element_namespaceObject.createElement)(Section, {
42823        type: "foot",
42824        rows: foot
42825      }));
42826    }
42827  
42828  }];
42829  /* harmony default export */ var table_deprecated = (table_deprecated_deprecated);
42830  
42831  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/align-left.js
42832  
42833  
42834  /**
42835   * WordPress dependencies
42836   */
42837  
42838  const alignLeft = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
42839    xmlns: "http://www.w3.org/2000/svg",
42840    viewBox: "0 0 24 24"
42841  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
42842    d: "M4 19.8h8.9v-1.5H4v1.5zm8.9-15.6H4v1.5h8.9V4.2zm-8.9 7v1.5h16v-1.5H4z"
42843  }));
42844  /* harmony default export */ var align_left = (alignLeft);
42845  
42846  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/align-center.js
42847  
42848  
42849  /**
42850   * WordPress dependencies
42851   */
42852  
42853  const alignCenter = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
42854    xmlns: "http://www.w3.org/2000/svg",
42855    viewBox: "0 0 24 24"
42856  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
42857    d: "M16.4 4.2H7.6v1.5h8.9V4.2zM4 11.2v1.5h16v-1.5H4zm3.6 8.6h8.9v-1.5H7.6v1.5z"
42858  }));
42859  /* harmony default export */ var align_center = (alignCenter);
42860  
42861  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/align-right.js
42862  
42863  
42864  /**
42865   * WordPress dependencies
42866   */
42867  
42868  const alignRight = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
42869    xmlns: "http://www.w3.org/2000/svg",
42870    viewBox: "0 0 24 24"
42871  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
42872    d: "M11.1 19.8H20v-1.5h-8.9v1.5zm0-15.6v1.5H20V4.2h-8.9zM4 12.8h16v-1.5H4v1.5z"
42873  }));
42874  /* harmony default export */ var align_right = (alignRight);
42875  
42876  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/table-row-before.js
42877  
42878  
42879  /**
42880   * WordPress dependencies
42881   */
42882  
42883  const tableRowBefore = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
42884    xmlns: "http://www.w3.org/2000/svg",
42885    viewBox: "-2 -2 24 24"
42886  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
42887    d: "M6.656 6.464h2.88v2.88h1.408v-2.88h2.88V5.12h-2.88V2.24H9.536v2.88h-2.88zM0 17.92V0h20.48v17.92H0zm7.68-2.56h5.12v-3.84H7.68v3.84zm-6.4 0H6.4v-3.84H1.28v3.84zM19.2 1.28H1.28v9.024H19.2V1.28zm0 10.24h-5.12v3.84h5.12v-3.84zM6.656 6.464h2.88v2.88h1.408v-2.88h2.88V5.12h-2.88V2.24H9.536v2.88h-2.88zM0 17.92V0h20.48v17.92H0zm7.68-2.56h5.12v-3.84H7.68v3.84zm-6.4 0H6.4v-3.84H1.28v3.84zM19.2 1.28H1.28v9.024H19.2V1.28zm0 10.24h-5.12v3.84h5.12v-3.84z"
42888  }));
42889  /* harmony default export */ var table_row_before = (tableRowBefore);
42890  
42891  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/table-row-after.js
42892  
42893  
42894  /**
42895   * WordPress dependencies
42896   */
42897  
42898  const tableRowAfter = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
42899    xmlns: "http://www.w3.org/2000/svg",
42900    viewBox: "-2 -2 24 24"
42901  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
42902    d: "M13.824 10.176h-2.88v-2.88H9.536v2.88h-2.88v1.344h2.88v2.88h1.408v-2.88h2.88zM0 17.92V0h20.48v17.92H0zM6.4 1.28H1.28v3.84H6.4V1.28zm6.4 0H7.68v3.84h5.12V1.28zm6.4 0h-5.12v3.84h5.12V1.28zm0 5.056H1.28v9.024H19.2V6.336z"
42903  }));
42904  /* harmony default export */ var table_row_after = (tableRowAfter);
42905  
42906  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/table-row-delete.js
42907  
42908  
42909  /**
42910   * WordPress dependencies
42911   */
42912  
42913  const tableRowDelete = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
42914    xmlns: "http://www.w3.org/2000/svg",
42915    viewBox: "-2 -2 24 24"
42916  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
42917    d: "M17.728 11.456L14.592 8.32l3.2-3.2-1.536-1.536-3.2 3.2L9.92 3.648 8.384 5.12l3.2 3.2-3.264 3.264 1.536 1.536 3.264-3.264 3.136 3.136 1.472-1.536zM0 17.92V0h20.48v17.92H0zm19.2-6.4h-.448l-1.28-1.28H19.2V6.4h-1.792l1.28-1.28h.512V1.28H1.28v3.84h6.208l1.28 1.28H1.28v3.84h7.424l-1.28 1.28H1.28v3.84H19.2v-3.84z"
42918  }));
42919  /* harmony default export */ var table_row_delete = (tableRowDelete);
42920  
42921  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/table-column-before.js
42922  
42923  
42924  /**
42925   * WordPress dependencies
42926   */
42927  
42928  const tableColumnBefore = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
42929    xmlns: "http://www.w3.org/2000/svg",
42930    viewBox: "-2 -2 24 24"
42931  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
42932    d: "M6.4 3.776v3.648H2.752v1.792H6.4v3.648h1.728V9.216h3.712V7.424H8.128V3.776zM0 17.92V0h20.48v17.92H0zM12.8 1.28H1.28v14.08H12.8V1.28zm6.4 0h-5.12v3.84h5.12V1.28zm0 5.12h-5.12v3.84h5.12V6.4zm0 5.12h-5.12v3.84h5.12v-3.84z"
42933  }));
42934  /* harmony default export */ var table_column_before = (tableColumnBefore);
42935  
42936  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/table-column-after.js
42937  
42938  
42939  /**
42940   * WordPress dependencies
42941   */
42942  
42943  const tableColumnAfter = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
42944    xmlns: "http://www.w3.org/2000/svg",
42945    viewBox: "-2 -2 24 24"
42946  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
42947    d: "M14.08 12.864V9.216h3.648V7.424H14.08V3.776h-1.728v3.648H8.64v1.792h3.712v3.648zM0 17.92V0h20.48v17.92H0zM6.4 1.28H1.28v3.84H6.4V1.28zm0 5.12H1.28v3.84H6.4V6.4zm0 5.12H1.28v3.84H6.4v-3.84zM19.2 1.28H7.68v14.08H19.2V1.28z"
42948  }));
42949  /* harmony default export */ var table_column_after = (tableColumnAfter);
42950  
42951  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/table-column-delete.js
42952  
42953  
42954  /**
42955   * WordPress dependencies
42956   */
42957  
42958  const tableColumnDelete = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
42959    xmlns: "http://www.w3.org/2000/svg",
42960    viewBox: "-2 -2 24 24"
42961  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
42962    d: "M6.4 9.98L7.68 8.7v-.256L6.4 7.164V9.98zm6.4-1.532l1.28-1.28V9.92L12.8 8.64v-.192zm7.68 9.472V0H0v17.92h20.48zm-1.28-2.56h-5.12v-1.024l-.256.256-1.024-1.024v1.792H7.68v-1.792l-1.024 1.024-.256-.256v1.024H1.28V1.28H6.4v2.368l.704-.704.576.576V1.216h5.12V3.52l.96-.96.32.32V1.216h5.12V15.36zm-5.76-2.112l-3.136-3.136-3.264 3.264-1.536-1.536 3.264-3.264L5.632 5.44l1.536-1.536 3.136 3.136 3.2-3.2 1.536 1.536-3.2 3.2 3.136 3.136-1.536 1.536z"
42963  }));
42964  /* harmony default export */ var table_column_delete = (tableColumnDelete);
42965  
42966  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/table.js
42967  
42968  
42969  /**
42970   * WordPress dependencies
42971   */
42972  
42973  const table = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
42974    xmlns: "http://www.w3.org/2000/svg",
42975    viewBox: "0 0 24 24"
42976  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
42977    d: "M4 6v11.5h16V6H4zm1.5 1.5h6V11h-6V7.5zm0 8.5v-3.5h6V16h-6zm13 0H13v-3.5h5.5V16zM13 11V7.5h5.5V11H13z"
42978  }));
42979  /* harmony default export */ var library_table = (table);
42980  
42981  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/table/state.js
42982  /**
42983   * External dependencies
42984   */
42985  
42986  const INHERITED_COLUMN_ATTRIBUTES = ['align'];
42987  /**
42988   * Creates a table state.
42989   *
42990   * @param {Object} options
42991   * @param {number} options.rowCount    Row count for the table to create.
42992   * @param {number} options.columnCount Column count for the table to create.
42993   *
42994   * @return {Object} New table state.
42995   */
42996  
42997  function createTable(_ref) {
42998    let {
42999      rowCount,
43000      columnCount
43001    } = _ref;
43002    return {
43003      body: (0,external_lodash_namespaceObject.times)(rowCount, () => ({
43004        cells: (0,external_lodash_namespaceObject.times)(columnCount, () => ({
43005          content: '',
43006          tag: 'td'
43007        }))
43008      }))
43009    };
43010  }
43011  /**
43012   * Returns the first row in the table.
43013   *
43014   * @param {Object} state Current table state.
43015   *
43016   * @return {Object} The first table row.
43017   */
43018  
43019  function getFirstRow(state) {
43020    if (!isEmptyTableSection(state.head)) {
43021      return state.head[0];
43022    }
43023  
43024    if (!isEmptyTableSection(state.body)) {
43025      return state.body[0];
43026    }
43027  
43028    if (!isEmptyTableSection(state.foot)) {
43029      return state.foot[0];
43030    }
43031  }
43032  /**
43033   * Gets an attribute for a cell.
43034   *
43035   * @param {Object} state         Current table state.
43036   * @param {Object} cellLocation  The location of the cell
43037   * @param {string} attributeName The name of the attribute to get the value of.
43038   *
43039   * @return {*} The attribute value.
43040   */
43041  
43042  function getCellAttribute(state, cellLocation, attributeName) {
43043    const {
43044      sectionName,
43045      rowIndex,
43046      columnIndex
43047    } = cellLocation;
43048    return (0,external_lodash_namespaceObject.get)(state, [sectionName, rowIndex, 'cells', columnIndex, attributeName]);
43049  }
43050  /**
43051   * Returns updated cell attributes after applying the `updateCell` function to the selection.
43052   *
43053   * @param {Object}   state      The block attributes.
43054   * @param {Object}   selection  The selection of cells to update.
43055   * @param {Function} updateCell A function to update the selected cell attributes.
43056   *
43057   * @return {Object} New table state including the updated cells.
43058   */
43059  
43060  function updateSelectedCell(state, selection, updateCell) {
43061    if (!selection) {
43062      return state;
43063    }
43064  
43065    const tableSections = (0,external_lodash_namespaceObject.pick)(state, ['head', 'body', 'foot']);
43066    const {
43067      sectionName: selectionSectionName,
43068      rowIndex: selectionRowIndex
43069    } = selection;
43070    return (0,external_lodash_namespaceObject.mapValues)(tableSections, (section, sectionName) => {
43071      if (selectionSectionName && selectionSectionName !== sectionName) {
43072        return section;
43073      }
43074  
43075      return section.map((row, rowIndex) => {
43076        if (selectionRowIndex && selectionRowIndex !== rowIndex) {
43077          return row;
43078        }
43079  
43080        return {
43081          cells: row.cells.map((cellAttributes, columnIndex) => {
43082            const cellLocation = {
43083              sectionName,
43084              columnIndex,
43085              rowIndex
43086            };
43087  
43088            if (!isCellSelected(cellLocation, selection)) {
43089              return cellAttributes;
43090            }
43091  
43092            return updateCell(cellAttributes);
43093          })
43094        };
43095      });
43096    });
43097  }
43098  /**
43099   * Returns whether the cell at `cellLocation` is included in the selection `selection`.
43100   *
43101   * @param {Object} cellLocation An object containing cell location properties.
43102   * @param {Object} selection    An object containing selection properties.
43103   *
43104   * @return {boolean} True if the cell is selected, false otherwise.
43105   */
43106  
43107  function isCellSelected(cellLocation, selection) {
43108    if (!cellLocation || !selection) {
43109      return false;
43110    }
43111  
43112    switch (selection.type) {
43113      case 'column':
43114        return selection.type === 'column' && cellLocation.columnIndex === selection.columnIndex;
43115  
43116      case 'cell':
43117        return selection.type === 'cell' && cellLocation.sectionName === selection.sectionName && cellLocation.columnIndex === selection.columnIndex && cellLocation.rowIndex === selection.rowIndex;
43118    }
43119  }
43120  /**
43121   * Inserts a row in the table state.
43122   *
43123   * @param {Object} state               Current table state.
43124   * @param {Object} options
43125   * @param {string} options.sectionName Section in which to insert the row.
43126   * @param {number} options.rowIndex    Row index at which to insert the row.
43127   * @param {number} options.columnCount Column count for the table to create.
43128   *
43129   * @return {Object} New table state.
43130   */
43131  
43132  function insertRow(state, _ref2) {
43133    let {
43134      sectionName,
43135      rowIndex,
43136      columnCount
43137    } = _ref2;
43138    const firstRow = getFirstRow(state);
43139    const cellCount = columnCount === undefined ? (0,external_lodash_namespaceObject.get)(firstRow, ['cells', 'length']) : columnCount; // Bail early if the function cannot determine how many cells to add.
43140  
43141    if (!cellCount) {
43142      return state;
43143    }
43144  
43145    return {
43146      [sectionName]: [...state[sectionName].slice(0, rowIndex), {
43147        cells: (0,external_lodash_namespaceObject.times)(cellCount, index => {
43148          const firstCellInColumn = (0,external_lodash_namespaceObject.get)(firstRow, ['cells', index], {});
43149          const inheritedAttributes = (0,external_lodash_namespaceObject.pick)(firstCellInColumn, INHERITED_COLUMN_ATTRIBUTES);
43150          return { ...inheritedAttributes,
43151            content: '',
43152            tag: sectionName === 'head' ? 'th' : 'td'
43153          };
43154        })
43155      }, ...state[sectionName].slice(rowIndex)]
43156    };
43157  }
43158  /**
43159   * Deletes a row from the table state.
43160   *
43161   * @param {Object} state               Current table state.
43162   * @param {Object} options
43163   * @param {string} options.sectionName Section in which to delete the row.
43164   * @param {number} options.rowIndex    Row index to delete.
43165   *
43166   * @return {Object} New table state.
43167   */
43168  
43169  function deleteRow(state, _ref3) {
43170    let {
43171      sectionName,
43172      rowIndex
43173    } = _ref3;
43174    return {
43175      [sectionName]: state[sectionName].filter((row, index) => index !== rowIndex)
43176    };
43177  }
43178  /**
43179   * Inserts a column in the table state.
43180   *
43181   * @param {Object} state               Current table state.
43182   * @param {Object} options
43183   * @param {number} options.columnIndex Column index at which to insert the column.
43184   *
43185   * @return {Object} New table state.
43186   */
43187  
43188  function insertColumn(state, _ref4) {
43189    let {
43190      columnIndex
43191    } = _ref4;
43192    const tableSections = (0,external_lodash_namespaceObject.pick)(state, ['head', 'body', 'foot']);
43193    return (0,external_lodash_namespaceObject.mapValues)(tableSections, (section, sectionName) => {
43194      // Bail early if the table section is empty.
43195      if (isEmptyTableSection(section)) {
43196        return section;
43197      }
43198  
43199      return section.map(row => {
43200        // Bail early if the row is empty or it's an attempt to insert past
43201        // the last possible index of the array.
43202        if (isEmptyRow(row) || row.cells.length < columnIndex) {
43203          return row;
43204        }
43205  
43206        return {
43207          cells: [...row.cells.slice(0, columnIndex), {
43208            content: '',
43209            tag: sectionName === 'head' ? 'th' : 'td'
43210          }, ...row.cells.slice(columnIndex)]
43211        };
43212      });
43213    });
43214  }
43215  /**
43216   * Deletes a column from the table state.
43217   *
43218   * @param {Object} state               Current table state.
43219   * @param {Object} options
43220   * @param {number} options.columnIndex Column index to delete.
43221   *
43222   * @return {Object} New table state.
43223   */
43224  
43225  function deleteColumn(state, _ref5) {
43226    let {
43227      columnIndex
43228    } = _ref5;
43229    const tableSections = (0,external_lodash_namespaceObject.pick)(state, ['head', 'body', 'foot']);
43230    return (0,external_lodash_namespaceObject.mapValues)(tableSections, section => {
43231      // Bail early if the table section is empty.
43232      if (isEmptyTableSection(section)) {
43233        return section;
43234      }
43235  
43236      return section.map(row => ({
43237        cells: row.cells.length >= columnIndex ? row.cells.filter((cell, index) => index !== columnIndex) : row.cells
43238      })).filter(row => row.cells.length);
43239    });
43240  }
43241  /**
43242   * Toggles the existance of a section.
43243   *
43244   * @param {Object} state       Current table state.
43245   * @param {string} sectionName Name of the section to toggle.
43246   *
43247   * @return {Object} New table state.
43248   */
43249  
43250  function toggleSection(state, sectionName) {
43251    // Section exists, replace it with an empty row to remove it.
43252    if (!isEmptyTableSection(state[sectionName])) {
43253      return {
43254        [sectionName]: []
43255      };
43256    } // Get the length of the first row of the body to use when creating the header.
43257  
43258  
43259    const columnCount = (0,external_lodash_namespaceObject.get)(state, ['body', 0, 'cells', 'length'], 1); // Section doesn't exist, insert an empty row to create the section.
43260  
43261    return insertRow(state, {
43262      sectionName,
43263      rowIndex: 0,
43264      columnCount
43265    });
43266  }
43267  /**
43268   * Determines whether a table section is empty.
43269   *
43270   * @param {Object} section Table section state.
43271   *
43272   * @return {boolean} True if the table section is empty, false otherwise.
43273   */
43274  
43275  function isEmptyTableSection(section) {
43276    return !section || !section.length || (0,external_lodash_namespaceObject.every)(section, isEmptyRow);
43277  }
43278  /**
43279   * Determines whether a table row is empty.
43280   *
43281   * @param {Object} row Table row state.
43282   *
43283   * @return {boolean} True if the table section is empty, false otherwise.
43284   */
43285  
43286  function isEmptyRow(row) {
43287    return !(row.cells && row.cells.length);
43288  }
43289  
43290  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/table/edit.js
43291  
43292  
43293  /**
43294   * External dependencies
43295   */
43296  
43297  /**
43298   * WordPress dependencies
43299   */
43300  
43301  
43302  
43303  
43304  
43305  
43306  
43307  /**
43308   * Internal dependencies
43309   */
43310  
43311  
43312  const ALIGNMENT_CONTROLS = [{
43313    icon: align_left,
43314    title: (0,external_wp_i18n_namespaceObject.__)('Align column left'),
43315    align: 'left'
43316  }, {
43317    icon: align_center,
43318    title: (0,external_wp_i18n_namespaceObject.__)('Align column center'),
43319    align: 'center'
43320  }, {
43321    icon: align_right,
43322    title: (0,external_wp_i18n_namespaceObject.__)('Align column right'),
43323    align: 'right'
43324  }];
43325  const cellAriaLabel = {
43326    head: (0,external_wp_i18n_namespaceObject.__)('Header cell text'),
43327    body: (0,external_wp_i18n_namespaceObject.__)('Body cell text'),
43328    foot: (0,external_wp_i18n_namespaceObject.__)('Footer cell text')
43329  };
43330  const placeholder = {
43331    head: (0,external_wp_i18n_namespaceObject.__)('Header label'),
43332    foot: (0,external_wp_i18n_namespaceObject.__)('Footer label')
43333  };
43334  
43335  function TSection(_ref) {
43336    let {
43337      name,
43338      ...props
43339    } = _ref;
43340    const TagName = `t$name}`;
43341    return (0,external_wp_element_namespaceObject.createElement)(TagName, props);
43342  }
43343  
43344  function TableEdit(_ref2) {
43345    let {
43346      attributes,
43347      setAttributes,
43348      insertBlocksAfter,
43349      isSelected
43350    } = _ref2;
43351    const {
43352      hasFixedLayout,
43353      caption,
43354      head,
43355      foot
43356    } = attributes;
43357    const [initialRowCount, setInitialRowCount] = (0,external_wp_element_namespaceObject.useState)(2);
43358    const [initialColumnCount, setInitialColumnCount] = (0,external_wp_element_namespaceObject.useState)(2);
43359    const [selectedCell, setSelectedCell] = (0,external_wp_element_namespaceObject.useState)();
43360    const colorProps = (0,external_wp_blockEditor_namespaceObject.__experimentalUseColorProps)(attributes);
43361    const borderProps = (0,external_wp_blockEditor_namespaceObject.__experimentalUseBorderProps)(attributes);
43362    /**
43363     * Updates the initial column count used for table creation.
43364     *
43365     * @param {number} count New initial column count.
43366     */
43367  
43368    function onChangeInitialColumnCount(count) {
43369      setInitialColumnCount(count);
43370    }
43371    /**
43372     * Updates the initial row count used for table creation.
43373     *
43374     * @param {number} count New initial row count.
43375     */
43376  
43377  
43378    function onChangeInitialRowCount(count) {
43379      setInitialRowCount(count);
43380    }
43381    /**
43382     * Creates a table based on dimensions in local state.
43383     *
43384     * @param {Object} event Form submit event.
43385     */
43386  
43387  
43388    function onCreateTable(event) {
43389      event.preventDefault();
43390      setAttributes(createTable({
43391        rowCount: parseInt(initialRowCount, 10) || 2,
43392        columnCount: parseInt(initialColumnCount, 10) || 2
43393      }));
43394    }
43395    /**
43396     * Toggles whether the table has a fixed layout or not.
43397     */
43398  
43399  
43400    function onChangeFixedLayout() {
43401      setAttributes({
43402        hasFixedLayout: !hasFixedLayout
43403      });
43404    }
43405    /**
43406     * Changes the content of the currently selected cell.
43407     *
43408     * @param {Array} content A RichText content value.
43409     */
43410  
43411  
43412    function onChange(content) {
43413      if (!selectedCell) {
43414        return;
43415      }
43416  
43417      setAttributes(updateSelectedCell(attributes, selectedCell, cellAttributes => ({ ...cellAttributes,
43418        content
43419      })));
43420    }
43421    /**
43422     * Align text within the a column.
43423     *
43424     * @param {string} align The new alignment to apply to the column.
43425     */
43426  
43427  
43428    function onChangeColumnAlignment(align) {
43429      if (!selectedCell) {
43430        return;
43431      } // Convert the cell selection to a column selection so that alignment
43432      // is applied to the entire column.
43433  
43434  
43435      const columnSelection = {
43436        type: 'column',
43437        columnIndex: selectedCell.columnIndex
43438      };
43439      const newAttributes = updateSelectedCell(attributes, columnSelection, cellAttributes => ({ ...cellAttributes,
43440        align
43441      }));
43442      setAttributes(newAttributes);
43443    }
43444    /**
43445     * Get the alignment of the currently selected cell.
43446     *
43447     * @return {string} The new alignment to apply to the column.
43448     */
43449  
43450  
43451    function getCellAlignment() {
43452      if (!selectedCell) {
43453        return;
43454      }
43455  
43456      return getCellAttribute(attributes, selectedCell, 'align');
43457    }
43458    /**
43459     * Add or remove a `head` table section.
43460     */
43461  
43462  
43463    function onToggleHeaderSection() {
43464      setAttributes(toggleSection(attributes, 'head'));
43465    }
43466    /**
43467     * Add or remove a `foot` table section.
43468     */
43469  
43470  
43471    function onToggleFooterSection() {
43472      setAttributes(toggleSection(attributes, 'foot'));
43473    }
43474    /**
43475     * Inserts a row at the currently selected row index, plus `delta`.
43476     *
43477     * @param {number} delta Offset for selected row index at which to insert.
43478     */
43479  
43480  
43481    function onInsertRow(delta) {
43482      if (!selectedCell) {
43483        return;
43484      }
43485  
43486      const {
43487        sectionName,
43488        rowIndex
43489      } = selectedCell;
43490      const newRowIndex = rowIndex + delta;
43491      setAttributes(insertRow(attributes, {
43492        sectionName,
43493        rowIndex: newRowIndex
43494      })); // Select the first cell of the new row.
43495  
43496      setSelectedCell({
43497        sectionName,
43498        rowIndex: newRowIndex,
43499        columnIndex: 0,
43500        type: 'cell'
43501      });
43502    }
43503    /**
43504     * Inserts a row before the currently selected row.
43505     */
43506  
43507  
43508    function onInsertRowBefore() {
43509      onInsertRow(0);
43510    }
43511    /**
43512     * Inserts a row after the currently selected row.
43513     */
43514  
43515  
43516    function onInsertRowAfter() {
43517      onInsertRow(1);
43518    }
43519    /**
43520     * Deletes the currently selected row.
43521     */
43522  
43523  
43524    function onDeleteRow() {
43525      if (!selectedCell) {
43526        return;
43527      }
43528  
43529      const {
43530        sectionName,
43531        rowIndex
43532      } = selectedCell;
43533      setSelectedCell();
43534      setAttributes(deleteRow(attributes, {
43535        sectionName,
43536        rowIndex
43537      }));
43538    }
43539    /**
43540     * Inserts a column at the currently selected column index, plus `delta`.
43541     *
43542     * @param {number} delta Offset for selected column index at which to insert.
43543     */
43544  
43545  
43546    function onInsertColumn() {
43547      let delta = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0;
43548  
43549      if (!selectedCell) {
43550        return;
43551      }
43552  
43553      const {
43554        columnIndex
43555      } = selectedCell;
43556      const newColumnIndex = columnIndex + delta;
43557      setAttributes(insertColumn(attributes, {
43558        columnIndex: newColumnIndex
43559      })); // Select the first cell of the new column.
43560  
43561      setSelectedCell({
43562        rowIndex: 0,
43563        columnIndex: newColumnIndex,
43564        type: 'cell'
43565      });
43566    }
43567    /**
43568     * Inserts a column before the currently selected column.
43569     */
43570  
43571  
43572    function onInsertColumnBefore() {
43573      onInsertColumn(0);
43574    }
43575    /**
43576     * Inserts a column after the currently selected column.
43577     */
43578  
43579  
43580    function onInsertColumnAfter() {
43581      onInsertColumn(1);
43582    }
43583    /**
43584     * Deletes the currently selected column.
43585     */
43586  
43587  
43588    function onDeleteColumn() {
43589      if (!selectedCell) {
43590        return;
43591      }
43592  
43593      const {
43594        sectionName,
43595        columnIndex
43596      } = selectedCell;
43597      setSelectedCell();
43598      setAttributes(deleteColumn(attributes, {
43599        sectionName,
43600        columnIndex
43601      }));
43602    }
43603  
43604    (0,external_wp_element_namespaceObject.useEffect)(() => {
43605      if (!isSelected) {
43606        setSelectedCell();
43607      }
43608    }, [isSelected]);
43609    const sections = ['head', 'body', 'foot'].filter(name => !isEmptyTableSection(attributes[name]));
43610    const tableControls = [{
43611      icon: table_row_before,
43612      title: (0,external_wp_i18n_namespaceObject.__)('Insert row before'),
43613      isDisabled: !selectedCell,
43614      onClick: onInsertRowBefore
43615    }, {
43616      icon: table_row_after,
43617      title: (0,external_wp_i18n_namespaceObject.__)('Insert row after'),
43618      isDisabled: !selectedCell,
43619      onClick: onInsertRowAfter
43620    }, {
43621      icon: table_row_delete,
43622      title: (0,external_wp_i18n_namespaceObject.__)('Delete row'),
43623      isDisabled: !selectedCell,
43624      onClick: onDeleteRow
43625    }, {
43626      icon: table_column_before,
43627      title: (0,external_wp_i18n_namespaceObject.__)('Insert column before'),
43628      isDisabled: !selectedCell,
43629      onClick: onInsertColumnBefore
43630    }, {
43631      icon: table_column_after,
43632      title: (0,external_wp_i18n_namespaceObject.__)('Insert column after'),
43633      isDisabled: !selectedCell,
43634      onClick: onInsertColumnAfter
43635    }, {
43636      icon: table_column_delete,
43637      title: (0,external_wp_i18n_namespaceObject.__)('Delete column'),
43638      isDisabled: !selectedCell,
43639      onClick: onDeleteColumn
43640    }];
43641    const renderedSections = ['head', 'body', 'foot'].map(name => (0,external_wp_element_namespaceObject.createElement)(TSection, {
43642      name: name,
43643      key: name
43644    }, attributes[name].map((_ref3, rowIndex) => {
43645      let {
43646        cells
43647      } = _ref3;
43648      return (0,external_wp_element_namespaceObject.createElement)("tr", {
43649        key: rowIndex
43650      }, cells.map((_ref4, columnIndex) => {
43651        let {
43652          content,
43653          tag: CellTag,
43654          scope,
43655          align
43656        } = _ref4;
43657        return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText, {
43658          tagName: CellTag,
43659          key: columnIndex,
43660          className: classnames_default()({
43661            [`has-text-align-$align}`]: align
43662          }, 'wp-block-table__cell-content'),
43663          scope: CellTag === 'th' ? scope : undefined,
43664          value: content,
43665          onChange: onChange,
43666          unstableOnFocus: () => {
43667            setSelectedCell({
43668              sectionName: name,
43669              rowIndex,
43670              columnIndex,
43671              type: 'cell'
43672            });
43673          },
43674          "aria-label": cellAriaLabel[name],
43675          placeholder: placeholder[name]
43676        });
43677      }));
43678    })));
43679    const isEmpty = !sections.length;
43680    return (0,external_wp_element_namespaceObject.createElement)("figure", (0,external_wp_blockEditor_namespaceObject.useBlockProps)(), !isEmpty && (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, {
43681      group: "block"
43682    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.AlignmentControl, {
43683      label: (0,external_wp_i18n_namespaceObject.__)('Change column alignment'),
43684      alignmentControls: ALIGNMENT_CONTROLS,
43685      value: getCellAlignment(),
43686      onChange: nextAlign => onChangeColumnAlignment(nextAlign)
43687    })), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, {
43688      group: "other"
43689    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarDropdownMenu, {
43690      hasArrowIndicator: true,
43691      icon: library_table,
43692      label: (0,external_wp_i18n_namespaceObject.__)('Edit table'),
43693      controls: tableControls
43694    }))), !isEmpty && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
43695      title: (0,external_wp_i18n_namespaceObject.__)('Table settings'),
43696      className: "blocks-table-settings"
43697    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
43698      label: (0,external_wp_i18n_namespaceObject.__)('Fixed width table cells'),
43699      checked: !!hasFixedLayout,
43700      onChange: onChangeFixedLayout
43701    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
43702      label: (0,external_wp_i18n_namespaceObject.__)('Header section'),
43703      checked: !!(head && head.length),
43704      onChange: onToggleHeaderSection
43705    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
43706      label: (0,external_wp_i18n_namespaceObject.__)('Footer section'),
43707      checked: !!(foot && foot.length),
43708      onChange: onToggleFooterSection
43709    }))), !isEmpty && (0,external_wp_element_namespaceObject.createElement)("table", {
43710      className: classnames_default()(colorProps.className, borderProps.className, {
43711        'has-fixed-layout': hasFixedLayout
43712      }),
43713      style: { ...colorProps.style,
43714        ...borderProps.style
43715      }
43716    }, renderedSections), !isEmpty && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText, {
43717      tagName: "figcaption",
43718      "aria-label": (0,external_wp_i18n_namespaceObject.__)('Table caption text'),
43719      placeholder: (0,external_wp_i18n_namespaceObject.__)('Add caption'),
43720      value: caption,
43721      onChange: value => setAttributes({
43722        caption: value
43723      }) // Deselect the selected table cell when the caption is focused.
43724      ,
43725      unstableOnFocus: () => setSelectedCell(),
43726      __unstableOnSplitAtEnd: () => insertBlocksAfter((0,external_wp_blocks_namespaceObject.createBlock)('core/paragraph'))
43727    }), isEmpty && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Placeholder, {
43728      label: (0,external_wp_i18n_namespaceObject.__)('Table'),
43729      icon: (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockIcon, {
43730        icon: block_table,
43731        showColors: true
43732      }),
43733      instructions: (0,external_wp_i18n_namespaceObject.__)('Insert a table for sharing data.')
43734    }, (0,external_wp_element_namespaceObject.createElement)("form", {
43735      className: "blocks-table__placeholder-form",
43736      onSubmit: onCreateTable
43737    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TextControl, {
43738      type: "number",
43739      label: (0,external_wp_i18n_namespaceObject.__)('Column count'),
43740      value: initialColumnCount,
43741      onChange: onChangeInitialColumnCount,
43742      min: "1",
43743      className: "blocks-table__placeholder-input"
43744    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TextControl, {
43745      type: "number",
43746      label: (0,external_wp_i18n_namespaceObject.__)('Row count'),
43747      value: initialRowCount,
43748      onChange: onChangeInitialRowCount,
43749      min: "1",
43750      className: "blocks-table__placeholder-input"
43751    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
43752      className: "blocks-table__placeholder-button",
43753      variant: "primary",
43754      type: "submit"
43755    }, (0,external_wp_i18n_namespaceObject.__)('Create Table')))));
43756  }
43757  
43758  /* harmony default export */ var table_edit = (TableEdit);
43759  
43760  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/table/save.js
43761  
43762  
43763  /**
43764   * External dependencies
43765   */
43766  
43767  /**
43768   * WordPress dependencies
43769   */
43770  
43771  
43772  function table_save_save(_ref) {
43773    let {
43774      attributes
43775    } = _ref;
43776    const {
43777      hasFixedLayout,
43778      head,
43779      body,
43780      foot,
43781      caption
43782    } = attributes;
43783    const isEmpty = !head.length && !body.length && !foot.length;
43784  
43785    if (isEmpty) {
43786      return null;
43787    }
43788  
43789    const colorProps = (0,external_wp_blockEditor_namespaceObject.__experimentalGetColorClassesAndStyles)(attributes);
43790    const borderProps = (0,external_wp_blockEditor_namespaceObject.__experimentalGetBorderClassesAndStyles)(attributes);
43791    const classes = classnames_default()(colorProps.className, borderProps.className, {
43792      'has-fixed-layout': hasFixedLayout
43793    });
43794    const hasCaption = !external_wp_blockEditor_namespaceObject.RichText.isEmpty(caption);
43795  
43796    const Section = _ref2 => {
43797      let {
43798        type,
43799        rows
43800      } = _ref2;
43801  
43802      if (!rows.length) {
43803        return null;
43804      }
43805  
43806      const Tag = `t$type}`;
43807      return (0,external_wp_element_namespaceObject.createElement)(Tag, null, rows.map((_ref3, rowIndex) => {
43808        let {
43809          cells
43810        } = _ref3;
43811        return (0,external_wp_element_namespaceObject.createElement)("tr", {
43812          key: rowIndex
43813        }, cells.map((_ref4, cellIndex) => {
43814          let {
43815            content,
43816            tag,
43817            scope,
43818            align
43819          } = _ref4;
43820          const cellClasses = classnames_default()({
43821            [`has-text-align-$align}`]: align
43822          });
43823          return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
43824            className: cellClasses ? cellClasses : undefined,
43825            "data-align": align,
43826            tagName: tag,
43827            value: content,
43828            key: cellIndex,
43829            scope: tag === 'th' ? scope : undefined
43830          });
43831        }));
43832      }));
43833    };
43834  
43835    return (0,external_wp_element_namespaceObject.createElement)("figure", external_wp_blockEditor_namespaceObject.useBlockProps.save(), (0,external_wp_element_namespaceObject.createElement)("table", {
43836      className: classes === '' ? undefined : classes,
43837      style: { ...colorProps.style,
43838        ...borderProps.style
43839      }
43840    }, (0,external_wp_element_namespaceObject.createElement)(Section, {
43841      type: "head",
43842      rows: head
43843    }), (0,external_wp_element_namespaceObject.createElement)(Section, {
43844      type: "body",
43845      rows: body
43846    }), (0,external_wp_element_namespaceObject.createElement)(Section, {
43847      type: "foot",
43848      rows: foot
43849    })), hasCaption && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
43850      tagName: "figcaption",
43851      value: caption
43852    }));
43853  }
43854  
43855  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/table/transforms.js
43856  const tableContentPasteSchema = _ref => {
43857    let {
43858      phrasingContentSchema
43859    } = _ref;
43860    return {
43861      tr: {
43862        allowEmpty: true,
43863        children: {
43864          th: {
43865            allowEmpty: true,
43866            children: phrasingContentSchema,
43867            attributes: ['scope']
43868          },
43869          td: {
43870            allowEmpty: true,
43871            children: phrasingContentSchema
43872          }
43873        }
43874      }
43875    };
43876  };
43877  
43878  const tablePasteSchema = args => ({
43879    table: {
43880      children: {
43881        thead: {
43882          allowEmpty: true,
43883          children: tableContentPasteSchema(args)
43884        },
43885        tfoot: {
43886          allowEmpty: true,
43887          children: tableContentPasteSchema(args)
43888        },
43889        tbody: {
43890          allowEmpty: true,
43891          children: tableContentPasteSchema(args)
43892        }
43893      }
43894    }
43895  });
43896  
43897  const table_transforms_transforms = {
43898    from: [{
43899      type: 'raw',
43900      selector: 'table',
43901      schema: tablePasteSchema
43902    }]
43903  };
43904  /* harmony default export */ var table_transforms = (table_transforms_transforms);
43905  
43906  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/table/index.js
43907  /**
43908   * WordPress dependencies
43909   */
43910  
43911  
43912  /**
43913   * Internal dependencies
43914   */
43915  
43916  
43917  
43918  const table_metadata = {
43919    $schema: "https://schemas.wp.org/trunk/block.json",
43920    apiVersion: 2,
43921    name: "core/table",
43922    title: "Table",
43923    category: "text",
43924    description: "Create structured content in rows and columns to display information.",
43925    textdomain: "default",
43926    attributes: {
43927      hasFixedLayout: {
43928        type: "boolean",
43929        "default": false
43930      },
43931      caption: {
43932        type: "string",
43933        source: "html",
43934        selector: "figcaption",
43935        "default": ""
43936      },
43937      head: {
43938        type: "array",
43939        "default": [],
43940        source: "query",
43941        selector: "thead tr",
43942        query: {
43943          cells: {
43944            type: "array",
43945            "default": [],
43946            source: "query",
43947            selector: "td,th",
43948            query: {
43949              content: {
43950                type: "string",
43951                source: "html"
43952              },
43953              tag: {
43954                type: "string",
43955                "default": "td",
43956                source: "tag"
43957              },
43958              scope: {
43959                type: "string",
43960                source: "attribute",
43961                attribute: "scope"
43962              },
43963              align: {
43964                type: "string",
43965                source: "attribute",
43966                attribute: "data-align"
43967              }
43968            }
43969          }
43970        }
43971      },
43972      body: {
43973        type: "array",
43974        "default": [],
43975        source: "query",
43976        selector: "tbody tr",
43977        query: {
43978          cells: {
43979            type: "array",
43980            "default": [],
43981            source: "query",
43982            selector: "td,th",
43983            query: {
43984              content: {
43985                type: "string",
43986                source: "html"
43987              },
43988              tag: {
43989                type: "string",
43990                "default": "td",
43991                source: "tag"
43992              },
43993              scope: {
43994                type: "string",
43995                source: "attribute",
43996                attribute: "scope"
43997              },
43998              align: {
43999                type: "string",
44000                source: "attribute",
44001                attribute: "data-align"
44002              }
44003            }
44004          }
44005        }
44006      },
44007      foot: {
44008        type: "array",
44009        "default": [],
44010        source: "query",
44011        selector: "tfoot tr",
44012        query: {
44013          cells: {
44014            type: "array",
44015            "default": [],
44016            source: "query",
44017            selector: "td,th",
44018            query: {
44019              content: {
44020                type: "string",
44021                source: "html"
44022              },
44023              tag: {
44024                type: "string",
44025                "default": "td",
44026                source: "tag"
44027              },
44028              scope: {
44029                type: "string",
44030                source: "attribute",
44031                attribute: "scope"
44032              },
44033              align: {
44034                type: "string",
44035                source: "attribute",
44036                attribute: "data-align"
44037              }
44038            }
44039          }
44040        }
44041      }
44042    },
44043    supports: {
44044      anchor: true,
44045      align: true,
44046      color: {
44047        __experimentalSkipSerialization: true,
44048        gradients: true,
44049        __experimentalDefaultControls: {
44050          background: true,
44051          text: true
44052        }
44053      },
44054      typography: {
44055        fontSize: true,
44056        lineHeight: true,
44057        __experimentalFontStyle: true,
44058        __experimentalFontWeight: true,
44059        __experimentalLetterSpacing: true,
44060        __experimentalTextTransform: true,
44061        __experimentalDefaultControls: {
44062          fontSize: true
44063        }
44064      },
44065      __experimentalBorder: {
44066        __experimentalSkipSerialization: true,
44067        color: true,
44068        style: true,
44069        width: true,
44070        __experimentalDefaultControls: {
44071          color: true,
44072          style: true,
44073          width: true
44074        }
44075      },
44076      __experimentalSelector: ".wp-block-table > table"
44077    },
44078    styles: [{
44079      name: "regular",
44080      label: "Default",
44081      isDefault: true
44082    }, {
44083      name: "stripes",
44084      label: "Stripes"
44085    }],
44086    editorStyle: "wp-block-table-editor",
44087    style: "wp-block-table"
44088  };
44089  
44090  
44091  const {
44092    name: table_name
44093  } = table_metadata;
44094  
44095  const table_settings = {
44096    icon: block_table,
44097    example: {
44098      attributes: {
44099        head: [{
44100          cells: [{
44101            content: (0,external_wp_i18n_namespaceObject.__)('Version'),
44102            tag: 'th'
44103          }, {
44104            content: (0,external_wp_i18n_namespaceObject.__)('Jazz Musician'),
44105            tag: 'th'
44106          }, {
44107            content: (0,external_wp_i18n_namespaceObject.__)('Release Date'),
44108            tag: 'th'
44109          }]
44110        }],
44111        body: [{
44112          cells: [{
44113            content: '5.2',
44114            tag: 'td'
44115          }, {
44116            content: 'Jaco Pastorius',
44117            tag: 'td'
44118          }, {
44119            content: (0,external_wp_i18n_namespaceObject.__)('May 7, 2019'),
44120            tag: 'td'
44121          }]
44122        }, {
44123          cells: [{
44124            content: '5.1',
44125            tag: 'td'
44126          }, {
44127            content: 'Betty Carter',
44128            tag: 'td'
44129          }, {
44130            content: (0,external_wp_i18n_namespaceObject.__)('February 21, 2019'),
44131            tag: 'td'
44132          }]
44133        }, {
44134          cells: [{
44135            content: '5.0',
44136            tag: 'td'
44137          }, {
44138            content: 'Bebo Valdés',
44139            tag: 'td'
44140          }, {
44141            content: (0,external_wp_i18n_namespaceObject.__)('December 6, 2018'),
44142            tag: 'td'
44143          }]
44144        }]
44145      }
44146    },
44147    transforms: table_transforms,
44148    edit: table_edit,
44149    save: table_save_save,
44150    deprecated: table_deprecated
44151  };
44152  
44153  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/tag-cloud/transforms.js
44154  /**
44155   * WordPress dependencies
44156   */
44157  
44158  const tag_cloud_transforms_transforms = {
44159    from: [{
44160      type: 'block',
44161      blocks: ['core/categories'],
44162      transform: () => (0,external_wp_blocks_namespaceObject.createBlock)('core/tag-cloud')
44163    }],
44164    to: [{
44165      type: 'block',
44166      blocks: ['core/categories'],
44167      transform: () => (0,external_wp_blocks_namespaceObject.createBlock)('core/categories')
44168    }]
44169  };
44170  /* harmony default export */ var tag_cloud_transforms = (tag_cloud_transforms_transforms);
44171  
44172  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/tag-cloud/edit.js
44173  
44174  
44175  /**
44176   * External dependencies
44177   */
44178  
44179  /**
44180   * WordPress dependencies
44181   */
44182  
44183  
44184  
44185  
44186  
44187  
44188  
44189  /**
44190   * Minimum number of tags a user can show using this block.
44191   *
44192   * @type {number}
44193   */
44194  
44195  const MIN_TAGS = 1;
44196  /**
44197   * Maximum number of tags a user can show using this block.
44198   *
44199   * @type {number}
44200   */
44201  
44202  const MAX_TAGS = 100;
44203  const MIN_FONT_SIZE = 0.1;
44204  const MAX_FONT_SIZE = 100;
44205  
44206  function TagCloudEdit(_ref) {
44207    let {
44208      attributes,
44209      setAttributes,
44210      taxonomies
44211    } = _ref;
44212    const {
44213      taxonomy,
44214      showTagCounts,
44215      numberOfTags,
44216      smallestFontSize,
44217      largestFontSize
44218    } = attributes;
44219    const units = (0,external_wp_components_namespaceObject.__experimentalUseCustomUnits)({
44220      availableUnits: (0,external_wp_blockEditor_namespaceObject.useSetting)('spacing.units') || ['%', 'px', 'em', 'rem']
44221    });
44222  
44223    const getTaxonomyOptions = () => {
44224      const selectOption = {
44225        label: (0,external_wp_i18n_namespaceObject.__)('- Select -'),
44226        value: '',
44227        disabled: true
44228      };
44229      const taxonomyOptions = (0,external_lodash_namespaceObject.map)((0,external_lodash_namespaceObject.filter)(taxonomies, 'show_cloud'), item => {
44230        return {
44231          value: item.slug,
44232          label: item.name
44233        };
44234      });
44235      return [selectOption, ...taxonomyOptions];
44236    };
44237  
44238    const onFontSizeChange = (fontSizeLabel, newValue) => {
44239      // eslint-disable-next-line @wordpress/no-unused-vars-before-return
44240      const [quantity, newUnit] = (0,external_wp_components_namespaceObject.__experimentalParseQuantityAndUnitFromRawValue)(newValue);
44241  
44242      if (!Number.isFinite(quantity)) {
44243        return;
44244      }
44245  
44246      const updateObj = {
44247        [fontSizeLabel]: newValue
44248      }; // We need to keep in sync the `unit` changes to both `smallestFontSize`
44249      // and `largestFontSize` attributes.
44250  
44251      Object.entries({
44252        smallestFontSize,
44253        largestFontSize
44254      }).forEach(_ref2 => {
44255        let [attribute, currentValue] = _ref2;
44256        const [currentQuantity, currentUnit] = (0,external_wp_components_namespaceObject.__experimentalParseQuantityAndUnitFromRawValue)(currentValue); // Only add an update if the other font size attribute has a different unit.
44257  
44258        if (attribute !== fontSizeLabel && currentUnit !== newUnit) {
44259          updateObj[attribute] = `$currentQuantity}$newUnit}`;
44260        }
44261      });
44262      setAttributes(updateObj);
44263    };
44264  
44265    const inspectorControls = (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
44266      title: (0,external_wp_i18n_namespaceObject.__)('Tag Cloud settings')
44267    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SelectControl, {
44268      label: (0,external_wp_i18n_namespaceObject.__)('Taxonomy'),
44269      options: getTaxonomyOptions(),
44270      value: taxonomy,
44271      onChange: selectedTaxonomy => setAttributes({
44272        taxonomy: selectedTaxonomy
44273      })
44274    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
44275      label: (0,external_wp_i18n_namespaceObject.__)('Show post counts'),
44276      checked: showTagCounts,
44277      onChange: () => setAttributes({
44278        showTagCounts: !showTagCounts
44279      })
44280    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.RangeControl, {
44281      label: (0,external_wp_i18n_namespaceObject.__)('Number of tags'),
44282      value: numberOfTags,
44283      onChange: value => setAttributes({
44284        numberOfTags: value
44285      }),
44286      min: MIN_TAGS,
44287      max: MAX_TAGS,
44288      required: true
44289    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Flex, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.FlexItem, {
44290      isBlock: true
44291    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalUnitControl, {
44292      label: (0,external_wp_i18n_namespaceObject.__)('Smallest size'),
44293      value: smallestFontSize,
44294      onChange: value => {
44295        onFontSizeChange('smallestFontSize', value);
44296      },
44297      units: units,
44298      min: MIN_FONT_SIZE,
44299      max: MAX_FONT_SIZE
44300    })), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.FlexItem, {
44301      isBlock: true
44302    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.__experimentalUnitControl, {
44303      label: (0,external_wp_i18n_namespaceObject.__)('Largest size'),
44304      value: largestFontSize,
44305      onChange: value => {
44306        onFontSizeChange('largestFontSize', value);
44307      },
44308      units: units,
44309      min: MIN_FONT_SIZE,
44310      max: MAX_FONT_SIZE
44311    })))));
44312    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, inspectorControls, (0,external_wp_element_namespaceObject.createElement)("div", (0,external_wp_blockEditor_namespaceObject.useBlockProps)(), (0,external_wp_element_namespaceObject.createElement)((external_wp_serverSideRender_default()), {
44313      key: "tag-cloud",
44314      block: "core/tag-cloud",
44315      attributes: attributes
44316    })));
44317  }
44318  
44319  /* harmony default export */ var tag_cloud_edit = ((0,external_wp_data_namespaceObject.withSelect)(select => {
44320    return {
44321      taxonomies: select(external_wp_coreData_namespaceObject.store).getTaxonomies({
44322        per_page: -1
44323      })
44324    };
44325  })(TagCloudEdit));
44326  
44327  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/tag-cloud/index.js
44328  /**
44329   * WordPress dependencies
44330   */
44331  
44332  /**
44333   * Internal dependencies
44334   */
44335  
44336  
44337  const tag_cloud_metadata = {
44338    $schema: "https://schemas.wp.org/trunk/block.json",
44339    apiVersion: 2,
44340    name: "core/tag-cloud",
44341    title: "Tag Cloud",
44342    category: "widgets",
44343    description: "A cloud of your most used tags.",
44344    textdomain: "default",
44345    attributes: {
44346      numberOfTags: {
44347        type: "number",
44348        "default": 45,
44349        minimum: 1,
44350        maximum: 100
44351      },
44352      taxonomy: {
44353        type: "string",
44354        "default": "post_tag"
44355      },
44356      showTagCounts: {
44357        type: "boolean",
44358        "default": false
44359      },
44360      smallestFontSize: {
44361        type: "string",
44362        "default": "8pt"
44363      },
44364      largestFontSize: {
44365        type: "string",
44366        "default": "22pt"
44367      }
44368    },
44369    styles: [{
44370      name: "default",
44371      label: "Default",
44372      isDefault: true
44373    }, {
44374      name: "outline",
44375      label: "Outline"
44376    }],
44377    supports: {
44378      html: false,
44379      align: true
44380    },
44381    editorStyle: "wp-block-tag-cloud-editor"
44382  };
44383  
44384  const {
44385    name: tag_cloud_name
44386  } = tag_cloud_metadata;
44387  
44388  const tag_cloud_settings = {
44389    icon: library_tag,
44390    example: {},
44391    edit: tag_cloud_edit,
44392    transforms: tag_cloud_transforms
44393  };
44394  
44395  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/symbol-filled.js
44396  
44397  
44398  /**
44399   * WordPress dependencies
44400   */
44401  
44402  const symbolFilled = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
44403    xmlns: "http://www.w3.org/2000/svg",
44404    viewBox: "0 0 24 24"
44405  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
44406    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"
44407  }));
44408  /* harmony default export */ var symbol_filled = (symbolFilled);
44409  
44410  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/template-part/edit/utils/hooks.js
44411  /**
44412   * External dependencies
44413   */
44414  
44415  /**
44416   * WordPress dependencies
44417   */
44418  
44419  
44420  
44421  
44422  
44423  
44424  
44425  /**
44426   * Internal dependencies
44427   */
44428  
44429  
44430  /**
44431   * Retrieves the available template parts for the given area.
44432   *
44433   * @param {string} area       Template part area.
44434   * @param {string} excludedId Template part ID to exclude.
44435   *
44436   * @return {{ templateParts: Array, isResolving: boolean }} array of template parts.
44437   */
44438  
44439  function useAlternativeTemplateParts(area, excludedId) {
44440    const {
44441      templateParts,
44442      isResolving
44443    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
44444      const {
44445        getEntityRecords,
44446        isResolving: _isResolving
44447      } = select(external_wp_coreData_namespaceObject.store);
44448      const query = {
44449        per_page: -1
44450      };
44451      return {
44452        templateParts: getEntityRecords('postType', 'wp_template_part', query),
44453        isLoading: _isResolving('getEntityRecords', ['postType', 'wp_template_part', query])
44454      };
44455    }, []);
44456    const filteredTemplateParts = (0,external_wp_element_namespaceObject.useMemo)(() => {
44457      if (!templateParts) {
44458        return [];
44459      }
44460  
44461      return templateParts.filter(templatePart => createTemplatePartId(templatePart.theme, templatePart.slug) !== excludedId && (!area || 'uncategorized' === area || templatePart.area === area)) || [];
44462    }, [templateParts, area]);
44463    return {
44464      templateParts: filteredTemplateParts,
44465      isResolving
44466    };
44467  }
44468  /**
44469   * Retrieves the available block patterns for the given area.
44470   *
44471   * @param {string} area     Template part area.
44472   * @param {string} clientId Block Client ID. (The container of the block can impact allowed blocks).
44473   *
44474   * @return {Array} array of block patterns.
44475   */
44476  
44477  function useAlternativeBlockPatterns(area, clientId) {
44478    return (0,external_wp_data_namespaceObject.useSelect)(select => {
44479      const blockNameWithArea = area ? `core/template-part/$area}` : 'core/template-part';
44480      const {
44481        getBlockRootClientId,
44482        __experimentalGetPatternsByBlockTypes
44483      } = select(external_wp_blockEditor_namespaceObject.store);
44484      const rootClientId = getBlockRootClientId(clientId);
44485      return __experimentalGetPatternsByBlockTypes(blockNameWithArea, rootClientId);
44486    }, [area, clientId]);
44487  }
44488  function useCreateTemplatePartFromBlocks(area, setAttributes) {
44489    const {
44490      saveEntityRecord
44491    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_coreData_namespaceObject.store);
44492    return async function () {
44493      let blocks = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
44494      let title = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : (0,external_wp_i18n_namespaceObject.__)('Untitled Template Part');
44495      // Currently template parts only allow latin chars.
44496      // Fallback slug will receive suffix by default.
44497      const cleanSlug = (0,external_lodash_namespaceObject.kebabCase)(title).replace(/[^\w-]+/g, '') || 'wp-custom-part'; // If we have `area` set from block attributes, means an exposed
44498      // block variation was inserted. So add this prop to the template
44499      // part entity on creation. Afterwards remove `area` value from
44500      // block attributes.
44501  
44502      const record = {
44503        title,
44504        slug: cleanSlug,
44505        content: (0,external_wp_blocks_namespaceObject.serialize)(blocks),
44506        // `area` is filterable on the server and defaults to `UNCATEGORIZED`
44507        // if provided value is not allowed.
44508        area
44509      };
44510      const templatePart = await saveEntityRecord('postType', 'wp_template_part', record);
44511      setAttributes({
44512        slug: templatePart.slug,
44513        theme: templatePart.theme,
44514        area: undefined
44515      });
44516    };
44517  }
44518  /**
44519   * Retrieves the template part area object.
44520   *
44521   * @param {string} area Template part area identifier.
44522   *
44523   * @return {{icon: Object, label: string, tagName: string}} Template Part area.
44524   */
44525  
44526  function useTemplatePartArea(area) {
44527    return (0,external_wp_data_namespaceObject.useSelect)(select => {
44528      var _selectedArea$area_ta;
44529  
44530      // FIXME: @wordpress/block-library should not depend on @wordpress/editor.
44531      // Blocks can be loaded into a *non-post* block editor.
44532      // eslint-disable-next-line @wordpress/data-no-store-string-literals
44533      const definedAreas = select('core/editor').__experimentalGetDefaultTemplatePartAreas();
44534  
44535      const selectedArea = (0,external_lodash_namespaceObject.find)(definedAreas, {
44536        area
44537      });
44538      const defaultArea = (0,external_lodash_namespaceObject.find)(definedAreas, {
44539        area: 'uncategorized'
44540      });
44541      return {
44542        icon: (selectedArea === null || selectedArea === void 0 ? void 0 : selectedArea.icon) || (defaultArea === null || defaultArea === void 0 ? void 0 : defaultArea.icon),
44543        label: (selectedArea === null || selectedArea === void 0 ? void 0 : selectedArea.label) || (0,external_wp_i18n_namespaceObject.__)('Template Part'),
44544        tagName: (_selectedArea$area_ta = selectedArea === null || selectedArea === void 0 ? void 0 : selectedArea.area_tag) !== null && _selectedArea$area_ta !== void 0 ? _selectedArea$area_ta : 'div'
44545      };
44546    }, [area]);
44547  }
44548  
44549  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/template-part/edit/title-modal.js
44550  
44551  
44552  /**
44553   * WordPress dependencies
44554   */
44555  
44556  
44557  
44558  function TitleModal(_ref) {
44559    let {
44560      areaLabel,
44561      onClose,
44562      onSubmit
44563    } = _ref;
44564    // Restructure onCreate to set the blocks on local state.
44565    // Add modal to confirm title and trigger onCreate.
44566    const [title, setTitle] = (0,external_wp_element_namespaceObject.useState)((0,external_wp_i18n_namespaceObject.__)('Untitled Template Part'));
44567  
44568    const submitForCreation = event => {
44569      event.preventDefault();
44570      onSubmit(title);
44571    };
44572  
44573    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Modal, {
44574      title: (0,external_wp_i18n_namespaceObject.sprintf)( // Translators: %s as template part area title ("Header", "Footer", etc.).
44575      (0,external_wp_i18n_namespaceObject.__)('Name and create your new %s'), areaLabel.toLowerCase()),
44576      closeLabel: (0,external_wp_i18n_namespaceObject.__)('Cancel'),
44577      overlayClassName: "wp-block-template-part__placeholder-create-new__title-form",
44578      onRequestClose: onClose
44579    }, (0,external_wp_element_namespaceObject.createElement)("form", {
44580      onSubmit: submitForCreation
44581    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TextControl, {
44582      label: (0,external_wp_i18n_namespaceObject.__)('Name'),
44583      value: title,
44584      onChange: setTitle
44585    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Flex, {
44586      className: "wp-block-template-part__placeholder-create-new__title-form-actions",
44587      justify: "flex-end"
44588    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.FlexItem, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
44589      variant: "primary",
44590      type: "submit",
44591      disabled: !title.length,
44592      "aria-disabled": !title.length
44593    }, (0,external_wp_i18n_namespaceObject.__)('Create'))))));
44594  }
44595  
44596  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/template-part/edit/placeholder.js
44597  
44598  
44599  /**
44600   * WordPress dependencies
44601   */
44602  
44603  
44604  
44605  /**
44606   * Internal dependencies
44607   */
44608  
44609  
44610  
44611  function TemplatePartPlaceholder(_ref) {
44612    let {
44613      area,
44614      clientId,
44615      templatePartId,
44616      onOpenSelectionModal,
44617      setAttributes
44618    } = _ref;
44619    const {
44620      templateParts,
44621      isResolving
44622    } = useAlternativeTemplateParts(area, templatePartId);
44623    const blockPatterns = useAlternativeBlockPatterns(area, clientId);
44624    const [showTitleModal, setShowTitleModal] = (0,external_wp_element_namespaceObject.useState)(false);
44625    const areaObject = useTemplatePartArea(area);
44626    const createFromBlocks = useCreateTemplatePartFromBlocks(area, setAttributes);
44627    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Placeholder, {
44628      icon: areaObject.icon,
44629      label: areaObject.label,
44630      instructions: (0,external_wp_i18n_namespaceObject.sprintf)( // Translators: %s as template part area title ("Header", "Footer", etc.).
44631      (0,external_wp_i18n_namespaceObject.__)('Choose an existing %s or create a new one.'), areaObject.label.toLowerCase())
44632    }, isResolving && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Spinner, null), !isResolving && !!(templateParts.length || blockPatterns.length) && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
44633      variant: "primary",
44634      onClick: onOpenSelectionModal
44635    }, (0,external_wp_i18n_namespaceObject.__)('Choose')), !isResolving && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
44636      variant: "secondary",
44637      onClick: () => {
44638        setShowTitleModal(true);
44639      }
44640    }, (0,external_wp_i18n_namespaceObject.__)('Start blank')), showTitleModal && (0,external_wp_element_namespaceObject.createElement)(TitleModal, {
44641      areaLabel: areaObject.label,
44642      onClose: () => setShowTitleModal(false),
44643      onSubmit: title => {
44644        createFromBlocks([], title);
44645      }
44646    }));
44647  }
44648  
44649  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/template-part/edit/selection-modal.js
44650  
44651  
44652  /**
44653   * WordPress dependencies
44654   */
44655  
44656  
44657  
44658  
44659  
44660  
44661  
44662  /**
44663   * Internal dependencies
44664   */
44665  
44666  
44667  
44668  function TemplatePartSelectionModal(_ref) {
44669    let {
44670      setAttributes,
44671      onClose,
44672      templatePartId = null,
44673      area,
44674      clientId
44675    } = _ref;
44676    // When the templatePartId is undefined,
44677    // it means the user is creating a new one from the placeholder.
44678    const isReplacingTemplatePartContent = !!templatePartId;
44679    const {
44680      templateParts
44681    } = useAlternativeTemplateParts(area, templatePartId); // We can map template parts to block patters to reuse the BlockPatternsList UI
44682  
44683    const templartPartsAsBlockPatterns = (0,external_wp_element_namespaceObject.useMemo)(() => {
44684      return templateParts.map(templatePart => ({
44685        name: createTemplatePartId(templatePart.theme, templatePart.slug),
44686        title: templatePart.title.rendered,
44687        blocks: (0,external_wp_blocks_namespaceObject.parse)(templatePart.content.raw),
44688        templatePart
44689      }));
44690    }, [templateParts]);
44691    const shownTemplateParts = (0,external_wp_compose_namespaceObject.useAsyncList)(templartPartsAsBlockPatterns);
44692    const {
44693      createSuccessNotice
44694    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_notices_namespaceObject.store);
44695    const blockPatterns = useAlternativeBlockPatterns(area, clientId);
44696    const shownBlockPatterns = (0,external_wp_compose_namespaceObject.useAsyncList)(blockPatterns);
44697    const {
44698      replaceInnerBlocks
44699    } = (0,external_wp_data_namespaceObject.useDispatch)(external_wp_blockEditor_namespaceObject.store);
44700    const onTemplatePartSelect = (0,external_wp_element_namespaceObject.useCallback)(templatePart => {
44701      var _templatePart$title;
44702  
44703      setAttributes({
44704        slug: templatePart.slug,
44705        theme: templatePart.theme,
44706        area: undefined
44707      });
44708      createSuccessNotice((0,external_wp_i18n_namespaceObject.sprintf)(
44709      /* translators: %s: template part title. */
44710      (0,external_wp_i18n_namespaceObject.__)('Template Part "%s" inserted.'), ((_templatePart$title = templatePart.title) === null || _templatePart$title === void 0 ? void 0 : _templatePart$title.rendered) || templatePart.slug), {
44711        type: 'snackbar'
44712      });
44713      onClose();
44714    }, []);
44715    const createFromBlocks = useCreateTemplatePartFromBlocks(area, setAttributes);
44716    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)("div", {
44717      className: "block-library-template-part__selection-content"
44718    }, !!templartPartsAsBlockPatterns.length && (0,external_wp_element_namespaceObject.createElement)("div", null, (0,external_wp_element_namespaceObject.createElement)("h2", null, (0,external_wp_i18n_namespaceObject.__)('Existing template parts')), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.__experimentalBlockPatternsList, {
44719      blockPatterns: templartPartsAsBlockPatterns,
44720      shownPatterns: shownTemplateParts,
44721      onClickPattern: pattern => {
44722        onTemplatePartSelect(pattern.templatePart);
44723      }
44724    })), !!blockPatterns.length && (0,external_wp_element_namespaceObject.createElement)("div", null, (0,external_wp_element_namespaceObject.createElement)("h2", null, (0,external_wp_i18n_namespaceObject.__)('Patterns')), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.__experimentalBlockPatternsList, {
44725      blockPatterns: blockPatterns,
44726      shownPatterns: shownBlockPatterns,
44727      onClickPattern: (pattern, blocks) => {
44728        if (isReplacingTemplatePartContent) {
44729          replaceInnerBlocks(clientId, blocks);
44730        } else {
44731          createFromBlocks(blocks, pattern.title);
44732        }
44733  
44734        onClose();
44735      }
44736    }))));
44737  }
44738  
44739  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/template-part/edit/advanced-controls.js
44740  
44741  
44742  /**
44743   * WordPress dependencies
44744   */
44745  
44746  
44747  
44748  
44749  
44750  function TemplatePartAdvancedControls(_ref) {
44751    let {
44752      tagName,
44753      setAttributes,
44754      isEntityAvailable,
44755      templatePartId,
44756      defaultWrapper
44757    } = _ref;
44758    const [area, setArea] = (0,external_wp_coreData_namespaceObject.useEntityProp)('postType', 'wp_template_part', 'area', templatePartId);
44759    const [title, setTitle] = (0,external_wp_coreData_namespaceObject.useEntityProp)('postType', 'wp_template_part', 'title', templatePartId);
44760    const {
44761      areaOptions
44762    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
44763      // FIXME: @wordpress/block-library should not depend on @wordpress/editor.
44764      // Blocks can be loaded into a *non-post* block editor.
44765      // eslint-disable-next-line @wordpress/data-no-store-string-literals
44766      const definedAreas = select('core/editor').__experimentalGetDefaultTemplatePartAreas();
44767  
44768      return {
44769        areaOptions: definedAreas.map(_ref2 => {
44770          let {
44771            label,
44772            area: _area
44773          } = _ref2;
44774          return {
44775            label,
44776            value: _area
44777          };
44778        })
44779      };
44780    }, []);
44781    return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, {
44782      __experimentalGroup: "advanced"
44783    }, isEntityAvailable && (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TextControl, {
44784      label: (0,external_wp_i18n_namespaceObject.__)('Title'),
44785      value: title,
44786      onChange: value => {
44787        setTitle(value);
44788      },
44789      onFocus: event => event.target.select()
44790    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SelectControl, {
44791      label: (0,external_wp_i18n_namespaceObject.__)('Area'),
44792      labelPosition: "top",
44793      options: areaOptions,
44794      value: area,
44795      onChange: setArea
44796    })), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SelectControl, {
44797      label: (0,external_wp_i18n_namespaceObject.__)('HTML element'),
44798      options: [{
44799        label: (0,external_wp_i18n_namespaceObject.sprintf)(
44800        /* translators: %s: HTML tag based on area. */
44801        (0,external_wp_i18n_namespaceObject.__)('Default based on area (%s)'), `<$defaultWrapper}>`),
44802        value: ''
44803      }, {
44804        label: '<header>',
44805        value: 'header'
44806      }, {
44807        label: '<main>',
44808        value: 'main'
44809      }, {
44810        label: '<section>',
44811        value: 'section'
44812      }, {
44813        label: '<article>',
44814        value: 'article'
44815      }, {
44816        label: '<aside>',
44817        value: 'aside'
44818      }, {
44819        label: '<footer>',
44820        value: 'footer'
44821      }, {
44822        label: '<div>',
44823        value: 'div'
44824      }],
44825      value: tagName || '',
44826      onChange: value => setAttributes({
44827        tagName: value
44828      })
44829    }));
44830  }
44831  
44832  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/template-part/edit/inner-blocks.js
44833  
44834  
44835  /**
44836   * WordPress dependencies
44837   */
44838  
44839  
44840  
44841  function TemplatePartInnerBlocks(_ref) {
44842    let {
44843      postId: id,
44844      hasInnerBlocks,
44845      layout,
44846      tagName,
44847      blockProps,
44848      clientId
44849    } = _ref;
44850    const themeSupportsLayout = (0,external_wp_data_namespaceObject.useSelect)(select => {
44851      var _getSettings;
44852  
44853      const {
44854        getSettings
44855      } = select(external_wp_blockEditor_namespaceObject.store);
44856      return (_getSettings = getSettings()) === null || _getSettings === void 0 ? void 0 : _getSettings.supportsLayout;
44857    }, []);
44858    const defaultLayout = (0,external_wp_blockEditor_namespaceObject.useSetting)('layout') || {};
44859    const usedLayout = !!layout && layout.inherit ? defaultLayout : layout;
44860    const [blocks, onInput, onChange] = (0,external_wp_coreData_namespaceObject.useEntityBlockEditor)('postType', 'wp_template_part', {
44861      id
44862    });
44863    const innerBlocksProps = (0,external_wp_blockEditor_namespaceObject.useInnerBlocksProps)(blockProps, {
44864      value: blocks,
44865      onInput,
44866      onChange,
44867      renderAppender: hasInnerBlocks ? undefined : external_wp_blockEditor_namespaceObject.InnerBlocks.ButtonBlockAppender,
44868      __experimentalLayout: themeSupportsLayout ? usedLayout : undefined
44869    });
44870    return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.__experimentalBlockContentOverlay, {
44871      clientId: clientId,
44872      tagName: tagName,
44873      wrapperProps: innerBlocksProps
44874    });
44875  }
44876  
44877  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/template-part/edit/index.js
44878  
44879  
44880  /**
44881   * External dependencies
44882   */
44883  
44884  /**
44885   * WordPress dependencies
44886   */
44887  
44888  
44889  
44890  
44891  
44892  
44893  
44894  /**
44895   * Internal dependencies
44896   */
44897  
44898  
44899  
44900  
44901  
44902  
44903  
44904  function TemplatePartEdit(_ref) {
44905    let {
44906      attributes,
44907      setAttributes,
44908      clientId
44909    } = _ref;
44910    const {
44911      slug,
44912      theme,
44913      tagName,
44914      layout = {}
44915    } = attributes;
44916    const templatePartId = createTemplatePartId(theme, slug);
44917    const [hasAlreadyRendered, RecursionProvider] = (0,external_wp_blockEditor_namespaceObject.__experimentalUseNoRecursiveRenders)(templatePartId);
44918    const [isTemplatePartSelectionOpen, setIsTemplatePartSelectionOpen] = (0,external_wp_element_namespaceObject.useState)(false); // Set the postId block attribute if it did not exist,
44919    // but wait until the inner blocks have loaded to allow
44920    // new edits to trigger this.
44921  
44922    const {
44923      isResolved,
44924      innerBlocks,
44925      isMissing,
44926      area
44927    } = (0,external_wp_data_namespaceObject.useSelect)(select => {
44928      const {
44929        getEditedEntityRecord,
44930        hasFinishedResolution
44931      } = select(external_wp_coreData_namespaceObject.store);
44932      const {
44933        getBlocks
44934      } = select(external_wp_blockEditor_namespaceObject.store);
44935      const getEntityArgs = ['postType', 'wp_template_part', templatePartId];
44936      const entityRecord = templatePartId ? getEditedEntityRecord(...getEntityArgs) : null;
44937  
44938      const _area = (entityRecord === null || entityRecord === void 0 ? void 0 : entityRecord.area) || attributes.area;
44939  
44940      const hasResolvedEntity = templatePartId ? hasFinishedResolution('getEditedEntityRecord', getEntityArgs) : false;
44941      return {
44942        innerBlocks: getBlocks(clientId),
44943        isResolved: hasResolvedEntity,
44944        isMissing: hasResolvedEntity && (0,external_lodash_namespaceObject.isEmpty)(entityRecord),
44945        area: _area
44946      };
44947    }, [templatePartId, clientId]);
44948    const {
44949      templateParts
44950    } = useAlternativeTemplateParts(area, templatePartId);
44951    const blockPatterns = useAlternativeBlockPatterns(area, clientId);
44952    const hasReplacements = !!templateParts.length || !!blockPatterns.length;
44953    const areaObject = useTemplatePartArea(area);
44954    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)();
44955    const isPlaceholder = !slug;
44956    const isEntityAvailable = !isPlaceholder && !isMissing && isResolved;
44957    const TagName = tagName || areaObject.tagName; // We don't want to render a missing state if we have any inner blocks.
44958    // A new template part is automatically created if we have any inner blocks but no entity.
44959  
44960    if (innerBlocks.length === 0 && (slug && !theme || slug && isMissing)) {
44961      return (0,external_wp_element_namespaceObject.createElement)(TagName, blockProps, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.Warning, null, (0,external_wp_i18n_namespaceObject.sprintf)(
44962      /* translators: %s: Template part slug */
44963      (0,external_wp_i18n_namespaceObject.__)('Template part has been deleted or is unavailable: %s'), slug)));
44964    }
44965  
44966    if (isEntityAvailable && hasAlreadyRendered) {
44967      return (0,external_wp_element_namespaceObject.createElement)(TagName, blockProps, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.Warning, null, (0,external_wp_i18n_namespaceObject.__)('Block cannot be rendered inside itself.')));
44968    }
44969  
44970    return (0,external_wp_element_namespaceObject.createElement)(RecursionProvider, null, (0,external_wp_element_namespaceObject.createElement)(TemplatePartAdvancedControls, {
44971      tagName: tagName,
44972      setAttributes: setAttributes,
44973      isEntityAvailable: isEntityAvailable,
44974      templatePartId: templatePartId,
44975      defaultWrapper: areaObject.tagName
44976    }), isPlaceholder && (0,external_wp_element_namespaceObject.createElement)(TagName, blockProps, (0,external_wp_element_namespaceObject.createElement)(TemplatePartPlaceholder, {
44977      area: attributes.area,
44978      templatePartId: templatePartId,
44979      clientId: clientId,
44980      setAttributes: setAttributes,
44981      onOpenSelectionModal: () => setIsTemplatePartSelectionOpen(true)
44982    })), isEntityAvailable && hasReplacements && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarGroup, {
44983      className: "wp-block-template-part__block-control-group"
44984    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, {
44985      onClick: () => setIsTemplatePartSelectionOpen(true)
44986    }, (0,external_wp_i18n_namespaceObject.__)('Replace')))), isEntityAvailable && (0,external_wp_element_namespaceObject.createElement)(TemplatePartInnerBlocks, {
44987      clientId: clientId,
44988      tagName: TagName,
44989      blockProps: blockProps,
44990      postId: templatePartId,
44991      hasInnerBlocks: innerBlocks.length > 0,
44992      layout: layout
44993    }), !isPlaceholder && !isResolved && (0,external_wp_element_namespaceObject.createElement)(TagName, blockProps, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Spinner, null)), isTemplatePartSelectionOpen && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Modal, {
44994      className: "block-editor-template-part__selection-modal",
44995      title: (0,external_wp_i18n_namespaceObject.sprintf)( // Translators: %s as template part area title ("Header", "Footer", etc.).
44996      (0,external_wp_i18n_namespaceObject.__)('Choose a %s'), areaObject.label.toLowerCase()),
44997      closeLabel: (0,external_wp_i18n_namespaceObject.__)('Cancel'),
44998      onRequestClose: () => setIsTemplatePartSelectionOpen(false)
44999    }, (0,external_wp_element_namespaceObject.createElement)(TemplatePartSelectionModal, {
45000      templatePartId: templatePartId,
45001      clientId: clientId,
45002      area: area,
45003      setAttributes: setAttributes,
45004      onClose: () => setIsTemplatePartSelectionOpen(false)
45005    })));
45006  }
45007  
45008  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/header.js
45009  
45010  
45011  /**
45012   * WordPress dependencies
45013   */
45014  
45015  const header = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
45016    xmlns: "http://www.w3.org/2000/svg",
45017    viewBox: "0 0 24 24"
45018  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
45019    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"
45020  }));
45021  /* harmony default export */ var library_header = (header);
45022  
45023  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/footer.js
45024  
45025  
45026  /**
45027   * WordPress dependencies
45028   */
45029  
45030  const footer = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
45031    xmlns: "http://www.w3.org/2000/svg",
45032    viewBox: "0 0 24 24"
45033  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
45034    fillRule: "evenodd",
45035    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"
45036  }));
45037  /* harmony default export */ var library_footer = (footer);
45038  
45039  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/sidebar.js
45040  
45041  
45042  /**
45043   * WordPress dependencies
45044   */
45045  
45046  const sidebar = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
45047    xmlns: "http://www.w3.org/2000/svg",
45048    viewBox: "0 0 24 24"
45049  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
45050    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"
45051  }));
45052  /* harmony default export */ var library_sidebar = (sidebar);
45053  
45054  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/template-part/fallback-variations.js
45055  /**
45056   * WordPress dependencies
45057   */
45058  
45059  
45060  
45061  
45062  const fallback_variations_fallbackVariations = [{
45063    name: 'header',
45064    icon: library_header,
45065    title: (0,external_wp_i18n_namespaceObject.__)('Header'),
45066    description: (0,external_wp_i18n_namespaceObject.__)('The Header template defines a page area that typically contains a title, logo, and main navigation.'),
45067    attributes: {
45068      area: 'header'
45069    },
45070    scope: ['inserter']
45071  }, {
45072    name: 'footer',
45073    icon: library_footer,
45074    title: (0,external_wp_i18n_namespaceObject.__)('Footer'),
45075    description: (0,external_wp_i18n_namespaceObject.__)('The Footer template defines a page area that typically contains site credits, social links, or any other combination of blocks.'),
45076    attributes: {
45077      area: 'footer'
45078    },
45079    scope: ['inserter']
45080  }];
45081  fallback_variations_fallbackVariations.forEach(variation => {
45082    if (variation.isActive) return;
45083  
45084    variation.isActive = (blockAttributes, variationAttributes) => {
45085      const {
45086        area,
45087        theme,
45088        slug
45089      } = blockAttributes; // We first check the `area` block attribute which is set during insertion.
45090      // This property is removed on the creation of a template part.
45091  
45092      if (area) return area === variationAttributes.area; // Find a matching variation from the created template part
45093      // by checking the entity's `area` property.
45094  
45095      if (!slug) return false;
45096      const entity = (0,external_wp_data_namespaceObject.select)(external_wp_coreData_namespaceObject.store).getEntityRecord('postType', 'wp_template_part', `$theme}//${slug}`);
45097      return (entity === null || entity === void 0 ? void 0 : entity.area) === variationAttributes.area;
45098    };
45099  });
45100  /* harmony default export */ var template_part_fallback_variations = (fallback_variations_fallbackVariations);
45101  
45102  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/template-part/variations.js
45103  /**
45104   * WordPress dependencies
45105   */
45106  
45107  
45108  
45109  /**
45110   * Internal dependencies
45111   */
45112  
45113  
45114  
45115  function getTemplatePartIcon(iconName) {
45116    if ('header' === iconName) {
45117      return library_header;
45118    } else if ('footer' === iconName) {
45119      return library_footer;
45120    } else if ('sidebar' === iconName) {
45121      return library_sidebar;
45122    }
45123  
45124    return symbol_filled;
45125  }
45126  
45127  function enhanceTemplatePartVariations(settings, name) {
45128    if (name !== 'core/template-part') {
45129      return settings;
45130    } // WordPress versions pre-5.8 do not support server side variation registration.
45131    // So we must register the fallback variations until those versions are no longer supported.
45132  
45133  
45134    if (!(settings.variations && settings.variations.length)) {
45135      return { ...settings,
45136        variations: template_part_fallback_variations
45137      };
45138    }
45139  
45140    if (settings.variations) {
45141      const isActive = (blockAttributes, variationAttributes) => {
45142        const {
45143          area,
45144          theme,
45145          slug
45146        } = blockAttributes; // We first check the `area` block attribute which is set during insertion.
45147        // This property is removed on the creation of a template part.
45148  
45149        if (area) return area === variationAttributes.area; // Find a matching variation from the created template part
45150        // by checking the entity's `area` property.
45151  
45152        if (!slug) return false;
45153        const entity = (0,external_wp_data_namespaceObject.select)(external_wp_coreData_namespaceObject.store).getEntityRecord('postType', 'wp_template_part', `$theme}//${slug}`);
45154        return (entity === null || entity === void 0 ? void 0 : entity.area) === variationAttributes.area;
45155      };
45156  
45157      const variations = settings.variations.map(variation => {
45158        return { ...variation,
45159          ...(!variation.isActive && {
45160            isActive
45161          }),
45162          ...(typeof variation.icon === 'string' && {
45163            icon: getTemplatePartIcon(variation.icon)
45164          })
45165        };
45166      });
45167      return { ...settings,
45168        variations
45169      };
45170    }
45171  
45172    return settings;
45173  }
45174  
45175  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/template-part/index.js
45176  /**
45177   * External dependencies
45178   */
45179  
45180  /**
45181   * WordPress dependencies
45182   */
45183  
45184  
45185  
45186  
45187  
45188  
45189  /**
45190   * Internal dependencies
45191   */
45192  
45193  const template_part_metadata = {
45194    $schema: "https://schemas.wp.org/trunk/block.json",
45195    apiVersion: 2,
45196    name: "core/template-part",
45197    title: "Template Part",
45198    category: "theme",
45199    description: "Edit the different global regions of your site, like the header, footer, sidebar, or create your own.",
45200    textdomain: "default",
45201    attributes: {
45202      slug: {
45203        type: "string"
45204      },
45205      theme: {
45206        type: "string"
45207      },
45208      tagName: {
45209        type: "string"
45210      },
45211      area: {
45212        type: "string"
45213      }
45214    },
45215    supports: {
45216      align: true,
45217      html: false,
45218      reusable: false
45219    },
45220    editorStyle: "wp-block-template-part-editor"
45221  };
45222  
45223  
45224  const {
45225    name: template_part_name
45226  } = template_part_metadata;
45227  
45228  const template_part_settings = {
45229    icon: symbol_filled,
45230    __experimentalLabel: _ref => {
45231      var _entity$title;
45232  
45233      let {
45234        slug,
45235        theme
45236      } = _ref;
45237  
45238      // Attempt to find entity title if block is a template part.
45239      // Require slug to request, otherwise entity is uncreated and will throw 404.
45240      if (!slug) {
45241        return;
45242      }
45243  
45244      const entity = (0,external_wp_data_namespaceObject.select)(external_wp_coreData_namespaceObject.store).getEntityRecord('postType', 'wp_template_part', theme + '//' + slug);
45245  
45246      if (!entity) {
45247        return;
45248      }
45249  
45250      return (0,external_wp_htmlEntities_namespaceObject.decodeEntities)((_entity$title = entity.title) === null || _entity$title === void 0 ? void 0 : _entity$title.rendered) || (0,external_lodash_namespaceObject.startCase)(entity.slug);
45251    },
45252    edit: TemplatePartEdit
45253  }; // Importing this file includes side effects. This is whitelisted in block-library/package.json under sideEffects
45254  
45255  (0,external_wp_hooks_namespaceObject.addFilter)('blocks.registerBlockType', 'core/template-part', enhanceTemplatePartVariations); // Prevent adding template parts inside post templates.
45256  
45257  const DISALLOWED_PARENTS = ['core/post-template', 'core/post-content'];
45258  (0,external_wp_hooks_namespaceObject.addFilter)('blockEditor.__unstableCanInsertBlockType', 'removeTemplatePartsFromPostTemplates', (can, blockType, rootClientId, _ref2) => {
45259    let {
45260      getBlock,
45261      getBlockParentsByBlockName
45262    } = _ref2;
45263  
45264    if (blockType.name !== 'core/template-part') {
45265      return can;
45266    }
45267  
45268    for (const disallowedParentType of DISALLOWED_PARENTS) {
45269      var _getBlock;
45270  
45271      const hasDisallowedParent = ((_getBlock = getBlock(rootClientId)) === null || _getBlock === void 0 ? void 0 : _getBlock.name) === disallowedParentType || getBlockParentsByBlockName(rootClientId, disallowedParentType).length;
45272  
45273      if (hasDisallowedParent) {
45274        return false;
45275      }
45276    }
45277  
45278    return true;
45279  });
45280  
45281  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/term-description.js
45282  
45283  
45284  /**
45285   * WordPress dependencies
45286   */
45287  
45288  const term_description_tag = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
45289    xmlns: "http://www.w3.org/2000/svg",
45290    viewBox: "0 0 24 24"
45291  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
45292    d: "M6.08 10.103h2.914L9.657 12h1.417L8.23 4H6.846L4 12h1.417l.663-1.897Zm1.463-4.137.994 2.857h-2l1.006-2.857ZM11 16H4v-1.5h7V16Zm1 0h8v-1.5h-8V16Zm-4 4H4v-1.5h4V20Zm7-1.5V20H9v-1.5h6Z"
45293  }));
45294  /* harmony default export */ var term_description = (term_description_tag);
45295  
45296  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/term-description/edit.js
45297  
45298  
45299  /**
45300   * External dependencies
45301   */
45302  
45303  /**
45304   * WordPress dependencies
45305   */
45306  
45307  
45308  
45309  function TermDescriptionEdit(_ref) {
45310    let {
45311      attributes,
45312      setAttributes,
45313      mergedStyle
45314    } = _ref;
45315    const {
45316      textAlign
45317    } = attributes;
45318    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
45319      className: classnames_default()({
45320        [`has-text-align-$textAlign}`]: textAlign
45321      }),
45322      style: mergedStyle
45323    });
45324    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, {
45325      group: "block"
45326    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.AlignmentControl, {
45327      value: textAlign,
45328      onChange: nextAlign => {
45329        setAttributes({
45330          textAlign: nextAlign
45331        });
45332      }
45333    })), (0,external_wp_element_namespaceObject.createElement)("div", blockProps, (0,external_wp_element_namespaceObject.createElement)("div", {
45334      className: "wp-block-term-description__placeholder"
45335    }, (0,external_wp_element_namespaceObject.createElement)("span", null, (0,external_wp_i18n_namespaceObject.__)('Term Description')))));
45336  }
45337  
45338  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/term-description/index.js
45339  /**
45340   * WordPress dependencies
45341   */
45342  
45343  /**
45344   * Internal dependencies
45345   */
45346  
45347  const term_description_metadata = {
45348    $schema: "https://schemas.wp.org/trunk/block.json",
45349    apiVersion: 2,
45350    name: "core/term-description",
45351    title: "Term Description",
45352    category: "theme",
45353    description: "Display the description of categories, tags and custom taxonomies when viewing an archive.",
45354    textdomain: "default",
45355    attributes: {
45356      textAlign: {
45357        type: "string"
45358      }
45359    },
45360    supports: {
45361      align: ["wide", "full"],
45362      html: false,
45363      color: {
45364        link: true,
45365        __experimentalDefaultControls: {
45366          background: true,
45367          text: true
45368        }
45369      },
45370      typography: {
45371        fontSize: true,
45372        lineHeight: true,
45373        __experimentalDefaultControls: {
45374          fontSize: true
45375        }
45376      }
45377    },
45378    editorStyle: "wp-block-term-description-editor"
45379  };
45380  
45381  const {
45382    name: term_description_name
45383  } = term_description_metadata;
45384  
45385  const term_description_settings = {
45386    icon: term_description,
45387    edit: TermDescriptionEdit
45388  };
45389  
45390  ;// CONCATENATED MODULE: external ["wp","deprecated"]
45391  var external_wp_deprecated_namespaceObject = window["wp"]["deprecated"];
45392  var external_wp_deprecated_default = /*#__PURE__*/__webpack_require__.n(external_wp_deprecated_namespaceObject);
45393  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/text-columns/edit.js
45394  
45395  
45396  /**
45397   * External dependencies
45398   */
45399  
45400  /**
45401   * WordPress dependencies
45402   */
45403  
45404  
45405  
45406  
45407  
45408  function TextColumnsEdit(_ref) {
45409    let {
45410      attributes,
45411      setAttributes
45412    } = _ref;
45413    const {
45414      width,
45415      content,
45416      columns
45417    } = attributes;
45418    external_wp_deprecated_default()('The Text Columns block', {
45419      since: '5.3',
45420      alternative: 'the Columns block'
45421    });
45422    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockAlignmentToolbar, {
45423      value: width,
45424      onChange: nextWidth => setAttributes({
45425        width: nextWidth
45426      }),
45427      controls: ['center', 'wide', 'full']
45428    })), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.RangeControl, {
45429      label: (0,external_wp_i18n_namespaceObject.__)('Columns'),
45430      value: columns,
45431      onChange: value => setAttributes({
45432        columns: value
45433      }),
45434      min: 2,
45435      max: 4,
45436      required: true
45437    }))), (0,external_wp_element_namespaceObject.createElement)("div", (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
45438      className: `align$width} columns-$columns}`
45439    }), (0,external_lodash_namespaceObject.times)(columns, index => {
45440      return (0,external_wp_element_namespaceObject.createElement)("div", {
45441        className: "wp-block-column",
45442        key: `column-$index}`
45443      }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText, {
45444        tagName: "p",
45445        value: (0,external_lodash_namespaceObject.get)(content, [index, 'children']),
45446        onChange: nextContent => {
45447          setAttributes({
45448            content: [...content.slice(0, index), {
45449              children: nextContent
45450            }, ...content.slice(index + 1)]
45451          });
45452        },
45453        "aria-label": (0,external_wp_i18n_namespaceObject.sprintf)( // translators: %d: column index (starting with 1)
45454        (0,external_wp_i18n_namespaceObject.__)('Column %d text'), index + 1),
45455        placeholder: (0,external_wp_i18n_namespaceObject.__)('New Column')
45456      }));
45457    })));
45458  }
45459  
45460  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/text-columns/save.js
45461  
45462  
45463  /**
45464   * External dependencies
45465   */
45466  
45467  /**
45468   * WordPress dependencies
45469   */
45470  
45471  
45472  function text_columns_save_save(_ref) {
45473    let {
45474      attributes
45475    } = _ref;
45476    const {
45477      width,
45478      content,
45479      columns
45480    } = attributes;
45481    return (0,external_wp_element_namespaceObject.createElement)("div", external_wp_blockEditor_namespaceObject.useBlockProps.save({
45482      className: `align$width} columns-$columns}`
45483    }), (0,external_lodash_namespaceObject.times)(columns, index => (0,external_wp_element_namespaceObject.createElement)("div", {
45484      className: "wp-block-column",
45485      key: `column-$index}`
45486    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
45487      tagName: "p",
45488      value: (0,external_lodash_namespaceObject.get)(content, [index, 'children'])
45489    }))));
45490  }
45491  
45492  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/text-columns/transforms.js
45493  /**
45494   * WordPress dependencies
45495   */
45496  
45497  const text_columns_transforms_transforms = {
45498    to: [{
45499      type: 'block',
45500      blocks: ['core/columns'],
45501      transform: _ref => {
45502        let {
45503          className,
45504          columns,
45505          content,
45506          width
45507        } = _ref;
45508        return (0,external_wp_blocks_namespaceObject.createBlock)('core/columns', {
45509          align: 'wide' === width || 'full' === width ? width : undefined,
45510          className,
45511          columns
45512        }, content.map(_ref2 => {
45513          let {
45514            children
45515          } = _ref2;
45516          return (0,external_wp_blocks_namespaceObject.createBlock)('core/column', {}, [(0,external_wp_blocks_namespaceObject.createBlock)('core/paragraph', {
45517            content: children
45518          })]);
45519        }));
45520      }
45521    }]
45522  };
45523  /* harmony default export */ var text_columns_transforms = (text_columns_transforms_transforms);
45524  
45525  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/text-columns/index.js
45526  /**
45527   * Internal dependencies
45528   */
45529  
45530  const text_columns_metadata = {
45531    $schema: "https://schemas.wp.org/trunk/block.json",
45532    apiVersion: 2,
45533    name: "core/text-columns",
45534    title: "Text Columns (deprecated)",
45535    icon: "columns",
45536    category: "design",
45537    description: "This block is deprecated. Please use the Columns block instead.",
45538    textdomain: "default",
45539    attributes: {
45540      content: {
45541        type: "array",
45542        source: "query",
45543        selector: "p",
45544        query: {
45545          children: {
45546            type: "string",
45547            source: "html"
45548          }
45549        },
45550        "default": [{}, {}]
45551      },
45552      columns: {
45553        type: "number",
45554        "default": 2
45555      },
45556      width: {
45557        type: "string"
45558      }
45559    },
45560    supports: {
45561      inserter: false
45562    },
45563    editorStyle: "wp-block-text-columns-editor",
45564    style: "wp-block-text-columns"
45565  };
45566  
45567  
45568  const {
45569    name: text_columns_name
45570  } = text_columns_metadata;
45571  
45572  const text_columns_settings = {
45573    transforms: text_columns_transforms,
45574  
45575    getEditWrapperProps(attributes) {
45576      const {
45577        width
45578      } = attributes;
45579  
45580      if ('wide' === width || 'full' === width) {
45581        return {
45582          'data-align': width
45583        };
45584      }
45585    },
45586  
45587    edit: TextColumnsEdit,
45588    save: text_columns_save_save
45589  };
45590  
45591  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/verse.js
45592  
45593  
45594  /**
45595   * WordPress dependencies
45596   */
45597  
45598  const verse = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
45599    viewBox: "0 0 24 24",
45600    xmlns: "http://www.w3.org/2000/svg"
45601  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
45602    d: "M17.8 2l-.9.3c-.1 0-3.6 1-5.2 2.1C10 5.5 9.3 6.5 8.9 7.1c-.6.9-1.7 4.7-1.7 6.3l-.9 2.3c-.2.4 0 .8.4 1 .1 0 .2.1.3.1.3 0 .6-.2.7-.5l.6-1.5c.3 0 .7-.1 1.2-.2.7-.1 1.4-.3 2.2-.5.8-.2 1.6-.5 2.4-.8.7-.3 1.4-.7 1.9-1.2s.8-1.2 1-1.9c.2-.7.3-1.6.4-2.4.1-.8.1-1.7.2-2.5 0-.8.1-1.5.2-2.1V2zm-1.9 5.6c-.1.8-.2 1.5-.3 2.1-.2.6-.4 1-.6 1.3-.3.3-.8.6-1.4.9-.7.3-1.4.5-2.2.8-.6.2-1.3.3-1.8.4L15 7.5c.3-.3.6-.7 1-1.1 0 .4 0 .8-.1 1.2zM6 20h8v-1.5H6V20z"
45603  }));
45604  /* harmony default export */ var library_verse = (verse);
45605  
45606  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/verse/deprecated.js
45607  
45608  
45609  /**
45610   * External dependencies
45611   */
45612  
45613  /**
45614   * WordPress dependencies
45615   */
45616  
45617  
45618  /**
45619   * Internal dependencies
45620   */
45621  
45622  
45623  const verse_deprecated_v1 = {
45624    attributes: {
45625      content: {
45626        type: 'string',
45627        source: 'html',
45628        selector: 'pre',
45629        default: ''
45630      },
45631      textAlign: {
45632        type: 'string'
45633      }
45634    },
45635  
45636    save(_ref) {
45637      let {
45638        attributes
45639      } = _ref;
45640      const {
45641        textAlign,
45642        content
45643      } = attributes;
45644      return (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
45645        tagName: "pre",
45646        style: {
45647          textAlign
45648        },
45649        value: content
45650      });
45651    }
45652  
45653  };
45654  const verse_deprecated_v2 = {
45655    attributes: {
45656      content: {
45657        type: 'string',
45658        source: 'html',
45659        selector: 'pre',
45660        default: '',
45661        __unstablePreserveWhiteSpace: true,
45662        __experimentalRole: 'content'
45663      },
45664      textAlign: {
45665        type: 'string'
45666      }
45667    },
45668    supports: {
45669      anchor: true,
45670      color: {
45671        gradients: true,
45672        link: true
45673      },
45674      typography: {
45675        fontSize: true,
45676        __experimentalFontFamily: true
45677      },
45678      spacing: {
45679        padding: true
45680      }
45681    },
45682  
45683    save(_ref2) {
45684      let {
45685        attributes
45686      } = _ref2;
45687      const {
45688        textAlign,
45689        content
45690      } = attributes;
45691      const className = classnames_default()({
45692        [`has-text-align-$textAlign}`]: textAlign
45693      });
45694      return (0,external_wp_element_namespaceObject.createElement)("pre", external_wp_blockEditor_namespaceObject.useBlockProps.save({
45695        className
45696      }), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
45697        value: content
45698      }));
45699    },
45700  
45701    migrate: migrate_font_family,
45702  
45703    isEligible(_ref3) {
45704      var _style$typography;
45705  
45706      let {
45707        style
45708      } = _ref3;
45709      return style === null || style === void 0 ? void 0 : (_style$typography = style.typography) === null || _style$typography === void 0 ? void 0 : _style$typography.fontFamily;
45710    }
45711  
45712  };
45713  /**
45714   * New deprecations need to be placed first
45715   * for them to have higher priority.
45716   *
45717   * Old deprecations may need to be updated as well.
45718   *
45719   * See block-deprecation.md
45720   */
45721  
45722  /* harmony default export */ var verse_deprecated = ([verse_deprecated_v2, verse_deprecated_v1]);
45723  
45724  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/verse/edit.js
45725  
45726  
45727  
45728  /**
45729   * External dependencies
45730   */
45731  
45732  /**
45733   * WordPress dependencies
45734   */
45735  
45736  
45737  
45738  function VerseEdit(_ref) {
45739    let {
45740      attributes,
45741      setAttributes,
45742      mergeBlocks,
45743      onRemove,
45744      style
45745    } = _ref;
45746    const {
45747      textAlign,
45748      content
45749    } = attributes;
45750    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
45751      className: classnames_default()({
45752        [`has-text-align-$textAlign}`]: textAlign
45753      }),
45754      style
45755    });
45756    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.AlignmentToolbar, {
45757      value: textAlign,
45758      onChange: nextAlign => {
45759        setAttributes({
45760          textAlign: nextAlign
45761        });
45762      }
45763    })), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText, _extends({
45764      tagName: "pre",
45765      identifier: "content",
45766      preserveWhiteSpace: true,
45767      value: content,
45768      onChange: nextContent => {
45769        setAttributes({
45770          content: nextContent
45771        });
45772      },
45773      "aria-label": (0,external_wp_i18n_namespaceObject.__)('Verse text'),
45774      placeholder: (0,external_wp_i18n_namespaceObject.__)('Write verse…'),
45775      onRemove: onRemove,
45776      onMerge: mergeBlocks,
45777      textAlign: textAlign
45778    }, blockProps, {
45779      __unstablePastePlainText: true
45780    })));
45781  }
45782  
45783  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/verse/save.js
45784  
45785  
45786  /**
45787   * External dependencies
45788   */
45789  
45790  /**
45791   * WordPress dependencies
45792   */
45793  
45794  
45795  function verse_save_save(_ref) {
45796    let {
45797      attributes
45798    } = _ref;
45799    const {
45800      textAlign,
45801      content
45802    } = attributes;
45803    const className = classnames_default()({
45804      [`has-text-align-$textAlign}`]: textAlign
45805    });
45806    return (0,external_wp_element_namespaceObject.createElement)("pre", external_wp_blockEditor_namespaceObject.useBlockProps.save({
45807      className
45808    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
45809      value: content
45810    }));
45811  }
45812  
45813  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/verse/transforms.js
45814  /**
45815   * WordPress dependencies
45816   */
45817  
45818  const verse_transforms_transforms = {
45819    from: [{
45820      type: 'block',
45821      blocks: ['core/paragraph'],
45822      transform: attributes => (0,external_wp_blocks_namespaceObject.createBlock)('core/verse', attributes)
45823    }],
45824    to: [{
45825      type: 'block',
45826      blocks: ['core/paragraph'],
45827      transform: attributes => (0,external_wp_blocks_namespaceObject.createBlock)('core/paragraph', attributes)
45828    }]
45829  };
45830  /* harmony default export */ var verse_transforms = (verse_transforms_transforms);
45831  
45832  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/verse/index.js
45833  /**
45834   * WordPress dependencies
45835   */
45836  
45837  
45838  /**
45839   * Internal dependencies
45840   */
45841  
45842  
45843  
45844  const verse_metadata = {
45845    $schema: "https://schemas.wp.org/trunk/block.json",
45846    apiVersion: 2,
45847    name: "core/verse",
45848    title: "Verse",
45849    category: "text",
45850    description: "Insert poetry. Use special spacing formats. Or quote song lyrics.",
45851    keywords: ["poetry", "poem"],
45852    textdomain: "default",
45853    attributes: {
45854      content: {
45855        type: "string",
45856        source: "html",
45857        selector: "pre",
45858        "default": "",
45859        __unstablePreserveWhiteSpace: true,
45860        __experimentalRole: "content"
45861      },
45862      textAlign: {
45863        type: "string"
45864      }
45865    },
45866    supports: {
45867      anchor: true,
45868      color: {
45869        gradients: true,
45870        link: true,
45871        __experimentalDefaultControls: {
45872          background: true,
45873          text: true
45874        }
45875      },
45876      typography: {
45877        fontSize: true,
45878        __experimentalFontFamily: true,
45879        lineHeight: true,
45880        __experimentalFontStyle: true,
45881        __experimentalFontWeight: true,
45882        __experimentalLetterSpacing: true,
45883        __experimentalTextTransform: true,
45884        __experimentalDefaultControls: {
45885          fontSize: true,
45886          fontAppearance: true
45887        }
45888      },
45889      spacing: {
45890        padding: true
45891      }
45892    },
45893    style: "wp-block-verse",
45894    editorStyle: "wp-block-verse-editor"
45895  };
45896  
45897  
45898  const {
45899    name: verse_name
45900  } = verse_metadata;
45901  
45902  const verse_settings = {
45903    icon: library_verse,
45904    example: {
45905      attributes: {
45906        /* eslint-disable @wordpress/i18n-no-collapsible-whitespace */
45907        // translators: Sample content for the Verse block. Can be replaced with a more locale-adequate work.
45908        content: (0,external_wp_i18n_namespaceObject.__)('WHAT was he doing, the great god Pan,\n    Down in the reeds by the river?\nSpreading ruin and scattering ban,\nSplashing and paddling with hoofs of a goat,\nAnd breaking the golden lilies afloat\n    With the dragon-fly on the river.')
45909        /* eslint-enable @wordpress/i18n-no-collapsible-whitespace */
45910  
45911      }
45912    },
45913    transforms: verse_transforms,
45914    deprecated: verse_deprecated,
45915  
45916    merge(attributes, attributesToMerge) {
45917      return {
45918        content: attributes.content + attributesToMerge.content
45919      };
45920    },
45921  
45922    edit: VerseEdit,
45923    save: verse_save_save
45924  };
45925  
45926  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/video.js
45927  
45928  
45929  /**
45930   * WordPress dependencies
45931   */
45932  
45933  const video = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
45934    viewBox: "0 0 24 24",
45935    xmlns: "http://www.w3.org/2000/svg"
45936  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
45937    d: "M18.7 3H5.3C4 3 3 4 3 5.3v13.4C3 20 4 21 5.3 21h13.4c1.3 0 2.3-1 2.3-2.3V5.3C21 4 20 3 18.7 3zm.8 15.7c0 .4-.4.8-.8.8H5.3c-.4 0-.8-.4-.8-.8V5.3c0-.4.4-.8.8-.8h13.4c.4 0 .8.4.8.8v13.4zM10 15l5-3-5-3v6z"
45938  }));
45939  /* harmony default export */ var library_video = (video);
45940  
45941  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/video/edit-common-settings.js
45942  
45943  
45944  /**
45945   * WordPress dependencies
45946   */
45947  
45948  
45949  
45950  const options = [{
45951    value: 'auto',
45952    label: (0,external_wp_i18n_namespaceObject.__)('Auto')
45953  }, {
45954    value: 'metadata',
45955    label: (0,external_wp_i18n_namespaceObject.__)('Metadata')
45956  }, {
45957    value: 'none',
45958    label: (0,external_wp_i18n_namespaceObject._x)('None', 'Preload value')
45959  }];
45960  
45961  const VideoSettings = _ref => {
45962    let {
45963      setAttributes,
45964      attributes
45965    } = _ref;
45966    const {
45967      autoplay,
45968      controls,
45969      loop,
45970      muted,
45971      playsInline,
45972      preload
45973    } = attributes;
45974  
45975    const autoPlayHelpText = (0,external_wp_i18n_namespaceObject.__)('Autoplay may cause usability issues for some users.');
45976  
45977    const getAutoplayHelp = external_wp_element_namespaceObject.Platform.select({
45978      web: (0,external_wp_element_namespaceObject.useCallback)(checked => {
45979        return checked ? autoPlayHelpText : null;
45980      }, []),
45981      native: autoPlayHelpText
45982    });
45983    const toggleFactory = (0,external_wp_element_namespaceObject.useMemo)(() => {
45984      const toggleAttribute = attribute => {
45985        return newValue => {
45986          setAttributes({
45987            [attribute]: newValue
45988          });
45989        };
45990      };
45991  
45992      return {
45993        autoplay: toggleAttribute('autoplay'),
45994        loop: toggleAttribute('loop'),
45995        muted: toggleAttribute('muted'),
45996        controls: toggleAttribute('controls'),
45997        playsInline: toggleAttribute('playsInline')
45998      };
45999    }, []);
46000    const onChangePreload = (0,external_wp_element_namespaceObject.useCallback)(value => {
46001      setAttributes({
46002        preload: value
46003      });
46004    }, []);
46005    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
46006      label: (0,external_wp_i18n_namespaceObject.__)('Autoplay'),
46007      onChange: toggleFactory.autoplay,
46008      checked: autoplay,
46009      help: getAutoplayHelp
46010    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
46011      label: (0,external_wp_i18n_namespaceObject.__)('Loop'),
46012      onChange: toggleFactory.loop,
46013      checked: loop
46014    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
46015      label: (0,external_wp_i18n_namespaceObject.__)('Muted'),
46016      onChange: toggleFactory.muted,
46017      checked: muted
46018    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
46019      label: (0,external_wp_i18n_namespaceObject.__)('Playback controls'),
46020      onChange: toggleFactory.controls,
46021      checked: controls
46022    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToggleControl, {
46023      label: (0,external_wp_i18n_namespaceObject.__)('Play inline'),
46024      onChange: toggleFactory.playsInline,
46025      checked: playsInline
46026    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SelectControl, {
46027      label: (0,external_wp_i18n_namespaceObject.__)('Preload'),
46028      value: preload,
46029      onChange: onChangePreload,
46030      options: options,
46031      hideCancelButton: true
46032    }));
46033  };
46034  
46035  /* harmony default export */ var edit_common_settings = (VideoSettings);
46036  
46037  ;// CONCATENATED MODULE: ./node_modules/@wordpress/icons/build-module/library/media.js
46038  
46039  
46040  /**
46041   * WordPress dependencies
46042   */
46043  
46044  const media = (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.SVG, {
46045    xmlns: "http://www.w3.org/2000/svg",
46046    viewBox: "0 0 24 24"
46047  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_primitives_namespaceObject.Path, {
46048    d: "M18.7 3H5.3C4 3 3 4 3 5.3v13.4C3 20 4 21 5.3 21h13.4c1.3 0 2.3-1 2.3-2.3V5.3C21 4 20 3 18.7 3zm.8 15.7c0 .4-.4.8-.8.8H5.3c-.4 0-.8-.4-.8-.8V5.3c0-.4.4-.8.8-.8h13.4c.4 0 .8.4.8.8v13.4zM10 15l5-3-5-3v6z"
46049  }));
46050  /* harmony default export */ var library_media = (media);
46051  
46052  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/video/tracks-editor.js
46053  
46054  
46055  /**
46056   * WordPress dependencies
46057   */
46058  
46059  
46060  
46061  
46062  
46063  
46064  
46065  const ALLOWED_TYPES = ['text/vtt'];
46066  const DEFAULT_KIND = 'subtitles';
46067  const KIND_OPTIONS = [{
46068    label: (0,external_wp_i18n_namespaceObject.__)('Subtitles'),
46069    value: 'subtitles'
46070  }, {
46071    label: (0,external_wp_i18n_namespaceObject.__)('Captions'),
46072    value: 'captions'
46073  }, {
46074    label: (0,external_wp_i18n_namespaceObject.__)('Descriptions'),
46075    value: 'descriptions'
46076  }, {
46077    label: (0,external_wp_i18n_namespaceObject.__)('Chapters'),
46078    value: 'chapters'
46079  }, {
46080    label: (0,external_wp_i18n_namespaceObject.__)('Metadata'),
46081    value: 'metadata'
46082  }];
46083  const captionIcon = (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SVG, {
46084    width: "18",
46085    height: "14",
46086    viewBox: "0 0 18 14",
46087    role: "img",
46088    fill: "none"
46089  }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Rect, {
46090    x: "0.75",
46091    y: "0.75",
46092    width: "16.5",
46093    height: "12.5",
46094    rx: "1.25",
46095    stroke: "black",
46096    strokeWidth: "1.5",
46097    fill: "none"
46098  }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
46099    d: "M3 7H15",
46100    stroke: "black",
46101    strokeWidth: "1.5"
46102  }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Path, {
46103    d: "M3 10L15 10",
46104    stroke: "black",
46105    strokeWidth: "1.5"
46106  }));
46107  
46108  function TrackList(_ref) {
46109    let {
46110      tracks,
46111      onEditPress
46112    } = _ref;
46113    let content;
46114  
46115    if (tracks.length === 0) {
46116      content = (0,external_wp_element_namespaceObject.createElement)("p", {
46117        className: "block-library-video-tracks-editor__tracks-informative-message"
46118      }, (0,external_wp_i18n_namespaceObject.__)('Tracks can be subtitles, captions, chapters, or descriptions. They help make your content more accessible to a wider range of users.'));
46119    } else {
46120      content = tracks.map((track, index) => {
46121        return (0,external_wp_element_namespaceObject.createElement)("div", {
46122          key: index,
46123          className: "block-library-video-tracks-editor__track-list-track"
46124        }, (0,external_wp_element_namespaceObject.createElement)("span", null, track.label, " "), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
46125          variant: "tertiary",
46126          onClick: () => onEditPress(index),
46127          "aria-label": (0,external_wp_i18n_namespaceObject.sprintf)(
46128          /* translators: %s: Label of the video text track e.g: "French subtitles" */
46129          (0,external_wp_i18n_namespaceObject.__)('Edit %s'), track.label)
46130        }, (0,external_wp_i18n_namespaceObject.__)('Edit')));
46131      });
46132    }
46133  
46134    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuGroup, {
46135      label: (0,external_wp_i18n_namespaceObject.__)('Text tracks'),
46136      className: "block-library-video-tracks-editor__track-list"
46137    }, content);
46138  }
46139  
46140  function SingleTrackEditor(_ref2) {
46141    let {
46142      track,
46143      onChange,
46144      onClose,
46145      onRemove
46146    } = _ref2;
46147    const {
46148      src = '',
46149      label = '',
46150      srcLang = '',
46151      kind = DEFAULT_KIND
46152    } = track;
46153    const fileName = src.startsWith('blob:') ? '' : (0,external_wp_url_namespaceObject.getFilename)(src) || '';
46154    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.NavigableMenu, null, (0,external_wp_element_namespaceObject.createElement)("div", {
46155      className: "block-library-video-tracks-editor__single-track-editor"
46156    }, (0,external_wp_element_namespaceObject.createElement)("span", {
46157      className: "block-library-video-tracks-editor__single-track-editor-edit-track-label"
46158    }, (0,external_wp_i18n_namespaceObject.__)('Edit track')), (0,external_wp_element_namespaceObject.createElement)("span", null, (0,external_wp_i18n_namespaceObject.__)('File'), ": ", (0,external_wp_element_namespaceObject.createElement)("b", null, fileName)), (0,external_wp_element_namespaceObject.createElement)("div", {
46159      className: "block-library-video-tracks-editor__single-track-editor-label-language"
46160    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TextControl
46161    /* eslint-disable jsx-a11y/no-autofocus */
46162    , {
46163      autoFocus: true
46164      /* eslint-enable jsx-a11y/no-autofocus */
46165      ,
46166      onChange: newLabel => onChange({ ...track,
46167        label: newLabel
46168      }),
46169      label: (0,external_wp_i18n_namespaceObject.__)('Label'),
46170      value: label,
46171      help: (0,external_wp_i18n_namespaceObject.__)('Title of track')
46172    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.TextControl, {
46173      onChange: newSrcLang => onChange({ ...track,
46174        srcLang: newSrcLang
46175      }),
46176      label: (0,external_wp_i18n_namespaceObject.__)('Source language'),
46177      value: srcLang,
46178      help: (0,external_wp_i18n_namespaceObject.__)('Language tag (en, fr, etc.)')
46179    })), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.SelectControl, {
46180      className: "block-library-video-tracks-editor__single-track-editor-kind-select",
46181      options: KIND_OPTIONS,
46182      value: kind,
46183      label: (0,external_wp_i18n_namespaceObject.__)('Kind'),
46184      onChange: newKind => {
46185        onChange({ ...track,
46186          kind: newKind
46187        });
46188      }
46189    }), (0,external_wp_element_namespaceObject.createElement)("div", {
46190      className: "block-library-video-tracks-editor__single-track-editor-buttons-container"
46191    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
46192      variant: "secondary",
46193      onClick: () => {
46194        const changes = {};
46195        let hasChanges = false;
46196  
46197        if (label === '') {
46198          changes.label = (0,external_wp_i18n_namespaceObject.__)('English');
46199          hasChanges = true;
46200        }
46201  
46202        if (srcLang === '') {
46203          changes.srcLang = 'en';
46204          hasChanges = true;
46205        }
46206  
46207        if (track.kind === undefined) {
46208          changes.kind = DEFAULT_KIND;
46209          hasChanges = true;
46210        }
46211  
46212        if (hasChanges) {
46213          onChange({ ...track,
46214            ...changes
46215          });
46216        }
46217  
46218        onClose();
46219      }
46220    }, (0,external_wp_i18n_namespaceObject.__)('Close')), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
46221      isDestructive: true,
46222      variant: "link",
46223      onClick: onRemove
46224    }, (0,external_wp_i18n_namespaceObject.__)('Remove track')))));
46225  }
46226  
46227  function TracksEditor(_ref3) {
46228    let {
46229      tracks = [],
46230      onChange
46231    } = _ref3;
46232    const mediaUpload = (0,external_wp_data_namespaceObject.useSelect)(select => {
46233      return select(external_wp_blockEditor_namespaceObject.store).getSettings().mediaUpload;
46234    }, []);
46235    const [trackBeingEdited, setTrackBeingEdited] = (0,external_wp_element_namespaceObject.useState)(null);
46236  
46237    if (!mediaUpload) {
46238      return null;
46239    }
46240  
46241    return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Dropdown, {
46242      contentClassName: "block-library-video-tracks-editor",
46243      renderToggle: _ref4 => {
46244        let {
46245          isOpen,
46246          onToggle
46247        } = _ref4;
46248        return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.ToolbarButton, {
46249          label: (0,external_wp_i18n_namespaceObject.__)('Text tracks'),
46250          showTooltip: true,
46251          "aria-expanded": isOpen,
46252          "aria-haspopup": "true",
46253          onClick: onToggle,
46254          icon: captionIcon
46255        });
46256      },
46257      renderContent: _ref5 => {
46258        let {} = _ref5;
46259  
46260        if (trackBeingEdited !== null) {
46261          return (0,external_wp_element_namespaceObject.createElement)(SingleTrackEditor, {
46262            track: tracks[trackBeingEdited],
46263            onChange: newTrack => {
46264              const newTracks = [...tracks];
46265              newTracks[trackBeingEdited] = newTrack;
46266              onChange(newTracks);
46267            },
46268            onClose: () => setTrackBeingEdited(null),
46269            onRemove: () => {
46270              onChange(tracks.filter((_track, index) => index !== trackBeingEdited));
46271              setTrackBeingEdited(null);
46272            }
46273          });
46274        }
46275  
46276        return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.NavigableMenu, null, (0,external_wp_element_namespaceObject.createElement)(TrackList, {
46277          tracks: tracks,
46278          onEditPress: setTrackBeingEdited
46279        }), (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuGroup, {
46280          className: "block-library-video-tracks-editor__add-tracks-container",
46281          label: (0,external_wp_i18n_namespaceObject.__)('Add tracks')
46282        }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.MediaUpload, {
46283          onSelect: _ref6 => {
46284            let {
46285              url
46286            } = _ref6;
46287            const trackIndex = tracks.length;
46288            onChange([...tracks, {
46289              src: url
46290            }]);
46291            setTrackBeingEdited(trackIndex);
46292          },
46293          allowedTypes: ALLOWED_TYPES,
46294          render: _ref7 => {
46295            let {
46296              open
46297            } = _ref7;
46298            return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, {
46299              icon: library_media,
46300              onClick: open
46301            }, (0,external_wp_i18n_namespaceObject.__)('Open Media Library'));
46302          }
46303        }), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.MediaUploadCheck, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.FormFileUpload, {
46304          onChange: event => {
46305            const files = event.target.files;
46306            const trackIndex = tracks.length;
46307            mediaUpload({
46308              allowedTypes: ALLOWED_TYPES,
46309              filesList: files,
46310              onFileChange: _ref8 => {
46311                let [{
46312                  url
46313                }] = _ref8;
46314                const newTracks = [...tracks];
46315  
46316                if (!newTracks[trackIndex]) {
46317                  newTracks[trackIndex] = {};
46318                }
46319  
46320                newTracks[trackIndex] = { ...tracks[trackIndex],
46321                  src: url
46322                };
46323                onChange(newTracks);
46324                setTrackBeingEdited(trackIndex);
46325              }
46326            });
46327          },
46328          accept: ".vtt,text/vtt",
46329          render: _ref9 => {
46330            let {
46331              openFileDialog
46332            } = _ref9;
46333            return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.MenuItem, {
46334              icon: library_upload,
46335              onClick: () => {
46336                openFileDialog();
46337              }
46338            }, (0,external_wp_i18n_namespaceObject.__)('Upload'));
46339          }
46340        })))));
46341      }
46342    });
46343  }
46344  
46345  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/video/tracks.js
46346  
46347  
46348  function Tracks(_ref) {
46349    let {
46350      tracks = []
46351    } = _ref;
46352    return tracks.map(track => {
46353      return (0,external_wp_element_namespaceObject.createElement)("track", _extends({
46354        key: track.src
46355      }, track));
46356    });
46357  }
46358  
46359  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/video/edit.js
46360  
46361  
46362  /**
46363   * External dependencies
46364   */
46365  
46366  /**
46367   * WordPress dependencies
46368   */
46369  
46370  
46371  
46372  
46373  
46374  
46375  
46376  
46377  
46378  
46379  /**
46380   * Internal dependencies
46381   */
46382  
46383  
46384  
46385  
46386  
46387  const video_edit_ALLOWED_MEDIA_TYPES = ['video'];
46388  const VIDEO_POSTER_ALLOWED_MEDIA_TYPES = ['image'];
46389  
46390  function VideoEdit(_ref) {
46391    let {
46392      isSelected,
46393      noticeUI,
46394      attributes,
46395      className,
46396      setAttributes,
46397      insertBlocksAfter,
46398      onReplace,
46399      noticeOperations
46400    } = _ref;
46401    const instanceId = (0,external_wp_compose_namespaceObject.useInstanceId)(VideoEdit);
46402    const videoPlayer = (0,external_wp_element_namespaceObject.useRef)();
46403    const posterImageButton = (0,external_wp_element_namespaceObject.useRef)();
46404    const {
46405      id,
46406      caption,
46407      controls,
46408      poster,
46409      src,
46410      tracks
46411    } = attributes;
46412    const isTemporaryVideo = !id && (0,external_wp_blob_namespaceObject.isBlobURL)(src);
46413    const mediaUpload = (0,external_wp_data_namespaceObject.useSelect)(select => select(external_wp_blockEditor_namespaceObject.store).getSettings().mediaUpload);
46414    (0,external_wp_element_namespaceObject.useEffect)(() => {
46415      if (!id && (0,external_wp_blob_namespaceObject.isBlobURL)(src)) {
46416        const file = (0,external_wp_blob_namespaceObject.getBlobByURL)(src);
46417  
46418        if (file) {
46419          mediaUpload({
46420            filesList: [file],
46421            onFileChange: _ref2 => {
46422              let [{
46423                url
46424              }] = _ref2;
46425              setAttributes({
46426                src: url
46427              });
46428            },
46429            onError: message => {
46430              noticeOperations.createErrorNotice(message);
46431            },
46432            allowedTypes: video_edit_ALLOWED_MEDIA_TYPES
46433          });
46434        }
46435      }
46436    }, []);
46437    (0,external_wp_element_namespaceObject.useEffect)(() => {
46438      // Placeholder may be rendered.
46439      if (videoPlayer.current) {
46440        videoPlayer.current.load();
46441      }
46442    }, [poster]);
46443  
46444    function onSelectVideo(media) {
46445      var _media$image, _media$image2;
46446  
46447      if (!media || !media.url) {
46448        // In this case there was an error
46449        // previous attributes should be removed
46450        // because they may be temporary blob urls.
46451        setAttributes({
46452          src: undefined,
46453          id: undefined,
46454          poster: undefined
46455        });
46456        return;
46457      } // Sets the block's attribute and updates the edit component from the
46458      // selected media.
46459  
46460  
46461      setAttributes({
46462        src: media.url,
46463        id: media.id,
46464        poster: ((_media$image = media.image) === null || _media$image === void 0 ? void 0 : _media$image.src) !== media.icon ? (_media$image2 = media.image) === null || _media$image2 === void 0 ? void 0 : _media$image2.src : undefined
46465      });
46466    }
46467  
46468    function onSelectURL(newSrc) {
46469      if (newSrc !== src) {
46470        // Check if there's an embed block that handles this URL.
46471        const embedBlock = createUpgradedEmbedBlock({
46472          attributes: {
46473            url: newSrc
46474          }
46475        });
46476  
46477        if (undefined !== embedBlock) {
46478          onReplace(embedBlock);
46479          return;
46480        }
46481  
46482        setAttributes({
46483          src: newSrc,
46484          id: undefined,
46485          poster: undefined
46486        });
46487      }
46488    }
46489  
46490    function onUploadError(message) {
46491      noticeOperations.removeAllNotices();
46492      noticeOperations.createErrorNotice(message);
46493    }
46494  
46495    const classes = classnames_default()(className, {
46496      'is-transient': isTemporaryVideo
46497    });
46498    const blockProps = (0,external_wp_blockEditor_namespaceObject.useBlockProps)({
46499      className: classes
46500    });
46501  
46502    if (!src) {
46503      return (0,external_wp_element_namespaceObject.createElement)("div", blockProps, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.MediaPlaceholder, {
46504        icon: (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockIcon, {
46505          icon: library_video
46506        }),
46507        onSelect: onSelectVideo,
46508        onSelectURL: onSelectURL,
46509        accept: "video/*",
46510        allowedTypes: video_edit_ALLOWED_MEDIA_TYPES,
46511        value: attributes,
46512        notices: noticeUI,
46513        onError: onUploadError
46514      }));
46515    }
46516  
46517    function onSelectPoster(image) {
46518      setAttributes({
46519        poster: image.url
46520      });
46521    }
46522  
46523    function onRemovePoster() {
46524      setAttributes({
46525        poster: undefined
46526      }); // Move focus back to the Media Upload button.
46527  
46528      posterImageButton.current.focus();
46529    }
46530  
46531    const videoPosterDescription = `video-block__poster-image-description-${instanceId}`;
46532    return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.Fragment, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, {
46533      group: "block"
46534    }, (0,external_wp_element_namespaceObject.createElement)(TracksEditor, {
46535      tracks: tracks,
46536      onChange: newTracks => {
46537        setAttributes({
46538          tracks: newTracks
46539        });
46540      }
46541    })), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.BlockControls, {
46542      group: "other"
46543    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.MediaReplaceFlow, {
46544      mediaId: id,
46545      mediaURL: src,
46546      allowedTypes: video_edit_ALLOWED_MEDIA_TYPES,
46547      accept: "video/*",
46548      onSelect: onSelectVideo,
46549      onSelectURL: onSelectURL,
46550      onError: onUploadError
46551    })), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.InspectorControls, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.PanelBody, {
46552      title: (0,external_wp_i18n_namespaceObject.__)('Video settings')
46553    }, (0,external_wp_element_namespaceObject.createElement)(edit_common_settings, {
46554      setAttributes: setAttributes,
46555      attributes: attributes
46556    }), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.MediaUploadCheck, null, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.BaseControl, {
46557      className: "editor-video-poster-control"
46558    }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.BaseControl.VisualLabel, null, (0,external_wp_i18n_namespaceObject.__)('Poster image')), (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.MediaUpload, {
46559      title: (0,external_wp_i18n_namespaceObject.__)('Select poster image'),
46560      onSelect: onSelectPoster,
46561      allowedTypes: VIDEO_POSTER_ALLOWED_MEDIA_TYPES,
46562      render: _ref3 => {
46563        let {
46564          open
46565        } = _ref3;
46566        return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
46567          variant: "primary",
46568          onClick: open,
46569          ref: posterImageButton,
46570          "aria-describedby": videoPosterDescription
46571        }, !poster ? (0,external_wp_i18n_namespaceObject.__)('Select') : (0,external_wp_i18n_namespaceObject.__)('Replace'));
46572      }
46573    }), (0,external_wp_element_namespaceObject.createElement)("p", {
46574      id: videoPosterDescription,
46575      hidden: true
46576    }, poster ? (0,external_wp_i18n_namespaceObject.sprintf)(
46577    /* translators: %s: poster image URL. */
46578    (0,external_wp_i18n_namespaceObject.__)('The current poster image url is %s'), poster) : (0,external_wp_i18n_namespaceObject.__)('There is no poster image currently selected')), !!poster && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Button, {
46579      onClick: onRemovePoster,
46580      variant: "tertiary"
46581    }, (0,external_wp_i18n_namespaceObject.__)('Remove')))))), (0,external_wp_element_namespaceObject.createElement)("figure", blockProps, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Disabled, {
46582      isDisabled: !isSelected
46583    }, (0,external_wp_element_namespaceObject.createElement)("video", {
46584      controls: controls,
46585      poster: poster,
46586      src: src,
46587      ref: videoPlayer
46588    }, (0,external_wp_element_namespaceObject.createElement)(Tracks, {
46589      tracks: tracks
46590    }))), isTemporaryVideo && (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Spinner, null), (!external_wp_blockEditor_namespaceObject.RichText.isEmpty(caption) || isSelected) && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText, {
46591      tagName: "figcaption",
46592      "aria-label": (0,external_wp_i18n_namespaceObject.__)('Video caption text'),
46593      placeholder: (0,external_wp_i18n_namespaceObject.__)('Add caption'),
46594      value: caption,
46595      onChange: value => setAttributes({
46596        caption: value
46597      }),
46598      inlineToolbar: true,
46599      __unstableOnSplitAtEnd: () => insertBlocksAfter((0,external_wp_blocks_namespaceObject.createBlock)('core/paragraph'))
46600    })));
46601  }
46602  
46603  /* harmony default export */ var video_edit = ((0,external_wp_components_namespaceObject.withNotices)(VideoEdit));
46604  
46605  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/video/save.js
46606  
46607  
46608  /**
46609   * WordPress dependencies
46610   */
46611  
46612  /**
46613   * Internal dependencies
46614   */
46615  
46616  
46617  function video_save_save(_ref) {
46618    let {
46619      attributes
46620    } = _ref;
46621    const {
46622      autoplay,
46623      caption,
46624      controls,
46625      loop,
46626      muted,
46627      poster,
46628      preload,
46629      src,
46630      playsInline,
46631      tracks
46632    } = attributes;
46633    return (0,external_wp_element_namespaceObject.createElement)("figure", external_wp_blockEditor_namespaceObject.useBlockProps.save(), src && (0,external_wp_element_namespaceObject.createElement)("video", {
46634      autoPlay: autoplay,
46635      controls: controls,
46636      loop: loop,
46637      muted: muted,
46638      poster: poster,
46639      preload: preload !== 'metadata' ? preload : undefined,
46640      src: src,
46641      playsInline: playsInline
46642    }, (0,external_wp_element_namespaceObject.createElement)(Tracks, {
46643      tracks: tracks
46644    })), !external_wp_blockEditor_namespaceObject.RichText.isEmpty(caption) && (0,external_wp_element_namespaceObject.createElement)(external_wp_blockEditor_namespaceObject.RichText.Content, {
46645      tagName: "figcaption",
46646      value: caption
46647    }));
46648  }
46649  
46650  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/video/transforms.js
46651  /**
46652   * WordPress dependencies
46653   */
46654  
46655  
46656  const video_transforms_transforms = {
46657    from: [{
46658      type: 'files',
46659  
46660      isMatch(files) {
46661        return files.length === 1 && files[0].type.indexOf('video/') === 0;
46662      },
46663  
46664      transform(files) {
46665        const file = files[0]; // We don't need to upload the media directly here
46666        // It's already done as part of the `componentDidMount`
46667        // in the video block
46668  
46669        const block = (0,external_wp_blocks_namespaceObject.createBlock)('core/video', {
46670          src: (0,external_wp_blob_namespaceObject.createBlobURL)(file)
46671        });
46672        return block;
46673      }
46674  
46675    }, {
46676      type: 'shortcode',
46677      tag: 'video',
46678      attributes: {
46679        src: {
46680          type: 'string',
46681          shortcode: _ref => {
46682            let {
46683              named: {
46684                src,
46685                mp4,
46686                m4v,
46687                webm,
46688                ogv,
46689                flv
46690              }
46691            } = _ref;
46692            return src || mp4 || m4v || webm || ogv || flv;
46693          }
46694        },
46695        poster: {
46696          type: 'string',
46697          shortcode: _ref2 => {
46698            let {
46699              named: {
46700                poster
46701              }
46702            } = _ref2;
46703            return poster;
46704          }
46705        },
46706        loop: {
46707          type: 'string',
46708          shortcode: _ref3 => {
46709            let {
46710              named: {
46711                loop
46712              }
46713            } = _ref3;
46714            return loop;
46715          }
46716        },
46717        autoplay: {
46718          type: 'string',
46719          shortcode: _ref4 => {
46720            let {
46721              named: {
46722                autoplay
46723              }
46724            } = _ref4;
46725            return autoplay;
46726          }
46727        },
46728        preload: {
46729          type: 'string',
46730          shortcode: _ref5 => {
46731            let {
46732              named: {
46733                preload
46734              }
46735            } = _ref5;
46736            return preload;
46737          }
46738        }
46739      }
46740    }]
46741  };
46742  /* harmony default export */ var video_transforms = (video_transforms_transforms);
46743  
46744  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/video/index.js
46745  /**
46746   * WordPress dependencies
46747   */
46748  
46749  
46750  /**
46751   * Internal dependencies
46752   */
46753  
46754  
46755  const video_metadata = {
46756    $schema: "https://schemas.wp.org/trunk/block.json",
46757    apiVersion: 2,
46758    name: "core/video",
46759    title: "Video",
46760    category: "media",
46761    description: "Embed a video from your media library or upload a new one.",
46762    keywords: ["movie"],
46763    textdomain: "default",
46764    attributes: {
46765      autoplay: {
46766        type: "boolean",
46767        source: "attribute",
46768        selector: "video",
46769        attribute: "autoplay"
46770      },
46771      caption: {
46772        type: "string",
46773        source: "html",
46774        selector: "figcaption"
46775      },
46776      controls: {
46777        type: "boolean",
46778        source: "attribute",
46779        selector: "video",
46780        attribute: "controls",
46781        "default": true
46782      },
46783      id: {
46784        type: "number"
46785      },
46786      loop: {
46787        type: "boolean",
46788        source: "attribute",
46789        selector: "video",
46790        attribute: "loop"
46791      },
46792      muted: {
46793        type: "boolean",
46794        source: "attribute",
46795        selector: "video",
46796        attribute: "muted"
46797      },
46798      poster: {
46799        type: "string",
46800        source: "attribute",
46801        selector: "video",
46802        attribute: "poster"
46803      },
46804      preload: {
46805        type: "string",
46806        source: "attribute",
46807        selector: "video",
46808        attribute: "preload",
46809        "default": "metadata"
46810      },
46811      src: {
46812        type: "string",
46813        source: "attribute",
46814        selector: "video",
46815        attribute: "src"
46816      },
46817      playsInline: {
46818        type: "boolean",
46819        source: "attribute",
46820        selector: "video",
46821        attribute: "playsinline"
46822      },
46823      tracks: {
46824        type: "array",
46825        items: {
46826          type: "object"
46827        },
46828        "default": []
46829      }
46830    },
46831    supports: {
46832      anchor: true,
46833      align: true
46834    },
46835    editorStyle: "wp-block-video-editor",
46836    style: "wp-block-video"
46837  };
46838  
46839  
46840  const {
46841    name: video_name
46842  } = video_metadata;
46843  
46844  const video_settings = {
46845    icon: library_video,
46846    example: {
46847      attributes: {
46848        src: 'https://upload.wikimedia.org/wikipedia/commons/c/ca/Wood_thrush_in_Central_Park_switch_sides_%2816510%29.webm',
46849        // translators: Caption accompanying a video of the wood thrush singing, which serves as an example for the Video block.
46850        caption: (0,external_wp_i18n_namespaceObject.__)('Wood thrush singing in Central Park, NYC.')
46851      }
46852    },
46853    transforms: video_transforms,
46854    edit: video_edit,
46855    save: video_save_save
46856  };
46857  
46858  ;// CONCATENATED MODULE: ./node_modules/@wordpress/block-library/build-module/index.js
46859  /**
46860   * WordPress dependencies
46861   */
46862  
46863  /**
46864   * Internal dependencies
46865   */
46866  
46867  
46868  
46869  
46870  
46871  
46872  
46873  
46874  
46875  
46876  
46877  
46878  
46879  
46880  
46881  
46882  
46883  
46884  
46885  
46886  
46887  
46888  
46889  
46890  
46891  
46892  
46893  
46894  
46895  
46896  
46897  
46898  
46899  
46900  
46901  
46902  
46903  
46904  
46905  
46906  
46907  
46908  
46909  
46910  
46911  
46912  
46913  
46914  
46915  
46916  
46917  
46918  
46919  
46920  
46921  
46922  
46923  
46924  
46925  
46926  
46927  
46928  
46929  
46930  
46931  
46932  
46933  
46934  
46935  
46936  
46937  
46938  
46939  
46940  
46941  
46942  
46943  
46944  
46945  
46946  
46947  
46948  
46949  
46950  
46951  
46952  
46953  
46954  
46955  
46956  
46957  
46958  
46959  
46960  /**
46961   * Function to register an individual block.
46962   *
46963   * @param {Object} block The block to be registered.
46964   *
46965   */
46966  
46967  const registerBlock = block => {
46968    if (!block) {
46969      return;
46970    }
46971  
46972    const {
46973      metadata,
46974      settings,
46975      name
46976    } = block;
46977    (0,external_wp_blocks_namespaceObject.registerBlockType)({
46978      name,
46979      ...metadata
46980    }, settings);
46981  };
46982  /**
46983   * Function to get all the core blocks in an array.
46984   *
46985   * @example
46986   * ```js
46987   * import { __experimentalGetCoreBlocks } from '@wordpress/block-library';
46988   *
46989   * const coreBlocks = __experimentalGetCoreBlocks();
46990   * ```
46991   */
46992  
46993  
46994  const __experimentalGetCoreBlocks = () => [// Common blocks are grouped at the top to prioritize their display
46995  // in various contexts — like the inserter and auto-complete components.
46996  build_module_paragraph_namespaceObject, build_module_image_namespaceObject, build_module_heading_namespaceObject, build_module_gallery_namespaceObject, build_module_list_namespaceObject, build_module_quote_namespaceObject, // Register all remaining core blocks.
46997  archives_namespaceObject, build_module_audio_namespaceObject, build_module_button_namespaceObject, build_module_buttons_namespaceObject, build_module_calendar_namespaceObject, categories_namespaceObject, window.wp && window.wp.oldEditor ? freeform_namespaceObject : null, // Only add the classic block in WP Context.
46998  build_module_code_namespaceObject, build_module_column_namespaceObject, build_module_columns_namespaceObject, build_module_cover_namespaceObject, embed_namespaceObject, build_module_file_namespaceObject, build_module_group_namespaceObject, build_module_html_namespaceObject, latest_comments_namespaceObject, latest_posts_namespaceObject, media_text_namespaceObject, missing_namespaceObject, build_module_more_namespaceObject, nextpage_namespaceObject, page_list_namespaceObject, pattern_namespaceObject, build_module_preformatted_namespaceObject, build_module_pullquote_namespaceObject, block_namespaceObject, build_module_rss_namespaceObject, build_module_search_namespaceObject, build_module_separator_namespaceObject, build_module_shortcode_namespaceObject, social_link_namespaceObject, social_links_namespaceObject, spacer_namespaceObject, build_module_table_namespaceObject, // tableOfContents,
46999  tag_cloud_namespaceObject, text_columns_namespaceObject, build_module_verse_namespaceObject, build_module_video_namespaceObject, // theme blocks
47000  build_module_navigation_namespaceObject, navigation_link_namespaceObject, navigation_submenu_namespaceObject, build_module_site_logo_namespaceObject, site_title_namespaceObject, site_tagline_namespaceObject, query_namespaceObject, template_part_namespaceObject, avatar_namespaceObject, build_module_post_title_namespaceObject, build_module_post_excerpt_namespaceObject, build_module_post_featured_image_namespaceObject, build_module_post_content_namespaceObject, build_module_post_author_namespaceObject, build_module_post_date_namespaceObject, build_module_post_terms_namespaceObject, post_navigation_link_namespaceObject, post_template_namespaceObject, build_module_query_pagination_namespaceObject, build_module_query_pagination_next_namespaceObject, build_module_query_pagination_numbers_namespaceObject, build_module_query_pagination_previous_namespaceObject, query_no_results_namespaceObject, read_more_namespaceObject, build_module_comment_author_name_namespaceObject, build_module_comment_content_namespaceObject, comment_date_namespaceObject, build_module_comment_edit_link_namespaceObject, build_module_comment_reply_link_namespaceObject, comment_template_namespaceObject, comments_title_namespaceObject, comments_query_loop_namespaceObject, comments_pagination_namespaceObject, comments_pagination_next_namespaceObject, comments_pagination_numbers_namespaceObject, comments_pagination_previous_namespaceObject, build_module_post_comments_namespaceObject, build_module_post_comments_form_namespaceObject, home_link_namespaceObject, loginout_namespaceObject, build_module_term_description_namespaceObject, build_module_query_title_namespaceObject, post_author_biography_namespaceObject];
47001  /**
47002   * Function to register core blocks provided by the block editor.
47003   *
47004   * @param {Array} blocks An optional array of the core blocks being registered.
47005   *
47006   * @example
47007   * ```js
47008   * import { registerCoreBlocks } from '@wordpress/block-library';
47009   *
47010   * registerCoreBlocks();
47011   * ```
47012   */
47013  
47014  const registerCoreBlocks = function () {
47015    let blocks = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : __experimentalGetCoreBlocks();
47016    blocks.forEach(registerBlock);
47017    (0,external_wp_blocks_namespaceObject.setDefaultBlockName)(paragraph_name);
47018  
47019    if (window.wp && window.wp.oldEditor) {
47020      (0,external_wp_blocks_namespaceObject.setFreeformContentHandlerName)(freeform_name);
47021    }
47022  
47023    (0,external_wp_blocks_namespaceObject.setUnregisteredTypeHandlerName)(missing_name);
47024    (0,external_wp_blocks_namespaceObject.setGroupingBlockName)(group_name);
47025  };
47026  /**
47027   * Function to register experimental core blocks depending on editor settings.
47028   *
47029   * @param {boolean} enableFSEBlocks Whether to enable the full site editing blocks.
47030   * @example
47031   * ```js
47032   * import { __experimentalRegisterExperimentalCoreBlocks } from '@wordpress/block-library';
47033   *
47034   * __experimentalRegisterExperimentalCoreBlocks( settings );
47035   * ```
47036   */
47037  
47038  const __experimentalRegisterExperimentalCoreBlocks =  false ? 0 : undefined;
47039  
47040  }();
47041  (window.wp = window.wp || {}).blockLibrary = __webpack_exports__;
47042  /******/ })()
47043  ;


Generated: Wed Jan 22 01:00:02 2025 Cross-referenced by PHPXref 0.7.1